-
Notifications
You must be signed in to change notification settings - Fork 91
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
collect the reused part and undef after usage
Co-authored-by: Marcel Koch <[email protected]>
- Loading branch information
1 parent
2e8b510
commit 4af7c54
Showing
5 changed files
with
133 additions
and
191 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
// SPDX-FileCopyrightText: 2024 The Ginkgo authors | ||
// | ||
// SPDX-License-Identifier: BSD-3-Clause | ||
|
||
#ifndef GKO_CORE_TEST_BASE_FLOATING_BIT_HELPER_HPP_ | ||
#define GKO_CORE_TEST_BASE_FLOATING_BIT_HELPER_HPP_ | ||
|
||
|
||
#include <bitset> | ||
#include <cstring> | ||
|
||
#include <ginkgo/core/base/half.hpp> | ||
|
||
namespace floating_bit_helper { | ||
|
||
|
||
constexpr auto byte_size = gko::detail::byte_size; | ||
|
||
|
||
template <std::size_t N> | ||
struct floating_impl; | ||
|
||
template <> | ||
struct floating_impl<16> { | ||
using type = gko::half; | ||
}; | ||
|
||
template <> | ||
struct floating_impl<32> { | ||
using type = float; | ||
}; | ||
|
||
template <> | ||
struct floating_impl<64> { | ||
using type = double; | ||
}; | ||
|
||
|
||
template <std::size_t N> | ||
using floating = typename floating_impl<N>::type; | ||
|
||
|
||
template <std::size_t N> | ||
floating<N - 1> create_from_bits(const char (&s)[N]) | ||
{ | ||
auto bits = std::bitset<N - 1>(s).to_ullong(); | ||
// We cast to the same size of integer type first. | ||
// Otherwise, the first memory chunk is different when we use | ||
// reinterpret_cast or memcpy to get the smaller type out of unsigned | ||
// long long. | ||
using bits_type = | ||
typename gko::detail::float_traits<floating<N - 1>>::bits_type; | ||
auto bits_val = static_cast<bits_type>(bits); | ||
floating<N - 1> result; | ||
static_assert(sizeof(floating<N - 1>) == sizeof(bits_type), | ||
"the type should have the same size as its bits_type"); | ||
std::memcpy(&result, &bits_val, sizeof(bits_type)); | ||
return result; | ||
} | ||
|
||
|
||
template <typename T> | ||
std::bitset<sizeof(T) * byte_size> get_bits(T val) | ||
{ | ||
using bits_type = typename gko::detail::float_traits<T>::bits_type; | ||
bits_type bits; | ||
static_assert(sizeof(T) == sizeof(bits_type), | ||
"the type should have the same size as its bits_type"); | ||
std::memcpy(&bits, &val, sizeof(T)); | ||
return std::bitset<sizeof(T) * byte_size>(bits); | ||
} | ||
|
||
template <std::size_t N> | ||
std::bitset<N - 1> get_bits(const char (&s)[N]) | ||
{ | ||
return std::bitset<N - 1>(s); | ||
} | ||
|
||
|
||
} // namespace floating_bit_helper | ||
|
||
#endif // GKO_CORE_TEST_BASE_FLOATING_BIT_HELPER_HPP_ |
Oops, something went wrong.