cusum op optimization for GPU kernel (#24321)

v1.8
wangchaochaohu 6 years ago committed by GitHub
parent d43e4047ff
commit c4dd596de6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

File diff suppressed because it is too large Load Diff

@ -108,24 +108,108 @@ class TestSumOp7(OpTest):
self.check_grad(['X'], 'Out')
class TestSumOp8(OpTest):
class TestSumOpExclusive1(OpTest):
def setUp(self):
self.op_type = "cumsum"
self.attrs = {'axis': 2, "exclusive": True}
a = np.random.random((5, 6, 4)).astype("float64")
a = np.random.random((4, 5, 65)).astype("float64")
self.inputs = {'X': a}
self.outputs = {
'Out': np.concatenate(
(np.zeros(
(5, 6, 1), dtype=np.float64), a[:, :, :-1].cumsum(axis=2)),
(4, 5, 1), dtype=np.float64), a[:, :, :-1].cumsum(axis=2)),
axis=2)
}
def test_check_output(self):
self.check_output()
def test_check_grad(self):
self.check_grad(['X'], 'Out')
class TestSumOpExclusive2(OpTest):
def setUp(self):
self.op_type = "cumsum"
self.attrs = {'axis': 2, "exclusive": True}
a = np.random.random((1, 1, 888)).astype("float64")
self.inputs = {'X': a}
self.outputs = {
'Out': np.concatenate(
(np.zeros(
(1, 1, 1), dtype=np.float64), a[:, :, :-1].cumsum(axis=2)),
axis=2)
}
def test_check_output(self):
self.check_output()
class TestSumOpExclusive3(OpTest):
def setUp(self):
self.op_type = "cumsum"
self.attrs = {'axis': 2, "exclusive": True}
a = np.random.random((4, 5, 888)).astype("float32")
self.inputs = {'X': a}
self.outputs = {
'Out': np.concatenate(
(np.zeros(
(4, 5, 1), dtype=np.float64), a[:, :, :-1].cumsum(axis=2)),
axis=2)
}
def test_check_output(self):
self.check_output()
class TestSumOpExclusive4(OpTest):
def setUp(self):
self.op_type = "cumsum"
self.attrs = {'axis': 2, "exclusive": True}
a = np.random.random((1, 1, 3049)).astype("float64")
self.inputs = {'X': a}
self.outputs = {
'Out': np.concatenate(
(np.zeros(
(1, 1, 1), dtype=np.float64), a[:, :, :-1].cumsum(axis=2)),
axis=2)
}
def test_check_output(self):
self.check_output()
class TestSumOpExclusive5(OpTest):
def setUp(self):
self.op_type = "cumsum"
self.attrs = {'axis': 2, "exclusive": True}
a = np.random.random((4, 5, 3096)).astype("float64")
self.inputs = {'X': a}
self.outputs = {
'Out': np.concatenate(
(np.zeros(
(4, 5, 1), dtype=np.float64), a[:, :, :-1].cumsum(axis=2)),
axis=2)
}
def test_check_output(self):
self.check_output()
class TestSumOpReverseExclusive(OpTest):
def setUp(self):
self.op_type = "cumsum"
self.attrs = {'axis': 2, 'reverse': True, "exclusive": True}
a = np.random.random((4, 5, 6)).astype("float64")
self.inputs = {'X': a}
a = np.flip(a, axis=2)
self.outputs = {
'Out': np.concatenate(
(np.flip(
a[:, :, :-1].cumsum(axis=2), axis=2), np.zeros(
(4, 5, 1), dtype=np.float64)),
axis=2)
}
def test_check_output(self):
self.check_output()
class BadInputTest(unittest.TestCase):
@ -133,7 +217,7 @@ class BadInputTest(unittest.TestCase):
with fluid.program_guard(fluid.Program()):
def test_bad_x():
data = [1, 2, 3]
data = [1, 2, 4]
result = fluid.layers.cumsum(data, axis=0)
self.assertRaises(TypeError, test_bad_x)

Loading…
Cancel
Save