| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- #!/usr/bin/env python3
- # -*- coding: utf-8 -*-
- # Copyright 2019 Shigeki Karita
- # Apache 2.0 (http://www.apache.org/licenses/LICENSE-2.0)
- """Positionwise feed forward layer definition."""
- import torch
- from funasr.modules.layer_norm import LayerNorm
- class PositionwiseFeedForward(torch.nn.Module):
- """Positionwise feed forward layer.
- Args:
- idim (int): Input dimenstion.
- hidden_units (int): The number of hidden units.
- dropout_rate (float): Dropout rate.
- """
- def __init__(self, idim, hidden_units, dropout_rate, activation=torch.nn.ReLU()):
- """Construct an PositionwiseFeedForward object."""
- super(PositionwiseFeedForward, self).__init__()
- self.w_1 = torch.nn.Linear(idim, hidden_units)
- self.w_2 = torch.nn.Linear(hidden_units, idim)
- self.dropout = torch.nn.Dropout(dropout_rate)
- self.activation = activation
- def forward(self, x):
- """Forward function."""
- return self.w_2(self.dropout(self.activation(self.w_1(x))))
- class PositionwiseFeedForwardDecoderSANM(torch.nn.Module):
- """Positionwise feed forward layer.
- Args:
- idim (int): Input dimenstion.
- hidden_units (int): The number of hidden units.
- dropout_rate (float): Dropout rate.
- """
- def __init__(self, idim, hidden_units, dropout_rate, adim=None, activation=torch.nn.ReLU()):
- """Construct an PositionwiseFeedForward object."""
- super(PositionwiseFeedForwardDecoderSANM, self).__init__()
- self.w_1 = torch.nn.Linear(idim, hidden_units)
- self.w_2 = torch.nn.Linear(hidden_units, idim if adim is None else adim, bias=False)
- self.dropout = torch.nn.Dropout(dropout_rate)
- self.activation = activation
- self.norm = LayerNorm(hidden_units)
- def forward(self, x):
- """Forward function."""
- return self.w_2(self.norm(self.dropout(self.activation(self.w_1(x)))))
|