File: sigmoid_test.cc

package info (click to toggle)
pytorch 1.13.1%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 139,252 kB
  • sloc: cpp: 1,100,274; python: 706,454; ansic: 83,052; asm: 7,618; java: 3,273; sh: 2,841; javascript: 612; makefile: 323; xml: 269; ruby: 185; yacc: 144; objc: 68; lex: 44
file content (42 lines) | stat: -rw-r--r-- 1,437 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#include <iostream>
#include <random>
#include "sigmoid.h"

#include <gtest/gtest.h>
#include "caffe2/core/logging.h"

using namespace dnnlowp;
using namespace std;

TEST(Sigmoid, SigmoidUnitTest) {
  for (double max_abs_err = 0.02; max_abs_err <= 0.1; max_abs_err += 0.01) {
    Sigmoid<uint8_t> sigmoid_approx(max_abs_err);
    LOG(INFO) << "max_abs_err " << max_abs_err;

    const int NSAMPLES = 1 << 16;

    std::uniform_real_distribution<float> distribution(-5., 5.);
    std::default_random_engine generator;
    float sq_err_sum = 0, max_err = 0;
    for (int i = 0; i < NSAMPLES; ++i) {
      float x = distribution(generator);
      uint8_t x_q = fbgemm::Quantize<uint8_t>(
          x, sigmoid_approx.GetInputQuantizationParams());
      uint8_t y_q = sigmoid_approx.Compute(x_q);
      float y = fbgemm::Dequantize<uint8_t>(
          y_q, sigmoid_approx.GetOutputQuantizationParams());
      float sigmoid = exp(x) / (exp(x) + 1);
      float err = fabs(sigmoid - y);
      sq_err_sum += err * err;
      max_err = std::max(err, max_err);
      if (err > max_abs_err) {
        LOG(INFO) << "x " << x << " sigmoid_real " << sigmoid
                  << " sigmoid_approx " << y << " err " << err << " x_q "
                  << (int)x_q << " y_q " << (int)y_q;
      }
      EXPECT_LE(err, max_abs_err);
    }
    LOG(INFO) << "avg_l2_err " << std::sqrt(sq_err_sum) / NSAMPLES
              << " max_err " << max_err;
  }
}