ONE - On-device Neural Engine
Loading...
Searching...
No Matches
PALDequantize.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2023 Samsung Electronics Co., Ltd. All Rights Reserved
3 * Copyright 2019 The TensorFlow Authors. All Rights Reserved.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18#ifndef LUCI_INTERPRETER_PAL_DEQUANTIZE_H
19#define LUCI_INTERPRETER_PAL_DEQUANTIZE_H
20
21#include "Params.h"
22#include <cmath>
23
25{
26template <typename InputT, typename OutputT>
27inline void Dequantize(const QuantizationParams &op_params, const int flat_size,
28 const InputT *input_data, OutputT *output_data)
29{
30 const int32_t zero_point = op_params.zero_point;
31 const double scale = op_params.scale;
32
33 for (int i = 0; i < flat_size; i++)
34 {
35 const int32_t val = input_data[i];
36 const OutputT result = static_cast<OutputT>(scale * (val - zero_point));
37 output_data[i] = result;
38 }
39}
40} // namespace luci_interpreter_pal
41
42#endif // LUCI_INTERPRETER_PAL_QUANTIZE_H