|
|
- from torch import nn
-
-
- class Tacotron2Loss(nn.Module):
- def __init__(self):
- super(Tacotron2Loss, self).__init__()
-
- def forward(self, model_output, targets):
- mel_target, gate_target = targets[0], targets[1]
- mel_target.requires_grad = False
- gate_target.requires_grad = False
- gate_target = gate_target.view(-1, 1)
-
- mel_out, mel_out_postnet, gate_out, _ = model_output
- gate_out = gate_out.view(-1, 1)
- mel_loss = nn.MSELoss()(mel_out, mel_target) + \
- nn.MSELoss()(mel_out_postnet, mel_target)
- gate_loss = nn.BCEWithLogitsLoss()(gate_out, gate_target)
- return mel_loss + gate_loss
|