|
|
|
@@ -173,15 +173,15 @@ def test_conv(): |
|
|
|
|
|
|
|
|
|
|
|
class NetConv3d(nn.Cell): |
|
|
|
def __init__(self): |
|
|
|
def __init__(self, mode, pad_mode, pad): |
|
|
|
super(NetConv3d, self).__init__() |
|
|
|
out_channel = 4 |
|
|
|
kernel_size = 2 |
|
|
|
self.conv = P.Conv3D(out_channel, |
|
|
|
kernel_size, |
|
|
|
mode=1, |
|
|
|
pad_mode="valid", |
|
|
|
pad=0, |
|
|
|
mode=mode, |
|
|
|
pad_mode=pad_mode, |
|
|
|
pad=pad, |
|
|
|
stride=1, |
|
|
|
dilation=1, |
|
|
|
group=1) |
|
|
|
@@ -212,13 +212,94 @@ def test_conv3d(): |
|
|
|
[76860., 78864.]], |
|
|
|
[[88884., 90888.], |
|
|
|
[94896., 96900.]]]]]).astype(np.float32) |
|
|
|
|
|
|
|
mode = 1 |
|
|
|
pad_mode = "valid" |
|
|
|
pad = 0 |
|
|
|
context.set_context(mode=context.PYNATIVE_MODE, device_target="CPU") |
|
|
|
net = NetConv3d() |
|
|
|
net = NetConv3d(mode, pad_mode, pad) |
|
|
|
output = net(x, w) |
|
|
|
assert (output.asnumpy() == expect).all() |
|
|
|
context.set_context(mode=context.GRAPH_MODE, device_target="CPU") |
|
|
|
net = NetConv3d(mode, pad_mode, pad) |
|
|
|
output = net(x, w) |
|
|
|
assert (output.asnumpy() == expect).all() |
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.level0 |
|
|
|
@pytest.mark.platform_x86_cpu |
|
|
|
@pytest.mark.env_onecard |
|
|
|
def test_conv3d_2(): |
|
|
|
context.set_context(mode=context.GRAPH_MODE, device_target="CPU") |
|
|
|
net = NetConv3d() |
|
|
|
x = Tensor(np.arange(1 * 3 * 3 * 3 * 3).reshape(1, 3, 3, 3, 3).astype(np.float32)) |
|
|
|
w = Tensor(np.arange(4 * 3 * 2 * 2 * 2).reshape(4, 3, 2, 2, 2).astype(np.float32)) |
|
|
|
expect = np.array([[[[[1647, 3258, 3345, 1650], |
|
|
|
[3267, 6447, 6609, 3252], |
|
|
|
[3519, 6933, 7095, 3486], |
|
|
|
[1719, 3378, 3453, 1692]], |
|
|
|
[[3375, 6639, 6789, 3330], |
|
|
|
[6606, 12960, 13236, 6474], |
|
|
|
[7038, 13788, 14064, 6870], |
|
|
|
[3393, 6627, 6753, 3288]], |
|
|
|
[[4077, 7989, 8139, 3978], |
|
|
|
[7902, 15444, 15720, 7662], |
|
|
|
[8334, 16272, 16548, 8058], |
|
|
|
[3987, 7761, 7887, 3828]], |
|
|
|
[[1917, 3732, 3795, 1842], |
|
|
|
[3663, 7107, 7221, 3492], |
|
|
|
[3843, 7449, 7563, 3654], |
|
|
|
[1809, 3492, 3543, 1704]]], |
|
|
|
[[[3591, 7218, 7449, 3738], |
|
|
|
[7371, 14799, 15249, 7644], |
|
|
|
[8055, 16149, 16599, 8310], |
|
|
|
[4095, 8202, 8421, 4212]], |
|
|
|
[[7911, 15855, 16293, 8154], |
|
|
|
[16110, 32256, 33108, 16554], |
|
|
|
[17406, 34812, 35664, 17814], |
|
|
|
[8793, 17571, 17985, 8976]], |
|
|
|
[[9909, 19797, 20235, 10098], |
|
|
|
[19998, 39924, 40776, 20334], |
|
|
|
[21294, 42480, 43332, 21594], |
|
|
|
[10683, 21297, 21711, 10812]], |
|
|
|
[[5157, 10284, 10491, 5226], |
|
|
|
[10359, 20643, 21045, 10476], |
|
|
|
[10971, 21849, 22251, 11070], |
|
|
|
[5481, 10908, 11103, 5520]]], |
|
|
|
[[[5535, 11178, 11553, 5826], |
|
|
|
[11475, 23151, 23889, 12036], |
|
|
|
[12591, 25365, 26103, 13134], |
|
|
|
[6471, 13026, 13389, 6732]], |
|
|
|
[[12447, 25071, 25797, 12978], |
|
|
|
[25614, 51552, 52980, 26634], |
|
|
|
[27774, 55836, 57264, 28758], |
|
|
|
[14193, 28515, 29217, 14664]], |
|
|
|
[[15741, 31605, 32331, 16218], |
|
|
|
[32094, 64404, 65832, 33006], |
|
|
|
[34254, 68688, 70116, 35130], |
|
|
|
[17379, 34833, 35535, 17796]], |
|
|
|
[[8397, 16836, 17187, 8610], |
|
|
|
[17055, 34179, 34869, 17460], |
|
|
|
[18099, 36249, 36939, 18486], |
|
|
|
[9153, 18324, 18663, 9336]]], |
|
|
|
[[[7479, 15138, 15657, 7914], |
|
|
|
[15579, 31503, 32529, 16428], |
|
|
|
[17127, 34581, 35607, 17958], |
|
|
|
[8847, 17850, 18357, 9252]], |
|
|
|
[[16983, 34287, 35301, 17802], |
|
|
|
[35118, 70848, 72852, 36714], |
|
|
|
[38142, 76860, 78864, 39702], |
|
|
|
[19593, 39459, 40449, 20352]], |
|
|
|
[[21573, 43413, 44427, 22338], |
|
|
|
[44190, 88884, 90888, 45678], |
|
|
|
[47214, 94896, 96900, 48666], |
|
|
|
[24075, 48369, 49359, 24780]], |
|
|
|
[[11637, 23388, 23883, 11994], |
|
|
|
[23751, 47715, 48693, 24444], |
|
|
|
[25227, 50649, 51627, 25902], |
|
|
|
[12825, 25740, 26223, 13152]]]]]).astype(np.float32) |
|
|
|
mode = 1 |
|
|
|
pad_mode = "pad" |
|
|
|
pad = (1, 1, 1, 1, 1, 1) |
|
|
|
net = NetConv3d(mode, pad_mode, pad) |
|
|
|
output = net(x, w) |
|
|
|
assert (output.asnumpy() == expect).all() |
|
|
|
|
|
|
|
|