Skip to content

Commit

Permalink
w
Browse files Browse the repository at this point in the history
  • Loading branch information
nihui committed Feb 5, 2025
1 parent 02ea72c commit 20a9cdb
Show file tree
Hide file tree
Showing 3 changed files with 82 additions and 2 deletions.
2 changes: 1 addition & 1 deletion src/layer/loongarch/quantize_loongarch.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,7 @@ static void quantize_pack4to1(const float* ptr, signed char* s8ptr0, signed char
{
__m128 _v = (__m128)__lsx_vld(ptr, 0);
_v = __lsx_vfmul_s(_v, _scale);
v16i8 v = (v16i8)float2int8(_v, _v);
v16i8 v = (v16i8)float2int8(_v);
s8ptr0[0] = v[0];
s8ptr1[0] = v[1];
s8ptr2[0] = v[2];
Expand Down
2 changes: 1 addition & 1 deletion src/layer/mips/quantize_mips.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,7 @@ static void quantize_pack4to1(const float* ptr, signed char* s8ptr0, signed char
{
v4f32 _v = (v4f32)__msa_ld_w(ptr, 0);
_v = __msa_fmul_w(_v, _scale);
v16i8 v = float2int8(_v, _v);
v16i8 v = float2int8(_v);
s8ptr0[0] = v[0];
s8ptr1[0] = v[1];
s8ptr2[0] = v[2];
Expand Down
80 changes: 80 additions & 0 deletions tests/test_quantize_oom.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
// Tencent is pleased to support the open source community by making ncnn available.
//
// Copyright (C) 2021 THL A29 Limited, a Tencent company. All rights reserved.
//
// Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
// in compliance with the License. You may obtain a copy of the License at
//
// https://opensource.org/licenses/BSD-3-Clause
//
// Unless required by applicable law or agreed to in writing, software distributed
// under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
// CONDITIONS OF ANY KIND, either express or implied. See the License for the
// specific language governing permissions and limitations under the License.

#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(a.w);
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();
}

0 comments on commit 20a9cdb

Please sign in to comment.