1*da0073e9SAndroid Build Coastguard Worker #pragma once
2*da0073e9SAndroid Build Coastguard Worker
3*da0073e9SAndroid Build Coastguard Worker #include <c10/macros/Macros.h>
4*da0073e9SAndroid Build Coastguard Worker #include <cstring>
5*da0073e9SAndroid Build Coastguard Worker #include <limits>
6*da0073e9SAndroid Build Coastguard Worker
7*da0073e9SAndroid Build Coastguard Worker C10_CLANG_DIAGNOSTIC_PUSH()
8*da0073e9SAndroid Build Coastguard Worker #if C10_CLANG_HAS_WARNING("-Wimplicit-int-float-conversion")
9*da0073e9SAndroid Build Coastguard Worker C10_CLANG_DIAGNOSTIC_IGNORE("-Wimplicit-int-float-conversion")
10*da0073e9SAndroid Build Coastguard Worker #endif
11*da0073e9SAndroid Build Coastguard Worker
12*da0073e9SAndroid Build Coastguard Worker #define EXP_WIDTH_FP8 5
13*da0073e9SAndroid Build Coastguard Worker #define MAN_WIDTH_FP8 2
14*da0073e9SAndroid Build Coastguard Worker #define EXP_BIAS_FP8 15
15*da0073e9SAndroid Build Coastguard Worker
16*da0073e9SAndroid Build Coastguard Worker namespace c10 {
17*da0073e9SAndroid Build Coastguard Worker
18*da0073e9SAndroid Build Coastguard Worker /// Constructors
19*da0073e9SAndroid Build Coastguard Worker
Float8_e5m2(float value)20*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2::Float8_e5m2(float value)
21*da0073e9SAndroid Build Coastguard Worker : x(detail::fp8e5m2_from_fp32_value(value)) {}
22*da0073e9SAndroid Build Coastguard Worker
23*da0073e9SAndroid Build Coastguard Worker /// Implicit conversions
24*da0073e9SAndroid Build Coastguard Worker
25*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2::operator float() const {
26*da0073e9SAndroid Build Coastguard Worker return detail::fp8e5m2_to_fp32_value(x);
27*da0073e9SAndroid Build Coastguard Worker }
28*da0073e9SAndroid Build Coastguard Worker
29*da0073e9SAndroid Build Coastguard Worker /// Special values helpers
30*da0073e9SAndroid Build Coastguard Worker
isnan()31*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE bool Float8_e5m2::isnan() const {
32*da0073e9SAndroid Build Coastguard Worker return (x & 0b01111111) > 0b01111100;
33*da0073e9SAndroid Build Coastguard Worker }
34*da0073e9SAndroid Build Coastguard Worker
isinf()35*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE bool Float8_e5m2::isinf() const {
36*da0073e9SAndroid Build Coastguard Worker return (x & 0b01111111) == 0b01111100;
37*da0073e9SAndroid Build Coastguard Worker }
38*da0073e9SAndroid Build Coastguard Worker
39*da0073e9SAndroid Build Coastguard Worker /// Arithmetic
40*da0073e9SAndroid Build Coastguard Worker
41*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2
42*da0073e9SAndroid Build Coastguard Worker operator+(const Float8_e5m2& a, const Float8_e5m2& b) {
43*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) + static_cast<float>(b);
44*da0073e9SAndroid Build Coastguard Worker }
45*da0073e9SAndroid Build Coastguard Worker
46*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2
47*da0073e9SAndroid Build Coastguard Worker operator-(const Float8_e5m2& a, const Float8_e5m2& b) {
48*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) - static_cast<float>(b);
49*da0073e9SAndroid Build Coastguard Worker }
50*da0073e9SAndroid Build Coastguard Worker
51*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2
52*da0073e9SAndroid Build Coastguard Worker operator*(const Float8_e5m2& a, const Float8_e5m2& b) {
53*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) * static_cast<float>(b);
54*da0073e9SAndroid Build Coastguard Worker }
55*da0073e9SAndroid Build Coastguard Worker
56*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator/(
57*da0073e9SAndroid Build Coastguard Worker const Float8_e5m2& a,
58*da0073e9SAndroid Build Coastguard Worker const Float8_e5m2& b) __ubsan_ignore_float_divide_by_zero__ {
59*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) / static_cast<float>(b);
60*da0073e9SAndroid Build Coastguard Worker }
61*da0073e9SAndroid Build Coastguard Worker
62*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator-(const Float8_e5m2& a) {
63*da0073e9SAndroid Build Coastguard Worker return -static_cast<float>(a);
64*da0073e9SAndroid Build Coastguard Worker }
65*da0073e9SAndroid Build Coastguard Worker
66*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2& operator+=(
67*da0073e9SAndroid Build Coastguard Worker Float8_e5m2& a,
68*da0073e9SAndroid Build Coastguard Worker const Float8_e5m2& b) {
69*da0073e9SAndroid Build Coastguard Worker a = a + b;
70*da0073e9SAndroid Build Coastguard Worker return a;
71*da0073e9SAndroid Build Coastguard Worker }
72*da0073e9SAndroid Build Coastguard Worker
73*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2& operator-=(
74*da0073e9SAndroid Build Coastguard Worker Float8_e5m2& a,
75*da0073e9SAndroid Build Coastguard Worker const Float8_e5m2& b) {
76*da0073e9SAndroid Build Coastguard Worker a = a - b;
77*da0073e9SAndroid Build Coastguard Worker return a;
78*da0073e9SAndroid Build Coastguard Worker }
79*da0073e9SAndroid Build Coastguard Worker
80*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2& operator*=(
81*da0073e9SAndroid Build Coastguard Worker Float8_e5m2& a,
82*da0073e9SAndroid Build Coastguard Worker const Float8_e5m2& b) {
83*da0073e9SAndroid Build Coastguard Worker a = a * b;
84*da0073e9SAndroid Build Coastguard Worker return a;
85*da0073e9SAndroid Build Coastguard Worker }
86*da0073e9SAndroid Build Coastguard Worker
87*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2& operator/=(
88*da0073e9SAndroid Build Coastguard Worker Float8_e5m2& a,
89*da0073e9SAndroid Build Coastguard Worker const Float8_e5m2& b) {
90*da0073e9SAndroid Build Coastguard Worker a = a / b;
91*da0073e9SAndroid Build Coastguard Worker return a;
92*da0073e9SAndroid Build Coastguard Worker }
93*da0073e9SAndroid Build Coastguard Worker
94*da0073e9SAndroid Build Coastguard Worker /// Arithmetic with floats
95*da0073e9SAndroid Build Coastguard Worker
96*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator+(Float8_e5m2 a, float b) {
97*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) + b;
98*da0073e9SAndroid Build Coastguard Worker }
99*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator-(Float8_e5m2 a, float b) {
100*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) - b;
101*da0073e9SAndroid Build Coastguard Worker }
102*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator*(Float8_e5m2 a, float b) {
103*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) * b;
104*da0073e9SAndroid Build Coastguard Worker }
105*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator/(Float8_e5m2 a, float b)
106*da0073e9SAndroid Build Coastguard Worker __ubsan_ignore_float_divide_by_zero__ {
107*da0073e9SAndroid Build Coastguard Worker return static_cast<float>(a) / b;
108*da0073e9SAndroid Build Coastguard Worker }
109*da0073e9SAndroid Build Coastguard Worker
110*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator+(float a, Float8_e5m2 b) {
111*da0073e9SAndroid Build Coastguard Worker return a + static_cast<float>(b);
112*da0073e9SAndroid Build Coastguard Worker }
113*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator-(float a, Float8_e5m2 b) {
114*da0073e9SAndroid Build Coastguard Worker return a - static_cast<float>(b);
115*da0073e9SAndroid Build Coastguard Worker }
116*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator*(float a, Float8_e5m2 b) {
117*da0073e9SAndroid Build Coastguard Worker return a * static_cast<float>(b);
118*da0073e9SAndroid Build Coastguard Worker }
119*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float operator/(float a, Float8_e5m2 b)
120*da0073e9SAndroid Build Coastguard Worker __ubsan_ignore_float_divide_by_zero__ {
121*da0073e9SAndroid Build Coastguard Worker return a / static_cast<float>(b);
122*da0073e9SAndroid Build Coastguard Worker }
123*da0073e9SAndroid Build Coastguard Worker
124*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float& operator+=(float& a, const Float8_e5m2& b) {
125*da0073e9SAndroid Build Coastguard Worker return a += static_cast<float>(b);
126*da0073e9SAndroid Build Coastguard Worker }
127*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float& operator-=(float& a, const Float8_e5m2& b) {
128*da0073e9SAndroid Build Coastguard Worker return a -= static_cast<float>(b);
129*da0073e9SAndroid Build Coastguard Worker }
130*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float& operator*=(float& a, const Float8_e5m2& b) {
131*da0073e9SAndroid Build Coastguard Worker return a *= static_cast<float>(b);
132*da0073e9SAndroid Build Coastguard Worker }
133*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE float& operator/=(float& a, const Float8_e5m2& b) {
134*da0073e9SAndroid Build Coastguard Worker return a /= static_cast<float>(b);
135*da0073e9SAndroid Build Coastguard Worker }
136*da0073e9SAndroid Build Coastguard Worker
137*da0073e9SAndroid Build Coastguard Worker /// Arithmetic with doubles
138*da0073e9SAndroid Build Coastguard Worker
139*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator+(Float8_e5m2 a, double b) {
140*da0073e9SAndroid Build Coastguard Worker return static_cast<double>(a) + b;
141*da0073e9SAndroid Build Coastguard Worker }
142*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator-(Float8_e5m2 a, double b) {
143*da0073e9SAndroid Build Coastguard Worker return static_cast<double>(a) - b;
144*da0073e9SAndroid Build Coastguard Worker }
145*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator*(Float8_e5m2 a, double b) {
146*da0073e9SAndroid Build Coastguard Worker return static_cast<double>(a) * b;
147*da0073e9SAndroid Build Coastguard Worker }
148*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator/(Float8_e5m2 a, double b)
149*da0073e9SAndroid Build Coastguard Worker __ubsan_ignore_float_divide_by_zero__ {
150*da0073e9SAndroid Build Coastguard Worker return static_cast<double>(a) / b;
151*da0073e9SAndroid Build Coastguard Worker }
152*da0073e9SAndroid Build Coastguard Worker
153*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator+(double a, Float8_e5m2 b) {
154*da0073e9SAndroid Build Coastguard Worker return a + static_cast<double>(b);
155*da0073e9SAndroid Build Coastguard Worker }
156*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator-(double a, Float8_e5m2 b) {
157*da0073e9SAndroid Build Coastguard Worker return a - static_cast<double>(b);
158*da0073e9SAndroid Build Coastguard Worker }
159*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator*(double a, Float8_e5m2 b) {
160*da0073e9SAndroid Build Coastguard Worker return a * static_cast<double>(b);
161*da0073e9SAndroid Build Coastguard Worker }
162*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE double operator/(double a, Float8_e5m2 b)
163*da0073e9SAndroid Build Coastguard Worker __ubsan_ignore_float_divide_by_zero__ {
164*da0073e9SAndroid Build Coastguard Worker return a / static_cast<double>(b);
165*da0073e9SAndroid Build Coastguard Worker }
166*da0073e9SAndroid Build Coastguard Worker
167*da0073e9SAndroid Build Coastguard Worker /// Arithmetic with ints
168*da0073e9SAndroid Build Coastguard Worker
169*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator+(Float8_e5m2 a, int b) {
170*da0073e9SAndroid Build Coastguard Worker return a + static_cast<Float8_e5m2>(b);
171*da0073e9SAndroid Build Coastguard Worker }
172*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator-(Float8_e5m2 a, int b) {
173*da0073e9SAndroid Build Coastguard Worker return a - static_cast<Float8_e5m2>(b);
174*da0073e9SAndroid Build Coastguard Worker }
175*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator*(Float8_e5m2 a, int b) {
176*da0073e9SAndroid Build Coastguard Worker return a * static_cast<Float8_e5m2>(b);
177*da0073e9SAndroid Build Coastguard Worker }
178*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator/(Float8_e5m2 a, int b) {
179*da0073e9SAndroid Build Coastguard Worker return a / static_cast<Float8_e5m2>(b);
180*da0073e9SAndroid Build Coastguard Worker }
181*da0073e9SAndroid Build Coastguard Worker
182*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator+(int a, Float8_e5m2 b) {
183*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) + b;
184*da0073e9SAndroid Build Coastguard Worker }
185*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator-(int a, Float8_e5m2 b) {
186*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) - b;
187*da0073e9SAndroid Build Coastguard Worker }
188*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator*(int a, Float8_e5m2 b) {
189*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) * b;
190*da0073e9SAndroid Build Coastguard Worker }
191*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator/(int a, Float8_e5m2 b) {
192*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) / b;
193*da0073e9SAndroid Build Coastguard Worker }
194*da0073e9SAndroid Build Coastguard Worker
195*da0073e9SAndroid Build Coastguard Worker //// Arithmetic with int64_t
196*da0073e9SAndroid Build Coastguard Worker
197*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator+(Float8_e5m2 a, int64_t b) {
198*da0073e9SAndroid Build Coastguard Worker return a + static_cast<Float8_e5m2>(b);
199*da0073e9SAndroid Build Coastguard Worker }
200*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator-(Float8_e5m2 a, int64_t b) {
201*da0073e9SAndroid Build Coastguard Worker return a - static_cast<Float8_e5m2>(b);
202*da0073e9SAndroid Build Coastguard Worker }
203*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator*(Float8_e5m2 a, int64_t b) {
204*da0073e9SAndroid Build Coastguard Worker return a * static_cast<Float8_e5m2>(b);
205*da0073e9SAndroid Build Coastguard Worker }
206*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator/(Float8_e5m2 a, int64_t b) {
207*da0073e9SAndroid Build Coastguard Worker return a / static_cast<Float8_e5m2>(b);
208*da0073e9SAndroid Build Coastguard Worker }
209*da0073e9SAndroid Build Coastguard Worker
210*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator+(int64_t a, Float8_e5m2 b) {
211*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) + b;
212*da0073e9SAndroid Build Coastguard Worker }
213*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator-(int64_t a, Float8_e5m2 b) {
214*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) - b;
215*da0073e9SAndroid Build Coastguard Worker }
216*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator*(int64_t a, Float8_e5m2 b) {
217*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) * b;
218*da0073e9SAndroid Build Coastguard Worker }
219*da0073e9SAndroid Build Coastguard Worker inline C10_HOST_DEVICE Float8_e5m2 operator/(int64_t a, Float8_e5m2 b) {
220*da0073e9SAndroid Build Coastguard Worker return static_cast<Float8_e5m2>(a) / b;
221*da0073e9SAndroid Build Coastguard Worker }
222*da0073e9SAndroid Build Coastguard Worker
223*da0073e9SAndroid Build Coastguard Worker /// NOTE: we do not define comparisons directly and instead rely on the implicit
224*da0073e9SAndroid Build Coastguard Worker /// conversion from c10::Float8_e5m2 to float.
225*da0073e9SAndroid Build Coastguard Worker
226*da0073e9SAndroid Build Coastguard Worker } // namespace c10
227*da0073e9SAndroid Build Coastguard Worker
228*da0073e9SAndroid Build Coastguard Worker namespace std {
229*da0073e9SAndroid Build Coastguard Worker
230*da0073e9SAndroid Build Coastguard Worker template <>
231*da0073e9SAndroid Build Coastguard Worker class numeric_limits<c10::Float8_e5m2> {
232*da0073e9SAndroid Build Coastguard Worker public:
233*da0073e9SAndroid Build Coastguard Worker static constexpr bool is_signed = true;
234*da0073e9SAndroid Build Coastguard Worker static constexpr bool is_integer = false;
235*da0073e9SAndroid Build Coastguard Worker static constexpr bool is_specialized = true;
236*da0073e9SAndroid Build Coastguard Worker static constexpr bool is_exact = false;
237*da0073e9SAndroid Build Coastguard Worker static constexpr bool has_infinity = true;
238*da0073e9SAndroid Build Coastguard Worker static constexpr bool has_quiet_NaN = true;
239*da0073e9SAndroid Build Coastguard Worker static constexpr bool has_signaling_NaN = false;
240*da0073e9SAndroid Build Coastguard Worker static constexpr auto has_denorm = true;
241*da0073e9SAndroid Build Coastguard Worker static constexpr auto has_denorm_loss = true;
242*da0073e9SAndroid Build Coastguard Worker static constexpr auto round_style = numeric_limits<float>::round_style;
243*da0073e9SAndroid Build Coastguard Worker static constexpr bool is_iec559 = false;
244*da0073e9SAndroid Build Coastguard Worker static constexpr bool is_bounded = true;
245*da0073e9SAndroid Build Coastguard Worker static constexpr bool is_modulo = false;
246*da0073e9SAndroid Build Coastguard Worker static constexpr int digits = 3;
247*da0073e9SAndroid Build Coastguard Worker static constexpr int digits10 = 0;
248*da0073e9SAndroid Build Coastguard Worker static constexpr int max_digits10 = 2;
249*da0073e9SAndroid Build Coastguard Worker static constexpr int radix = 2;
250*da0073e9SAndroid Build Coastguard Worker static constexpr int min_exponent = -13;
251*da0073e9SAndroid Build Coastguard Worker static constexpr int min_exponent10 = -4;
252*da0073e9SAndroid Build Coastguard Worker static constexpr int max_exponent = 16;
253*da0073e9SAndroid Build Coastguard Worker static constexpr int max_exponent10 = 4;
254*da0073e9SAndroid Build Coastguard Worker static constexpr auto traps = numeric_limits<float>::traps;
255*da0073e9SAndroid Build Coastguard Worker static constexpr auto tinyness_before =
256*da0073e9SAndroid Build Coastguard Worker numeric_limits<float>::tinyness_before;
257*da0073e9SAndroid Build Coastguard Worker
min()258*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 min() {
259*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0x4, c10::Float8_e5m2::from_bits());
260*da0073e9SAndroid Build Coastguard Worker }
max()261*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 max() {
262*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0x7B, c10::Float8_e5m2::from_bits());
263*da0073e9SAndroid Build Coastguard Worker }
lowest()264*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 lowest() {
265*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0xFB, c10::Float8_e5m2::from_bits());
266*da0073e9SAndroid Build Coastguard Worker }
epsilon()267*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 epsilon() {
268*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0x34, c10::Float8_e5m2::from_bits());
269*da0073e9SAndroid Build Coastguard Worker }
round_error()270*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 round_error() {
271*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0x38, c10::Float8_e5m2::from_bits());
272*da0073e9SAndroid Build Coastguard Worker }
infinity()273*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 infinity() {
274*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0x7C, c10::Float8_e5m2::from_bits());
275*da0073e9SAndroid Build Coastguard Worker }
quiet_NaN()276*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 quiet_NaN() {
277*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0x7F, c10::Float8_e5m2::from_bits());
278*da0073e9SAndroid Build Coastguard Worker }
denorm_min()279*da0073e9SAndroid Build Coastguard Worker static constexpr c10::Float8_e5m2 denorm_min() {
280*da0073e9SAndroid Build Coastguard Worker return c10::Float8_e5m2(0x01, c10::Float8_e5m2::from_bits());
281*da0073e9SAndroid Build Coastguard Worker }
282*da0073e9SAndroid Build Coastguard Worker };
283*da0073e9SAndroid Build Coastguard Worker
284*da0073e9SAndroid Build Coastguard Worker } // namespace std
285*da0073e9SAndroid Build Coastguard Worker
286*da0073e9SAndroid Build Coastguard Worker C10_CLANG_DIAGNOSTIC_POP()
287