summaryrefslogtreecommitdiffstats
path: root/contrib/lua-torch/nn/SoftMin.lua
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/lua-torch/nn/SoftMin.lua')
-rw-r--r--contrib/lua-torch/nn/SoftMin.lua31
1 files changed, 31 insertions, 0 deletions
diff --git a/contrib/lua-torch/nn/SoftMin.lua b/contrib/lua-torch/nn/SoftMin.lua
new file mode 100644
index 000000000..7da2a6589
--- /dev/null
+++ b/contrib/lua-torch/nn/SoftMin.lua
@@ -0,0 +1,31 @@
+local SoftMin, parent = torch.class('nn.SoftMin', 'nn.Module')
+
+function SoftMin:updateOutput(input)
+ self.mininput = self.mininput or input.new()
+ self.mininput:resizeAs(input):copy(input):mul(-1)
+ input.THNN.SoftMax_updateOutput(
+ self.mininput:cdata(),
+ self.output:cdata()
+ )
+ return self.output
+end
+
+function SoftMin:updateGradInput(input, gradOutput)
+ self.mininput = self.mininput or input.new()
+ self.mininput:resizeAs(input):copy(input):mul(-1)
+
+ input.THNN.SoftMax_updateGradInput(
+ self.mininput:cdata(),
+ gradOutput:cdata(),
+ self.gradInput:cdata(),
+ self.output:cdata()
+ )
+
+ self.gradInput:mul(-1)
+ return self.gradInput
+end
+
+function SoftMin:clearState()
+ if self.mininput then self.mininput:set() end
+ return parent.clearState(self)
+end