58 Star 283 Fork 3

腾讯开源/ncnn

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
test_quantize_oom.cpp 1.75 KB
一键复制 编辑 原始数据 按行查看 历史
nihui 提交于 2025-07-08 11:01 +08:00 . use spdx license header, copyright Tencent (#6152)
// Copyright 2021 Tencent
// SPDX-License-Identifier: BSD-3-Clause
#include "testutil.h"
static int test_quantize_oom(const ncnn::Mat& a, float scale_low, float scale_high)
{
ncnn::Mat scale_data;
if (scale_low == scale_high)
{
scale_data.create(1);
scale_data[0] = scale_low;
}
else
{
if (a.dims == 1) scale_data.create(1);
if (a.dims == 2) scale_data.create(a.h);
if (a.dims == 3) scale_data.create(a.c);
Randomize(scale_data, scale_low, scale_high);
}
ncnn::ParamDict pd;
pd.set(0, scale_data.w);
std::vector<ncnn::Mat> weights(1);
weights[0] = scale_data;
int ret = test_layer_oom("Quantize", pd, weights, a);
if (ret != 0)
{
fprintf(stderr, "test_quantize_oom failed a.dims=%d a=(%d %d %d) scale_low=%f scale_high=%f\n", a.dims, a.w, a.h, a.c, scale_low, scale_high);
}
return ret;
}
static int test_quantize_0()
{
return 0
|| test_quantize_oom(RandomMat(5, 7, 24), 100.f, 100.f)
|| test_quantize_oom(RandomMat(7, 9, 12), 100.f, 100.f)
|| test_quantize_oom(RandomMat(3, 5, 13), 100.f, 100.f);
}
static int test_quantize_1()
{
return 0
|| test_quantize_oom(RandomMat(15, 24), 100.f, 100.f)
|| test_quantize_oom(RandomMat(17, 12), 100.f, 100.f)
|| test_quantize_oom(RandomMat(19, 15), 100.f, 100.f);
}
static int test_quantize_2()
{
return 0
|| test_quantize_oom(RandomMat(128), 120.f, 140.f)
|| test_quantize_oom(RandomMat(124), 120.f, 140.f)
|| test_quantize_oom(RandomMat(127), 120.f, 140.f);
}
int main()
{
SRAND(7767517);
return 0
|| test_quantize_0()
|| test_quantize_1()
|| test_quantize_2();
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C/C++
1
https://gitee.com/Tencent/ncnn.git
git@gitee.com:Tencent/ncnn.git
Tencent
ncnn
ncnn
master

搜索帮助