You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

quantize.cpp 2.9 kB

Fix warnings on Visual Studio (#1431) * Fix warnings C4244, C4267 in src/layer/yolov3detectionoutput.cpp C4244: '=': conversion from 'int' to 'float', possible loss of data C4244: 'initializing': conversion from 'float' to 'int', possible loss of data C4244: 'initializing': conversion from 'double' to 'float', possible loss of data C4244: 'return': conversion from 'double' to 'float', possible loss of data C4267: 'argument': conversion from 'size_t' to 'int', possible loss of data C4267: 'initializing': conversion from 'size_t' to 'int', possible loss of data * Fix warnings C4244, C4267 in src/layer/yolodetectionoutput.cpp C4244: '=': conversion from 'int' to 'float', possible loss of data C4244: 'initializing': conversion from 'float' to 'int', possible loss of data C4244: 'initializing': conversion from 'double' to 'float', possible loss of data C4244: 'return': conversion from 'double' to 'float', possible loss of data C4267: 'argument': conversion from 'size_t' to 'int', possible loss of data C4267: 'initializing': conversion from 'size_t' to 'int', possible loss of data * Fix warning C4244 in src/layer/quantize.cpp C4244: 'initializing': conversion from 'double' to 'int', possible loss of data * Fix warnings C4244, C4267 in src/layer/detectionoutput.cpp C4244: '=': conversion from 'int' to 'float', possible loss of data C4244: 'initializing': conversion from 'double' to 'float', possible loss of data C4267: 'argument': conversion from 'size_t' to 'int', possible loss of data C4267: 'initializing': conversion from 'size_t' to 'int', possible loss of data * Fix warning C4244 in src/layer/roipooling.cpp C4244: 'initializing': conversion from 'double' to 'int', possible loss of data * Fix warning C4244 in src/layer/sigmoid.cpp C4244: '=': conversion from 'double' to 'float', possible loss of data * Fix warning C4267 in src/layer/slice.cpp C4267: '=': conversion from 'size_t' to 'int', possible loss of data C4267: 'initializing': conversion from 'size_t' to 'int', possible loss of data * Fix warning C4267 in src/layer/softmax.cpp C4244: '=': conversion from 'double' to 'float', possible loss of data * Fix warning C4244 in src/layer/interp.cpp C4244: '=': conversion from 'float' to 'int', possible loss of data C4244: 'initializing': conversion from 'double' to 'int', possible loss of data * Fix warning C4244 in src/layer/instancenorm.cpp C4244: 'initializing': conversion from 'double' to 'float', possible loss of data * Fix warning C4244 in src/layer/deconvolutiondepthwise.cpp C4244: '=': conversion from 'double' to 'float', possible loss of data * Fix warning C4244 in src/layer/convolutiondepthwise.cpp C4244: '=': conversion from 'double' to 'float', possible loss of data * Fix warning C4244 in src/net.cpp C4244: 'return': conversion from '__int64' to 'int', possible loss of data C4267: 'argument': conversion from 'size_t' to 'int', possible loss of data C4267: 'initializing': conversion from 'size_t' to 'int', possible loss of data C4267: 'return': conversion from 'size_t' to 'int', possible loss of data * Fix warning C4244 in src/layer/bnll.cpp C4244: '=': conversion from 'double' to 'float', possible loss of data * Fix warning C4267 in src/layer/concat.cpp C4267: 'initializing': conversion from 'size_t' to 'int', possible loss of data * Fix warning C4267 in tools/mxnet/mxnet2ncnn.cpp C4244: 'initializing': conversion from 'double' to 'float', possible loss of data C4267: '=': conversion from 'size_t' to 'int', possible loss of data C4267: 'initializing': conversion from 'size_t' to 'int', possible loss of data C4305: 'initializing': truncation from 'double' to 'float'
6 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. // Tencent is pleased to support the open source community by making ncnn available.
  2. //
  3. // Copyright (C) 2018 THL A29 Limited, a Tencent company. All rights reserved.
  4. //
  5. // Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
  6. // in compliance with the License. You may obtain a copy of the License at
  7. //
  8. // https://opensource.org/licenses/BSD-3-Clause
  9. //
  10. // Unless required by applicable law or agreed to in writing, software distributed
  11. // under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
  12. // CONDITIONS OF ANY KIND, either express or implied. See the License for the
  13. // specific language governing permissions and limitations under the License.
  14. #include "quantize.h"
  15. #include <math.h>
  16. namespace ncnn {
  17. DEFINE_LAYER_CREATOR(Quantize)
  18. Quantize::Quantize()
  19. {
  20. one_blob_only = true;
  21. support_inplace = false;
  22. }
  23. int Quantize::load_param(const ParamDict& pd)
  24. {
  25. scale = pd.get(0, 1.f);
  26. return 0;
  27. }
  28. static inline signed char float2int8(float v)
  29. {
  30. int int32 = static_cast<int>(round(v));
  31. if (int32 > 127) return 127;
  32. if (int32 < -127) return -127;
  33. return (signed char)int32;
  34. }
  35. int Quantize::forward(const Mat& bottom_blob, Mat& top_blob, const Option& opt) const
  36. {
  37. int dims = bottom_blob.dims;
  38. if (dims == 1)
  39. {
  40. int w = bottom_blob.w;
  41. top_blob.create(w, (size_t)1u, opt.blob_allocator);
  42. if (top_blob.empty())
  43. return -100;
  44. const float* ptr = bottom_blob;
  45. signed char* outptr = top_blob;
  46. #pragma omp parallel for num_threads(opt.num_threads)
  47. for (int i=0; i<w; i++)
  48. {
  49. outptr[i] = float2int8(ptr[i] * scale);
  50. }
  51. }
  52. if (dims == 2)
  53. {
  54. int w = bottom_blob.w;
  55. int h = bottom_blob.h;
  56. int size = w * h;
  57. top_blob.create(w, h, (size_t)1u, opt.blob_allocator);
  58. if (top_blob.empty())
  59. return -100;
  60. const float* ptr = bottom_blob;
  61. signed char* outptr = top_blob;
  62. #pragma omp parallel for num_threads(opt.num_threads)
  63. for (int i=0; i<size; i++)
  64. {
  65. outptr[i] = float2int8(ptr[i] * scale);
  66. }
  67. }
  68. if (dims == 3)
  69. {
  70. int w = bottom_blob.w;
  71. int h = bottom_blob.h;
  72. int channels = bottom_blob.c;
  73. int size = w * h;
  74. top_blob.create(w, h, channels, (size_t)1u, opt.blob_allocator);
  75. if (top_blob.empty())
  76. return -100;
  77. #pragma omp parallel for num_threads(opt.num_threads)
  78. for (int q=0; q<channels; q++)
  79. {
  80. const float* ptr = bottom_blob.channel(q);
  81. signed char* outptr = top_blob.channel(q);
  82. for (int i=0; i<size; i++)
  83. {
  84. outptr[i] = float2int8(ptr[i] * scale);
  85. }
  86. }
  87. }
  88. return 0;
  89. }
  90. } // namespace ncnn