Как torch.einsum получает этот 4D-тензор из 3D-тензора и 2D-тензора?Python

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Как torch.einsum получает этот 4D-тензор из 3D-тензора и 2D-тензора?

Сообщение Anonymous »

У меня возникли проблемы с пониманием этой строки кода pytorch при чтении исходных кодов mamba_ssm. (исходный код здесь: https://github.com/state-spaces/mamba/b ... _interface. py#L121).

Код: Выделить всё

# Tensor shape
# b: batch_size, d: d_inner, l: sequence_length, n: d_state
# delta: [b,d,l]
# A: [d,n]
...
deltaA = torch.exp(torch.einsum('bdl,dn->bdln', delta, A))
...
4D-тензор deltaA рассчитывается на основе 3D-тензора delta и 2D-тензора A. Я знаю torch.einsum, но не могу понять, какие операции были выполнены для получения deltaA (объяснение) о том, как тензоры были умножены/сложены/транспонированы и т. д.)?
Я могу понять код ниже, поскольку это умножение матриц.

Код: Выделить всё

torch.einsum('bdl,dn->bln',delta,A)
Однако мне пока сложно полностью понять, что именно произошло в исходном коде. Кажется, что это связано с тензорным внешним произведением, но я не уверен.


Подробнее здесь: https://stackoverflow.com/questions/790 ... -2d-tensor
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»