58 Star 283 Fork 3

腾讯开源/ncnn

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
test_concat.cpp 6.51 KB
一键复制 编辑 原始数据 按行查看 历史
// Copyright 2020 Tencent
// SPDX-License-Identifier: BSD-3-Clause
#include "testutil.h"
static int test_concat(const std::vector<ncnn::Mat>& a, int axis)
{
ncnn::ParamDict pd;
pd.set(0, axis); //axis
std::vector<ncnn::Mat> weights(0);
int ret = test_layer("Concat", pd, weights, a);
if (ret != 0)
{
fprintf(stderr, "test_concat failed a[0].dims=%d a[0]=(%d %d %d %d) axis=%d\n", a[0].dims, a[0].w, a[0].h, a[0].d, a[0].c, axis);
}
return ret;
}
static int test_concat_0()
{
ncnn::Mat a[] = {
RandomMat(15, 5, 6, 13),
RandomMat(15, 5, 6, 20),
RandomMat(15, 5, 6, 24),
RandomMat(15, 5, 6, 48)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
for (int k = 0; k < n; k++)
{
std::vector<ncnn::Mat> as(4);
as[0] = a[i];
as[1] = a[j];
as[2] = a[k];
as[3] = a[k];
int ret = test_concat(as, 0) || test_concat(as, -4);
if (ret != 0)
return ret;
}
}
}
return 0;
}
static int test_concat_1()
{
ncnn::Mat a[] = {
RandomMat(15, 3, 15, 13),
RandomMat(15, 3, 16, 20),
RandomMat(15, 3, 17, 24),
RandomMat(15, 3, 18, 48)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
std::vector<ncnn::Mat> as(3);
as[0] = a[i];
as[1] = a[i];
as[2] = a[i];
int ret = test_concat(as, 1) || test_concat(as, -3);
if (ret != 0)
return ret;
}
return 0;
}
static int test_concat_2()
{
ncnn::Mat a[] = {
RandomMat(15, 15, 6, 13),
RandomMat(15, 16, 6, 20),
RandomMat(15, 17, 6, 24),
RandomMat(15, 18, 6, 48)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
std::vector<ncnn::Mat> as(3);
as[0] = a[i];
as[1] = a[i];
as[2] = a[i];
int ret = test_concat(as, 2) || test_concat(as, -2);
if (ret != 0)
return ret;
}
return 0;
}
static int test_concat_3()
{
ncnn::Mat a[] = {
RandomMat(15, 5, 7, 13),
RandomMat(16, 5, 7, 20),
RandomMat(17, 5, 7, 24),
RandomMat(18, 5, 7, 48)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
std::vector<ncnn::Mat> as(3);
as[0] = a[i];
as[1] = a[i];
as[2] = a[i];
int ret = test_concat(as, 3) || test_concat(as, -1);
if (ret != 0)
return ret;
}
return 0;
}
static int test_concat_4()
{
ncnn::Mat a[] = {
RandomMat(15, 13, 13),
RandomMat(15, 13, 20),
RandomMat(15, 13, 24),
RandomMat(15, 13, 48)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
for (int k = 0; k < n; k++)
{
std::vector<ncnn::Mat> as(4);
as[0] = a[i];
as[1] = a[j];
as[2] = a[k];
as[3] = a[k];
int ret = test_concat(as, 0) || test_concat(as, -3);
if (ret != 0)
return ret;
}
}
}
return 0;
}
static int test_concat_5()
{
ncnn::Mat a[] = {
RandomMat(15, 15, 13),
RandomMat(15, 16, 20),
RandomMat(15, 17, 24),
RandomMat(15, 18, 48)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
std::vector<ncnn::Mat> as(3);
as[0] = a[i];
as[1] = a[i];
as[2] = a[i];
int ret = test_concat(as, 1) || test_concat(as, -2);
if (ret != 0)
return ret;
}
return 0;
}
static int test_concat_6()
{
ncnn::Mat a[] = {
RandomMat(15, 13, 13),
RandomMat(16, 13, 20),
RandomMat(17, 13, 24),
RandomMat(18, 13, 48)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
std::vector<ncnn::Mat> as(3);
as[0] = a[i];
as[1] = a[i];
as[2] = a[i];
int ret = test_concat(as, 2) || test_concat(as, -1);
if (ret != 0)
return ret;
}
return 0;
}
static int test_concat_7()
{
ncnn::Mat a[] = {
RandomMat(19, 29),
RandomMat(19, 44),
RandomMat(19, 56),
RandomMat(19, 80)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
for (int k = 0; k < n; k++)
{
std::vector<ncnn::Mat> as(4);
as[0] = a[i];
as[1] = a[j];
as[2] = a[k];
as[3] = a[k];
int ret = test_concat(as, 0) || test_concat(as, -2);
if (ret != 0)
return ret;
}
}
}
return 0;
}
static int test_concat_8()
{
ncnn::Mat a[] = {
RandomMat(19, 29),
RandomMat(16, 44),
RandomMat(17, 56),
RandomMat(18, 80)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
std::vector<ncnn::Mat> as(3);
as[0] = a[i];
as[1] = a[i];
as[2] = a[i];
int ret = test_concat(as, 1) || test_concat(as, -1);
if (ret != 0)
return ret;
}
return 0;
}
static int test_concat_9()
{
ncnn::Mat a[] = {
RandomMat(29),
RandomMat(44),
RandomMat(56),
RandomMat(80)
};
const int n = sizeof(a) / sizeof(a[0]);
for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
for (int k = 0; k < n; k++)
{
std::vector<ncnn::Mat> as(4);
as[0] = a[i];
as[1] = a[j];
as[2] = a[k];
as[3] = a[k];
int ret = test_concat(as, 0) || test_concat(as, -1);
if (ret != 0)
return ret;
}
}
}
return 0;
}
int main()
{
SRAND(7767517);
return 0
|| test_concat_0()
|| test_concat_1()
|| test_concat_2()
|| test_concat_3()
|| test_concat_4()
|| test_concat_5()
|| test_concat_6()
|| test_concat_7()
|| test_concat_8()
|| test_concat_9();
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C/C++
1
https://gitee.com/Tencent/ncnn.git
git@gitee.com:Tencent/ncnn.git
Tencent
ncnn
ncnn
master

搜索帮助