2016-03-12 10:53:42 +13:00
|
|
|
local PSNRCriterion, parent = torch.class('w2nn.PSNRCriterion','nn.Criterion')
|
|
|
|
|
|
|
|
function PSNRCriterion:__init()
|
|
|
|
parent.__init(self)
|
|
|
|
self.image = torch.Tensor()
|
|
|
|
self.diff = torch.Tensor()
|
|
|
|
end
|
|
|
|
function PSNRCriterion:updateOutput(input, target)
|
|
|
|
self.image:resizeAs(input):copy(input)
|
|
|
|
self.image:clamp(0.0, 1.0)
|
|
|
|
self.diff:resizeAs(self.image):copy(self.image)
|
|
|
|
|
2016-03-12 12:47:14 +13:00
|
|
|
local mse = math.max(self.diff:add(-1, target):pow(2):mean(), (0.1/255)^2)
|
2016-03-12 10:53:42 +13:00
|
|
|
self.output = 10 * math.log10(1.0 / mse)
|
|
|
|
return self.output
|
|
|
|
end
|
|
|
|
function PSNRCriterion:updateGradInput(input, target)
|
|
|
|
error("PSNRCriterion does not support backward")
|
|
|
|
end
|