From 96964ff85d4f02b207e89d56ad496ca75dd6b314 Mon Sep 17 00:00:00 2001 From: Leo Chen Date: Tue, 8 Feb 2022 10:54:31 +0800 Subject: [PATCH] [bf16] change bf16 print behavior (#39370) --- paddle/fluid/platform/bfloat16_test.cc | 6 +++++- paddle/pten/common/bfloat16.h | 6 +++--- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/paddle/fluid/platform/bfloat16_test.cc b/paddle/fluid/platform/bfloat16_test.cc index cac9767dc29..d193f7a0c5b 100644 --- a/paddle/fluid/platform/bfloat16_test.cc +++ b/paddle/fluid/platform/bfloat16_test.cc @@ -132,7 +132,11 @@ TEST(bfloat16, floating) { TEST(bfloat16, print) { bfloat16 a = bfloat16(1.0f); - std::cout << a << std::endl; + std::cout << "a:" << a << std::endl; + std::stringstream ss1, ss2; + ss1 << a; + ss2 << 1.0f; + EXPECT_EQ(ss1.str(), ss2.str()); } // CPU test diff --git a/paddle/pten/common/bfloat16.h b/paddle/pten/common/bfloat16.h index 0d9db3dbe9b..56ba7fb54f0 100644 --- a/paddle/pten/common/bfloat16.h +++ b/paddle/pten/common/bfloat16.h @@ -82,7 +82,7 @@ struct PADDLE_ALIGN(2) bfloat16 { #if defined(PADDLE_CUDA_BF16) HOSTDEVICE inline explicit bfloat16(const __nv_bfloat16& val) { - x = *reinterpret_cast(&val); + x = *reinterpret_cast(&val); // NOLINT } #endif @@ -93,7 +93,7 @@ struct PADDLE_ALIGN(2) bfloat16 { // Assignment operators #if defined(PADDLE_CUDA_BF16) HOSTDEVICE inline bfloat16& operator=(const __nv_bfloat16& val) { - x = *reinterpret_cast(&val); + x = *reinterpret_cast(&val); // NOLINT return *this; } #endif @@ -311,7 +311,7 @@ HOSTDEVICE inline bool(isfinite)(const bfloat16& a) { } inline std::ostream& operator<<(std::ostream& os, const bfloat16& a) { - os << a.x; + os << static_cast(a); return os; } -- GitLab