| 
									
										
										
										
											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"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-05 20:27:57 +08:00
										 |  |  | // 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; | 
					
						
							| 
									
										
										
										
											2019-05-05 20:27:57 +08:00
										 |  |  |     int mLeftShiftResult1, mLeftShiftResult2; | 
					
						
							|  |  |  |     int mRightShift1, mRightShift2; | 
					
						
							| 
									
										
										
										
											2020-11-05 16:41:56 +08:00
										 |  |  |     int mLeftShiftOut, mRightShiftOut;     | 
					
						
							| 
									
										
										
										
											2019-04-17 10:49:11 +08:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace MNN
 | 
					
						
							|  |  |  | #endif /* CPUQuantizedAdd_hpp */
 |