blob: 8123cf35776a7af33432454de0a27e50cf4ba795 [file] [log] [blame]
telsoa01c577f2c2018-08-31 09:22:23 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003// SPDX-License-Identifier: MIT
telsoa01c577f2c2018-08-31 09:22:23 +01004//
5
Matteo Martincighe011d202019-11-28 11:35:47 +00006#include <armnnUtils/FloatingPointConverter.hpp>
arovir01616e7752018-10-01 17:08:59 +01007
Narumol Prangnawarat88325222020-03-06 14:45:57 +00008#include "BFloat16.hpp"
arovir01616e7752018-10-01 17:08:59 +01009#include "Half.hpp"
telsoa01c577f2c2018-08-31 09:22:23 +010010
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010011#include <armnn/utility/Assert.hpp>
telsoa01c577f2c2018-08-31 09:22:23 +010012
13namespace armnnUtils
14{
15
16void FloatingPointConverter::ConvertFloat32To16(const float* srcFloat32Buffer,
17 size_t numElements,
18 void* dstFloat16Buffer)
19{
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010020 ARMNN_ASSERT(srcFloat32Buffer != nullptr);
21 ARMNN_ASSERT(dstFloat16Buffer != nullptr);
telsoa01c577f2c2018-08-31 09:22:23 +010022
Ryan OSheaf4bfa6a2020-06-10 11:33:37 +010023 armnn::Half* pHalf = static_cast<armnn::Half*>(dstFloat16Buffer);
telsoa01c577f2c2018-08-31 09:22:23 +010024
25 for (size_t i = 0; i < numElements; i++)
26 {
27 pHalf[i] = armnn::Half(srcFloat32Buffer[i]);
28 }
29}
30
31void FloatingPointConverter::ConvertFloat16To32(const void* srcFloat16Buffer,
32 size_t numElements,
33 float* dstFloat32Buffer)
34{
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010035 ARMNN_ASSERT(srcFloat16Buffer != nullptr);
36 ARMNN_ASSERT(dstFloat32Buffer != nullptr);
telsoa01c577f2c2018-08-31 09:22:23 +010037
Ryan OSheaf4bfa6a2020-06-10 11:33:37 +010038 const armnn::Half* pHalf = static_cast<const armnn::Half*>(srcFloat16Buffer);
telsoa01c577f2c2018-08-31 09:22:23 +010039
40 for (size_t i = 0; i < numElements; i++)
41 {
42 dstFloat32Buffer[i] = pHalf[i];
43 }
44}
45
Narumol Prangnawarat88325222020-03-06 14:45:57 +000046void FloatingPointConverter::ConvertFloat32ToBFloat16(const float* srcFloat32Buffer,
47 size_t numElements,
48 void* dstBFloat16Buffer)
49{
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010050 ARMNN_ASSERT(srcFloat32Buffer != nullptr);
51 ARMNN_ASSERT(dstBFloat16Buffer != nullptr);
Narumol Prangnawarat88325222020-03-06 14:45:57 +000052
Ryan OSheaf4bfa6a2020-06-10 11:33:37 +010053 armnn::BFloat16* bf16 = static_cast<armnn::BFloat16*>(dstBFloat16Buffer);
Narumol Prangnawarat88325222020-03-06 14:45:57 +000054
55 for (size_t i = 0; i < numElements; i++)
56 {
57 bf16[i] = armnn::BFloat16(srcFloat32Buffer[i]);
58 }
59}
60
61void FloatingPointConverter::ConvertBFloat16ToFloat32(const void* srcBFloat16Buffer,
62 size_t numElements,
63 float* dstFloat32Buffer)
64{
Narumol Prangnawaratac2770a2020-04-01 16:51:23 +010065 ARMNN_ASSERT(srcBFloat16Buffer != nullptr);
66 ARMNN_ASSERT(dstFloat32Buffer != nullptr);
Narumol Prangnawarat88325222020-03-06 14:45:57 +000067
Ryan OSheaf4bfa6a2020-06-10 11:33:37 +010068 const armnn::BFloat16* bf16 = static_cast<const armnn::BFloat16*>(srcBFloat16Buffer);
Narumol Prangnawarat88325222020-03-06 14:45:57 +000069
70 for (size_t i = 0; i < numElements; i++)
71 {
Narumol Prangnawarate9e68182020-03-11 11:34:55 +000072 dstFloat32Buffer[i] = bf16[i].ToFloat32();
Narumol Prangnawarat88325222020-03-06 14:45:57 +000073 }
74}
75
telsoa01c577f2c2018-08-31 09:22:23 +010076} //namespace armnnUtils