mirror of
https://github.com/saymrwulf/pytorch.git
synced 2026-05-15 21:00:47 +00:00
Summary: Pull Request resolved: https://github.com/pytorch/pytorch/pull/14160 clang-format of C++ files Reviewed By: hx89 Differential Revision: D13115201 fbshipit-source-id: d2ad65f66209e00578ef90f87f41272de2d24aa9
55 lines
1.2 KiB
C++
55 lines
1.2 KiB
C++
#pragma once
|
|
|
|
#include "dnnlowp.h"
|
|
|
|
namespace dnnlowp {
|
|
|
|
class QuantizationErrorMinimization {
|
|
public:
|
|
virtual TensorQuantizationParams ChooseQuantizationParams(
|
|
const Histogram& hist,
|
|
bool preserve_sparsity = false,
|
|
int precision = 8) = 0;
|
|
virtual ~QuantizationErrorMinimization(){};
|
|
};
|
|
|
|
class NormMinimization : public QuantizationErrorMinimization {
|
|
public:
|
|
enum Kind {
|
|
L1,
|
|
L2,
|
|
};
|
|
|
|
NormMinimization(Kind kind) : kind_(kind) {}
|
|
|
|
/**
|
|
* Faster approximate search
|
|
*/
|
|
TensorQuantizationParams NonlinearQuantizationParamsSearch(
|
|
const Histogram& hist,
|
|
bool preserve_sparsity = false,
|
|
int precision = 8);
|
|
|
|
TensorQuantizationParams ChooseQuantizationParams(
|
|
const Histogram& hist,
|
|
bool preserve_sparsity = false,
|
|
int precision = 8) override;
|
|
|
|
protected:
|
|
Kind kind_;
|
|
};
|
|
|
|
class L1ErrorMinimization : public NormMinimization {
|
|
public:
|
|
L1ErrorMinimization() : NormMinimization(L1) {}
|
|
};
|
|
|
|
class P99 : public QuantizationErrorMinimization {
|
|
public:
|
|
TensorQuantizationParams ChooseQuantizationParams(
|
|
const Histogram& hist,
|
|
bool preserve_sparsity = true,
|
|
int precision = 8) override;
|
|
}; // class P99QuantizationFactory
|
|
|
|
} // namespace dnnlowp
|