forked from mrq/DL-Art-School
19 lines
672 B
Python
19 lines
672 B
Python
|
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
|