1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
|
local ModuleCriterion, parent = torch.class("nn.ModuleCriterion", "nn.Criterion")
function ModuleCriterion:__init(criterion, inputModule, targetModule, castTarget)
self.inputModule = inputModule
self.targetModule = targetModule
self.castTarget = (castTarget == nil) and true or castTarget
if self.inputModule then
local params = self.inputModule:parameters()
if params and #params > 0 then
print"Warning: nn.ModuleCriterion doesn't support parameter updates"
end
end
self.criterion = criterion
end
function ModuleCriterion:updateOutput(input, target)
if self.inputModule then
self.input = self.inputModule:forward(input)
end
if self.targetModule then
self.target = self.targetModule:forward(target)
end
self.output = self.criterion:forward(self.input or input, self.target or target)
return self.output
end
function ModuleCriterion:updateGradInput(input, target)
self.gradInput = self.criterion:backward(self.input or input, self.target or target)
if self.inputModule then
self.gradInput = self.inputModule:backward(input, self.gradInput)
end
return self.gradInput
end
function ModuleCriterion:type(type, typecache)
if self.inputModule then
self.inputModule:type(type, typecache)
end
if self.castTarget and self.targetModule then
self.targetModule:type(type, typecache)
end
self.criterion:type(type, typecache)
return parent.type(self, type, typecache)
end
|