import unittest import numpy as np from op_test import OpTest class TestMarginRankLossOp(OpTest): def setUp(self): self.op_type = "margin_rank_loss" batch_size = 5 margin = 0.5 # labels_{i} = {-1, 1} label = 2 * np.random.randint( 0, 2, size=(batch_size, 1)).astype("float32") - 1 x1 = np.random.random((batch_size, 1)).astype("float32") x2 = np.random.random((batch_size, 1)).astype("float32") # loss = max(0, -label * (x1 - x2) + margin) loss = -label * (x1 - x2) + margin loss = np.where(loss > 0, loss, 0) act = np.where(loss > 0, 1., 0.) self.attrs = {'margin': margin} self.inputs = {'Label': label, 'X1': x1, 'X2': x2} self.outputs = {'Activated': act, 'Out': loss} def test_check_output(self): self.check_output() def test_check_grad(self): self.check_grad(["X1", "X2"], "Out") def test_check_grad_ignore_x1(self): self.check_grad(["X2"], "Out", no_grad_set=set('X1')) def test_check_grad_ignore_x2(self): self.check_grad(["X1"], "Out", no_grad_set=set('X2')) if __name__ == '__main__': unittest.main()