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
|