MNN/source/backend/cpu/CPUQuantizedAdd.hpp

51 lines
1.5 KiB
C++
Raw Normal View History

2019-04-17 10:49:11 +08:00
//
// CPUQuantizedAdd.hpp
// MNN
//
// Created by MNN on 2018/10/18.
// Copyright © 2018, Alibaba Group Holding Limited
//
#ifndef CPUQuantizedAdd_hpp
#define CPUQuantizedAdd_hpp
2019-12-27 22:16:57 +08:00
#include "core/Execution.hpp"
2019-04-17 10:49:11 +08:00
#include "TFQuantizeOp_generated.h"
// have to include after Marco.h
#include "CPUFixedPoint.hpp"
2019-04-17 10:49:11 +08:00
namespace MNN {
class CPUQuantizedAdd : public Execution {
public:
CPUQuantizedAdd(Backend *backend, const Op *op);
virtual ~CPUQuantizedAdd() = default;
virtual ErrorCode onResize(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override;
virtual ErrorCode onExecute(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override;
private:
const QuantizedAdd *mQuantizedAddParam;
int mInput1Offset;
int mInput2Offset;
int mOutputOffset;
int mInput1Multiplier;
int mInput2Multiplier;
int mOutputMultiplier;
int mInput1Shift;
int mInput2Shift;
int mOutputShift;
int mOutputActivationMin, mOutputActivationMax;
int mLeftShiftResult1, mLeftShiftResult2;
int mRightShift1, mRightShift2;
int mLeftShiftOut, mRightShiftOut;
#ifdef MNN_USE_NEON
int16x8_t input1OffsetVec, input2OffsetVec;
int32x4_t outputOffsetVec, outputActivationMinVec, outputActivationMaxVec, leftShiftResult1Vec, leftShiftResult2Vec, input1MultiplierVec, input2MultiplierVec, outputMultiplierVec, leftShiftOutVec, rightShift1Vec, rightShift2Vec;
#endif
2019-04-17 10:49:11 +08:00
};
} // namespace MNN
#endif /* CPUQuantizedAdd_hpp */