15.20. __nv_fp8_e8m0
- 
struct __nv_fp8_e8m0
- __nv_fp8_e8m0 datatype - This structure implements the datatype for handling 8-bit scale factors of - e8m0kind: interpreted as powers of two with biased exponent. Bias equals to 127, so numbers 0 through 254 represent 2^-127 through 2^127. Number- 0xFF= 255 is reserved for NaN.- The structure implements converting constructors and operators. - Public Functions - 
__nv_fp8_e8m0() = default
- Constructor by default. 
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const __half f)
- Constructor from - __halfdata type, relies on- __NV_SATFINITEbehavior for large input values and- cudaRoundPosInffor rounding.- See also - __nv_cvt_float_to_e8m0 for further details 
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const __nv_bfloat16 f)
- Constructor from - __nv_bfloat16data type, relies on- __NV_SATFINITEbehavior for large input values and- cudaRoundPosInffor rounding.- See also - __nv_cvt_bfloat16raw_to_e8m0 for further details 
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const double f)
- Constructor from - doubledata type, relies on- __NV_SATFINITEbehavior for large input values and- cudaRoundPosInffor rounding.- See also - __nv_cvt_double_to_e8m0 for further details 
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const float f)
- Constructor from - floatdata type, relies on- __NV_SATFINITEbehavior behavior for large input values and- cudaRoundPosInffor rounding.- See also - __nv_cvt_float_to_e8m0 for further details 
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const int val)
- Constructor from - intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const long int val)
- Constructor from - long- intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const long long int val)
- Constructor from - long- long- intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const short int val)
- Constructor from - short- intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const unsigned int val)
- Constructor from - unsigned- intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const unsigned long int val)
- Constructor from - unsigned- long- intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const unsigned long long int val)
- Constructor from - unsigned- long- long- intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit __nv_fp8_e8m0(const unsigned short int val)
- Constructor from - unsigned- short- intdata type, relies on- cudaRoundPosInfrounding.
 - 
__host__ __device__ inline explicit operator __half() const
- Conversion operator to - __halfdata type.
 - 
__host__ __device__ inline explicit operator __nv_bfloat16() const
- Conversion operator to - __nv_bfloat16data type.
 - 
__host__ __device__ inline explicit operator bool() const
- Conversion operator to - booldata type.- All values in input range are non-zero, so result is always - true.
 - 
__host__ __device__ inline explicit operator char() const
- Conversion operator to an implementation defined - chardata type.- Detects signedness of the - chartype and proceeds accordingly, see further details in signed and unsigned char operators.- Clamps inputs to the output range. - NaNinputs convert to- zero.
 - 
__host__ __device__ inline explicit operator double() const
- Conversion operator to - doubledata type.
 - 
__host__ __device__ inline explicit operator float() const
- Conversion operator to - floatdata type.
 - 
__host__ __device__ inline explicit operator int() const
- Conversion operator to - intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zero.
 - 
__host__ __device__ inline explicit operator long int() const
- Conversion operator to - long- intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zeroif output type is 32-bit.- NaNinputs convert to- 0x8000000000000000ULLif output type is 64-bit.
 - 
__host__ __device__ inline explicit operator long long int() const
- Conversion operator to - long- long- intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- 0x8000000000000000LL.
 - 
__host__ __device__ inline explicit operator short int() const
- Conversion operator to - short- intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zero.
 - 
__host__ __device__ inline explicit operator signed char() const
- Conversion operator to - signed- chardata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zero.
 - 
__host__ __device__ inline explicit operator unsigned char() const
- Conversion operator to - unsigned- chardata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zero.
 - 
__host__ __device__ inline explicit operator unsigned int() const
- Conversion operator to - unsigned- intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zero.
 - 
__host__ __device__ inline explicit operator unsigned long int() const
- Conversion operator to - unsigned- long- intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zeroif output type is 32-bit.- NaNinputs convert to- 0x8000000000000000ULLif output type is 64-bit.
 - 
__host__ __device__ inline explicit operator unsigned long long int() const
- Conversion operator to - unsigned- long- long- intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- 0x8000000000000000ULL.
 - 
__host__ __device__ inline explicit operator unsigned short int() const
- Conversion operator to - unsigned- short- intdata type.- Clamps too large inputs to the output range. - NaNinputs convert to- zero.
 - Public Members - 
__nv_fp8_storage_t __x
- Storage variable contains the 8-bit scale data. 
 
- 
__nv_fp8_e8m0() = default