Welcome to mirror list, hosted at ThFree Co, Russian Federation.

MarginRankingCriterion.lua - github.com/torch/nn.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: ec85fb98c54eeb69ce95c854f1b224d8a780dd20 (plain)
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
local MarginRankingCriterion, parent = torch.class('nn.MarginRankingCriterion', 'nn.Criterion')

function MarginRankingCriterion:__init(margin)
   parent.__init(self)
   margin=margin or 1
   self.margin = margin 
   self.gradInput = {torch.Tensor(1), torch.Tensor(1)}
end 
 
function MarginRankingCriterion:updateOutput(input,y)
   self.output=math.max(0, -y*(input[1][1]-input[2][1]) + self.margin  ) 
   return self.output
end

function MarginRankingCriterion:updateGradInput(input, y)
  local dist = -y*(input[1][1]-input[2][1]) + self.margin
  if dist < 0 then
     self.gradInput[1][1]=0;
     self.gradInput[2][1]=0;
  else	
     self.gradInput[1][1]=-y
     self.gradInput[2][1]=y
  end
  return self.gradInput 
end