17
static int test_einsum(const std::vector<ncnn::Mat>& a, const std::string& equation)
19
ncnn::Mat equation_mat(equation.size());
20
for (size_t i = 0; i < equation.size(); i++)
22
((int*)equation_mat)[i] = equation[i];
26
pd.set(0, equation_mat);
28
std::vector<ncnn::Mat> weights(0);
30
int ret = test_layer("Einsum", pd, weights, a);
33
fprintf(stderr, "test_einsum failed a[0].dims=%d a[0]=(%d %d %d) equation=%s\n", a[0].dims, a[0].w, a[0].h, a[0].c, equation.c_str());
39
static int test_einsum_0()
41
std::vector<ncnn::Mat> a(1);
42
a[0] = RandomMat(32, 32);
44
return test_einsum(a, "ii");
47
static int test_einsum_1()
49
std::vector<ncnn::Mat> a(1);
50
a[0] = RandomMat(27, 32);
52
return test_einsum(a, "ij->i") || test_einsum(a, "ji->i");
55
static int test_einsum_2()
57
std::vector<ncnn::Mat> a(1);
58
a[0] = RandomMat(17, 14, 32);
61
|| test_einsum(a, "ijk->i")
62
|| test_einsum(a, "jik->i")
63
|| test_einsum(a, "jki->i")
64
|| test_einsum(a, "ikj->ij")
65
|| test_einsum(a, "kij->ij")
66
|| test_einsum(a, "ijk->ij");
69
static int test_einsum_3()
71
std::vector<ncnn::Mat> a(1);
72
a[0] = RandomMat(17, 14, 9, 32);
75
|| test_einsum(a, "jkli->i")
76
|| test_einsum(a, "jkil->i")
77
|| test_einsum(a, "jikl->i")
78
|| test_einsum(a, "ijkl->i")
79
|| test_einsum(a, "iklj->ij")
80
|| test_einsum(a, "klij->ij")
81
|| test_einsum(a, "kijl->ij")
82
|| test_einsum(a, "ijkl->ij")
83
|| test_einsum(a, "ijlk->ijk")
84
|| test_einsum(a, "lijk->ijk")
85
|| test_einsum(a, "ijkl->ijk");
88
static int test_einsum_4()
90
std::vector<ncnn::Mat> a(2);
91
a[0] = RandomMat(12, 28);
94
return test_einsum(a, "ij,j->i");
97
static int test_einsum_5()
99
std::vector<ncnn::Mat> a(2);
100
a[0] = RandomMat(14);
101
a[1] = RandomMat(14, 7, 16);
103
return test_einsum(a, "k,ijk->ij");
106
static int test_einsum_6()
108
std::vector<ncnn::Mat> a(2);
109
a[0] = RandomMat(27);
110
a[1] = RandomMat(32);
112
return test_einsum(a, "i,j->ij");
115
static int test_einsum_7()
117
std::vector<ncnn::Mat> a(4);
120
a[2] = RandomMat(11);
121
a[3] = RandomMat(16);
123
return test_einsum(a, "i,j,k,l->ijkl");
126
static int test_einsum_8()
128
std::vector<ncnn::Mat> a(2);
129
a[0] = RandomMat(5, 2, 3);
130
a[1] = RandomMat(4, 5, 3);
132
return test_einsum(a, "ijl,ilk->ijk");
135
static int test_einsum_9()
137
std::vector<ncnn::Mat> a(2);
138
a[0] = RandomMat(4, 5, 3);
139
a[1] = RandomMat(5, 2, 3);
141
return test_einsum(a, "ilk,ijl->ijk");
144
static int test_einsum_10()
146
std::vector<ncnn::Mat> a(3);
147
a[0] = RandomMat(15, 12);
148
a[1] = RandomMat(24, 15, 13);
149
a[2] = RandomMat(24, 12);
151
return test_einsum(a, "ik,jkl,il->ij");
154
static int test_einsum_11()
156
std::vector<ncnn::Mat> a(2);
157
a[0] = RandomMat(7, 5, 3, 2);
158
a[1] = RandomMat(5, 17, 3, 11);
160
return test_einsum(a, "imnj,kmln->ijkl");