diff options
author | 2015-11-06 16:27:58 -0800 | |
---|---|---|
committer | 2015-11-06 16:27:58 -0800 | |
commit | f41959ccb2d9d4c722fe8fc3351401d53bcf4900 (patch) | |
tree | ef0ca22cb2a5ac4bdec9d080d8e0788a53ed496d /tensorflow/core/framework/bfloat16.cc |
TensorFlow: Initial commit of TensorFlow library.
TensorFlow is an open source software library for numerical computation
using data flow graphs.
Base CL: 107276108
Diffstat (limited to 'tensorflow/core/framework/bfloat16.cc')
-rw-r--r-- | tensorflow/core/framework/bfloat16.cc | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/tensorflow/core/framework/bfloat16.cc b/tensorflow/core/framework/bfloat16.cc new file mode 100644 index 0000000000..0068283367 --- /dev/null +++ b/tensorflow/core/framework/bfloat16.cc @@ -0,0 +1,22 @@ +#include "tensorflow/core/framework/bfloat16.h" + +namespace tensorflow { + +void FloatToBFloat16(const float* src, bfloat16* dst, int64 size) { + const uint16_t* p = reinterpret_cast<const uint16_t*>(src); + uint16_t* q = reinterpret_cast<uint16_t*>(dst); + for (; size; p += 2, q++, size--) { + *q = p[1]; + } +} + +void BFloat16ToFloat(const bfloat16* src, float* dst, int64 size) { + const uint16_t* p = reinterpret_cast<const uint16_t*>(src); + uint16_t* q = reinterpret_cast<uint16_t*>(dst); + for (; size; p++, q += 2, size--) { + q[0] = 0; + q[1] = *p; + } +} + +} // end namespace tensorflow |