2.1. __half Struct Reference
[Half Precision Intrinsics]
This structure implements the datatype for storing half-precision floating-point numbers. The structure implements assignment, arithmetic and comparison operators, and type conversions. 16 bits are being used in total: 1 sign bit, 5 bits for the exponent, and the significand is being stored in 10 bits. The total precision is 11 bits. There are 15361 representable numbers within the interval [0.0, 1.0], endpoints included. On average we have log10(2**11) ~ 3.311 decimal digits.
The objective here is to provide IEEE754-compliant implementation of binary16 type and arithmetic with limitations due to device HW not supporting floating-point exceptions.
Public Constructors
- __host__  __device__  __half ( const unsigned long long val )
- __host__  __device__  __half ( const long long val )
- __host__  __device__  __half ( const unsignedlong val )
- __host__  __device__  __half ( const long val )
- __host__  __device__  __half ( const unsigned int val )
- __host__  __device__  __half ( const int val )
- __host__  __device__  __half ( const unsigned short val )
- __host__  __device__  __half ( const short val )
- __host__  __device__  __half ( const double f )
- __host__  __device__  __half ( const float f )
- __host__  __device__  __half ( const __half_raw& hr )
- __host__  __device__  __half ( )
Public Member Functions
- __host__  __device__  operator __half_raw ( ) const
- __host__  __device__  operator __half_raw ( ) const
- __host__  __device__  constexpr operator bool ( ) const
- __host__  __device__  operator char ( ) const
- __host__  __device__  operator float ( ) const
- __host__  __device__  operator int ( ) const
- __host__  __device__  operator long ( ) const
- __host__  __device__  operator long long ( ) const
- __host__  __device__  operator short ( ) const
- __host__  __device__  operator signed char ( ) const
- __host__  __device__  operator unsigned char ( ) const
- __host__  __device__  operator unsigned int ( ) const
- __host__  __device__  operator unsigned long ( ) const
- __host__  __device__  operator unsigned long long ( ) const
- __host__  __device__  operator unsigned short ( ) const
- __host__  __device__ __half& operator= ( const unsigned long long val )
- __host__  __device__ __half& operator= ( const long long val )
- __host__  __device__ __half& operator= ( const unsigned int val )
- __host__  __device__ __half& operator= ( const int val )
- __host__  __device__ __half& operator= ( const unsigned short val )
- __host__  __device__ __half& operator= ( const short val )
- __host__  __device__ __half& operator= ( const double f )
- __host__  __device__ __half& operator= ( const float f )
- __host__  __device__ __half& operator= ( const __half_raw& hr )
- __host__  __device__ __half& operator= ( const __half_raw& hr )
- __host__  __device__ __half& operator= ( const __half_raw& hr )
Protected Variables
- unsigned short __x
Constructors
- __host__  __device__ __half::__half ( const unsigned long long val )
- 
                           
                           DescriptionConstruct __half from unsignedlonglong input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const long long val )
- 
                           
                           DescriptionConstruct __half from longlong input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const unsignedlong val )
- 
                           
                           DescriptionConstruct __half from unsignedlong input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const long val )
- 
                           
                           DescriptionConstruct __half from long input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const unsigned int val )
- 
                           
                           DescriptionConstruct __half from unsignedint input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const int val )
- 
                           
                           DescriptionConstruct __half from int input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const unsigned short val )
- 
                           
                           DescriptionConstruct __half from unsignedshort integer input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const short val )
- 
                           
                           DescriptionConstruct __half from short integer input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const double f )
- 
                           
                           DescriptionConstruct __half from double input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const float f )
- 
                           
                           DescriptionConstruct __half from float input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half::__half ( const __half_raw& hr ) [inline]
- 
                           
                           DescriptionConstructor from __half_raw. 
- __host__  __device__ __half::__half ( )
- 
                           
                           DescriptionConstructor by default. 
Member Functions
- __host__  __device__  __half::operator __half_raw ( ) const [inherited]
- 
                           
                           DescriptionType cast to __half_raw operator with volatile input. 
- __host__  __device__  __half::operator __half_raw ( ) const [inherited]
- 
                           
                           DescriptionType cast to __half_raw operator. 
- __host__  __device__  constexpr __half::operator bool ( ) const [inherited, inline]
- 
                           
                           DescriptionConversion operator to bool data type. +0 and -0 inputs convert to false. Non-zero inputs convert to true. 
- __host__  __device__  __half::operator char ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to an implementation defined char data type. Using round-toward-zero rounding mode. Detects signedness of the char type and proceeds accordingly, see further details in signed and unsigned char operators. 
- __host__  __device__  __half::operator float ( ) const [inherited]
- 
                           
                           DescriptionType cast to float operator. 
- __host__  __device__  __half::operator int ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to int data type. Using round-toward-zero rounding mode. See __half2int_rz( __half) for further details 
- __host__  __device__  __half::operator long ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to long data type. Using round-toward-zero rounding mode. 
- __host__  __device__  __half::operator long long ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to longlong data type. Using round-toward-zero rounding mode. See __half2ll_rz( __half) for further details 
- __host__  __device__  __half::operator short ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to short data type. Using round-toward-zero rounding mode. See __half2short_rz( __half) for further details 
- __host__  __device__  __half::operator signed char ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to signedchar data type. Using round-toward-zero rounding mode. See __half2char_rz( __half) for further details 
- __host__  __device__  __half::operator unsigned char ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to unsignedchar data type. Using round-toward-zero rounding mode. See __half2uchar_rz( __half) for further details 
- __host__  __device__  __half::operator unsigned int ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to unsignedint data type. Using round-toward-zero rounding mode. See __half2uint_rz( __half) for further details 
- __host__  __device__  __half::operator unsigned long ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to unsignedlong data type. Using round-toward-zero rounding mode. 
- __host__  __device__  __half::operator unsigned long long ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to unsignedlonglong data type. Using round-toward-zero rounding mode. See __half2ull_rz( __half) for further details 
- __host__  __device__  __half::operator unsigned short ( ) const [inherited]
- 
                           
                           DescriptionConversion operator to unsignedshort data type. Using round-toward-zero rounding mode. See __half2ushort_rz( __half) for further details 
- __host__  __device__ __half& __half::operator= ( const unsigned long long val ) [inherited]
- 
                           
                           DescriptionType cast from unsignedlonglong assignment operator, using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const long long val ) [inherited]
- 
                           
                           DescriptionType cast from longlong assignment operator, using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const unsigned int val ) [inherited]
- 
                           
                           DescriptionType cast from unsignedint assignment operator, using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const int val ) [inherited]
- 
                           
                           DescriptionType cast from int assignment operator, using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const unsigned short val ) [inherited]
- 
                           
                           DescriptionType cast from unsignedshort assignment operator, using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const short val ) [inherited]
- 
                           
                           DescriptionType cast from short assignment operator, using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const double f ) [inherited]
- 
                           
                           DescriptionType cast to __half assignment operator from double input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const float f ) [inherited]
- 
                           
                           DescriptionType cast to __half assignment operator from float input using default round-to-nearest-even rounding mode. 
- __host__  __device__ __half& __half::operator= ( const __half_raw& hr ) [inherited]
- 
                           
                           DescriptionAssignment operator from volatile__half_raw to volatile__half. 
- __host__  __device__ __half& __half::operator= ( const __half_raw& hr ) [inherited]
- 
                           
                           DescriptionAssignment operator from __half_raw to volatile__half. 
- __host__  __device__ __half& __half::operator= ( const __half_raw& hr ) [inherited]
- 
                           
                           DescriptionAssignment operator from __half_raw.