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