ONE - On-device Neural Engine
Loading...
Searching...
No Matches
PALQuantize.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_QUANTIZE_H
19#define LUCI_INTERPRETER_PAL_QUANTIZE_H
20
21#include "Params.h"
22#include <cmath>
23
25{
26template <typename InputT, typename OutputT>
27inline void Quantize(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 static constexpr int32_t min_val = std::numeric_limits<OutputT>::min();
33 static constexpr int32_t max_val = std::numeric_limits<OutputT>::max();
34
35 for (int i = 0; i < flat_size; i++)
36 {
37 const InputT val = input_data[i];
38 int32_t unclamped =
39 static_cast<int32_t>(std::round(val / static_cast<float>(scale))) + zero_point;
40 int32_t clamped = std::min(std::max(unclamped, min_val), max_val);
41 output_data[i] = clamped;
42 }
43}
44} // namespace luci_interpreter_pal
45
46#endif // LUCI_INTERPRETER_PAL_QUANTIZE_H