diff --git a/projects/hip/include/hip/hcc_detail/device_functions.h b/projects/hip/include/hip/hcc_detail/device_functions.h index 47c25c87d7..fb453d02e9 100644 --- a/projects/hip/include/hip/hcc_detail/device_functions.h +++ b/projects/hip/include/hip/hcc_detail/device_functions.h @@ -408,34 +408,34 @@ double __shfl_xor(double var, int lane_mask, int width = warpSize) { __device__ static inline char4 __hip_hc_add8pk(char4 in1, char4 in2) { char4 out; - unsigned one1 = in1.a & MASK1; - unsigned one2 = in2.a & MASK1; - out.a = (one1 + one2) & MASK1; - one1 = in1.a & MASK2; - one2 = in2.a & MASK2; - out.a = out.a | ((one1 + one2) & MASK2); + unsigned one1 = in1.w & MASK1; + unsigned one2 = in2.w & MASK1; + out.w = (one1 + one2) & MASK1; + one1 = in1.w & MASK2; + one2 = in2.w & MASK2; + out.w = out.w | ((one1 + one2) & MASK2); return out; } __device__ static inline char4 __hip_hc_sub8pk(char4 in1, char4 in2) { char4 out; - unsigned one1 = in1.a & MASK1; - unsigned one2 = in2.a & MASK1; - out.a = (one1 - one2) & MASK1; - one1 = in1.a & MASK2; - one2 = in2.a & MASK2; - out.a = out.a | ((one1 - one2) & MASK2); + unsigned one1 = in1.w & MASK1; + unsigned one2 = in2.w & MASK1; + out.w = (one1 - one2) & MASK1; + one1 = in1.w & MASK2; + one2 = in2.w & MASK2; + out.w = out.w | ((one1 - one2) & MASK2); return out; } __device__ static inline char4 __hip_hc_mul8pk(char4 in1, char4 in2) { char4 out; - unsigned one1 = in1.a & MASK1; - unsigned one2 = in2.a & MASK1; - out.a = (one1 * one2) & MASK1; - one1 = in1.a & MASK2; - one2 = in2.a & MASK2; - out.a = out.a | ((one1 * one2) & MASK2); + unsigned one1 = in1.w & MASK1; + unsigned one2 = in2.w & MASK1; + out.w = (one1 * one2) & MASK1; + one1 = in1.w & MASK2; + one2 = in2.w & MASK2; + out.w = out.w | ((one1 * one2) & MASK2); return out; } diff --git a/projects/hip/include/hip/hcc_detail/hip_vector_types.h b/projects/hip/include/hip/hcc_detail/hip_vector_types.h index 7cd250e257..cf7058af2b 100644 --- a/projects/hip/include/hip/hcc_detail/hip_vector_types.h +++ b/projects/hip/include/hip/hcc_detail/hip_vector_types.h @@ -34,1132 +34,679 @@ THE SOFTWARE. #include "hip/hcc_detail/host_defines.h" -#define MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(type) \ - __device__ __host__ type() {} \ - __device__ __host__ type(const type& val) : x(val.x) {} \ - __device__ __host__ ~type() {} - -#define MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(type) \ - __device__ __host__ type() {} \ - __device__ __host__ type(const type& val) : x(val.x), y(val.y) {} \ - __device__ __host__ ~type() {} - -#define MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(type) \ - __device__ __host__ type() {} \ - __device__ __host__ type(const type& val) : x(val.x), y(val.y), z(val.z) {} \ - __device__ __host__ ~type() {} - -#define MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(type) \ - __device__ __host__ type() {} \ - __device__ __host__ type(const type& val) : x(val.x), y(val.y), z(val.z), w(val.w) {} \ - __device__ __host__ ~type() {} - -#define MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(type, type1) \ - __device__ __host__ type(type1 val) : x(val) {} - -#define MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(type, type1) \ - __device__ __host__ type(type1 val) : x(val), y(val) {} \ - __device__ __host__ type(type1 val1, type1 val2) : x(val1), y(val2) {} - -#define MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(type, type1) \ - __device__ __host__ type(type1 val) : x(val), y(val), z(val) {} \ - __device__ __host__ type(type1 val1, type1 val2, type1 val3) : x(val1), y(val2), z(val3) {} - -#define MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(type, type1) \ - __device__ __host__ type(type1 val) : x(val), y(val), z(val), w(val) {} \ - __device__ __host__ type(type1 val1, type1 val2, type1 val3, type1 val4) \ - : x(val1), y(val2), z(val3), w(val4) {} - -struct uchar1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(uchar1) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uchar1, signed long long) - +#if defined(__clang__) + #define __NATIVE_VECTOR__(n, ...) __attribute__((ext_vector_type(n))) +#elif defined(__GNUC__) // N.B.: GCC does not support .xyzw syntax. + #define __ROUND_UP_TO_NEXT_POT__(x) \ + (1 << (31 - __builtin_clz(x) + (x > (1 << (31 - __builtin_clz(x)))))) + #define __NATIVE_VECTOR__(n, T) \ + __attribute__((vector_size(__ROUND_UP_TO_NEXT_POT__(n) * sizeof(T)))) #endif - unsigned char x; -} __attribute__((aligned(1))); +#if defined(__cplusplus) + #include -struct uchar2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(uchar2) + template struct HIP_vector_base; - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uchar2, signed long long) -#endif - union { - struct { - unsigned char x, y; + template + struct HIP_vector_base { + typedef T Native_vec_ __NATIVE_VECTOR__(1, T); + + union { + Native_vec_ data; + struct { + T x; + }; }; - unsigned short a; - }; -} __attribute__((aligned(2))); - -struct uchar3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(uchar3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uchar3, signed long long) -#endif - unsigned char x, y, z; -}; - -struct uchar4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(uchar4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uchar4, signed long long) -#endif - union { - struct { - unsigned char x, y, z, w; - }; - unsigned int a; - }; -} __attribute__((aligned(4))); - - -struct char1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(char1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(char1, signed long long) -#endif - signed char x; -} __attribute__((aligned(1))); - -struct char2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(char2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(char2, signed long long) -#endif - union { - struct { - signed char x, y; - }; - unsigned short a; - }; -} __attribute__((aligned(2))); - -struct char3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(char3) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(char3, signed long long) -#endif - signed char x, y, z; -}; - -struct char4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(char4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(char4, signed long long) -#endif - union { - struct { - signed char x, y, z, w; - }; - unsigned int a; - }; -} __attribute__((aligned(4))); - - -struct ushort1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(ushort1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ushort1, signed long long) -#endif - unsigned short x; -} __attribute__((aligned(2))); - -struct ushort2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(ushort2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ushort2, signed long long) -#endif - union { - struct { - unsigned short x, y; - }; - unsigned int a; - }; -} __attribute__((aligned(4))); - -struct ushort3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(ushort3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ushort3, signed long long) -#endif - unsigned short x, y, z; -}; - -struct ushort4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(ushort4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ushort4, signed long long) -#endif - union { - struct { - unsigned short x, y, z, w; - }; - unsigned int a, b; - }; -} __attribute__((aligned(8))); - -struct short1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(short1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(short1, signed long long) -#endif - signed short x; -} __attribute__((aligned(2))); - -struct short2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(short2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(short2, signed long long) -#endif - union { - struct { - signed short x, y; - }; - unsigned int a; }; -} __attribute__((aligned(4))); + template + struct HIP_vector_base { + typedef T Native_vec_ __NATIVE_VECTOR__(2, T); -struct short3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(short3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(short3, signed long long) -#endif - signed short x, y, z; -}; - -struct short4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(short4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(short4, signed long long) -#endif - union { - struct { - signed short x, y, z, w; + union { + Native_vec_ data; + struct { + T x; + T y; + }; }; - unsigned int a, b; }; -} __attribute__((aligned(8))); - -struct uint1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(uint1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(uint1, signed long long) -#endif - unsigned int x; -} __attribute__((aligned(4))); - -struct uint2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(uint2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(uint2, signed long long) -#endif - unsigned int x, y; -} __attribute__((aligned(8))); - -struct uint3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(uint3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(uint3, signed long long) -#endif - unsigned int x, y, z; -}; - -struct uint4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(uint4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(uint4, signed long long) -#endif - unsigned int x, y, z, w; -} __attribute__((aligned(16))); - -struct int1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(int1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(int1, signed long long) -#endif - signed int x; -} __attribute__((aligned(4))); - -struct int2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(int2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(int2, signed long long) -#endif - signed int x, y; -} __attribute__((aligned(8))); - -struct int3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(int3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(int3, signed long long) -#endif - signed int x, y, z; -}; - -struct int4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(int4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(int4, signed long long) -#endif - signed int x, y, z, w; -} __attribute__((aligned(16))); - - -struct float1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(float1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(float1, signed long long) -#endif - float x; -} __attribute__((aligned(4))); - -struct float2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(float2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(float2, signed long long) -#endif - float x, y; -} __attribute__((aligned(8))); - -struct float3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(float3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(float3, signed long long) -#endif - float x, y, z; -}; - -struct float4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(float4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(float4, signed long long) -#endif - float x, y, z, w; -} __attribute__((aligned(16))); - - -struct double1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(double1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(double1, signed long long) -#endif - double x; -} __attribute__((aligned(8))); - -struct double2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(double2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(double2, signed long long) -#endif - double x, y; -} __attribute__((aligned(16))); - -struct double3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(double3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(double3, signed long long) -#endif - double x, y, z; -}; - -struct double4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(double4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(double4, signed long long) -#endif - double x, y, z, w; -} __attribute__((aligned(32))); - - -struct ulong1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(ulong1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulong1, signed long long) -#endif - unsigned long x; -} __attribute__((aligned(8))); - -struct ulong2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(ulong2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulong2, signed long long) -#endif - unsigned long x, y; -} __attribute__((aligned(16))); - -struct ulong3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(ulong3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulong3, signed long long) -#endif - unsigned long x, y, z; -}; - -struct ulong4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(ulong4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulong4, signed long long) -#endif - unsigned long x, y, z, w; -} __attribute__((aligned(32))); - - -struct long1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(long1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(long1, signed long long) -#endif - signed long x; -} __attribute__((aligned(8))); - -struct long2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(long2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(long2, signed long long) -#endif - signed long x, y; -} __attribute__((aligned(16))); - -struct long3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(long3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(long3, signed long long) -#endif - signed long x, y, z; -}; - -struct long4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(long4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(long4, signed long long) -#endif - signed long x, y, z, w; -} __attribute__((aligned(32))); - - -struct ulonglong1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(ulonglong1, signed long long) -#endif - unsigned long long x; -} __attribute__((aligned(8))); - -struct ulonglong2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(ulonglong2, signed long long) -#endif - unsigned long long x, y; -} __attribute__((aligned(16))); - -struct ulonglong3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(ulonglong3, signed long long) -#endif - unsigned long long x, y, z; -}; - -struct ulonglong4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(ulonglong4, signed long long) -#endif - unsigned long long x, y, z, w; -} __attribute__((aligned(32))); - - -struct longlong1 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_ONE_COMPONENT(longlong1) - - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, signed char) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, signed short) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, signed int) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, float) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, double) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, signed long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_ONE_COMPONENT(longlong1, signed long long) -#endif - signed long long x; -} __attribute__((aligned(8))); - -struct longlong2 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_TWO_COMPONENT(longlong2) - - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, signed char) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, signed short) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, signed int) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, float) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, double) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, signed long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_TWO_COMPONENT(longlong2, signed long long) -#endif - signed long long x, y; -} __attribute__((aligned(16))); - -struct longlong3 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_THREE_COMPONENT(longlong3) - - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, signed char) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, signed short) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, signed int) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, float) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, double) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, signed long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_THREE_COMPONENT(longlong3, signed long long) -#endif - signed long long x, y, z; -}; - -struct longlong4 { -#ifdef __cplusplus - public: - MAKE_DEFAULT_CONSTRUCTOR_FOUR_COMPONENT(longlong4) - - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, unsigned char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, signed char) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, unsigned short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, signed short) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, unsigned int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, signed int) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, float) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, double) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, unsigned long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, signed long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, unsigned long long) - MAKE_COMPONENT_CONSTRUCTOR_FOUR_COMPONENT(longlong4, signed long long) -#endif - signed long x, y, z, w; -} __attribute__((aligned(32))); - -#define DECLOP_MAKE_ONE_COMPONENT(comp, type) \ - __device__ __host__ static inline struct type make_##type(comp x) { \ - struct type ret; \ - ret.x = x; \ - return ret; \ + template + struct HIP_vector_base { + typedef T Native_vec_ __NATIVE_VECTOR__(3, T); + + union { + Native_vec_ data; + struct { + T x; + T y; + T z; + }; + }; + }; + + template + struct HIP_vector_base { + typedef T Native_vec_ __NATIVE_VECTOR__(4, T); + + union { + Native_vec_ data; + struct { + T x; + T y; + T z; + T w; + }; + }; + }; + + template + struct HIP_vector_type : public HIP_vector_base { + using HIP_vector_base::data; + using typename HIP_vector_base::Native_vec_; + + __host__ __device__ + HIP_vector_type() = default; + template< + typename U, + typename std::enable_if< + std::is_convertible{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type(U x) noexcept + { + for (auto i = 0u; i != rank; ++i) data[i] = x; + } + template< // TODO: constrain based on type as well. + typename... Us, + typename std::enable_if::type* = nullptr> + __host__ __device__ + HIP_vector_type(Us... xs) noexcept { data = Native_vec_{xs...}; } + __host__ __device__ + HIP_vector_type(const HIP_vector_type&) = default; + __host__ __device__ + HIP_vector_type(HIP_vector_type&&) = default; + __host__ __device__ + ~HIP_vector_type() = default; + + __host__ __device__ + HIP_vector_type& operator=(const HIP_vector_type&) = default; + __host__ __device__ + HIP_vector_type& operator=(HIP_vector_type&&) = default; + + // Operators + __host__ __device__ + HIP_vector_type& operator++() noexcept + { + return *this += HIP_vector_type{1}; + } + __host__ __device__ + HIP_vector_type operator++(int) noexcept + { + auto tmp(*this); + ++*this; + return tmp; + } + __host__ __device__ + HIP_vector_type& operator--() noexcept + { + return *this -= HIP_vector_type{1}; + } + __host__ __device__ + HIP_vector_type operator--(int) noexcept + { + auto tmp(*this); + --*this; + return tmp; + } + __host__ __device__ + HIP_vector_type& operator+=(const HIP_vector_type& x) noexcept + { + data += x.data; + return *this; + } + __host__ __device__ + HIP_vector_type& operator-=(const HIP_vector_type& x) noexcept + { + data -= x.data; + return *this; + } + template< + typename U, + typename std::enable_if< + std::is_convertible{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type& operator-=(U x) noexcept + { + return *this -= HIP_vector_type{x}; + } + __host__ __device__ + HIP_vector_type& operator*=(const HIP_vector_type& x) noexcept + { + data *= x.data; + return *this; + } + __host__ __device__ + HIP_vector_type& operator/=(const HIP_vector_type& x) noexcept + { + data /= x.data; + return *this; + } + + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type operator-() noexcept + { + auto tmp(*this); + tmp.data = -tmp.data; + return tmp; + } + + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type operator~() noexcept + { + HIP_vector_type r{*this}; + r.data = ~r.data; + return r; + } + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type& operator%=(const HIP_vector_type& x) noexcept + { + data %= x.data; + return *this; + } + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type& operator^=(const HIP_vector_type& x) noexcept + { + data ^= x.data; + return *this; + } + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type& operator|=(const HIP_vector_type& x) noexcept + { + data |= x.data; + return *this; + } + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type& operator&=(const HIP_vector_type& x) noexcept + { + data &= x.data; + return *this; + } + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type& operator>>=(const HIP_vector_type& x) noexcept + { + data >>= x.data; + return *this; + } + template< + typename U = T, + typename std::enable_if{}>::type* = nullptr> + __host__ __device__ + HIP_vector_type& operator<<=(const HIP_vector_type& x) noexcept + { + data <<= x.data; + return *this; + } + }; + + + template + __host__ __device__ + inline + HIP_vector_type operator+( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} += y; + } + template + __host__ __device__ + inline + HIP_vector_type operator+( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} += y; + } + template + __host__ __device__ + inline + HIP_vector_type operator+( + U x, const HIP_vector_type& y) noexcept + { + return y + x; } -#define DECLOP_MAKE_TWO_COMPONENT(comp, type) \ - __device__ __host__ static inline struct type make_##type(comp x, comp y) { \ - struct type ret; \ - ret.x = x; \ - ret.y = y; \ - return ret; \ + template + __host__ __device__ + inline + HIP_vector_type operator-( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} -= y; + } + template + __host__ __device__ + inline + HIP_vector_type operator-( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} -= y; + } + template + __host__ __device__ + inline + HIP_vector_type operator-( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} -= y; } -#define DECLOP_MAKE_THREE_COMPONENT(comp, type) \ - __device__ __host__ static inline struct type make_##type(comp x, comp y, comp z) { \ - struct type ret; \ - ret.x = x; \ - ret.y = y; \ - ret.z = z; \ - return ret; \ + template + __host__ __device__ + inline + HIP_vector_type operator*( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} *= y; + } + template + __host__ __device__ + inline + HIP_vector_type operator*( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} *= y; + } + template + __host__ __device__ + inline + HIP_vector_type operator*( + U x, const HIP_vector_type& y) noexcept + { + return y * x; } -#define DECLOP_MAKE_FOUR_COMPONENT(comp, type) \ - __device__ __host__ static inline struct type make_##type(comp x, comp y, comp z, comp w) { \ - struct type ret; \ - ret.x = x; \ - ret.y = y; \ - ret.z = z; \ - ret.w = w; \ - return ret; \ + template + __host__ __device__ + inline + HIP_vector_type operator/( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} /= y; + } + template + __host__ __device__ + inline + HIP_vector_type operator/( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} /= y; + } + template + __host__ __device__ + inline + HIP_vector_type operator/( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} /= y; + } + + template + __host__ __device__ + inline + bool operator==( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + auto tmp = x.data == y.data; + for (auto i = 0u; i != n; ++i) if (tmp[i] == 0) return false; + return true; + } + template + __host__ __device__ + inline + bool operator==(const HIP_vector_type& x, U y) noexcept + { + return x == HIP_vector_type{y}; + } + template + __host__ __device__ + inline + bool operator==(U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} == y; + } + + template + __host__ __device__ + inline + bool operator!=( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return !(x == y); + } + template + __host__ __device__ + inline + bool operator!=(const HIP_vector_type& x, U y) noexcept + { + return !(x == y); + } + template + __host__ __device__ + inline + bool operator!=(U x, const HIP_vector_type& y) noexcept + { + return !(x == y); + } + + template< + typename T, + unsigned int n, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator%( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} %= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator%( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} %= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator%( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} %= y; + } + + template< + typename T, + unsigned int n, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator^( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} ^= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator^( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} ^= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator^( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} ^= y; + } + + template< + typename T, + unsigned int n, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator|( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} |= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator|( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} |= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator|( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} |= y; + } + + template< + typename T, + unsigned int n, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator&( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} &= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator&( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} &= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator&( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} &= y; + } + + template< + typename T, + unsigned int n, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator>>( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} >>= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator>>( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} >>= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator>>( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} >>= y; + } + + template< + typename T, + unsigned int n, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator<<( + const HIP_vector_type& x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} <<= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator<<( + const HIP_vector_type& x, U y) noexcept + { + return HIP_vector_type{x} <<= y; + } + template< + typename T, + unsigned int n, + typename U, + typename std::enable_if{}>* = nullptr> + inline + HIP_vector_type operator<<( + U x, const HIP_vector_type& y) noexcept + { + return HIP_vector_type{x} <<= y; + } + + #define __MAKE_VECTOR_TYPE__(CUDA_name, T) \ + using CUDA_name##1 = HIP_vector_type;\ + using CUDA_name##2 = HIP_vector_type;\ + using CUDA_name##3 = HIP_vector_type;\ + using CUDA_name##4 = HIP_vector_type; +#else + #define __MAKE_VECTOR_TYPE__(CUDA_name, T) \ + typedef T CUDA_name##_impl1 __NATIVE_VECTOR__(1, T);\ + typedef T CUDA_name##_impl2 __NATIVE_VECTOR__(2, T);\ + typedef T CUDA_name##_impl3 __NATIVE_VECTOR__(3, T);\ + typedef T CUDA_name##_impl4 __NATIVE_VECTOR__(4, T);\ + typedef struct {\ + union {\ + CUDA_name##_impl1 data;\ + struct {\ + T x;\ + };\ + };\ + } CUDA_name##1;\ + typedef struct {\ + union {\ + CUDA_name##_impl2 data;\ + struct {\ + T x;\ + T y;\ + };\ + };\ + } CUDA_name##2;\ + typedef struct {\ + union {\ + CUDA_name##_impl3 data;\ + struct {\ + T x;\ + T y;\ + T z;\ + };\ + };\ + } CUDA_name##3;\ + typedef struct {\ + union {\ + CUDA_name##_impl4 data;\ + struct {\ + T x;\ + T y;\ + T z;\ + T w;\ + };\ + };\ + } CUDA_name##4; +#endif + +__MAKE_VECTOR_TYPE__(uchar, unsigned char); +__MAKE_VECTOR_TYPE__(char, char); +__MAKE_VECTOR_TYPE__(ushort, unsigned short); +__MAKE_VECTOR_TYPE__(short, short); +__MAKE_VECTOR_TYPE__(uint, unsigned int); +__MAKE_VECTOR_TYPE__(int, int); +__MAKE_VECTOR_TYPE__(ulong, unsigned long); +__MAKE_VECTOR_TYPE__(long, long); +__MAKE_VECTOR_TYPE__(ulonglong, unsigned long long); +__MAKE_VECTOR_TYPE__(longlong, long long); +__MAKE_VECTOR_TYPE__(float, float); +__MAKE_VECTOR_TYPE__(double, double); + +#define DECLOP_MAKE_ONE_COMPONENT(comp, type) \ + __device__ __host__ \ + static \ + inline \ + type make_##type(comp x) { type r = {x}; return r; } + +#define DECLOP_MAKE_TWO_COMPONENT(comp, type) \ + __device__ __host__ \ + static \ + inline \ + type make_##type(comp x, comp y) { type r = {x, y}; return r; } + +#define DECLOP_MAKE_THREE_COMPONENT(comp, type) \ + __device__ __host__ \ + static \ + inline \ + type make_##type(comp x, comp y, comp z) { type r = {x, y, z}; return r; } + +#define DECLOP_MAKE_FOUR_COMPONENT(comp, type) \ + __device__ __host__ \ + static \ + inline \ + type make_##type(comp x, comp y, comp z, comp w) { \ + type r = {x, y, z, w}; \ + return r; \ } DECLOP_MAKE_ONE_COMPONENT(unsigned char, uchar1); @@ -1222,2894 +769,4 @@ DECLOP_MAKE_TWO_COMPONENT(signed long, longlong2); DECLOP_MAKE_THREE_COMPONENT(signed long, longlong3); DECLOP_MAKE_FOUR_COMPONENT(signed long, longlong4); - -#if __cplusplus - -#define DECLOP_1VAR_2IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(const type& lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs.x op rhs.x; \ - return ret; \ - } - -#define DECLOP_1VAR_SCALE_PRODUCT(type, type1) \ - __device__ __host__ static inline type operator*(const type& lhs, type1 rhs) { \ - type ret; \ - ret.x = lhs.x * rhs; \ - return ret; \ - } \ - \ - __device__ __host__ static inline type operator*(type1 lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs * rhs.x; \ - return ret; \ - } - -#define DECLOP_1VAR_ASSIGN(type, op) \ - __device__ __host__ static inline type& operator op(type& lhs, const type& rhs) { \ - lhs.x op rhs.x; \ - return lhs; \ - } - -#define DECLOP_1VAR_PREOP(type, op) \ - __device__ __host__ static inline type& operator op(type& val) { \ - op val.x; \ - return val; \ - } - -#define DECLOP_1VAR_POSTOP(type, op) \ - __device__ __host__ static inline type operator op(type& val, int) { \ - type ret; \ - ret.x = val.x; \ - val.x op; \ - return ret; \ - } - -#define DECLOP_1VAR_COMP(type, op) \ - __device__ __host__ static inline bool operator op(type& lhs, type& rhs) { \ - return lhs.x op rhs.x; \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, type& rhs) { \ - return lhs.x op rhs.x; \ - } \ - __device__ __host__ static inline bool operator op(type& lhs, const type& rhs) { \ - return lhs.x op rhs.x; \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, const type& rhs) { \ - return lhs.x op rhs.x; \ - } - -#define DECLOP_1VAR_1IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(type& rhs) { \ - type ret; \ - ret.x = op rhs.x; \ - return ret; \ - } - -#define DECLOP_1VAR_1IN_BOOLOUT(type, op) \ - __device__ __host__ static inline bool operator op(type& rhs) { return op rhs.x; } - -/* - Two Element Access -*/ - -#define DECLOP_2VAR_2IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(const type& lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs.x op rhs.x; \ - ret.y = lhs.y op rhs.y; \ - return ret; \ - } - -#define DECLOP_2VAR_SCALE_PRODUCT(type, type1) \ - __device__ __host__ static inline type operator*(const type& lhs, type1 rhs) { \ - type ret; \ - ret.x = lhs.x * rhs; \ - ret.y = lhs.y * rhs; \ - return ret; \ - } \ - \ - __device__ __host__ static inline type operator*(type1 lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs * rhs.x; \ - ret.y = lhs * rhs.y; \ - return ret; \ - } - -#define DECLOP_2VAR_ASSIGN(type, op) \ - __device__ __host__ static inline type& operator op(type& lhs, const type& rhs) { \ - lhs.x op rhs.x; \ - lhs.y op rhs.y; \ - return lhs; \ - } - -#define DECLOP_2VAR_PREOP(type, op) \ - __device__ __host__ static inline type& operator op(type& val) { \ - op val.x; \ - op val.y; \ - return val; \ - } - -#define DECLOP_2VAR_POSTOP(type, op) \ - __device__ __host__ static inline type operator op(type& val, int) { \ - type ret; \ - ret.x = val.x; \ - ret.y = val.y; \ - val.x op; \ - val.y op; \ - return ret; \ - } - -#define DECLOP_2VAR_COMP(type, op) \ - __device__ __host__ static inline bool operator op(type& lhs, type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y); \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y); \ - } \ - __device__ __host__ static inline bool operator op(type& lhs, const type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y); \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, const type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y); \ - } - -#define DECLOP_2VAR_1IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(type& rhs) { \ - type ret; \ - ret.x = op rhs.x; \ - ret.y = op rhs.y; \ - return ret; \ - } - -#define DECLOP_2VAR_1IN_BOOLOUT(type, op) \ - __device__ __host__ static inline bool operator op(type& rhs) { \ - return (op rhs.x) && (op rhs.y); \ - } - - -/* - Three Element Access -*/ - -#define DECLOP_3VAR_2IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(const type& lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs.x op rhs.x; \ - ret.y = lhs.y op rhs.y; \ - ret.z = lhs.z op rhs.z; \ - return ret; \ - } - -#define DECLOP_3VAR_SCALE_PRODUCT(type, type1) \ - __device__ __host__ static inline type operator*(const type& lhs, type1 rhs) { \ - type ret; \ - ret.x = lhs.x * rhs; \ - ret.y = lhs.y * rhs; \ - ret.z = lhs.z * rhs; \ - return ret; \ - } \ - \ - __device__ __host__ static inline type operator*(type1 lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs * rhs.x; \ - ret.y = lhs * rhs.y; \ - ret.z = lhs * rhs.z; \ - return ret; \ - } - -#define DECLOP_3VAR_ASSIGN(type, op) \ - __device__ __host__ static inline type& operator op(type& lhs, const type& rhs) { \ - lhs.x op rhs.x; \ - lhs.y op rhs.y; \ - lhs.z op rhs.z; \ - return lhs; \ - } - -#define DECLOP_3VAR_PREOP(type, op) \ - __device__ __host__ static inline type& operator op(type& val) { \ - op val.x; \ - op val.y; \ - op val.z; \ - return val; \ - } - -#define DECLOP_3VAR_POSTOP(type, op) \ - __device__ __host__ static inline type operator op(type& val, int) { \ - type ret; \ - ret.x = val.x; \ - ret.y = val.y; \ - ret.z = val.z; \ - val.x op; \ - val.y op; \ - val.z op; \ - return ret; \ - } - -#define DECLOP_3VAR_COMP(type, op) \ - __device__ __host__ static inline bool operator op(type& lhs, type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z); \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z); \ - } \ - __device__ __host__ static inline bool operator op(type& lhs, const type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z); \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, const type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z); \ - } - -#define DECLOP_3VAR_1IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(type& rhs) { \ - type ret; \ - ret.x = op rhs.x; \ - ret.y = op rhs.y; \ - ret.z = op rhs.z; \ - return ret; \ - } - -#define DECLOP_3VAR_1IN_BOOLOUT(type, op) \ - __device__ __host__ static inline bool operator op(type& rhs) { \ - return (op rhs.x) && (op rhs.y) && (op rhs.z); \ - } - - -/* - Four Element Access -*/ - -#define DECLOP_4VAR_2IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(const type& lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs.x op rhs.x; \ - ret.y = lhs.y op rhs.y; \ - ret.z = lhs.z op rhs.z; \ - ret.w = lhs.w op rhs.w; \ - return ret; \ - } - -#define DECLOP_4VAR_SCALE_PRODUCT(type, type1) \ - __device__ __host__ static inline type operator*(const type& lhs, type1 rhs) { \ - type ret; \ - ret.x = lhs.x * rhs; \ - ret.y = lhs.y * rhs; \ - ret.z = lhs.z * rhs; \ - ret.w = lhs.w * rhs; \ - return ret; \ - } \ - \ - __device__ __host__ static inline type operator*(type1 lhs, const type& rhs) { \ - type ret; \ - ret.x = lhs * rhs.x; \ - ret.y = lhs * rhs.y; \ - ret.z = lhs * rhs.z; \ - ret.w = lhs * rhs.w; \ - return ret; \ - } - -#define DECLOP_4VAR_ASSIGN(type, op) \ - __device__ __host__ static inline type& operator op(type& lhs, const type& rhs) { \ - lhs.x op rhs.x; \ - lhs.y op rhs.y; \ - lhs.z op rhs.z; \ - lhs.w op rhs.w; \ - return lhs; \ - } - -#define DECLOP_4VAR_PREOP(type, op) \ - __device__ __host__ static inline type& operator op(type& val) { \ - op val.x; \ - op val.y; \ - op val.z; \ - op val.w; \ - return val; \ - } - -#define DECLOP_4VAR_POSTOP(type, op) \ - __device__ __host__ static inline type operator op(type& val, int) { \ - type ret; \ - ret.x = val.x; \ - ret.y = val.y; \ - ret.z = val.z; \ - ret.w = val.w; \ - val.x op; \ - val.y op; \ - val.z op; \ - val.w op; \ - return ret; \ - } - -#define DECLOP_4VAR_COMP(type, op) \ - __device__ __host__ static inline bool operator op(type& lhs, type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z) && (lhs.w op rhs.w); \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z) && (lhs.w op rhs.w); \ - } \ - __device__ __host__ static inline bool operator op(type& lhs, const type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z) && (lhs.w op rhs.w); \ - } \ - __device__ __host__ static inline bool operator op(const type& lhs, const type& rhs) { \ - return (lhs.x op rhs.x) && (lhs.y op rhs.y) && (lhs.z op rhs.z) && (lhs.w op rhs.w); \ - } - -#define DECLOP_4VAR_1IN_1OUT(type, op) \ - __device__ __host__ static inline type operator op(type& rhs) { \ - type ret; \ - ret.x = op rhs.x; \ - ret.y = op rhs.y; \ - ret.z = op rhs.z; \ - ret.w = op rhs.w; \ - return ret; \ - } - -#define DECLOP_4VAR_1IN_BOOLOUT(type, op) \ - __device__ __host__ static inline bool operator op(type& rhs) { \ - return (op rhs.x) && (op rhs.y) && (op rhs.z) && (op rhs.w); \ - } - - -/* -Overloading operators -*/ - -// UNSIGNED CHAR1 - -DECLOP_1VAR_2IN_1OUT(uchar1, +) -DECLOP_1VAR_2IN_1OUT(uchar1, -) -DECLOP_1VAR_2IN_1OUT(uchar1, *) -DECLOP_1VAR_2IN_1OUT(uchar1, /) -DECLOP_1VAR_2IN_1OUT(uchar1, %) -DECLOP_1VAR_2IN_1OUT(uchar1, &) -DECLOP_1VAR_2IN_1OUT(uchar1, |) -DECLOP_1VAR_2IN_1OUT(uchar1, ^) -DECLOP_1VAR_2IN_1OUT(uchar1, <<) -DECLOP_1VAR_2IN_1OUT(uchar1, >>) - - -DECLOP_1VAR_ASSIGN(uchar1, +=) -DECLOP_1VAR_ASSIGN(uchar1, -=) -DECLOP_1VAR_ASSIGN(uchar1, *=) -DECLOP_1VAR_ASSIGN(uchar1, /=) -DECLOP_1VAR_ASSIGN(uchar1, %=) -DECLOP_1VAR_ASSIGN(uchar1, &=) -DECLOP_1VAR_ASSIGN(uchar1, |=) -DECLOP_1VAR_ASSIGN(uchar1, ^=) -DECLOP_1VAR_ASSIGN(uchar1, <<=) -DECLOP_1VAR_ASSIGN(uchar1, >>=) - -DECLOP_1VAR_PREOP(uchar1, ++) -DECLOP_1VAR_PREOP(uchar1, --) - -DECLOP_1VAR_POSTOP(uchar1, ++) -DECLOP_1VAR_POSTOP(uchar1, --) - -DECLOP_1VAR_COMP(uchar1, ==) -DECLOP_1VAR_COMP(uchar1, !=) -DECLOP_1VAR_COMP(uchar1, <) -DECLOP_1VAR_COMP(uchar1, >) -DECLOP_1VAR_COMP(uchar1, <=) -DECLOP_1VAR_COMP(uchar1, >=) - -DECLOP_1VAR_COMP(uchar1, &&) -DECLOP_1VAR_COMP(uchar1, ||) - -DECLOP_1VAR_1IN_1OUT(uchar1, ~) -DECLOP_1VAR_1IN_BOOLOUT(uchar1, !) - -DECLOP_1VAR_SCALE_PRODUCT(uchar1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, float) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, double) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(uchar1, signed long long) - -// UNSIGNED CHAR2 - -DECLOP_2VAR_2IN_1OUT(uchar2, +) -DECLOP_2VAR_2IN_1OUT(uchar2, -) -DECLOP_2VAR_2IN_1OUT(uchar2, *) -DECLOP_2VAR_2IN_1OUT(uchar2, /) -DECLOP_2VAR_2IN_1OUT(uchar2, %) -DECLOP_2VAR_2IN_1OUT(uchar2, &) -DECLOP_2VAR_2IN_1OUT(uchar2, |) -DECLOP_2VAR_2IN_1OUT(uchar2, ^) -DECLOP_2VAR_2IN_1OUT(uchar2, <<) -DECLOP_2VAR_2IN_1OUT(uchar2, >>) - -DECLOP_2VAR_ASSIGN(uchar2, +=) -DECLOP_2VAR_ASSIGN(uchar2, -=) -DECLOP_2VAR_ASSIGN(uchar2, *=) -DECLOP_2VAR_ASSIGN(uchar2, /=) -DECLOP_2VAR_ASSIGN(uchar2, %=) -DECLOP_2VAR_ASSIGN(uchar2, &=) -DECLOP_2VAR_ASSIGN(uchar2, |=) -DECLOP_2VAR_ASSIGN(uchar2, ^=) -DECLOP_2VAR_ASSIGN(uchar2, <<=) -DECLOP_2VAR_ASSIGN(uchar2, >>=) - -DECLOP_2VAR_PREOP(uchar2, ++) -DECLOP_2VAR_PREOP(uchar2, --) - -DECLOP_2VAR_POSTOP(uchar2, ++) -DECLOP_2VAR_POSTOP(uchar2, --) - -DECLOP_2VAR_COMP(uchar2, ==) -DECLOP_2VAR_COMP(uchar2, !=) -DECLOP_2VAR_COMP(uchar2, <) -DECLOP_2VAR_COMP(uchar2, >) -DECLOP_2VAR_COMP(uchar2, <=) -DECLOP_2VAR_COMP(uchar2, >=) - -DECLOP_2VAR_COMP(uchar2, &&) -DECLOP_2VAR_COMP(uchar2, ||) - -DECLOP_2VAR_1IN_1OUT(uchar2, ~) -DECLOP_2VAR_1IN_BOOLOUT(uchar2, !) - -DECLOP_2VAR_SCALE_PRODUCT(uchar2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, float) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, double) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(uchar2, signed long long) - -// UNSIGNED CHAR3 - -DECLOP_3VAR_2IN_1OUT(uchar3, +) -DECLOP_3VAR_2IN_1OUT(uchar3, -) -DECLOP_3VAR_2IN_1OUT(uchar3, *) -DECLOP_3VAR_2IN_1OUT(uchar3, /) -DECLOP_3VAR_2IN_1OUT(uchar3, %) -DECLOP_3VAR_2IN_1OUT(uchar3, &) -DECLOP_3VAR_2IN_1OUT(uchar3, |) -DECLOP_3VAR_2IN_1OUT(uchar3, ^) -DECLOP_3VAR_2IN_1OUT(uchar3, <<) -DECLOP_3VAR_2IN_1OUT(uchar3, >>) - -DECLOP_3VAR_ASSIGN(uchar3, +=) -DECLOP_3VAR_ASSIGN(uchar3, -=) -DECLOP_3VAR_ASSIGN(uchar3, *=) -DECLOP_3VAR_ASSIGN(uchar3, /=) -DECLOP_3VAR_ASSIGN(uchar3, %=) -DECLOP_3VAR_ASSIGN(uchar3, &=) -DECLOP_3VAR_ASSIGN(uchar3, |=) -DECLOP_3VAR_ASSIGN(uchar3, ^=) -DECLOP_3VAR_ASSIGN(uchar3, <<=) -DECLOP_3VAR_ASSIGN(uchar3, >>=) - -DECLOP_3VAR_PREOP(uchar3, ++) -DECLOP_3VAR_PREOP(uchar3, --) - -DECLOP_3VAR_POSTOP(uchar3, ++) -DECLOP_3VAR_POSTOP(uchar3, --) - -DECLOP_3VAR_COMP(uchar3, ==) -DECLOP_3VAR_COMP(uchar3, !=) -DECLOP_3VAR_COMP(uchar3, <) -DECLOP_3VAR_COMP(uchar3, >) -DECLOP_3VAR_COMP(uchar3, <=) -DECLOP_3VAR_COMP(uchar3, >=) - -DECLOP_3VAR_COMP(uchar3, &&) -DECLOP_3VAR_COMP(uchar3, ||) - -DECLOP_3VAR_1IN_1OUT(uchar3, ~) -DECLOP_3VAR_1IN_BOOLOUT(uchar3, !) - -DECLOP_3VAR_SCALE_PRODUCT(uchar3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, float) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, double) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(uchar3, signed long long) - -// UNSIGNED CHAR4 - -DECLOP_4VAR_2IN_1OUT(uchar4, +) -DECLOP_4VAR_2IN_1OUT(uchar4, -) -DECLOP_4VAR_2IN_1OUT(uchar4, *) -DECLOP_4VAR_2IN_1OUT(uchar4, /) -DECLOP_4VAR_2IN_1OUT(uchar4, %) -DECLOP_4VAR_2IN_1OUT(uchar4, &) -DECLOP_4VAR_2IN_1OUT(uchar4, |) -DECLOP_4VAR_2IN_1OUT(uchar4, ^) -DECLOP_4VAR_2IN_1OUT(uchar4, <<) -DECLOP_4VAR_2IN_1OUT(uchar4, >>) - -DECLOP_4VAR_ASSIGN(uchar4, +=) -DECLOP_4VAR_ASSIGN(uchar4, -=) -DECLOP_4VAR_ASSIGN(uchar4, *=) -DECLOP_4VAR_ASSIGN(uchar4, /=) -DECLOP_4VAR_ASSIGN(uchar4, %=) -DECLOP_4VAR_ASSIGN(uchar4, &=) -DECLOP_4VAR_ASSIGN(uchar4, |=) -DECLOP_4VAR_ASSIGN(uchar4, ^=) -DECLOP_4VAR_ASSIGN(uchar4, <<=) -DECLOP_4VAR_ASSIGN(uchar4, >>=) - -DECLOP_4VAR_PREOP(uchar4, ++) -DECLOP_4VAR_PREOP(uchar4, --) - -DECLOP_4VAR_POSTOP(uchar4, ++) -DECLOP_4VAR_POSTOP(uchar4, --) - -DECLOP_4VAR_COMP(uchar4, ==) -DECLOP_4VAR_COMP(uchar4, !=) -DECLOP_4VAR_COMP(uchar4, <) -DECLOP_4VAR_COMP(uchar4, >) -DECLOP_4VAR_COMP(uchar4, <=) -DECLOP_4VAR_COMP(uchar4, >=) - -DECLOP_4VAR_COMP(uchar4, &&) -DECLOP_4VAR_COMP(uchar4, ||) - -DECLOP_4VAR_1IN_1OUT(uchar4, ~) -DECLOP_4VAR_1IN_BOOLOUT(uchar4, !) - -DECLOP_4VAR_SCALE_PRODUCT(uchar4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, float) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, double) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(uchar4, signed long long) - -// SIGNED CHAR1 - -DECLOP_1VAR_2IN_1OUT(char1, +) -DECLOP_1VAR_2IN_1OUT(char1, -) -DECLOP_1VAR_2IN_1OUT(char1, *) -DECLOP_1VAR_2IN_1OUT(char1, /) -DECLOP_1VAR_2IN_1OUT(char1, %) -DECLOP_1VAR_2IN_1OUT(char1, &) -DECLOP_1VAR_2IN_1OUT(char1, |) -DECLOP_1VAR_2IN_1OUT(char1, ^) -DECLOP_1VAR_2IN_1OUT(char1, <<) -DECLOP_1VAR_2IN_1OUT(char1, >>) - - -DECLOP_1VAR_ASSIGN(char1, +=) -DECLOP_1VAR_ASSIGN(char1, -=) -DECLOP_1VAR_ASSIGN(char1, *=) -DECLOP_1VAR_ASSIGN(char1, /=) -DECLOP_1VAR_ASSIGN(char1, %=) -DECLOP_1VAR_ASSIGN(char1, &=) -DECLOP_1VAR_ASSIGN(char1, |=) -DECLOP_1VAR_ASSIGN(char1, ^=) -DECLOP_1VAR_ASSIGN(char1, <<=) -DECLOP_1VAR_ASSIGN(char1, >>=) - -DECLOP_1VAR_PREOP(char1, ++) -DECLOP_1VAR_PREOP(char1, --) - -DECLOP_1VAR_POSTOP(char1, ++) -DECLOP_1VAR_POSTOP(char1, --) - -DECLOP_1VAR_COMP(char1, ==) -DECLOP_1VAR_COMP(char1, !=) -DECLOP_1VAR_COMP(char1, <) -DECLOP_1VAR_COMP(char1, >) -DECLOP_1VAR_COMP(char1, <=) -DECLOP_1VAR_COMP(char1, >=) - -DECLOP_1VAR_COMP(char1, &&) -DECLOP_1VAR_COMP(char1, ||) - -DECLOP_1VAR_1IN_1OUT(char1, ~) -DECLOP_1VAR_1IN_BOOLOUT(char1, !) - -DECLOP_1VAR_SCALE_PRODUCT(char1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(char1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(char1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(char1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(char1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(char1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(char1, float) -DECLOP_1VAR_SCALE_PRODUCT(char1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(char1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(char1, double) -DECLOP_1VAR_SCALE_PRODUCT(char1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(char1, signed long long) - -// SIGNED CHAR2 - -DECLOP_2VAR_2IN_1OUT(char2, +) -DECLOP_2VAR_2IN_1OUT(char2, -) -DECLOP_2VAR_2IN_1OUT(char2, *) -DECLOP_2VAR_2IN_1OUT(char2, /) -DECLOP_2VAR_2IN_1OUT(char2, %) -DECLOP_2VAR_2IN_1OUT(char2, &) -DECLOP_2VAR_2IN_1OUT(char2, |) -DECLOP_2VAR_2IN_1OUT(char2, ^) -DECLOP_2VAR_2IN_1OUT(char2, <<) -DECLOP_2VAR_2IN_1OUT(char2, >>) - -DECLOP_2VAR_ASSIGN(char2, +=) -DECLOP_2VAR_ASSIGN(char2, -=) -DECLOP_2VAR_ASSIGN(char2, *=) -DECLOP_2VAR_ASSIGN(char2, /=) -DECLOP_2VAR_ASSIGN(char2, %=) -DECLOP_2VAR_ASSIGN(char2, &=) -DECLOP_2VAR_ASSIGN(char2, |=) -DECLOP_2VAR_ASSIGN(char2, ^=) -DECLOP_2VAR_ASSIGN(char2, <<=) -DECLOP_2VAR_ASSIGN(char2, >>=) - -DECLOP_2VAR_PREOP(char2, ++) -DECLOP_2VAR_PREOP(char2, --) - -DECLOP_2VAR_POSTOP(char2, ++) -DECLOP_2VAR_POSTOP(char2, --) - -DECLOP_2VAR_COMP(char2, ==) -DECLOP_2VAR_COMP(char2, !=) -DECLOP_2VAR_COMP(char2, <) -DECLOP_2VAR_COMP(char2, >) -DECLOP_2VAR_COMP(char2, <=) -DECLOP_2VAR_COMP(char2, >=) - -DECLOP_2VAR_COMP(char2, &&) -DECLOP_2VAR_COMP(char2, ||) - -DECLOP_2VAR_1IN_1OUT(char2, ~) -DECLOP_2VAR_1IN_BOOLOUT(char2, !) - -DECLOP_2VAR_SCALE_PRODUCT(char2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(char2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(char2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(char2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(char2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(char2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(char2, float) -DECLOP_2VAR_SCALE_PRODUCT(char2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(char2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(char2, double) -DECLOP_2VAR_SCALE_PRODUCT(char2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(char2, signed long long) - -// SIGNED CHAR3 - -DECLOP_3VAR_2IN_1OUT(char3, +) -DECLOP_3VAR_2IN_1OUT(char3, -) -DECLOP_3VAR_2IN_1OUT(char3, *) -DECLOP_3VAR_2IN_1OUT(char3, /) -DECLOP_3VAR_2IN_1OUT(char3, %) -DECLOP_3VAR_2IN_1OUT(char3, &) -DECLOP_3VAR_2IN_1OUT(char3, |) -DECLOP_3VAR_2IN_1OUT(char3, ^) -DECLOP_3VAR_2IN_1OUT(char3, <<) -DECLOP_3VAR_2IN_1OUT(char3, >>) - -DECLOP_3VAR_ASSIGN(char3, +=) -DECLOP_3VAR_ASSIGN(char3, -=) -DECLOP_3VAR_ASSIGN(char3, *=) -DECLOP_3VAR_ASSIGN(char3, /=) -DECLOP_3VAR_ASSIGN(char3, %=) -DECLOP_3VAR_ASSIGN(char3, &=) -DECLOP_3VAR_ASSIGN(char3, |=) -DECLOP_3VAR_ASSIGN(char3, ^=) -DECLOP_3VAR_ASSIGN(char3, <<=) -DECLOP_3VAR_ASSIGN(char3, >>=) - -DECLOP_3VAR_PREOP(char3, ++) -DECLOP_3VAR_PREOP(char3, --) - -DECLOP_3VAR_POSTOP(char3, ++) -DECLOP_3VAR_POSTOP(char3, --) - -DECLOP_3VAR_COMP(char3, ==) -DECLOP_3VAR_COMP(char3, !=) -DECLOP_3VAR_COMP(char3, <) -DECLOP_3VAR_COMP(char3, >) -DECLOP_3VAR_COMP(char3, <=) -DECLOP_3VAR_COMP(char3, >=) - -DECLOP_3VAR_COMP(char3, &&) -DECLOP_3VAR_COMP(char3, ||) - -DECLOP_3VAR_1IN_1OUT(char3, ~) -DECLOP_3VAR_1IN_BOOLOUT(char3, !) - -DECLOP_3VAR_SCALE_PRODUCT(char3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(char3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(char3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(char3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(char3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(char3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(char3, float) -DECLOP_3VAR_SCALE_PRODUCT(char3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(char3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(char3, double) -DECLOP_3VAR_SCALE_PRODUCT(char3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(char3, signed long long) - -// SIGNED CHAR4 - -DECLOP_4VAR_2IN_1OUT(char4, +) -DECLOP_4VAR_2IN_1OUT(char4, -) -DECLOP_4VAR_2IN_1OUT(char4, *) -DECLOP_4VAR_2IN_1OUT(char4, /) -DECLOP_4VAR_2IN_1OUT(char4, %) -DECLOP_4VAR_2IN_1OUT(char4, &) -DECLOP_4VAR_2IN_1OUT(char4, |) -DECLOP_4VAR_2IN_1OUT(char4, ^) -DECLOP_4VAR_2IN_1OUT(char4, <<) -DECLOP_4VAR_2IN_1OUT(char4, >>) - -DECLOP_4VAR_ASSIGN(char4, +=) -DECLOP_4VAR_ASSIGN(char4, -=) -DECLOP_4VAR_ASSIGN(char4, *=) -DECLOP_4VAR_ASSIGN(char4, /=) -DECLOP_4VAR_ASSIGN(char4, %=) -DECLOP_4VAR_ASSIGN(char4, &=) -DECLOP_4VAR_ASSIGN(char4, |=) -DECLOP_4VAR_ASSIGN(char4, ^=) -DECLOP_4VAR_ASSIGN(char4, <<=) -DECLOP_4VAR_ASSIGN(char4, >>=) - -DECLOP_4VAR_PREOP(char4, ++) -DECLOP_4VAR_PREOP(char4, --) - -DECLOP_4VAR_POSTOP(char4, ++) -DECLOP_4VAR_POSTOP(char4, --) - -DECLOP_4VAR_COMP(char4, ==) -DECLOP_4VAR_COMP(char4, !=) -DECLOP_4VAR_COMP(char4, <) -DECLOP_4VAR_COMP(char4, >) -DECLOP_4VAR_COMP(char4, <=) -DECLOP_4VAR_COMP(char4, >=) - -DECLOP_4VAR_COMP(char4, &&) -DECLOP_4VAR_COMP(char4, ||) - -DECLOP_4VAR_1IN_1OUT(char4, ~) -DECLOP_4VAR_1IN_BOOLOUT(char4, !) - -DECLOP_4VAR_SCALE_PRODUCT(char4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(char4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(char4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(char4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(char4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(char4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(char4, float) -DECLOP_4VAR_SCALE_PRODUCT(char4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(char4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(char4, double) -DECLOP_4VAR_SCALE_PRODUCT(char4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(char4, signed long long) - -// UNSIGNED SHORT1 - -DECLOP_1VAR_2IN_1OUT(ushort1, +) -DECLOP_1VAR_2IN_1OUT(ushort1, -) -DECLOP_1VAR_2IN_1OUT(ushort1, *) -DECLOP_1VAR_2IN_1OUT(ushort1, /) -DECLOP_1VAR_2IN_1OUT(ushort1, %) -DECLOP_1VAR_2IN_1OUT(ushort1, &) -DECLOP_1VAR_2IN_1OUT(ushort1, |) -DECLOP_1VAR_2IN_1OUT(ushort1, ^) -DECLOP_1VAR_2IN_1OUT(ushort1, <<) -DECLOP_1VAR_2IN_1OUT(ushort1, >>) - - -DECLOP_1VAR_ASSIGN(ushort1, +=) -DECLOP_1VAR_ASSIGN(ushort1, -=) -DECLOP_1VAR_ASSIGN(ushort1, *=) -DECLOP_1VAR_ASSIGN(ushort1, /=) -DECLOP_1VAR_ASSIGN(ushort1, %=) -DECLOP_1VAR_ASSIGN(ushort1, &=) -DECLOP_1VAR_ASSIGN(ushort1, |=) -DECLOP_1VAR_ASSIGN(ushort1, ^=) -DECLOP_1VAR_ASSIGN(ushort1, <<=) -DECLOP_1VAR_ASSIGN(ushort1, >>=) - -DECLOP_1VAR_PREOP(ushort1, ++) -DECLOP_1VAR_PREOP(ushort1, --) - -DECLOP_1VAR_POSTOP(ushort1, ++) -DECLOP_1VAR_POSTOP(ushort1, --) - -DECLOP_1VAR_COMP(ushort1, ==) -DECLOP_1VAR_COMP(ushort1, !=) -DECLOP_1VAR_COMP(ushort1, <) -DECLOP_1VAR_COMP(ushort1, >) -DECLOP_1VAR_COMP(ushort1, <=) -DECLOP_1VAR_COMP(ushort1, >=) - -DECLOP_1VAR_COMP(ushort1, &&) -DECLOP_1VAR_COMP(ushort1, ||) - -DECLOP_1VAR_1IN_1OUT(ushort1, ~) -DECLOP_1VAR_1IN_BOOLOUT(ushort1, !) - -DECLOP_1VAR_SCALE_PRODUCT(ushort1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, float) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, double) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(ushort1, signed long long) - -// UNSIGNED SHORT2 - -DECLOP_2VAR_2IN_1OUT(ushort2, +) -DECLOP_2VAR_2IN_1OUT(ushort2, -) -DECLOP_2VAR_2IN_1OUT(ushort2, *) -DECLOP_2VAR_2IN_1OUT(ushort2, /) -DECLOP_2VAR_2IN_1OUT(ushort2, %) -DECLOP_2VAR_2IN_1OUT(ushort2, &) -DECLOP_2VAR_2IN_1OUT(ushort2, |) -DECLOP_2VAR_2IN_1OUT(ushort2, ^) -DECLOP_2VAR_2IN_1OUT(ushort2, <<) -DECLOP_2VAR_2IN_1OUT(ushort2, >>) - -DECLOP_2VAR_ASSIGN(ushort2, +=) -DECLOP_2VAR_ASSIGN(ushort2, -=) -DECLOP_2VAR_ASSIGN(ushort2, *=) -DECLOP_2VAR_ASSIGN(ushort2, /=) -DECLOP_2VAR_ASSIGN(ushort2, %=) -DECLOP_2VAR_ASSIGN(ushort2, &=) -DECLOP_2VAR_ASSIGN(ushort2, |=) -DECLOP_2VAR_ASSIGN(ushort2, ^=) -DECLOP_2VAR_ASSIGN(ushort2, <<=) -DECLOP_2VAR_ASSIGN(ushort2, >>=) - -DECLOP_2VAR_PREOP(ushort2, ++) -DECLOP_2VAR_PREOP(ushort2, --) - -DECLOP_2VAR_POSTOP(ushort2, ++) -DECLOP_2VAR_POSTOP(ushort2, --) - -DECLOP_2VAR_COMP(ushort2, ==) -DECLOP_2VAR_COMP(ushort2, !=) -DECLOP_2VAR_COMP(ushort2, <) -DECLOP_2VAR_COMP(ushort2, >) -DECLOP_2VAR_COMP(ushort2, <=) -DECLOP_2VAR_COMP(ushort2, >=) - -DECLOP_2VAR_COMP(ushort2, &&) -DECLOP_2VAR_COMP(ushort2, ||) - -DECLOP_2VAR_1IN_1OUT(ushort2, ~) -DECLOP_2VAR_1IN_BOOLOUT(ushort2, !) - -DECLOP_2VAR_SCALE_PRODUCT(ushort2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, float) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, double) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(ushort2, signed long long) - -// UNSIGNED SHORT3 - -DECLOP_3VAR_2IN_1OUT(ushort3, +) -DECLOP_3VAR_2IN_1OUT(ushort3, -) -DECLOP_3VAR_2IN_1OUT(ushort3, *) -DECLOP_3VAR_2IN_1OUT(ushort3, /) -DECLOP_3VAR_2IN_1OUT(ushort3, %) -DECLOP_3VAR_2IN_1OUT(ushort3, &) -DECLOP_3VAR_2IN_1OUT(ushort3, |) -DECLOP_3VAR_2IN_1OUT(ushort3, ^) -DECLOP_3VAR_2IN_1OUT(ushort3, <<) -DECLOP_3VAR_2IN_1OUT(ushort3, >>) - -DECLOP_3VAR_ASSIGN(ushort3, +=) -DECLOP_3VAR_ASSIGN(ushort3, -=) -DECLOP_3VAR_ASSIGN(ushort3, *=) -DECLOP_3VAR_ASSIGN(ushort3, /=) -DECLOP_3VAR_ASSIGN(ushort3, %=) -DECLOP_3VAR_ASSIGN(ushort3, &=) -DECLOP_3VAR_ASSIGN(ushort3, |=) -DECLOP_3VAR_ASSIGN(ushort3, ^=) -DECLOP_3VAR_ASSIGN(ushort3, <<=) -DECLOP_3VAR_ASSIGN(ushort3, >>=) - -DECLOP_3VAR_PREOP(ushort3, ++) -DECLOP_3VAR_PREOP(ushort3, --) - -DECLOP_3VAR_POSTOP(ushort3, ++) -DECLOP_3VAR_POSTOP(ushort3, --) - -DECLOP_3VAR_COMP(ushort3, ==) -DECLOP_3VAR_COMP(ushort3, !=) -DECLOP_3VAR_COMP(ushort3, <) -DECLOP_3VAR_COMP(ushort3, >) -DECLOP_3VAR_COMP(ushort3, <=) -DECLOP_3VAR_COMP(ushort3, >=) - -DECLOP_3VAR_COMP(ushort3, &&) -DECLOP_3VAR_COMP(ushort3, ||) - -DECLOP_3VAR_1IN_1OUT(ushort3, ~) -DECLOP_3VAR_1IN_BOOLOUT(ushort3, !) - -DECLOP_3VAR_SCALE_PRODUCT(ushort3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, float) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, double) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(ushort3, signed long long) - -// UNSIGNED SHORT4 - -DECLOP_4VAR_2IN_1OUT(ushort4, +) -DECLOP_4VAR_2IN_1OUT(ushort4, -) -DECLOP_4VAR_2IN_1OUT(ushort4, *) -DECLOP_4VAR_2IN_1OUT(ushort4, /) -DECLOP_4VAR_2IN_1OUT(ushort4, %) -DECLOP_4VAR_2IN_1OUT(ushort4, &) -DECLOP_4VAR_2IN_1OUT(ushort4, |) -DECLOP_4VAR_2IN_1OUT(ushort4, ^) -DECLOP_4VAR_2IN_1OUT(ushort4, <<) -DECLOP_4VAR_2IN_1OUT(ushort4, >>) - -DECLOP_4VAR_ASSIGN(ushort4, +=) -DECLOP_4VAR_ASSIGN(ushort4, -=) -DECLOP_4VAR_ASSIGN(ushort4, *=) -DECLOP_4VAR_ASSIGN(ushort4, /=) -DECLOP_4VAR_ASSIGN(ushort4, %=) -DECLOP_4VAR_ASSIGN(ushort4, &=) -DECLOP_4VAR_ASSIGN(ushort4, |=) -DECLOP_4VAR_ASSIGN(ushort4, ^=) -DECLOP_4VAR_ASSIGN(ushort4, <<=) -DECLOP_4VAR_ASSIGN(ushort4, >>=) - -DECLOP_4VAR_PREOP(ushort4, ++) -DECLOP_4VAR_PREOP(ushort4, --) - -DECLOP_4VAR_POSTOP(ushort4, ++) -DECLOP_4VAR_POSTOP(ushort4, --) - -DECLOP_4VAR_COMP(ushort4, ==) -DECLOP_4VAR_COMP(ushort4, !=) -DECLOP_4VAR_COMP(ushort4, <) -DECLOP_4VAR_COMP(ushort4, >) -DECLOP_4VAR_COMP(ushort4, <=) -DECLOP_4VAR_COMP(ushort4, >=) - -DECLOP_4VAR_COMP(ushort4, &&) -DECLOP_4VAR_COMP(ushort4, ||) - -DECLOP_4VAR_1IN_1OUT(ushort4, ~) -DECLOP_4VAR_1IN_BOOLOUT(ushort4, !) - -DECLOP_4VAR_SCALE_PRODUCT(ushort4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, float) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, double) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(ushort4, signed long long) - -// SIGNED SHORT1 - -DECLOP_1VAR_2IN_1OUT(short1, +) -DECLOP_1VAR_2IN_1OUT(short1, -) -DECLOP_1VAR_2IN_1OUT(short1, *) -DECLOP_1VAR_2IN_1OUT(short1, /) -DECLOP_1VAR_2IN_1OUT(short1, %) -DECLOP_1VAR_2IN_1OUT(short1, &) -DECLOP_1VAR_2IN_1OUT(short1, |) -DECLOP_1VAR_2IN_1OUT(short1, ^) -DECLOP_1VAR_2IN_1OUT(short1, <<) -DECLOP_1VAR_2IN_1OUT(short1, >>) - - -DECLOP_1VAR_ASSIGN(short1, +=) -DECLOP_1VAR_ASSIGN(short1, -=) -DECLOP_1VAR_ASSIGN(short1, *=) -DECLOP_1VAR_ASSIGN(short1, /=) -DECLOP_1VAR_ASSIGN(short1, %=) -DECLOP_1VAR_ASSIGN(short1, &=) -DECLOP_1VAR_ASSIGN(short1, |=) -DECLOP_1VAR_ASSIGN(short1, ^=) -DECLOP_1VAR_ASSIGN(short1, <<=) -DECLOP_1VAR_ASSIGN(short1, >>=) - -DECLOP_1VAR_PREOP(short1, ++) -DECLOP_1VAR_PREOP(short1, --) - -DECLOP_1VAR_POSTOP(short1, ++) -DECLOP_1VAR_POSTOP(short1, --) - -DECLOP_1VAR_COMP(short1, ==) -DECLOP_1VAR_COMP(short1, !=) -DECLOP_1VAR_COMP(short1, <) -DECLOP_1VAR_COMP(short1, >) -DECLOP_1VAR_COMP(short1, <=) -DECLOP_1VAR_COMP(short1, >=) - -DECLOP_1VAR_COMP(short1, &&) -DECLOP_1VAR_COMP(short1, ||) - -DECLOP_1VAR_1IN_1OUT(short1, ~) -DECLOP_1VAR_1IN_BOOLOUT(short1, !) - -DECLOP_1VAR_SCALE_PRODUCT(short1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(short1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(short1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(short1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(short1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(short1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(short1, float) -DECLOP_1VAR_SCALE_PRODUCT(short1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(short1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(short1, double) -DECLOP_1VAR_SCALE_PRODUCT(short1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(short1, signed long long) - -// SIGNED SHORT2 - -DECLOP_2VAR_2IN_1OUT(short2, +) -DECLOP_2VAR_2IN_1OUT(short2, -) -DECLOP_2VAR_2IN_1OUT(short2, *) -DECLOP_2VAR_2IN_1OUT(short2, /) -DECLOP_2VAR_2IN_1OUT(short2, %) -DECLOP_2VAR_2IN_1OUT(short2, &) -DECLOP_2VAR_2IN_1OUT(short2, |) -DECLOP_2VAR_2IN_1OUT(short2, ^) -DECLOP_2VAR_2IN_1OUT(short2, <<) -DECLOP_2VAR_2IN_1OUT(short2, >>) - -DECLOP_2VAR_ASSIGN(short2, +=) -DECLOP_2VAR_ASSIGN(short2, -=) -DECLOP_2VAR_ASSIGN(short2, *=) -DECLOP_2VAR_ASSIGN(short2, /=) -DECLOP_2VAR_ASSIGN(short2, %=) -DECLOP_2VAR_ASSIGN(short2, &=) -DECLOP_2VAR_ASSIGN(short2, |=) -DECLOP_2VAR_ASSIGN(short2, ^=) -DECLOP_2VAR_ASSIGN(short2, <<=) -DECLOP_2VAR_ASSIGN(short2, >>=) - -DECLOP_2VAR_PREOP(short2, ++) -DECLOP_2VAR_PREOP(short2, --) - -DECLOP_2VAR_POSTOP(short2, ++) -DECLOP_2VAR_POSTOP(short2, --) - -DECLOP_2VAR_COMP(short2, ==) -DECLOP_2VAR_COMP(short2, !=) -DECLOP_2VAR_COMP(short2, <) -DECLOP_2VAR_COMP(short2, >) -DECLOP_2VAR_COMP(short2, <=) -DECLOP_2VAR_COMP(short2, >=) - -DECLOP_2VAR_COMP(short2, &&) -DECLOP_2VAR_COMP(short2, ||) - -DECLOP_2VAR_1IN_1OUT(short2, ~) -DECLOP_2VAR_1IN_BOOLOUT(short2, !) - -DECLOP_2VAR_SCALE_PRODUCT(short2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(short2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(short2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(short2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(short2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(short2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(short2, float) -DECLOP_2VAR_SCALE_PRODUCT(short2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(short2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(short2, double) -DECLOP_2VAR_SCALE_PRODUCT(short2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(short2, signed long long) - -// SIGNED SHORT3 - -DECLOP_3VAR_2IN_1OUT(short3, +) -DECLOP_3VAR_2IN_1OUT(short3, -) -DECLOP_3VAR_2IN_1OUT(short3, *) -DECLOP_3VAR_2IN_1OUT(short3, /) -DECLOP_3VAR_2IN_1OUT(short3, %) -DECLOP_3VAR_2IN_1OUT(short3, &) -DECLOP_3VAR_2IN_1OUT(short3, |) -DECLOP_3VAR_2IN_1OUT(short3, ^) -DECLOP_3VAR_2IN_1OUT(short3, <<) -DECLOP_3VAR_2IN_1OUT(short3, >>) - -DECLOP_3VAR_ASSIGN(short3, +=) -DECLOP_3VAR_ASSIGN(short3, -=) -DECLOP_3VAR_ASSIGN(short3, *=) -DECLOP_3VAR_ASSIGN(short3, /=) -DECLOP_3VAR_ASSIGN(short3, %=) -DECLOP_3VAR_ASSIGN(short3, &=) -DECLOP_3VAR_ASSIGN(short3, |=) -DECLOP_3VAR_ASSIGN(short3, ^=) -DECLOP_3VAR_ASSIGN(short3, <<=) -DECLOP_3VAR_ASSIGN(short3, >>=) - -DECLOP_3VAR_PREOP(short3, ++) -DECLOP_3VAR_PREOP(short3, --) - -DECLOP_3VAR_POSTOP(short3, ++) -DECLOP_3VAR_POSTOP(short3, --) - -DECLOP_3VAR_COMP(short3, ==) -DECLOP_3VAR_COMP(short3, !=) -DECLOP_3VAR_COMP(short3, <) -DECLOP_3VAR_COMP(short3, >) -DECLOP_3VAR_COMP(short3, <=) -DECLOP_3VAR_COMP(short3, >=) - -DECLOP_3VAR_COMP(short3, &&) -DECLOP_3VAR_COMP(short3, ||) - -DECLOP_3VAR_1IN_1OUT(short3, ~) -DECLOP_3VAR_1IN_BOOLOUT(short3, !) - -DECLOP_3VAR_SCALE_PRODUCT(short3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(short3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(short3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(short3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(short3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(short3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(short3, float) -DECLOP_3VAR_SCALE_PRODUCT(short3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(short3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(short3, double) -DECLOP_3VAR_SCALE_PRODUCT(short3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(short3, signed long long) - -// SIGNED SHORT4 - -DECLOP_4VAR_2IN_1OUT(short4, +) -DECLOP_4VAR_2IN_1OUT(short4, -) -DECLOP_4VAR_2IN_1OUT(short4, *) -DECLOP_4VAR_2IN_1OUT(short4, /) -DECLOP_4VAR_2IN_1OUT(short4, %) -DECLOP_4VAR_2IN_1OUT(short4, &) -DECLOP_4VAR_2IN_1OUT(short4, |) -DECLOP_4VAR_2IN_1OUT(short4, ^) -DECLOP_4VAR_2IN_1OUT(short4, <<) -DECLOP_4VAR_2IN_1OUT(short4, >>) - -DECLOP_4VAR_ASSIGN(short4, +=) -DECLOP_4VAR_ASSIGN(short4, -=) -DECLOP_4VAR_ASSIGN(short4, *=) -DECLOP_4VAR_ASSIGN(short4, /=) -DECLOP_4VAR_ASSIGN(short4, %=) -DECLOP_4VAR_ASSIGN(short4, &=) -DECLOP_4VAR_ASSIGN(short4, |=) -DECLOP_4VAR_ASSIGN(short4, ^=) -DECLOP_4VAR_ASSIGN(short4, <<=) -DECLOP_4VAR_ASSIGN(short4, >>=) - -DECLOP_4VAR_PREOP(short4, ++) -DECLOP_4VAR_PREOP(short4, --) - -DECLOP_4VAR_POSTOP(short4, ++) -DECLOP_4VAR_POSTOP(short4, --) - -DECLOP_4VAR_COMP(short4, ==) -DECLOP_4VAR_COMP(short4, !=) -DECLOP_4VAR_COMP(short4, <) -DECLOP_4VAR_COMP(short4, >) -DECLOP_4VAR_COMP(short4, <=) -DECLOP_4VAR_COMP(short4, >=) - -DECLOP_4VAR_COMP(short4, &&) -DECLOP_4VAR_COMP(short4, ||) - -DECLOP_4VAR_1IN_1OUT(short4, ~) -DECLOP_4VAR_1IN_BOOLOUT(short4, !) - -DECLOP_4VAR_SCALE_PRODUCT(short4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(short4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(short4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(short4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(short4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(short4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(short4, float) -DECLOP_4VAR_SCALE_PRODUCT(short4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(short4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(short4, double) -DECLOP_4VAR_SCALE_PRODUCT(short4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(short4, signed long long) - -// UNSIGNED INT1 - -DECLOP_1VAR_2IN_1OUT(uint1, +) -DECLOP_1VAR_2IN_1OUT(uint1, -) -DECLOP_1VAR_2IN_1OUT(uint1, *) -DECLOP_1VAR_2IN_1OUT(uint1, /) -DECLOP_1VAR_2IN_1OUT(uint1, %) -DECLOP_1VAR_2IN_1OUT(uint1, &) -DECLOP_1VAR_2IN_1OUT(uint1, |) -DECLOP_1VAR_2IN_1OUT(uint1, ^) -DECLOP_1VAR_2IN_1OUT(uint1, <<) -DECLOP_1VAR_2IN_1OUT(uint1, >>) - - -DECLOP_1VAR_ASSIGN(uint1, +=) -DECLOP_1VAR_ASSIGN(uint1, -=) -DECLOP_1VAR_ASSIGN(uint1, *=) -DECLOP_1VAR_ASSIGN(uint1, /=) -DECLOP_1VAR_ASSIGN(uint1, %=) -DECLOP_1VAR_ASSIGN(uint1, &=) -DECLOP_1VAR_ASSIGN(uint1, |=) -DECLOP_1VAR_ASSIGN(uint1, ^=) -DECLOP_1VAR_ASSIGN(uint1, <<=) -DECLOP_1VAR_ASSIGN(uint1, >>=) - -DECLOP_1VAR_PREOP(uint1, ++) -DECLOP_1VAR_PREOP(uint1, --) - -DECLOP_1VAR_POSTOP(uint1, ++) -DECLOP_1VAR_POSTOP(uint1, --) - -DECLOP_1VAR_COMP(uint1, ==) -DECLOP_1VAR_COMP(uint1, !=) -DECLOP_1VAR_COMP(uint1, <) -DECLOP_1VAR_COMP(uint1, >) -DECLOP_1VAR_COMP(uint1, <=) -DECLOP_1VAR_COMP(uint1, >=) - -DECLOP_1VAR_COMP(uint1, &&) -DECLOP_1VAR_COMP(uint1, ||) - -DECLOP_1VAR_1IN_1OUT(uint1, ~) -DECLOP_1VAR_1IN_BOOLOUT(uint1, !) - -DECLOP_1VAR_SCALE_PRODUCT(uint1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(uint1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(uint1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(uint1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(uint1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(uint1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(uint1, float) -DECLOP_1VAR_SCALE_PRODUCT(uint1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(uint1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(uint1, double) -DECLOP_1VAR_SCALE_PRODUCT(uint1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(uint1, signed long long) - -// UNSIGNED INT2 - -DECLOP_2VAR_2IN_1OUT(uint2, +) -DECLOP_2VAR_2IN_1OUT(uint2, -) -DECLOP_2VAR_2IN_1OUT(uint2, *) -DECLOP_2VAR_2IN_1OUT(uint2, /) -DECLOP_2VAR_2IN_1OUT(uint2, %) -DECLOP_2VAR_2IN_1OUT(uint2, &) -DECLOP_2VAR_2IN_1OUT(uint2, |) -DECLOP_2VAR_2IN_1OUT(uint2, ^) -DECLOP_2VAR_2IN_1OUT(uint2, <<) -DECLOP_2VAR_2IN_1OUT(uint2, >>) - -DECLOP_2VAR_ASSIGN(uint2, +=) -DECLOP_2VAR_ASSIGN(uint2, -=) -DECLOP_2VAR_ASSIGN(uint2, *=) -DECLOP_2VAR_ASSIGN(uint2, /=) -DECLOP_2VAR_ASSIGN(uint2, %=) -DECLOP_2VAR_ASSIGN(uint2, &=) -DECLOP_2VAR_ASSIGN(uint2, |=) -DECLOP_2VAR_ASSIGN(uint2, ^=) -DECLOP_2VAR_ASSIGN(uint2, <<=) -DECLOP_2VAR_ASSIGN(uint2, >>=) - -DECLOP_2VAR_PREOP(uint2, ++) -DECLOP_2VAR_PREOP(uint2, --) - -DECLOP_2VAR_POSTOP(uint2, ++) -DECLOP_2VAR_POSTOP(uint2, --) - -DECLOP_2VAR_COMP(uint2, ==) -DECLOP_2VAR_COMP(uint2, !=) -DECLOP_2VAR_COMP(uint2, <) -DECLOP_2VAR_COMP(uint2, >) -DECLOP_2VAR_COMP(uint2, <=) -DECLOP_2VAR_COMP(uint2, >=) - -DECLOP_2VAR_COMP(uint2, &&) -DECLOP_2VAR_COMP(uint2, ||) - -DECLOP_2VAR_1IN_1OUT(uint2, ~) -DECLOP_2VAR_1IN_BOOLOUT(uint2, !) - -DECLOP_2VAR_SCALE_PRODUCT(uint2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(uint2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(uint2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(uint2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(uint2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(uint2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(uint2, float) -DECLOP_2VAR_SCALE_PRODUCT(uint2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(uint2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(uint2, double) -DECLOP_2VAR_SCALE_PRODUCT(uint2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(uint2, signed long long) - -// UNSIGNED INT3 - -DECLOP_3VAR_2IN_1OUT(uint3, +) -DECLOP_3VAR_2IN_1OUT(uint3, -) -DECLOP_3VAR_2IN_1OUT(uint3, *) -DECLOP_3VAR_2IN_1OUT(uint3, /) -DECLOP_3VAR_2IN_1OUT(uint3, %) -DECLOP_3VAR_2IN_1OUT(uint3, &) -DECLOP_3VAR_2IN_1OUT(uint3, |) -DECLOP_3VAR_2IN_1OUT(uint3, ^) -DECLOP_3VAR_2IN_1OUT(uint3, <<) -DECLOP_3VAR_2IN_1OUT(uint3, >>) - -DECLOP_3VAR_ASSIGN(uint3, +=) -DECLOP_3VAR_ASSIGN(uint3, -=) -DECLOP_3VAR_ASSIGN(uint3, *=) -DECLOP_3VAR_ASSIGN(uint3, /=) -DECLOP_3VAR_ASSIGN(uint3, %=) -DECLOP_3VAR_ASSIGN(uint3, &=) -DECLOP_3VAR_ASSIGN(uint3, |=) -DECLOP_3VAR_ASSIGN(uint3, ^=) -DECLOP_3VAR_ASSIGN(uint3, <<=) -DECLOP_3VAR_ASSIGN(uint3, >>=) - -DECLOP_3VAR_PREOP(uint3, ++) -DECLOP_3VAR_PREOP(uint3, --) - -DECLOP_3VAR_POSTOP(uint3, ++) -DECLOP_3VAR_POSTOP(uint3, --) - -DECLOP_3VAR_COMP(uint3, ==) -DECLOP_3VAR_COMP(uint3, !=) -DECLOP_3VAR_COMP(uint3, <) -DECLOP_3VAR_COMP(uint3, >) -DECLOP_3VAR_COMP(uint3, <=) -DECLOP_3VAR_COMP(uint3, >=) - -DECLOP_3VAR_COMP(uint3, &&) -DECLOP_3VAR_COMP(uint3, ||) - -DECLOP_3VAR_1IN_1OUT(uint3, ~) -DECLOP_3VAR_1IN_BOOLOUT(uint3, !) - -DECLOP_3VAR_SCALE_PRODUCT(uint3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(uint3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(uint3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(uint3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(uint3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(uint3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(uint3, float) -DECLOP_3VAR_SCALE_PRODUCT(uint3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(uint3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(uint3, double) -DECLOP_3VAR_SCALE_PRODUCT(uint3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(uint3, signed long long) - -// UNSIGNED INT4 - -DECLOP_4VAR_2IN_1OUT(uint4, +) -DECLOP_4VAR_2IN_1OUT(uint4, -) -DECLOP_4VAR_2IN_1OUT(uint4, *) -DECLOP_4VAR_2IN_1OUT(uint4, /) -DECLOP_4VAR_2IN_1OUT(uint4, %) -DECLOP_4VAR_2IN_1OUT(uint4, &) -DECLOP_4VAR_2IN_1OUT(uint4, |) -DECLOP_4VAR_2IN_1OUT(uint4, ^) -DECLOP_4VAR_2IN_1OUT(uint4, <<) -DECLOP_4VAR_2IN_1OUT(uint4, >>) - -DECLOP_4VAR_ASSIGN(uint4, +=) -DECLOP_4VAR_ASSIGN(uint4, -=) -DECLOP_4VAR_ASSIGN(uint4, *=) -DECLOP_4VAR_ASSIGN(uint4, /=) -DECLOP_4VAR_ASSIGN(uint4, %=) -DECLOP_4VAR_ASSIGN(uint4, &=) -DECLOP_4VAR_ASSIGN(uint4, |=) -DECLOP_4VAR_ASSIGN(uint4, ^=) -DECLOP_4VAR_ASSIGN(uint4, <<=) -DECLOP_4VAR_ASSIGN(uint4, >>=) - -DECLOP_4VAR_PREOP(uint4, ++) -DECLOP_4VAR_PREOP(uint4, --) - -DECLOP_4VAR_POSTOP(uint4, ++) -DECLOP_4VAR_POSTOP(uint4, --) - -DECLOP_4VAR_COMP(uint4, ==) -DECLOP_4VAR_COMP(uint4, !=) -DECLOP_4VAR_COMP(uint4, <) -DECLOP_4VAR_COMP(uint4, >) -DECLOP_4VAR_COMP(uint4, <=) -DECLOP_4VAR_COMP(uint4, >=) - -DECLOP_4VAR_COMP(uint4, &&) -DECLOP_4VAR_COMP(uint4, ||) - -DECLOP_4VAR_1IN_1OUT(uint4, ~) -DECLOP_4VAR_1IN_BOOLOUT(uint4, !) - -DECLOP_4VAR_SCALE_PRODUCT(uint4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(uint4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(uint4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(uint4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(uint4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(uint4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(uint4, float) -DECLOP_4VAR_SCALE_PRODUCT(uint4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(uint4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(uint4, double) -DECLOP_4VAR_SCALE_PRODUCT(uint4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(uint4, signed long long) - -// SIGNED INT1 - -DECLOP_1VAR_2IN_1OUT(int1, +) -DECLOP_1VAR_2IN_1OUT(int1, -) -DECLOP_1VAR_2IN_1OUT(int1, *) -DECLOP_1VAR_2IN_1OUT(int1, /) -DECLOP_1VAR_2IN_1OUT(int1, %) -DECLOP_1VAR_2IN_1OUT(int1, &) -DECLOP_1VAR_2IN_1OUT(int1, |) -DECLOP_1VAR_2IN_1OUT(int1, ^) -DECLOP_1VAR_2IN_1OUT(int1, <<) -DECLOP_1VAR_2IN_1OUT(int1, >>) - - -DECLOP_1VAR_ASSIGN(int1, +=) -DECLOP_1VAR_ASSIGN(int1, -=) -DECLOP_1VAR_ASSIGN(int1, *=) -DECLOP_1VAR_ASSIGN(int1, /=) -DECLOP_1VAR_ASSIGN(int1, %=) -DECLOP_1VAR_ASSIGN(int1, &=) -DECLOP_1VAR_ASSIGN(int1, |=) -DECLOP_1VAR_ASSIGN(int1, ^=) -DECLOP_1VAR_ASSIGN(int1, <<=) -DECLOP_1VAR_ASSIGN(int1, >>=) - -DECLOP_1VAR_PREOP(int1, ++) -DECLOP_1VAR_PREOP(int1, --) - -DECLOP_1VAR_POSTOP(int1, ++) -DECLOP_1VAR_POSTOP(int1, --) - -DECLOP_1VAR_COMP(int1, ==) -DECLOP_1VAR_COMP(int1, !=) -DECLOP_1VAR_COMP(int1, <) -DECLOP_1VAR_COMP(int1, >) -DECLOP_1VAR_COMP(int1, <=) -DECLOP_1VAR_COMP(int1, >=) - -DECLOP_1VAR_COMP(int1, &&) -DECLOP_1VAR_COMP(int1, ||) - -DECLOP_1VAR_1IN_1OUT(int1, ~) -DECLOP_1VAR_1IN_BOOLOUT(int1, !) - -DECLOP_1VAR_SCALE_PRODUCT(int1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(int1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(int1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(int1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(int1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(int1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(int1, float) -DECLOP_1VAR_SCALE_PRODUCT(int1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(int1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(int1, double) -DECLOP_1VAR_SCALE_PRODUCT(int1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(int1, signed long long) - -// SIGNED INT2 - -DECLOP_2VAR_2IN_1OUT(int2, +) -DECLOP_2VAR_2IN_1OUT(int2, -) -DECLOP_2VAR_2IN_1OUT(int2, *) -DECLOP_2VAR_2IN_1OUT(int2, /) -DECLOP_2VAR_2IN_1OUT(int2, %) -DECLOP_2VAR_2IN_1OUT(int2, &) -DECLOP_2VAR_2IN_1OUT(int2, |) -DECLOP_2VAR_2IN_1OUT(int2, ^) -DECLOP_2VAR_2IN_1OUT(int2, <<) -DECLOP_2VAR_2IN_1OUT(int2, >>) - -DECLOP_2VAR_ASSIGN(int2, +=) -DECLOP_2VAR_ASSIGN(int2, -=) -DECLOP_2VAR_ASSIGN(int2, *=) -DECLOP_2VAR_ASSIGN(int2, /=) -DECLOP_2VAR_ASSIGN(int2, %=) -DECLOP_2VAR_ASSIGN(int2, &=) -DECLOP_2VAR_ASSIGN(int2, |=) -DECLOP_2VAR_ASSIGN(int2, ^=) -DECLOP_2VAR_ASSIGN(int2, <<=) -DECLOP_2VAR_ASSIGN(int2, >>=) - -DECLOP_2VAR_PREOP(int2, ++) -DECLOP_2VAR_PREOP(int2, --) - -DECLOP_2VAR_POSTOP(int2, ++) -DECLOP_2VAR_POSTOP(int2, --) - -DECLOP_2VAR_COMP(int2, ==) -DECLOP_2VAR_COMP(int2, !=) -DECLOP_2VAR_COMP(int2, <) -DECLOP_2VAR_COMP(int2, >) -DECLOP_2VAR_COMP(int2, <=) -DECLOP_2VAR_COMP(int2, >=) - -DECLOP_2VAR_COMP(int2, &&) -DECLOP_2VAR_COMP(int2, ||) - -DECLOP_2VAR_1IN_1OUT(int2, ~) -DECLOP_2VAR_1IN_BOOLOUT(int2, !) - -DECLOP_2VAR_SCALE_PRODUCT(int2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(int2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(int2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(int2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(int2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(int2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(int2, float) -DECLOP_2VAR_SCALE_PRODUCT(int2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(int2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(int2, double) -DECLOP_2VAR_SCALE_PRODUCT(int2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(int2, signed long long) - -// SIGNED INT3 - -DECLOP_3VAR_2IN_1OUT(int3, +) -DECLOP_3VAR_2IN_1OUT(int3, -) -DECLOP_3VAR_2IN_1OUT(int3, *) -DECLOP_3VAR_2IN_1OUT(int3, /) -DECLOP_3VAR_2IN_1OUT(int3, %) -DECLOP_3VAR_2IN_1OUT(int3, &) -DECLOP_3VAR_2IN_1OUT(int3, |) -DECLOP_3VAR_2IN_1OUT(int3, ^) -DECLOP_3VAR_2IN_1OUT(int3, <<) -DECLOP_3VAR_2IN_1OUT(int3, >>) - -DECLOP_3VAR_ASSIGN(int3, +=) -DECLOP_3VAR_ASSIGN(int3, -=) -DECLOP_3VAR_ASSIGN(int3, *=) -DECLOP_3VAR_ASSIGN(int3, /=) -DECLOP_3VAR_ASSIGN(int3, %=) -DECLOP_3VAR_ASSIGN(int3, &=) -DECLOP_3VAR_ASSIGN(int3, |=) -DECLOP_3VAR_ASSIGN(int3, ^=) -DECLOP_3VAR_ASSIGN(int3, <<=) -DECLOP_3VAR_ASSIGN(int3, >>=) - -DECLOP_3VAR_PREOP(int3, ++) -DECLOP_3VAR_PREOP(int3, --) - -DECLOP_3VAR_POSTOP(int3, ++) -DECLOP_3VAR_POSTOP(int3, --) - -DECLOP_3VAR_COMP(int3, ==) -DECLOP_3VAR_COMP(int3, !=) -DECLOP_3VAR_COMP(int3, <) -DECLOP_3VAR_COMP(int3, >) -DECLOP_3VAR_COMP(int3, <=) -DECLOP_3VAR_COMP(int3, >=) - -DECLOP_3VAR_COMP(int3, &&) -DECLOP_3VAR_COMP(int3, ||) - -DECLOP_3VAR_1IN_1OUT(int3, ~) -DECLOP_3VAR_1IN_BOOLOUT(int3, !) - -DECLOP_3VAR_SCALE_PRODUCT(int3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(int3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(int3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(int3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(int3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(int3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(int3, float) -DECLOP_3VAR_SCALE_PRODUCT(int3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(int3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(int3, double) -DECLOP_3VAR_SCALE_PRODUCT(int3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(int3, signed long long) - -// SIGNED INT4 - -DECLOP_4VAR_2IN_1OUT(int4, +) -DECLOP_4VAR_2IN_1OUT(int4, -) -DECLOP_4VAR_2IN_1OUT(int4, *) -DECLOP_4VAR_2IN_1OUT(int4, /) -DECLOP_4VAR_2IN_1OUT(int4, %) -DECLOP_4VAR_2IN_1OUT(int4, &) -DECLOP_4VAR_2IN_1OUT(int4, |) -DECLOP_4VAR_2IN_1OUT(int4, ^) -DECLOP_4VAR_2IN_1OUT(int4, <<) -DECLOP_4VAR_2IN_1OUT(int4, >>) - -DECLOP_4VAR_ASSIGN(int4, +=) -DECLOP_4VAR_ASSIGN(int4, -=) -DECLOP_4VAR_ASSIGN(int4, *=) -DECLOP_4VAR_ASSIGN(int4, /=) -DECLOP_4VAR_ASSIGN(int4, %=) -DECLOP_4VAR_ASSIGN(int4, &=) -DECLOP_4VAR_ASSIGN(int4, |=) -DECLOP_4VAR_ASSIGN(int4, ^=) -DECLOP_4VAR_ASSIGN(int4, <<=) -DECLOP_4VAR_ASSIGN(int4, >>=) - -DECLOP_4VAR_PREOP(int4, ++) -DECLOP_4VAR_PREOP(int4, --) - -DECLOP_4VAR_POSTOP(int4, ++) -DECLOP_4VAR_POSTOP(int4, --) - -DECLOP_4VAR_COMP(int4, ==) -DECLOP_4VAR_COMP(int4, !=) -DECLOP_4VAR_COMP(int4, <) -DECLOP_4VAR_COMP(int4, >) -DECLOP_4VAR_COMP(int4, <=) -DECLOP_4VAR_COMP(int4, >=) - -DECLOP_4VAR_COMP(int4, &&) -DECLOP_4VAR_COMP(int4, ||) - -DECLOP_4VAR_1IN_1OUT(int4, ~) -DECLOP_4VAR_1IN_BOOLOUT(int4, !) - -DECLOP_4VAR_SCALE_PRODUCT(int4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(int4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(int4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(int4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(int4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(int4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(int4, float) -DECLOP_4VAR_SCALE_PRODUCT(int4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(int4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(int4, double) -DECLOP_4VAR_SCALE_PRODUCT(int4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(int4, signed long long) - -// FLOAT1 - -DECLOP_1VAR_2IN_1OUT(float1, +) -DECLOP_1VAR_2IN_1OUT(float1, -) -DECLOP_1VAR_2IN_1OUT(float1, *) -DECLOP_1VAR_2IN_1OUT(float1, /) - -DECLOP_1VAR_ASSIGN(float1, +=) -DECLOP_1VAR_ASSIGN(float1, -=) -DECLOP_1VAR_ASSIGN(float1, *=) -DECLOP_1VAR_ASSIGN(float1, /=) - -DECLOP_1VAR_PREOP(float1, ++) -DECLOP_1VAR_PREOP(float1, --) - -DECLOP_1VAR_POSTOP(float1, ++) -DECLOP_1VAR_POSTOP(float1, --) - -DECLOP_1VAR_COMP(float1, ==) -DECLOP_1VAR_COMP(float1, !=) -DECLOP_1VAR_COMP(float1, <) -DECLOP_1VAR_COMP(float1, >) -DECLOP_1VAR_COMP(float1, <=) -DECLOP_1VAR_COMP(float1, >=) - -DECLOP_1VAR_SCALE_PRODUCT(float1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(float1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(float1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(float1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(float1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(float1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(float1, float) -DECLOP_1VAR_SCALE_PRODUCT(float1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(float1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(float1, double) -DECLOP_1VAR_SCALE_PRODUCT(float1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(float1, signed long long) - -// FLOAT2 - -DECLOP_2VAR_2IN_1OUT(float2, +) -DECLOP_2VAR_2IN_1OUT(float2, -) -DECLOP_2VAR_2IN_1OUT(float2, *) -DECLOP_2VAR_2IN_1OUT(float2, /) - -DECLOP_2VAR_ASSIGN(float2, +=) -DECLOP_2VAR_ASSIGN(float2, -=) -DECLOP_2VAR_ASSIGN(float2, *=) -DECLOP_2VAR_ASSIGN(float2, /=) - -DECLOP_2VAR_PREOP(float2, ++) -DECLOP_2VAR_PREOP(float2, --) - -DECLOP_2VAR_POSTOP(float2, ++) -DECLOP_2VAR_POSTOP(float2, --) - -DECLOP_2VAR_COMP(float2, ==) -DECLOP_2VAR_COMP(float2, !=) -DECLOP_2VAR_COMP(float2, <) -DECLOP_2VAR_COMP(float2, >) -DECLOP_2VAR_COMP(float2, <=) -DECLOP_2VAR_COMP(float2, >=) - -DECLOP_2VAR_SCALE_PRODUCT(float2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(float2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(float2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(float2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(float2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(float2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(float2, float) -DECLOP_2VAR_SCALE_PRODUCT(float2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(float2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(float2, double) -DECLOP_2VAR_SCALE_PRODUCT(float2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(float2, signed long long) - -// FLOAT3 - -DECLOP_3VAR_2IN_1OUT(float3, +) -DECLOP_3VAR_2IN_1OUT(float3, -) -DECLOP_3VAR_2IN_1OUT(float3, *) -DECLOP_3VAR_2IN_1OUT(float3, /) - -DECLOP_3VAR_ASSIGN(float3, +=) -DECLOP_3VAR_ASSIGN(float3, -=) -DECLOP_3VAR_ASSIGN(float3, *=) -DECLOP_3VAR_ASSIGN(float3, /=) - -DECLOP_3VAR_PREOP(float3, ++) -DECLOP_3VAR_PREOP(float3, --) - -DECLOP_3VAR_POSTOP(float3, ++) -DECLOP_3VAR_POSTOP(float3, --) - -DECLOP_3VAR_COMP(float3, ==) -DECLOP_3VAR_COMP(float3, !=) -DECLOP_3VAR_COMP(float3, <) -DECLOP_3VAR_COMP(float3, >) -DECLOP_3VAR_COMP(float3, <=) -DECLOP_3VAR_COMP(float3, >=) - -DECLOP_3VAR_SCALE_PRODUCT(float3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(float3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(float3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(float3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(float3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(float3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(float3, float) -DECLOP_3VAR_SCALE_PRODUCT(float3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(float3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(float3, double) -DECLOP_3VAR_SCALE_PRODUCT(float3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(float3, signed long long) - -// FLOAT4 - -DECLOP_4VAR_2IN_1OUT(float4, +) -DECLOP_4VAR_2IN_1OUT(float4, -) -DECLOP_4VAR_2IN_1OUT(float4, *) -DECLOP_4VAR_2IN_1OUT(float4, /) - -DECLOP_4VAR_ASSIGN(float4, +=) -DECLOP_4VAR_ASSIGN(float4, -=) -DECLOP_4VAR_ASSIGN(float4, *=) -DECLOP_4VAR_ASSIGN(float4, /=) - -DECLOP_4VAR_PREOP(float4, ++) -DECLOP_4VAR_PREOP(float4, --) - -DECLOP_4VAR_POSTOP(float4, ++) -DECLOP_4VAR_POSTOP(float4, --) - -DECLOP_4VAR_COMP(float4, ==) -DECLOP_4VAR_COMP(float4, !=) -DECLOP_4VAR_COMP(float4, <) -DECLOP_4VAR_COMP(float4, >) -DECLOP_4VAR_COMP(float4, <=) -DECLOP_4VAR_COMP(float4, >=) - -DECLOP_4VAR_SCALE_PRODUCT(float4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(float4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(float4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(float4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(float4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(float4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(float4, float) -DECLOP_4VAR_SCALE_PRODUCT(float4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(float4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(float4, double) -DECLOP_4VAR_SCALE_PRODUCT(float4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(float4, signed long long) - -// DOUBLE1 - -DECLOP_1VAR_2IN_1OUT(double1, +) -DECLOP_1VAR_2IN_1OUT(double1, -) -DECLOP_1VAR_2IN_1OUT(double1, *) -DECLOP_1VAR_2IN_1OUT(double1, /) - -DECLOP_1VAR_ASSIGN(double1, +=) -DECLOP_1VAR_ASSIGN(double1, -=) -DECLOP_1VAR_ASSIGN(double1, *=) -DECLOP_1VAR_ASSIGN(double1, /=) - -DECLOP_1VAR_PREOP(double1, ++) -DECLOP_1VAR_PREOP(double1, --) - -DECLOP_1VAR_POSTOP(double1, ++) -DECLOP_1VAR_POSTOP(double1, --) - -DECLOP_1VAR_COMP(double1, ==) -DECLOP_1VAR_COMP(double1, !=) -DECLOP_1VAR_COMP(double1, <) -DECLOP_1VAR_COMP(double1, >) -DECLOP_1VAR_COMP(double1, <=) -DECLOP_1VAR_COMP(double1, >=) - -DECLOP_1VAR_SCALE_PRODUCT(double1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(double1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(double1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(double1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(double1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(double1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(double1, float) -DECLOP_1VAR_SCALE_PRODUCT(double1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(double1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(double1, double) -DECLOP_1VAR_SCALE_PRODUCT(double1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(double1, signed long long) - -// DOUBLE2 - -DECLOP_2VAR_2IN_1OUT(double2, +) -DECLOP_2VAR_2IN_1OUT(double2, -) -DECLOP_2VAR_2IN_1OUT(double2, *) -DECLOP_2VAR_2IN_1OUT(double2, /) - -DECLOP_2VAR_ASSIGN(double2, +=) -DECLOP_2VAR_ASSIGN(double2, -=) -DECLOP_2VAR_ASSIGN(double2, *=) -DECLOP_2VAR_ASSIGN(double2, /=) - -DECLOP_2VAR_PREOP(double2, ++) -DECLOP_2VAR_PREOP(double2, --) - -DECLOP_2VAR_POSTOP(double2, ++) -DECLOP_2VAR_POSTOP(double2, --) - -DECLOP_2VAR_COMP(double2, ==) -DECLOP_2VAR_COMP(double2, !=) -DECLOP_2VAR_COMP(double2, <) -DECLOP_2VAR_COMP(double2, >) -DECLOP_2VAR_COMP(double2, <=) -DECLOP_2VAR_COMP(double2, >=) - -DECLOP_2VAR_SCALE_PRODUCT(double2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(double2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(double2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(double2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(double2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(double2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(double2, float) -DECLOP_2VAR_SCALE_PRODUCT(double2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(double2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(double2, double) -DECLOP_2VAR_SCALE_PRODUCT(double2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(double2, signed long long) - -// DOUBLE3 - -DECLOP_3VAR_2IN_1OUT(double3, +) -DECLOP_3VAR_2IN_1OUT(double3, -) -DECLOP_3VAR_2IN_1OUT(double3, *) -DECLOP_3VAR_2IN_1OUT(double3, /) - -DECLOP_3VAR_ASSIGN(double3, +=) -DECLOP_3VAR_ASSIGN(double3, -=) -DECLOP_3VAR_ASSIGN(double3, *=) -DECLOP_3VAR_ASSIGN(double3, /=) - -DECLOP_3VAR_PREOP(double3, ++) -DECLOP_3VAR_PREOP(double3, --) - -DECLOP_3VAR_POSTOP(double3, ++) -DECLOP_3VAR_POSTOP(double3, --) - -DECLOP_3VAR_COMP(double3, ==) -DECLOP_3VAR_COMP(double3, !=) -DECLOP_3VAR_COMP(double3, <) -DECLOP_3VAR_COMP(double3, >) -DECLOP_3VAR_COMP(double3, <=) -DECLOP_3VAR_COMP(double3, >=) - -DECLOP_3VAR_SCALE_PRODUCT(double3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(double3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(double3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(double3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(double3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(double3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(double3, float) -DECLOP_3VAR_SCALE_PRODUCT(double3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(double3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(double3, double) -DECLOP_3VAR_SCALE_PRODUCT(double3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(double3, signed long long) - -// DOUBLE4 - -DECLOP_4VAR_2IN_1OUT(double4, +) -DECLOP_4VAR_2IN_1OUT(double4, -) -DECLOP_4VAR_2IN_1OUT(double4, *) -DECLOP_4VAR_2IN_1OUT(double4, /) - -DECLOP_4VAR_ASSIGN(double4, +=) -DECLOP_4VAR_ASSIGN(double4, -=) -DECLOP_4VAR_ASSIGN(double4, *=) -DECLOP_4VAR_ASSIGN(double4, /=) - -DECLOP_4VAR_PREOP(double4, ++) -DECLOP_4VAR_PREOP(double4, --) - -DECLOP_4VAR_POSTOP(double4, ++) -DECLOP_4VAR_POSTOP(double4, --) - -DECLOP_4VAR_COMP(double4, ==) -DECLOP_4VAR_COMP(double4, !=) -DECLOP_4VAR_COMP(double4, <) -DECLOP_4VAR_COMP(double4, >) -DECLOP_4VAR_COMP(double4, <=) -DECLOP_4VAR_COMP(double4, >=) - -DECLOP_4VAR_SCALE_PRODUCT(double4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(double4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(double4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(double4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(double4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(double4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(double4, float) -DECLOP_4VAR_SCALE_PRODUCT(double4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(double4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(double4, double) -DECLOP_4VAR_SCALE_PRODUCT(double4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(double4, signed long long) - -// UNSIGNED LONG1 - -DECLOP_1VAR_2IN_1OUT(ulong1, +) -DECLOP_1VAR_2IN_1OUT(ulong1, -) -DECLOP_1VAR_2IN_1OUT(ulong1, *) -DECLOP_1VAR_2IN_1OUT(ulong1, /) -DECLOP_1VAR_2IN_1OUT(ulong1, %) -DECLOP_1VAR_2IN_1OUT(ulong1, &) -DECLOP_1VAR_2IN_1OUT(ulong1, |) -DECLOP_1VAR_2IN_1OUT(ulong1, ^) -DECLOP_1VAR_2IN_1OUT(ulong1, <<) -DECLOP_1VAR_2IN_1OUT(ulong1, >>) - - -DECLOP_1VAR_ASSIGN(ulong1, +=) -DECLOP_1VAR_ASSIGN(ulong1, -=) -DECLOP_1VAR_ASSIGN(ulong1, *=) -DECLOP_1VAR_ASSIGN(ulong1, /=) -DECLOP_1VAR_ASSIGN(ulong1, %=) -DECLOP_1VAR_ASSIGN(ulong1, &=) -DECLOP_1VAR_ASSIGN(ulong1, |=) -DECLOP_1VAR_ASSIGN(ulong1, ^=) -DECLOP_1VAR_ASSIGN(ulong1, <<=) -DECLOP_1VAR_ASSIGN(ulong1, >>=) - -DECLOP_1VAR_PREOP(ulong1, ++) -DECLOP_1VAR_PREOP(ulong1, --) - -DECLOP_1VAR_POSTOP(ulong1, ++) -DECLOP_1VAR_POSTOP(ulong1, --) - -DECLOP_1VAR_COMP(ulong1, ==) -DECLOP_1VAR_COMP(ulong1, !=) -DECLOP_1VAR_COMP(ulong1, <) -DECLOP_1VAR_COMP(ulong1, >) -DECLOP_1VAR_COMP(ulong1, <=) -DECLOP_1VAR_COMP(ulong1, >=) - -DECLOP_1VAR_COMP(ulong1, &&) -DECLOP_1VAR_COMP(ulong1, ||) - -DECLOP_1VAR_1IN_1OUT(ulong1, ~) -DECLOP_1VAR_1IN_BOOLOUT(ulong1, !) - -DECLOP_1VAR_SCALE_PRODUCT(ulong1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, float) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, double) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(ulong1, signed long long) - -// UNSIGNED LONG2 - -DECLOP_2VAR_2IN_1OUT(ulong2, +) -DECLOP_2VAR_2IN_1OUT(ulong2, -) -DECLOP_2VAR_2IN_1OUT(ulong2, *) -DECLOP_2VAR_2IN_1OUT(ulong2, /) -DECLOP_2VAR_2IN_1OUT(ulong2, %) -DECLOP_2VAR_2IN_1OUT(ulong2, &) -DECLOP_2VAR_2IN_1OUT(ulong2, |) -DECLOP_2VAR_2IN_1OUT(ulong2, ^) -DECLOP_2VAR_2IN_1OUT(ulong2, <<) -DECLOP_2VAR_2IN_1OUT(ulong2, >>) - -DECLOP_2VAR_ASSIGN(ulong2, +=) -DECLOP_2VAR_ASSIGN(ulong2, -=) -DECLOP_2VAR_ASSIGN(ulong2, *=) -DECLOP_2VAR_ASSIGN(ulong2, /=) -DECLOP_2VAR_ASSIGN(ulong2, %=) -DECLOP_2VAR_ASSIGN(ulong2, &=) -DECLOP_2VAR_ASSIGN(ulong2, |=) -DECLOP_2VAR_ASSIGN(ulong2, ^=) -DECLOP_2VAR_ASSIGN(ulong2, <<=) -DECLOP_2VAR_ASSIGN(ulong2, >>=) - -DECLOP_2VAR_PREOP(ulong2, ++) -DECLOP_2VAR_PREOP(ulong2, --) - -DECLOP_2VAR_POSTOP(ulong2, ++) -DECLOP_2VAR_POSTOP(ulong2, --) - -DECLOP_2VAR_COMP(ulong2, ==) -DECLOP_2VAR_COMP(ulong2, !=) -DECLOP_2VAR_COMP(ulong2, <) -DECLOP_2VAR_COMP(ulong2, >) -DECLOP_2VAR_COMP(ulong2, <=) -DECLOP_2VAR_COMP(ulong2, >=) - -DECLOP_2VAR_COMP(ulong2, &&) -DECLOP_2VAR_COMP(ulong2, ||) - -DECLOP_2VAR_1IN_1OUT(ulong2, ~) -DECLOP_2VAR_1IN_BOOLOUT(ulong2, !) - -DECLOP_2VAR_SCALE_PRODUCT(ulong2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, float) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, double) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(ulong2, signed long long) - -// UNSIGNED LONG3 - -DECLOP_3VAR_2IN_1OUT(ulong3, +) -DECLOP_3VAR_2IN_1OUT(ulong3, -) -DECLOP_3VAR_2IN_1OUT(ulong3, *) -DECLOP_3VAR_2IN_1OUT(ulong3, /) -DECLOP_3VAR_2IN_1OUT(ulong3, %) -DECLOP_3VAR_2IN_1OUT(ulong3, &) -DECLOP_3VAR_2IN_1OUT(ulong3, |) -DECLOP_3VAR_2IN_1OUT(ulong3, ^) -DECLOP_3VAR_2IN_1OUT(ulong3, <<) -DECLOP_3VAR_2IN_1OUT(ulong3, >>) - -DECLOP_3VAR_ASSIGN(ulong3, +=) -DECLOP_3VAR_ASSIGN(ulong3, -=) -DECLOP_3VAR_ASSIGN(ulong3, *=) -DECLOP_3VAR_ASSIGN(ulong3, /=) -DECLOP_3VAR_ASSIGN(ulong3, %=) -DECLOP_3VAR_ASSIGN(ulong3, &=) -DECLOP_3VAR_ASSIGN(ulong3, |=) -DECLOP_3VAR_ASSIGN(ulong3, ^=) -DECLOP_3VAR_ASSIGN(ulong3, <<=) -DECLOP_3VAR_ASSIGN(ulong3, >>=) - -DECLOP_3VAR_PREOP(ulong3, ++) -DECLOP_3VAR_PREOP(ulong3, --) - -DECLOP_3VAR_POSTOP(ulong3, ++) -DECLOP_3VAR_POSTOP(ulong3, --) - -DECLOP_3VAR_COMP(ulong3, ==) -DECLOP_3VAR_COMP(ulong3, !=) -DECLOP_3VAR_COMP(ulong3, <) -DECLOP_3VAR_COMP(ulong3, >) -DECLOP_3VAR_COMP(ulong3, <=) -DECLOP_3VAR_COMP(ulong3, >=) - -DECLOP_3VAR_COMP(ulong3, &&) -DECLOP_3VAR_COMP(ulong3, ||) - -DECLOP_3VAR_1IN_1OUT(ulong3, ~) -DECLOP_3VAR_1IN_BOOLOUT(ulong3, !) - -DECLOP_3VAR_SCALE_PRODUCT(ulong3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, float) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, double) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(ulong3, signed long long) - -// UNSIGNED LONG4 - -DECLOP_4VAR_2IN_1OUT(ulong4, +) -DECLOP_4VAR_2IN_1OUT(ulong4, -) -DECLOP_4VAR_2IN_1OUT(ulong4, *) -DECLOP_4VAR_2IN_1OUT(ulong4, /) -DECLOP_4VAR_2IN_1OUT(ulong4, %) -DECLOP_4VAR_2IN_1OUT(ulong4, &) -DECLOP_4VAR_2IN_1OUT(ulong4, |) -DECLOP_4VAR_2IN_1OUT(ulong4, ^) -DECLOP_4VAR_2IN_1OUT(ulong4, <<) -DECLOP_4VAR_2IN_1OUT(ulong4, >>) - -DECLOP_4VAR_ASSIGN(ulong4, +=) -DECLOP_4VAR_ASSIGN(ulong4, -=) -DECLOP_4VAR_ASSIGN(ulong4, *=) -DECLOP_4VAR_ASSIGN(ulong4, /=) -DECLOP_4VAR_ASSIGN(ulong4, %=) -DECLOP_4VAR_ASSIGN(ulong4, &=) -DECLOP_4VAR_ASSIGN(ulong4, |=) -DECLOP_4VAR_ASSIGN(ulong4, ^=) -DECLOP_4VAR_ASSIGN(ulong4, <<=) -DECLOP_4VAR_ASSIGN(ulong4, >>=) - -DECLOP_4VAR_PREOP(ulong4, ++) -DECLOP_4VAR_PREOP(ulong4, --) - -DECLOP_4VAR_POSTOP(ulong4, ++) -DECLOP_4VAR_POSTOP(ulong4, --) - -DECLOP_4VAR_COMP(ulong4, ==) -DECLOP_4VAR_COMP(ulong4, !=) -DECLOP_4VAR_COMP(ulong4, <) -DECLOP_4VAR_COMP(ulong4, >) -DECLOP_4VAR_COMP(ulong4, <=) -DECLOP_4VAR_COMP(ulong4, >=) - -DECLOP_4VAR_COMP(ulong4, &&) -DECLOP_4VAR_COMP(ulong4, ||) - -DECLOP_4VAR_1IN_1OUT(ulong4, ~) -DECLOP_4VAR_1IN_BOOLOUT(ulong4, !) - -DECLOP_4VAR_SCALE_PRODUCT(ulong4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, float) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, double) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(ulong4, signed long long) - -// SIGNED LONG1 - -DECLOP_1VAR_2IN_1OUT(long1, +) -DECLOP_1VAR_2IN_1OUT(long1, -) -DECLOP_1VAR_2IN_1OUT(long1, *) -DECLOP_1VAR_2IN_1OUT(long1, /) -DECLOP_1VAR_2IN_1OUT(long1, %) -DECLOP_1VAR_2IN_1OUT(long1, &) -DECLOP_1VAR_2IN_1OUT(long1, |) -DECLOP_1VAR_2IN_1OUT(long1, ^) -DECLOP_1VAR_2IN_1OUT(long1, <<) -DECLOP_1VAR_2IN_1OUT(long1, >>) - - -DECLOP_1VAR_ASSIGN(long1, +=) -DECLOP_1VAR_ASSIGN(long1, -=) -DECLOP_1VAR_ASSIGN(long1, *=) -DECLOP_1VAR_ASSIGN(long1, /=) -DECLOP_1VAR_ASSIGN(long1, %=) -DECLOP_1VAR_ASSIGN(long1, &=) -DECLOP_1VAR_ASSIGN(long1, |=) -DECLOP_1VAR_ASSIGN(long1, ^=) -DECLOP_1VAR_ASSIGN(long1, <<=) -DECLOP_1VAR_ASSIGN(long1, >>=) - -DECLOP_1VAR_PREOP(long1, ++) -DECLOP_1VAR_PREOP(long1, --) - -DECLOP_1VAR_POSTOP(long1, ++) -DECLOP_1VAR_POSTOP(long1, --) - -DECLOP_1VAR_COMP(long1, ==) -DECLOP_1VAR_COMP(long1, !=) -DECLOP_1VAR_COMP(long1, <) -DECLOP_1VAR_COMP(long1, >) -DECLOP_1VAR_COMP(long1, <=) -DECLOP_1VAR_COMP(long1, >=) - -DECLOP_1VAR_COMP(long1, &&) -DECLOP_1VAR_COMP(long1, ||) - -DECLOP_1VAR_1IN_1OUT(long1, ~) -DECLOP_1VAR_1IN_BOOLOUT(long1, !) - -DECLOP_1VAR_SCALE_PRODUCT(long1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(long1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(long1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(long1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(long1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(long1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(long1, float) -DECLOP_1VAR_SCALE_PRODUCT(long1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(long1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(long1, double) -DECLOP_1VAR_SCALE_PRODUCT(long1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(long1, signed long long) - -// SIGNED LONG2 - -DECLOP_2VAR_2IN_1OUT(long2, +) -DECLOP_2VAR_2IN_1OUT(long2, -) -DECLOP_2VAR_2IN_1OUT(long2, *) -DECLOP_2VAR_2IN_1OUT(long2, /) -DECLOP_2VAR_2IN_1OUT(long2, %) -DECLOP_2VAR_2IN_1OUT(long2, &) -DECLOP_2VAR_2IN_1OUT(long2, |) -DECLOP_2VAR_2IN_1OUT(long2, ^) -DECLOP_2VAR_2IN_1OUT(long2, <<) -DECLOP_2VAR_2IN_1OUT(long2, >>) - -DECLOP_2VAR_ASSIGN(long2, +=) -DECLOP_2VAR_ASSIGN(long2, -=) -DECLOP_2VAR_ASSIGN(long2, *=) -DECLOP_2VAR_ASSIGN(long2, /=) -DECLOP_2VAR_ASSIGN(long2, %=) -DECLOP_2VAR_ASSIGN(long2, &=) -DECLOP_2VAR_ASSIGN(long2, |=) -DECLOP_2VAR_ASSIGN(long2, ^=) -DECLOP_2VAR_ASSIGN(long2, <<=) -DECLOP_2VAR_ASSIGN(long2, >>=) - -DECLOP_2VAR_PREOP(long2, ++) -DECLOP_2VAR_PREOP(long2, --) - -DECLOP_2VAR_POSTOP(long2, ++) -DECLOP_2VAR_POSTOP(long2, --) - -DECLOP_2VAR_COMP(long2, ==) -DECLOP_2VAR_COMP(long2, !=) -DECLOP_2VAR_COMP(long2, <) -DECLOP_2VAR_COMP(long2, >) -DECLOP_2VAR_COMP(long2, <=) -DECLOP_2VAR_COMP(long2, >=) - -DECLOP_2VAR_COMP(long2, &&) -DECLOP_2VAR_COMP(long2, ||) - -DECLOP_2VAR_1IN_1OUT(long2, ~) -DECLOP_2VAR_1IN_BOOLOUT(long2, !) - -DECLOP_2VAR_SCALE_PRODUCT(long2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(long2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(long2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(long2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(long2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(long2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(long2, float) -DECLOP_2VAR_SCALE_PRODUCT(long2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(long2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(long2, double) -DECLOP_2VAR_SCALE_PRODUCT(long2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(long2, signed long long) - -// SIGNED LONG3 - -DECLOP_3VAR_2IN_1OUT(long3, +) -DECLOP_3VAR_2IN_1OUT(long3, -) -DECLOP_3VAR_2IN_1OUT(long3, *) -DECLOP_3VAR_2IN_1OUT(long3, /) -DECLOP_3VAR_2IN_1OUT(long3, %) -DECLOP_3VAR_2IN_1OUT(long3, &) -DECLOP_3VAR_2IN_1OUT(long3, |) -DECLOP_3VAR_2IN_1OUT(long3, ^) -DECLOP_3VAR_2IN_1OUT(long3, <<) -DECLOP_3VAR_2IN_1OUT(long3, >>) - -DECLOP_3VAR_ASSIGN(long3, +=) -DECLOP_3VAR_ASSIGN(long3, -=) -DECLOP_3VAR_ASSIGN(long3, *=) -DECLOP_3VAR_ASSIGN(long3, /=) -DECLOP_3VAR_ASSIGN(long3, %=) -DECLOP_3VAR_ASSIGN(long3, &=) -DECLOP_3VAR_ASSIGN(long3, |=) -DECLOP_3VAR_ASSIGN(long3, ^=) -DECLOP_3VAR_ASSIGN(long3, <<=) -DECLOP_3VAR_ASSIGN(long3, >>=) - -DECLOP_3VAR_PREOP(long3, ++) -DECLOP_3VAR_PREOP(long3, --) - -DECLOP_3VAR_POSTOP(long3, ++) -DECLOP_3VAR_POSTOP(long3, --) - -DECLOP_3VAR_COMP(long3, ==) -DECLOP_3VAR_COMP(long3, !=) -DECLOP_3VAR_COMP(long3, <) -DECLOP_3VAR_COMP(long3, >) -DECLOP_3VAR_COMP(long3, <=) -DECLOP_3VAR_COMP(long3, >=) - -DECLOP_3VAR_COMP(long3, &&) -DECLOP_3VAR_COMP(long3, ||) - -DECLOP_3VAR_1IN_1OUT(long3, ~) -DECLOP_3VAR_1IN_BOOLOUT(long3, !) - -DECLOP_3VAR_SCALE_PRODUCT(long3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(long3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(long3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(long3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(long3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(long3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(long3, float) -DECLOP_3VAR_SCALE_PRODUCT(long3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(long3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(long3, double) -DECLOP_3VAR_SCALE_PRODUCT(long3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(long3, signed long long) - -// SIGNED LONG4 - -DECLOP_4VAR_2IN_1OUT(long4, +) -DECLOP_4VAR_2IN_1OUT(long4, -) -DECLOP_4VAR_2IN_1OUT(long4, *) -DECLOP_4VAR_2IN_1OUT(long4, /) -DECLOP_4VAR_2IN_1OUT(long4, %) -DECLOP_4VAR_2IN_1OUT(long4, &) -DECLOP_4VAR_2IN_1OUT(long4, |) -DECLOP_4VAR_2IN_1OUT(long4, ^) -DECLOP_4VAR_2IN_1OUT(long4, <<) -DECLOP_4VAR_2IN_1OUT(long4, >>) - -DECLOP_4VAR_ASSIGN(long4, +=) -DECLOP_4VAR_ASSIGN(long4, -=) -DECLOP_4VAR_ASSIGN(long4, *=) -DECLOP_4VAR_ASSIGN(long4, /=) -DECLOP_4VAR_ASSIGN(long4, %=) -DECLOP_4VAR_ASSIGN(long4, &=) -DECLOP_4VAR_ASSIGN(long4, |=) -DECLOP_4VAR_ASSIGN(long4, ^=) -DECLOP_4VAR_ASSIGN(long4, <<=) -DECLOP_4VAR_ASSIGN(long4, >>=) - -DECLOP_4VAR_PREOP(long4, ++) -DECLOP_4VAR_PREOP(long4, --) - -DECLOP_4VAR_POSTOP(long4, ++) -DECLOP_4VAR_POSTOP(long4, --) - -DECLOP_4VAR_COMP(long4, ==) -DECLOP_4VAR_COMP(long4, !=) -DECLOP_4VAR_COMP(long4, <) -DECLOP_4VAR_COMP(long4, >) -DECLOP_4VAR_COMP(long4, <=) -DECLOP_4VAR_COMP(long4, >=) - -DECLOP_4VAR_COMP(long4, &&) -DECLOP_4VAR_COMP(long4, ||) - -DECLOP_4VAR_1IN_1OUT(long4, ~) -DECLOP_4VAR_1IN_BOOLOUT(long4, !) - -DECLOP_4VAR_SCALE_PRODUCT(long4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(long4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(long4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(long4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(long4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(long4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(long4, float) -DECLOP_4VAR_SCALE_PRODUCT(long4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(long4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(long4, double) -DECLOP_4VAR_SCALE_PRODUCT(long4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(long4, signed long long) - -// UNSIGNED LONGLONG1 - -DECLOP_1VAR_2IN_1OUT(ulonglong1, +) -DECLOP_1VAR_2IN_1OUT(ulonglong1, -) -DECLOP_1VAR_2IN_1OUT(ulonglong1, *) -DECLOP_1VAR_2IN_1OUT(ulonglong1, /) -DECLOP_1VAR_2IN_1OUT(ulonglong1, %) -DECLOP_1VAR_2IN_1OUT(ulonglong1, &) -DECLOP_1VAR_2IN_1OUT(ulonglong1, |) -DECLOP_1VAR_2IN_1OUT(ulonglong1, ^) -DECLOP_1VAR_2IN_1OUT(ulonglong1, <<) -DECLOP_1VAR_2IN_1OUT(ulonglong1, >>) - - -DECLOP_1VAR_ASSIGN(ulonglong1, +=) -DECLOP_1VAR_ASSIGN(ulonglong1, -=) -DECLOP_1VAR_ASSIGN(ulonglong1, *=) -DECLOP_1VAR_ASSIGN(ulonglong1, /=) -DECLOP_1VAR_ASSIGN(ulonglong1, %=) -DECLOP_1VAR_ASSIGN(ulonglong1, &=) -DECLOP_1VAR_ASSIGN(ulonglong1, |=) -DECLOP_1VAR_ASSIGN(ulonglong1, ^=) -DECLOP_1VAR_ASSIGN(ulonglong1, <<=) -DECLOP_1VAR_ASSIGN(ulonglong1, >>=) - -DECLOP_1VAR_PREOP(ulonglong1, ++) -DECLOP_1VAR_PREOP(ulonglong1, --) - -DECLOP_1VAR_POSTOP(ulonglong1, ++) -DECLOP_1VAR_POSTOP(ulonglong1, --) - -DECLOP_1VAR_COMP(ulonglong1, ==) -DECLOP_1VAR_COMP(ulonglong1, !=) -DECLOP_1VAR_COMP(ulonglong1, <) -DECLOP_1VAR_COMP(ulonglong1, >) -DECLOP_1VAR_COMP(ulonglong1, <=) -DECLOP_1VAR_COMP(ulonglong1, >=) - -DECLOP_1VAR_COMP(ulonglong1, &&) -DECLOP_1VAR_COMP(ulonglong1, ||) - -DECLOP_1VAR_1IN_1OUT(ulonglong1, ~) -DECLOP_1VAR_1IN_BOOLOUT(ulonglong1, !) - -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, float) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, double) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(ulonglong1, signed long long) - -// UNSIGNED LONGLONG2 - -DECLOP_2VAR_2IN_1OUT(ulonglong2, +) -DECLOP_2VAR_2IN_1OUT(ulonglong2, -) -DECLOP_2VAR_2IN_1OUT(ulonglong2, *) -DECLOP_2VAR_2IN_1OUT(ulonglong2, /) -DECLOP_2VAR_2IN_1OUT(ulonglong2, %) -DECLOP_2VAR_2IN_1OUT(ulonglong2, &) -DECLOP_2VAR_2IN_1OUT(ulonglong2, |) -DECLOP_2VAR_2IN_1OUT(ulonglong2, ^) -DECLOP_2VAR_2IN_1OUT(ulonglong2, <<) -DECLOP_2VAR_2IN_1OUT(ulonglong2, >>) - -DECLOP_2VAR_ASSIGN(ulonglong2, +=) -DECLOP_2VAR_ASSIGN(ulonglong2, -=) -DECLOP_2VAR_ASSIGN(ulonglong2, *=) -DECLOP_2VAR_ASSIGN(ulonglong2, /=) -DECLOP_2VAR_ASSIGN(ulonglong2, %=) -DECLOP_2VAR_ASSIGN(ulonglong2, &=) -DECLOP_2VAR_ASSIGN(ulonglong2, |=) -DECLOP_2VAR_ASSIGN(ulonglong2, ^=) -DECLOP_2VAR_ASSIGN(ulonglong2, <<=) -DECLOP_2VAR_ASSIGN(ulonglong2, >>=) - -DECLOP_2VAR_PREOP(ulonglong2, ++) -DECLOP_2VAR_PREOP(ulonglong2, --) - -DECLOP_2VAR_POSTOP(ulonglong2, ++) -DECLOP_2VAR_POSTOP(ulonglong2, --) - -DECLOP_2VAR_COMP(ulonglong2, ==) -DECLOP_2VAR_COMP(ulonglong2, !=) -DECLOP_2VAR_COMP(ulonglong2, <) -DECLOP_2VAR_COMP(ulonglong2, >) -DECLOP_2VAR_COMP(ulonglong2, <=) -DECLOP_2VAR_COMP(ulonglong2, >=) - -DECLOP_2VAR_COMP(ulonglong2, &&) -DECLOP_2VAR_COMP(ulonglong2, ||) - -DECLOP_2VAR_1IN_1OUT(ulonglong2, ~) -DECLOP_2VAR_1IN_BOOLOUT(ulonglong2, !) - -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, float) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, double) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(ulonglong2, signed long long) - -// UNSIGNED LONGLONG3 - -DECLOP_3VAR_2IN_1OUT(ulonglong3, +) -DECLOP_3VAR_2IN_1OUT(ulonglong3, -) -DECLOP_3VAR_2IN_1OUT(ulonglong3, *) -DECLOP_3VAR_2IN_1OUT(ulonglong3, /) -DECLOP_3VAR_2IN_1OUT(ulonglong3, %) -DECLOP_3VAR_2IN_1OUT(ulonglong3, &) -DECLOP_3VAR_2IN_1OUT(ulonglong3, |) -DECLOP_3VAR_2IN_1OUT(ulonglong3, ^) -DECLOP_3VAR_2IN_1OUT(ulonglong3, <<) -DECLOP_3VAR_2IN_1OUT(ulonglong3, >>) - -DECLOP_3VAR_ASSIGN(ulonglong3, +=) -DECLOP_3VAR_ASSIGN(ulonglong3, -=) -DECLOP_3VAR_ASSIGN(ulonglong3, *=) -DECLOP_3VAR_ASSIGN(ulonglong3, /=) -DECLOP_3VAR_ASSIGN(ulonglong3, %=) -DECLOP_3VAR_ASSIGN(ulonglong3, &=) -DECLOP_3VAR_ASSIGN(ulonglong3, |=) -DECLOP_3VAR_ASSIGN(ulonglong3, ^=) -DECLOP_3VAR_ASSIGN(ulonglong3, <<=) -DECLOP_3VAR_ASSIGN(ulonglong3, >>=) - -DECLOP_3VAR_PREOP(ulonglong3, ++) -DECLOP_3VAR_PREOP(ulonglong3, --) - -DECLOP_3VAR_POSTOP(ulonglong3, ++) -DECLOP_3VAR_POSTOP(ulonglong3, --) - -DECLOP_3VAR_COMP(ulonglong3, ==) -DECLOP_3VAR_COMP(ulonglong3, !=) -DECLOP_3VAR_COMP(ulonglong3, <) -DECLOP_3VAR_COMP(ulonglong3, >) -DECLOP_3VAR_COMP(ulonglong3, <=) -DECLOP_3VAR_COMP(ulonglong3, >=) - -DECLOP_3VAR_COMP(ulonglong3, &&) -DECLOP_3VAR_COMP(ulonglong3, ||) - -DECLOP_3VAR_1IN_1OUT(ulonglong3, ~) -DECLOP_3VAR_1IN_BOOLOUT(ulonglong3, !) - -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, float) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, double) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(ulonglong3, signed long long) - -// UNSIGNED LONGLONG4 - -DECLOP_4VAR_2IN_1OUT(ulonglong4, +) -DECLOP_4VAR_2IN_1OUT(ulonglong4, -) -DECLOP_4VAR_2IN_1OUT(ulonglong4, *) -DECLOP_4VAR_2IN_1OUT(ulonglong4, /) -DECLOP_4VAR_2IN_1OUT(ulonglong4, %) -DECLOP_4VAR_2IN_1OUT(ulonglong4, &) -DECLOP_4VAR_2IN_1OUT(ulonglong4, |) -DECLOP_4VAR_2IN_1OUT(ulonglong4, ^) -DECLOP_4VAR_2IN_1OUT(ulonglong4, <<) -DECLOP_4VAR_2IN_1OUT(ulonglong4, >>) - -DECLOP_4VAR_ASSIGN(ulonglong4, +=) -DECLOP_4VAR_ASSIGN(ulonglong4, -=) -DECLOP_4VAR_ASSIGN(ulonglong4, *=) -DECLOP_4VAR_ASSIGN(ulonglong4, /=) -DECLOP_4VAR_ASSIGN(ulonglong4, %=) -DECLOP_4VAR_ASSIGN(ulonglong4, &=) -DECLOP_4VAR_ASSIGN(ulonglong4, |=) -DECLOP_4VAR_ASSIGN(ulonglong4, ^=) -DECLOP_4VAR_ASSIGN(ulonglong4, <<=) -DECLOP_4VAR_ASSIGN(ulonglong4, >>=) - -DECLOP_4VAR_PREOP(ulonglong4, ++) -DECLOP_4VAR_PREOP(ulonglong4, --) - -DECLOP_4VAR_POSTOP(ulonglong4, ++) -DECLOP_4VAR_POSTOP(ulonglong4, --) - -DECLOP_4VAR_COMP(ulonglong4, ==) -DECLOP_4VAR_COMP(ulonglong4, !=) -DECLOP_4VAR_COMP(ulonglong4, <) -DECLOP_4VAR_COMP(ulonglong4, >) -DECLOP_4VAR_COMP(ulonglong4, <=) -DECLOP_4VAR_COMP(ulonglong4, >=) - -DECLOP_4VAR_COMP(ulonglong4, &&) -DECLOP_4VAR_COMP(ulonglong4, ||) - -DECLOP_4VAR_1IN_1OUT(ulonglong4, ~) -DECLOP_4VAR_1IN_BOOLOUT(ulonglong4, !) - -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, float) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, double) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(ulonglong4, signed long long) - -// SIGNED LONGLONG1 - -DECLOP_1VAR_2IN_1OUT(longlong1, +) -DECLOP_1VAR_2IN_1OUT(longlong1, -) -DECLOP_1VAR_2IN_1OUT(longlong1, *) -DECLOP_1VAR_2IN_1OUT(longlong1, /) -DECLOP_1VAR_2IN_1OUT(longlong1, %) -DECLOP_1VAR_2IN_1OUT(longlong1, &) -DECLOP_1VAR_2IN_1OUT(longlong1, |) -DECLOP_1VAR_2IN_1OUT(longlong1, ^) -DECLOP_1VAR_2IN_1OUT(longlong1, <<) -DECLOP_1VAR_2IN_1OUT(longlong1, >>) - - -DECLOP_1VAR_ASSIGN(longlong1, +=) -DECLOP_1VAR_ASSIGN(longlong1, -=) -DECLOP_1VAR_ASSIGN(longlong1, *=) -DECLOP_1VAR_ASSIGN(longlong1, /=) -DECLOP_1VAR_ASSIGN(longlong1, %=) -DECLOP_1VAR_ASSIGN(longlong1, &=) -DECLOP_1VAR_ASSIGN(longlong1, |=) -DECLOP_1VAR_ASSIGN(longlong1, ^=) -DECLOP_1VAR_ASSIGN(longlong1, <<=) -DECLOP_1VAR_ASSIGN(longlong1, >>=) - -DECLOP_1VAR_PREOP(longlong1, ++) -DECLOP_1VAR_PREOP(longlong1, --) - -DECLOP_1VAR_POSTOP(longlong1, ++) -DECLOP_1VAR_POSTOP(longlong1, --) - -DECLOP_1VAR_COMP(longlong1, ==) -DECLOP_1VAR_COMP(longlong1, !=) -DECLOP_1VAR_COMP(longlong1, <) -DECLOP_1VAR_COMP(longlong1, >) -DECLOP_1VAR_COMP(longlong1, <=) -DECLOP_1VAR_COMP(longlong1, >=) - -DECLOP_1VAR_COMP(longlong1, &&) -DECLOP_1VAR_COMP(longlong1, ||) - -DECLOP_1VAR_1IN_1OUT(longlong1, ~) -DECLOP_1VAR_1IN_BOOLOUT(longlong1, !) - -DECLOP_1VAR_SCALE_PRODUCT(longlong1, unsigned char) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, signed char) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, unsigned short) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, signed short) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, unsigned int) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, signed int) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, float) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, unsigned long) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, signed long) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, double) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, unsigned long long) -DECLOP_1VAR_SCALE_PRODUCT(longlong1, signed long long) - -// SIGNED LONGLONG2 - -DECLOP_2VAR_2IN_1OUT(longlong2, +) -DECLOP_2VAR_2IN_1OUT(longlong2, -) -DECLOP_2VAR_2IN_1OUT(longlong2, *) -DECLOP_2VAR_2IN_1OUT(longlong2, /) -DECLOP_2VAR_2IN_1OUT(longlong2, %) -DECLOP_2VAR_2IN_1OUT(longlong2, &) -DECLOP_2VAR_2IN_1OUT(longlong2, |) -DECLOP_2VAR_2IN_1OUT(longlong2, ^) -DECLOP_2VAR_2IN_1OUT(longlong2, <<) -DECLOP_2VAR_2IN_1OUT(longlong2, >>) - -DECLOP_2VAR_ASSIGN(longlong2, +=) -DECLOP_2VAR_ASSIGN(longlong2, -=) -DECLOP_2VAR_ASSIGN(longlong2, *=) -DECLOP_2VAR_ASSIGN(longlong2, /=) -DECLOP_2VAR_ASSIGN(longlong2, %=) -DECLOP_2VAR_ASSIGN(longlong2, &=) -DECLOP_2VAR_ASSIGN(longlong2, |=) -DECLOP_2VAR_ASSIGN(longlong2, ^=) -DECLOP_2VAR_ASSIGN(longlong2, <<=) -DECLOP_2VAR_ASSIGN(longlong2, >>=) - -DECLOP_2VAR_PREOP(longlong2, ++) -DECLOP_2VAR_PREOP(longlong2, --) - -DECLOP_2VAR_POSTOP(longlong2, ++) -DECLOP_2VAR_POSTOP(longlong2, --) - -DECLOP_2VAR_COMP(longlong2, ==) -DECLOP_2VAR_COMP(longlong2, !=) -DECLOP_2VAR_COMP(longlong2, <) -DECLOP_2VAR_COMP(longlong2, >) -DECLOP_2VAR_COMP(longlong2, <=) -DECLOP_2VAR_COMP(longlong2, >=) - -DECLOP_2VAR_COMP(longlong2, &&) -DECLOP_2VAR_COMP(longlong2, ||) - -DECLOP_2VAR_1IN_1OUT(longlong2, ~) -DECLOP_2VAR_1IN_BOOLOUT(longlong2, !) - -DECLOP_2VAR_SCALE_PRODUCT(longlong2, unsigned char) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, signed char) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, unsigned short) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, signed short) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, unsigned int) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, signed int) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, float) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, unsigned long) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, signed long) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, double) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, unsigned long long) -DECLOP_2VAR_SCALE_PRODUCT(longlong2, signed long long) - -// SIGNED LONGLONG3 - -DECLOP_3VAR_2IN_1OUT(longlong3, +) -DECLOP_3VAR_2IN_1OUT(longlong3, -) -DECLOP_3VAR_2IN_1OUT(longlong3, *) -DECLOP_3VAR_2IN_1OUT(longlong3, /) -DECLOP_3VAR_2IN_1OUT(longlong3, %) -DECLOP_3VAR_2IN_1OUT(longlong3, &) -DECLOP_3VAR_2IN_1OUT(longlong3, |) -DECLOP_3VAR_2IN_1OUT(longlong3, ^) -DECLOP_3VAR_2IN_1OUT(longlong3, <<) -DECLOP_3VAR_2IN_1OUT(longlong3, >>) - -DECLOP_3VAR_ASSIGN(longlong3, +=) -DECLOP_3VAR_ASSIGN(longlong3, -=) -DECLOP_3VAR_ASSIGN(longlong3, *=) -DECLOP_3VAR_ASSIGN(longlong3, /=) -DECLOP_3VAR_ASSIGN(longlong3, %=) -DECLOP_3VAR_ASSIGN(longlong3, &=) -DECLOP_3VAR_ASSIGN(longlong3, |=) -DECLOP_3VAR_ASSIGN(longlong3, ^=) -DECLOP_3VAR_ASSIGN(longlong3, <<=) -DECLOP_3VAR_ASSIGN(longlong3, >>=) - -DECLOP_3VAR_PREOP(longlong3, ++) -DECLOP_3VAR_PREOP(longlong3, --) - -DECLOP_3VAR_POSTOP(longlong3, ++) -DECLOP_3VAR_POSTOP(longlong3, --) - -DECLOP_3VAR_COMP(longlong3, ==) -DECLOP_3VAR_COMP(longlong3, !=) -DECLOP_3VAR_COMP(longlong3, <) -DECLOP_3VAR_COMP(longlong3, >) -DECLOP_3VAR_COMP(longlong3, <=) -DECLOP_3VAR_COMP(longlong3, >=) - -DECLOP_3VAR_COMP(longlong3, &&) -DECLOP_3VAR_COMP(longlong3, ||) - -DECLOP_3VAR_1IN_1OUT(longlong3, ~) -DECLOP_3VAR_1IN_BOOLOUT(longlong3, !) - -DECLOP_3VAR_SCALE_PRODUCT(longlong3, unsigned char) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, signed char) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, unsigned short) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, signed short) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, unsigned int) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, signed int) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, float) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, unsigned long) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, signed long) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, double) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, unsigned long long) -DECLOP_3VAR_SCALE_PRODUCT(longlong3, signed long long) - -// SIGNED LONGLONG4 - -DECLOP_4VAR_2IN_1OUT(longlong4, +) -DECLOP_4VAR_2IN_1OUT(longlong4, -) -DECLOP_4VAR_2IN_1OUT(longlong4, *) -DECLOP_4VAR_2IN_1OUT(longlong4, /) -DECLOP_4VAR_2IN_1OUT(longlong4, %) -DECLOP_4VAR_2IN_1OUT(longlong4, &) -DECLOP_4VAR_2IN_1OUT(longlong4, |) -DECLOP_4VAR_2IN_1OUT(longlong4, ^) -DECLOP_4VAR_2IN_1OUT(longlong4, <<) -DECLOP_4VAR_2IN_1OUT(longlong4, >>) - -DECLOP_4VAR_ASSIGN(longlong4, +=) -DECLOP_4VAR_ASSIGN(longlong4, -=) -DECLOP_4VAR_ASSIGN(longlong4, *=) -DECLOP_4VAR_ASSIGN(longlong4, /=) -DECLOP_4VAR_ASSIGN(longlong4, %=) -DECLOP_4VAR_ASSIGN(longlong4, &=) -DECLOP_4VAR_ASSIGN(longlong4, |=) -DECLOP_4VAR_ASSIGN(longlong4, ^=) -DECLOP_4VAR_ASSIGN(longlong4, <<=) -DECLOP_4VAR_ASSIGN(longlong4, >>=) - -DECLOP_4VAR_PREOP(longlong4, ++) -DECLOP_4VAR_PREOP(longlong4, --) - -DECLOP_4VAR_POSTOP(longlong4, ++) -DECLOP_4VAR_POSTOP(longlong4, --) - -DECLOP_4VAR_COMP(longlong4, ==) -DECLOP_4VAR_COMP(longlong4, !=) -DECLOP_4VAR_COMP(longlong4, <) -DECLOP_4VAR_COMP(longlong4, >) -DECLOP_4VAR_COMP(longlong4, <=) -DECLOP_4VAR_COMP(longlong4, >=) - -DECLOP_4VAR_COMP(longlong4, &&) -DECLOP_4VAR_COMP(longlong4, ||) - -DECLOP_4VAR_1IN_1OUT(longlong4, ~) -DECLOP_4VAR_1IN_BOOLOUT(longlong4, !) - -DECLOP_4VAR_SCALE_PRODUCT(longlong4, unsigned char) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, signed char) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, unsigned short) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, signed short) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, unsigned int) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, signed int) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, float) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, unsigned long) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, signed long) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, double) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, unsigned long long) -DECLOP_4VAR_SCALE_PRODUCT(longlong4, signed long long) - - -#endif - - -#endif +#endif \ No newline at end of file diff --git a/projects/hip/include/hip/hcc_detail/texture_functions.h b/projects/hip/include/hip/hcc_detail/texture_functions.h index 8a7aec9212..999f97e65e 100644 --- a/projects/hip/include/hip/hcc_detail/texture_functions.h +++ b/projects/hip/include/hip/hcc_detail/texture_functions.h @@ -110,47 +110,47 @@ union TData { #define TEXTURE_RETURN_UNSIGNED return texel.u.x; -#define TEXTURE_RETURN_CHAR_X return char1(texel.i.x); +#define TEXTURE_RETURN_CHAR_X return make_char1(texel.i.x); -#define TEXTURE_RETURN_UCHAR_X return uchar1(texel.u.x); +#define TEXTURE_RETURN_UCHAR_X return make_uchar1(texel.u.x); -#define TEXTURE_RETURN_SHORT_X return short1(texel.i.x); +#define TEXTURE_RETURN_SHORT_X return make_short1(texel.i.x); -#define TEXTURE_RETURN_USHORT_X return ushort1(texel.u.x); +#define TEXTURE_RETURN_USHORT_X return make_ushort1(texel.u.x); -#define TEXTURE_RETURN_INT_X return int1(texel.i.x); +#define TEXTURE_RETURN_INT_X return make_int1(texel.i.x); -#define TEXTURE_RETURN_UINT_X return uint1(texel.u.x); +#define TEXTURE_RETURN_UINT_X return make_uint1(texel.u.x); -#define TEXTURE_RETURN_FLOAT_X return float1(texel.f.x); +#define TEXTURE_RETURN_FLOAT_X return make_float1(texel.f.x); -#define TEXTURE_RETURN_CHAR_XY return char2(texel.i.x, texel.i.y); +#define TEXTURE_RETURN_CHAR_XY return make_char2(texel.i.x, texel.i.y); -#define TEXTURE_RETURN_UCHAR_XY return uchar2(texel.u.x, texel.u.y); +#define TEXTURE_RETURN_UCHAR_XY return make_uchar2(texel.u.x, texel.u.y); -#define TEXTURE_RETURN_SHORT_XY return short2(texel.i.x, texel.i.y); +#define TEXTURE_RETURN_SHORT_XY return make_short2(texel.i.x, texel.i.y); -#define TEXTURE_RETURN_USHORT_XY return ushort2(texel.u.x, texel.u.y); +#define TEXTURE_RETURN_USHORT_XY return make_ushort2(texel.u.x, texel.u.y); -#define TEXTURE_RETURN_INT_XY return int2(texel.i.x, texel.i.y); +#define TEXTURE_RETURN_INT_XY return make_int2(texel.i.x, texel.i.y); -#define TEXTURE_RETURN_UINT_XY return uint2(texel.u.x, texel.u.y); +#define TEXTURE_RETURN_UINT_XY return make_uint2(texel.u.x, texel.u.y); -#define TEXTURE_RETURN_FLOAT_XY return float2(texel.f.x, texel.f.y); +#define TEXTURE_RETURN_FLOAT_XY return make_float2(texel.f.x, texel.f.y); -#define TEXTURE_RETURN_CHAR_XYZW return char4(texel.i.x, texel.i.y, texel.i.z, texel.i.w); +#define TEXTURE_RETURN_CHAR_XYZW return make_char4(texel.i.x, texel.i.y, texel.i.z, texel.i.w); -#define TEXTURE_RETURN_UCHAR_XYZW return uchar4(texel.u.x, texel.u.y, texel.u.z, texel.u.w); +#define TEXTURE_RETURN_UCHAR_XYZW return make_uchar4(texel.u.x, texel.u.y, texel.u.z, texel.u.w); -#define TEXTURE_RETURN_SHORT_XYZW return short4(texel.i.x, texel.i.y, texel.i.z, texel.i.w); +#define TEXTURE_RETURN_SHORT_XYZW return make_short4(texel.i.x, texel.i.y, texel.i.z, texel.i.w); -#define TEXTURE_RETURN_USHORT_XYZW return ushort4(texel.u.x, texel.u.y, texel.u.z, texel.u.w); +#define TEXTURE_RETURN_USHORT_XYZW return make_ushort4(texel.u.x, texel.u.y, texel.u.z, texel.u.w); -#define TEXTURE_RETURN_INT_XYZW return int4(texel.i.x, texel.i.y, texel.i.z, texel.i.w); +#define TEXTURE_RETURN_INT_XYZW return make_int4(texel.i.x, texel.i.y, texel.i.z, texel.i.w); -#define TEXTURE_RETURN_UINT_XYZW return uint4(texel.u.x, texel.u.y, texel.u.z, texel.u.w); +#define TEXTURE_RETURN_UINT_XYZW return make_uint4(texel.u.x, texel.u.y, texel.u.z, texel.u.w); -#define TEXTURE_RETURN_FLOAT_XYZW return float4(texel.f.x, texel.f.y, texel.f.z, texel.f.w); +#define TEXTURE_RETURN_FLOAT_XYZW return make_float4(texel.f.x, texel.f.y, texel.f.z, texel.f.w); extern "C" { hc::short_vector::float4::vector_value_type __ockl_image_sample_1D(unsigned int ADDRESS_SPACE_CONSTANT* i, diff --git a/projects/hip/tests/src/deviceLib/hipVectorTypes.cpp b/projects/hip/tests/src/deviceLib/hipVectorTypes.cpp index da9e24d079..734878b516 100644 --- a/projects/hip/tests/src/deviceLib/hipVectorTypes.cpp +++ b/projects/hip/tests/src/deviceLib/hipVectorTypes.cpp @@ -26,7832 +26,174 @@ THE SOFTWARE. * HIT_END */ -#include -#include #include + +#include "vector_test_common.h" #include "test_common.h" -#define cmpVal1(in, exp) \ - if (in.x != exp) { \ - std::cout << "Failed at: " << __LINE__ << " in func: " << __func__ \ - << " expected output: " << exp << " but got: " << in.x << std::endl; \ - assert(-1); \ - } -#define cmpVal2(in, exp) \ - if (in.x != exp || in.y != exp) { \ - std::cout << "Failed at: " << __LINE__ << " in func: " << __func__ \ - << " expected output: " << exp << " but got: " << in.x << "," << in.y \ - << std::endl; \ - assert(-1); \ - } +#include +#include +#include +#include -#define cmpVal3(in, exp) \ - if (in.x != exp || in.y != exp || in.z != exp) { \ - std::cout << "Failed at: " << __LINE__ << " in func: " << __func__ \ - << " expected output: " << exp << " but got: " << in.x << "," << in.y << "," \ - << in.z << std::endl; \ - assert(-1); \ - } +using namespace std; -#define cmpVal4(in, exp) \ - if (in.x != exp || in.y != exp || in.z != exp || in.w != exp) { \ - std::cout << "Failed at: " << __LINE__ << " in func: " << __func__ \ - << " expected output: " << exp << " but got: " << in.x << "," << in.y << "," \ - << in.z << "," << in.w << std::endl; \ - assert(-1); \ - } +bool integer_unary_tests(...) { + return true; +} -bool TestUChar1() { - uchar1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); +bool integer_binary_tests(...) { + return true; +} - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); +template< + typename V, + Enable_if_t().x)>{}>* = nullptr> +__device__ +bool integer_unary_tests(V& f1, V& f2) { f1 %= f2; - cmpVal1(f1, 0); + if (f1 != V{0}) return false; f1 &= f2; - cmpVal1(f1, 0); + if (f1 != V{0}) return false; f1 |= f2; - cmpVal1(f1, 1); + if (f1 != V{1}) return false; f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; + if (f1 != V{0}) return false; + f1 = V{1}; f1 <<= f2; - cmpVal1(f1, 2); + if (f1 != V{2}) return false; f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - + if (f1 != V{1}) return false; f2 = ~f1; - cmpVal1(f2, 253); - assert(!f1 == false); - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - uchar1 fa((unsigned char)1); - uchar1 fb((signed char)1); - uchar1 fc((unsigned short)1); - uchar1 fd((signed short)1); - uchar1 fe((unsigned int)1); - uchar1 fg((signed int)1); - uchar1 fh((float)1); - uchar1 fi((double)1); - uchar1 fj((unsigned long)1); - uchar1 fk((signed long)1); - uchar1 fl((unsigned long long)1); - uchar1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; + return f2 == V{~1}; } -bool TestUChar2() { - uchar2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); +template< + typename V, + Enable_if_t().x)>{}>* = nullptr> +__device__ +bool integer_binary_tests(V& f1, V& f2, V& f3) { f3 = f1 % f2; - cmpVal2(f3, 0); + if (f3 != V{0}) return false; f1 = f3 & f2; - cmpVal2(f1, 0); + if (f1 != V{0}) return false; f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; + if (f2 != V{0}) return false; + f1 = V{1}; + f2 = V{2}; f3 = f1 << f2; - cmpVal2(f3, 4); + if (f3 != V{4}) return false; f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, 253); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - uchar2 fa1((unsigned char)1); - uchar2 fa2((unsigned char)1, (unsigned char)1); - uchar2 fb1((signed char)1); - uchar2 fb2((signed char)1, (signed char)1); - uchar2 fc1((unsigned short)1); - uchar2 fc2((unsigned short)1, (unsigned short)1); - uchar2 fd1((signed short)1); - uchar2 fd2((signed short)1, (signed short)1); - uchar2 fe1((unsigned int)1); - uchar2 fe2((unsigned int)1, (unsigned int)1); - uchar2 fg1((signed int)1); - uchar2 fg2((signed int)1, (signed int)1); - uchar2 fh1((float)1); - uchar2 fh2((float)1, (float)1); - uchar2 fi1((double)1); - uchar2 fi2((double)1, (double)1); - uchar2 fj1((unsigned long)1); - uchar2 fj2((unsigned long)1, (unsigned long)1); - uchar2 fk1((signed long)1); - uchar2 fk2((signed long)1, (signed long)1); - uchar2 fl1((unsigned long long)1); - uchar2 fl2((unsigned long long)1, (unsigned long long)1); - uchar2 fm1((signed long long)1); - uchar2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; + return f2 == V{2}; } -bool TestUChar3() { - uchar3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, 253); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - uchar3 fa1((unsigned char)1); - uchar3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - uchar3 fb1((signed char)1); - uchar3 fb2((signed char)1, (signed char)1, (signed char)1); - uchar3 fc1((unsigned short)1); - uchar3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - uchar3 fd1((signed short)1); - uchar3 fd2((signed short)1, (signed short)1, (signed short)1); - uchar3 fe1((unsigned int)1); - uchar3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - uchar3 fg1((signed int)1); - uchar3 fg2((signed int)1, (signed int)1, (signed int)1); - uchar3 fh1((float)1); - uchar3 fh2((float)1, (float)1, (float)1); - uchar3 fi1((double)1); - uchar3 fi2((double)1, (double)1, (double)1); - uchar3 fj1((unsigned long)1); - uchar3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - uchar3 fk1((signed long)1); - uchar3 fk2((signed long)1, (signed long)1, (signed long)1); - uchar3 fl1((unsigned long long)1); - uchar3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - uchar3 fm1((signed long long)1); - uchar3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestUChar4() { - uchar4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, 253); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - - uchar4 fa1((unsigned char)1); - uchar4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - uchar4 fb1((signed char)1); - uchar4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - uchar4 fc1((unsigned short)1); - uchar4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - uchar4 fd1((signed short)1); - uchar4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - uchar4 fe1((unsigned int)1); - uchar4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - uchar4 fg1((signed int)1); - uchar4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - uchar4 fh1((float)1); - uchar4 fh2((float)1, (float)1, (float)1, (float)1); - uchar4 fi1((double)1); - uchar4 fi2((double)1, (double)1, (double)1, (double)1); - uchar4 fj1((unsigned long)1); - uchar4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - uchar4 fk1((signed long)1); - uchar4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - uchar4 fl1((unsigned long long)1); - uchar4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - uchar4 fm1((signed long long)1); - uchar4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestChar1() { - char1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (char)253); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - char1 fa((unsigned char)1); - char1 fb((signed char)1); - char1 fc((unsigned short)1); - char1 fd((signed short)1); - char1 fe((unsigned int)1); - char1 fg((signed int)1); - char1 fh((float)1); - char1 fi((double)1); - char1 fj((unsigned long)1); - char1 fk((signed long)1); - char1 fl((unsigned long long)1); - char1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestChar2() { - char2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (char)253); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - char2 fa1((unsigned char)1); - char2 fa2((unsigned char)1, (unsigned char)1); - char2 fb1((signed char)1); - char2 fb2((signed char)1, (signed char)1); - char2 fc1((unsigned short)1); - char2 fc2((unsigned short)1, (unsigned short)1); - char2 fd1((signed short)1); - char2 fd2((signed short)1, (signed short)1); - char2 fe1((unsigned int)1); - char2 fe2((unsigned int)1, (unsigned int)1); - char2 fg1((signed int)1); - char2 fg2((signed int)1, (signed int)1); - char2 fh1((float)1); - char2 fh2((float)1, (float)1); - char2 fi1((double)1); - char2 fi2((double)1, (double)1); - char2 fj1((unsigned long)1); - char2 fj2((unsigned long)1, (unsigned long)1); - char2 fk1((signed long)1); - char2 fk2((signed long)1, (signed long)1); - char2 fl1((unsigned long long)1); - char2 fl2((unsigned long long)1, (unsigned long long)1); - char2 fm1((signed long long)1); - char2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestChar3() { - char3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (char)253); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - char3 fa1((unsigned char)1); - char3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - char3 fb1((signed char)1); - char3 fb2((signed char)1, (signed char)1, (signed char)1); - char3 fc1((unsigned short)1); - char3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - char3 fd1((signed short)1); - char3 fd2((signed short)1, (signed short)1, (signed short)1); - char3 fe1((unsigned int)1); - char3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - char3 fg1((signed int)1); - char3 fg2((signed int)1, (signed int)1, (signed int)1); - char3 fh1((float)1); - char3 fh2((float)1, (float)1, (float)1); - char3 fi1((double)1); - char3 fi2((double)1, (double)1, (double)1); - char3 fj1((unsigned long)1); - char3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - char3 fk1((signed long)1); - char3 fk2((signed long)1, (signed long)1, (signed long)1); - char3 fl1((unsigned long long)1); - char3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - char3 fm1((signed long long)1); - char3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestChar4() { - char4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (char)253); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - char4 fa1((unsigned char)1); - char4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - char4 fb1((signed char)1); - char4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - char4 fc1((unsigned short)1); - char4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - char4 fd1((signed short)1); - char4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - char4 fe1((unsigned int)1); - char4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - char4 fg1((signed int)1); - char4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - char4 fh1((float)1); - char4 fh2((float)1, (float)1, (float)1, (float)1); - char4 fi1((double)1); - char4 fi2((double)1, (double)1, (double)1, (double)1); - char4 fj1((unsigned long)1); - char4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - char4 fk1((signed long)1); - char4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - char4 fl1((unsigned long long)1); - char4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - char4 fm1((signed long long)1); - char4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestUShort1() { - ushort1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (unsigned short)65533); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - ushort1 fa((unsigned char)1); - ushort1 fb((signed char)1); - ushort1 fc((unsigned short)1); - ushort1 fd((signed short)1); - ushort1 fe((unsigned int)1); - ushort1 fg((signed int)1); - ushort1 fh((float)1); - ushort1 fi((double)1); - ushort1 fj((unsigned long)1); - ushort1 fk((signed long)1); - ushort1 fl((unsigned long long)1); - ushort1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestUShort2() { - ushort2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (unsigned short)65533); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - ushort2 fa1((unsigned char)1); - ushort2 fa2((unsigned char)1, (unsigned char)1); - ushort2 fb1((signed char)1); - ushort2 fb2((signed char)1, (signed char)1); - ushort2 fc1((unsigned short)1); - ushort2 fc2((unsigned short)1, (unsigned short)1); - ushort2 fd1((signed short)1); - ushort2 fd2((signed short)1, (signed short)1); - ushort2 fe1((unsigned int)1); - ushort2 fe2((unsigned int)1, (unsigned int)1); - ushort2 fg1((signed int)1); - ushort2 fg2((signed int)1, (signed int)1); - ushort2 fh1((float)1); - ushort2 fh2((float)1, (float)1); - ushort2 fi1((double)1); - ushort2 fi2((double)1, (double)1); - ushort2 fj1((unsigned long)1); - ushort2 fj2((unsigned long)1, (unsigned long)1); - ushort2 fk1((signed long)1); - ushort2 fk2((signed long)1, (signed long)1); - ushort2 fl1((unsigned long long)1); - ushort2 fl2((unsigned long long)1, (unsigned long long)1); - ushort2 fm1((signed long long)1); - ushort2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestUShort3() { - ushort3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (unsigned short)65533); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - ushort3 fa1((unsigned char)1); - ushort3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - ushort3 fb1((signed char)1); - ushort3 fb2((signed char)1, (signed char)1, (signed char)1); - ushort3 fc1((unsigned short)1); - ushort3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - ushort3 fd1((signed short)1); - ushort3 fd2((signed short)1, (signed short)1, (signed short)1); - ushort3 fe1((unsigned int)1); - ushort3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - ushort3 fg1((signed int)1); - ushort3 fg2((signed int)1, (signed int)1, (signed int)1); - ushort3 fh1((float)1); - ushort3 fh2((float)1, (float)1, (float)1); - ushort3 fi1((double)1); - ushort3 fi2((double)1, (double)1, (double)1); - ushort3 fj1((unsigned long)1); - ushort3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - ushort3 fk1((signed long)1); - ushort3 fk2((signed long)1, (signed long)1, (signed long)1); - ushort3 fl1((unsigned long long)1); - ushort3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - ushort3 fm1((signed long long)1); - ushort3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestUShort4() { - ushort4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (unsigned short)65533); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - ushort4 fa1((unsigned char)1); - ushort4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - ushort4 fb1((signed char)1); - ushort4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - ushort4 fc1((unsigned short)1); - ushort4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - ushort4 fd1((signed short)1); - ushort4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - ushort4 fe1((unsigned int)1); - ushort4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - ushort4 fg1((signed int)1); - ushort4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - ushort4 fh1((float)1); - ushort4 fh2((float)1, (float)1, (float)1, (float)1); - ushort4 fi1((double)1); - ushort4 fi2((double)1, (double)1, (double)1, (double)1); - ushort4 fj1((unsigned long)1); - ushort4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - ushort4 fk1((signed long)1); - ushort4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - ushort4 fl1((unsigned long long)1); - ushort4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - ushort4 fm1((signed long long)1); - ushort4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestShort1() { - short1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (signed short)65533); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - short1 fa((unsigned char)1); - short1 fb((signed char)1); - short1 fc((unsigned short)1); - short1 fd((signed short)1); - short1 fe((unsigned int)1); - short1 fg((signed int)1); - short1 fh((float)1); - short1 fi((double)1); - short1 fj((unsigned long)1); - short1 fk((signed long)1); - short1 fl((unsigned long long)1); - short1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestShort2() { - short2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (signed short)65533); - assert(!f1 == false); - - cmpVal2(f1, 3); - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - short2 fa1((unsigned char)1); - short2 fa2((unsigned char)1, (unsigned char)1); - short2 fb1((signed char)1); - short2 fb2((signed char)1, (signed char)1); - short2 fc1((unsigned short)1); - short2 fc2((unsigned short)1, (unsigned short)1); - short2 fd1((signed short)1); - short2 fd2((signed short)1, (signed short)1); - short2 fe1((unsigned int)1); - short2 fe2((unsigned int)1, (unsigned int)1); - short2 fg1((signed int)1); - short2 fg2((signed int)1, (signed int)1); - short2 fh1((float)1); - short2 fh2((float)1, (float)1); - short2 fi1((double)1); - short2 fi2((double)1, (double)1); - short2 fj1((unsigned long)1); - short2 fj2((unsigned long)1, (unsigned long)1); - short2 fk1((signed long)1); - short2 fk2((signed long)1, (signed long)1); - short2 fl1((unsigned long long)1); - short2 fl2((unsigned long long)1, (unsigned long long)1); - short2 fm1((signed long long)1); - short2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestShort3() { - short3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (signed short)65533); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - short3 fa1((unsigned char)1); - short3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - short3 fb1((signed char)1); - short3 fb2((signed char)1, (signed char)1, (signed char)1); - short3 fc1((unsigned short)1); - short3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - short3 fd1((signed short)1); - short3 fd2((signed short)1, (signed short)1, (signed short)1); - short3 fe1((unsigned int)1); - short3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - short3 fg1((signed int)1); - short3 fg2((signed int)1, (signed int)1, (signed int)1); - short3 fh1((float)1); - short3 fh2((float)1, (float)1, (float)1); - short3 fi1((double)1); - short3 fi2((double)1, (double)1, (double)1); - short3 fj1((unsigned long)1); - short3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - short3 fk1((signed long)1); - short3 fk2((signed long)1, (signed long)1, (signed long)1); - short3 fl1((unsigned long long)1); - short3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - short3 fm1((signed long long)1); - short3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestShort4() { - short4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (signed short)65533); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - short4 fa1((unsigned char)1); - short4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - short4 fb1((signed char)1); - short4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - short4 fc1((unsigned short)1); - short4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - short4 fd1((signed short)1); - short4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - short4 fe1((unsigned int)1); - short4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - short4 fg1((signed int)1); - short4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - short4 fh1((float)1); - short4 fh2((float)1, (float)1, (float)1, (float)1); - short4 fi1((double)1); - short4 fi2((double)1, (double)1, (double)1, (double)1); - short4 fj1((unsigned long)1); - short4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - short4 fk1((signed long)1); - short4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - short4 fl1((unsigned long long)1); - short4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - short4 fm1((signed long long)1); - short4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestUInt1() { - uint1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (unsigned int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - uint1 fa((unsigned char)1); - uint1 fb((signed char)1); - uint1 fc((unsigned short)1); - uint1 fd((signed short)1); - uint1 fe((unsigned int)1); - uint1 fg((signed int)1); - uint1 fh((float)1); - uint1 fi((double)1); - uint1 fj((unsigned long)1); - uint1 fk((signed long)1); - uint1 fl((unsigned long long)1); - uint1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestUInt2() { - uint2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (unsigned int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - uint2 fa1((unsigned char)1); - uint2 fa2((unsigned char)1, (unsigned char)1); - uint2 fb1((signed char)1); - uint2 fb2((signed char)1, (signed char)1); - uint2 fc1((unsigned short)1); - uint2 fc2((unsigned short)1, (unsigned short)1); - uint2 fd1((signed short)1); - uint2 fd2((signed short)1, (signed short)1); - uint2 fe1((unsigned int)1); - uint2 fe2((unsigned int)1, (unsigned int)1); - uint2 fg1((signed int)1); - uint2 fg2((signed int)1, (signed int)1); - uint2 fh1((float)1); - uint2 fh2((float)1, (float)1); - uint2 fi1((double)1); - uint2 fi2((double)1, (double)1); - uint2 fj1((unsigned long)1); - uint2 fj2((unsigned long)1, (unsigned long)1); - uint2 fk1((signed long)1); - uint2 fk2((signed long)1, (signed long)1); - uint2 fl1((unsigned long long)1); - uint2 fl2((unsigned long long)1, (unsigned long long)1); - uint2 fm1((signed long long)1); - uint2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestUInt3() { - uint3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (unsigned int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - uint3 fa1((unsigned char)1); - uint3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - uint3 fb1((signed char)1); - uint3 fb2((signed char)1, (signed char)1, (signed char)1); - uint3 fc1((unsigned short)1); - uint3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - uint3 fd1((signed short)1); - uint3 fd2((signed short)1, (signed short)1, (signed short)1); - uint3 fe1((unsigned int)1); - uint3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - uint3 fg1((signed int)1); - uint3 fg2((signed int)1, (signed int)1, (signed int)1); - uint3 fh1((float)1); - uint3 fh2((float)1, (float)1, (float)1); - uint3 fi1((double)1); - uint3 fi2((double)1, (double)1, (double)1); - uint3 fj1((unsigned long)1); - uint3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - uint3 fk1((signed long)1); - uint3 fk2((signed long)1, (signed long)1, (signed long)1); - uint3 fl1((unsigned long long)1); - uint3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - uint3 fm1((signed long long)1); - uint3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestUInt4() { - uint4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (unsigned int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - uint4 fa1((unsigned char)1); - uint4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - uint4 fb1((signed char)1); - uint4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - uint4 fc1((unsigned short)1); - uint4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - uint4 fd1((signed short)1); - uint4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - uint4 fe1((unsigned int)1); - uint4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - uint4 fg1((signed int)1); - uint4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - uint4 fh1((float)1); - uint4 fh2((float)1, (float)1, (float)1, (float)1); - uint4 fi1((double)1); - uint4 fi2((double)1, (double)1, (double)1, (double)1); - uint4 fj1((unsigned long)1); - uint4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - uint4 fk1((signed long)1); - uint4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - uint4 fl1((unsigned long long)1); - uint4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - uint4 fm1((signed long long)1); - uint4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestInt1() { - int1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (signed int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - int1 fa((unsigned char)1); - int1 fb((signed char)1); - int1 fc((unsigned short)1); - int1 fd((signed short)1); - int1 fe((unsigned int)1); - int1 fg((signed int)1); - int1 fh((float)1); - int1 fi((double)1); - int1 fj((unsigned long)1); - int1 fk((signed long)1); - int1 fl((unsigned long long)1); - int1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestInt2() { - int2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (signed int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - int2 fa1((unsigned char)1); - int2 fa2((unsigned char)1, (unsigned char)1); - int2 fb1((signed char)1); - int2 fb2((signed char)1, (signed char)1); - int2 fc1((unsigned short)1); - int2 fc2((unsigned short)1, (unsigned short)1); - int2 fd1((signed short)1); - int2 fd2((signed short)1, (signed short)1); - int2 fe1((unsigned int)1); - int2 fe2((unsigned int)1, (unsigned int)1); - int2 fg1((signed int)1); - int2 fg2((signed int)1, (signed int)1); - int2 fh1((float)1); - int2 fh2((float)1, (float)1); - int2 fi1((double)1); - int2 fi2((double)1, (double)1); - int2 fj1((unsigned long)1); - int2 fj2((unsigned long)1, (unsigned long)1); - int2 fk1((signed long)1); - int2 fk2((signed long)1, (signed long)1); - int2 fl1((unsigned long long)1); - int2 fl2((unsigned long long)1, (unsigned long long)1); - int2 fm1((signed long long)1); - int2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestInt3() { - int3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (signed int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - int3 fa1((unsigned char)1); - int3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - int3 fb1((signed char)1); - int3 fb2((signed char)1, (signed char)1, (signed char)1); - int3 fc1((unsigned short)1); - int3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - int3 fd1((signed short)1); - int3 fd2((signed short)1, (signed short)1, (signed short)1); - int3 fe1((unsigned int)1); - int3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - int3 fg1((signed int)1); - int3 fg2((signed int)1, (signed int)1, (signed int)1); - int3 fh1((float)1); - int3 fh2((float)1, (float)1, (float)1); - int3 fi1((double)1); - int3 fi2((double)1, (double)1, (double)1); - int3 fj1((unsigned long)1); - int3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - int3 fk1((signed long)1); - int3 fk2((signed long)1, (signed long)1, (signed long)1); - int3 fl1((unsigned long long)1); - int3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - int3 fm1((signed long long)1); - int3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestInt4() { - int4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (signed int)4294967293); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - int4 fa1((unsigned char)1); - int4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - int4 fb1((signed char)1); - int4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - int4 fc1((unsigned short)1); - int4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - int4 fd1((signed short)1); - int4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - int4 fe1((unsigned int)1); - int4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - int4 fg1((signed int)1); - int4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - int4 fh1((float)1); - int4 fh2((float)1, (float)1, (float)1, (float)1); - int4 fi1((double)1); - int4 fi2((double)1, (double)1, (double)1, (double)1); - int4 fj1((unsigned long)1); - int4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - int4 fk1((signed long)1); - int4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - int4 fl1((unsigned long long)1); - int4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - int4 fm1((signed long long)1); - int4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestFloat1() { - float1 f1, f2, f3; - f1.x = 1.0f; - f2.x = 1.0f; - f3 = f1 + f2; - cmpVal1(f3, 2.0f); - f2 = f3 - f1; - cmpVal1(f2, 1.0f); - f1 = f2 * f3; - cmpVal1(f1, 2.0f); - f2 = f1 / f3; - cmpVal1(f2, 2.0f / 2.0f); - f1 += f2; - cmpVal1(f1, 3.0f); - f1 -= f2; - cmpVal1(f1, 2.0f); - f1 *= f2; - cmpVal1(f1, 2.0f); - f1 /= f2; - cmpVal1(f1, 2.0f); - f2 = f1++; - cmpVal1(f1, 3.0f); - cmpVal1(f2, 2.0f); - f2 = f1--; - cmpVal1(f2, 3.0f); - cmpVal1(f1, 2.0f); - f2 = ++f1; - cmpVal1(f1, 3.0f); - cmpVal1(f2, 3.0f); - f2 = --f1; - cmpVal1(f1, 2.0f); - cmpVal1(f1, 2.0f); - - f1.x = 3.0f; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3.0f); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3.0f); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3.0f); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3.0f); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3.0f); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3.0f); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (float)1; - cmpVal1(f1, 3.0f); - f1 = (float)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3.0f); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3.0f); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (double)1; - cmpVal1(f1, 3.0f); - f1 = (double)1 * f1; - cmpVal1(f1, 3.0f); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3.0f); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3.0f); - - float1 fa((unsigned char)1); - float1 fb((signed char)1); - float1 fc((unsigned short)1); - float1 fd((signed short)1); - float1 fe((unsigned int)1); - float1 fg((signed int)1); - float1 fh((float)1); - float1 fi((double)1); - float1 fj((unsigned long)1); - float1 fk((signed long)1); - float1 fl((unsigned long long)1); - float1 fm((signed long long)1); - - - f1.x = 3.0f; - f2.x = 4.0f; - f3.x = 3.0f; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); +template +bool constructor_tests() { + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); + static_assert(is_constructible{}, ""); return true; } -bool TestFloat2() { - float2 f1, f2, f3; - f1.x = 1.0f; - f1.y = 1.0f; - f2.x = 1.0f; - f2.y = 1.0f; - f3 = f1 + f2; - cmpVal2(f3, 2.0f); +template +bool TestVectorType() { + V f1{1}; + V f2{1}; + V f3 = f1 + f2; + if (f3 != V{2}) return false; f2 = f3 - f1; - cmpVal2(f2, 1.0f); + if (f2 != V{1}) return false; f1 = f2 * f3; - cmpVal2(f1, 2.0f); + if (f1 != V{2}) return false; f2 = f1 / f3; - cmpVal2(f2, 2.0f / 2.0f); + if (f2 != V{1}) return false; + if (!integer_binary_tests(f1, f2, f3)) return false; + + f1 = V{2}; + f2 = V{1}; f1 += f2; - cmpVal2(f1, 3.0f); + if (f1 != V{3}) return false; f1 -= f2; - cmpVal2(f1, 2.0f); + if (f1 != V{2}) return false; f1 *= f2; - cmpVal2(f1, 2.0f); + if (f1 != V{2}) return false; f1 /= f2; - cmpVal2(f1, 2.0f); + if (f1 != V{2}) return false; + if (!integer_unary_tests(f1, f2)) return false; + f1 = V{2}; f2 = f1++; - cmpVal2(f1, 3.0f); - cmpVal2(f2, 2.0f); + if (f1 != V{3}) return false; + if (f2 != V{2}) return false; f2 = f1--; - cmpVal2(f2, 3.0f); - cmpVal2(f1, 2.0f); + if (f2 != V{3}) return false; + if (f1 != V{2}) return false; f2 = ++f1; - cmpVal2(f1, 3.0f); - cmpVal2(f2, 3.0f); + if (f1 != V{3}) return false; + if (f2 != V{3}) return false; f2 = --f1; - cmpVal2(f1, 2.0f); - cmpVal2(f1, 2.0f); + if (f1 != V{2}) return false; + if (f2 != V{2}) return false; - f1.x = 3.0f; - f1.y = 3.0f; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3.0f); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3.0f); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3.0f); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3.0f); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3.0f); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3.0f); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (float)1; - cmpVal2(f1, 3.0f); - f1 = (float)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3.0f); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3.0f); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (double)1; - cmpVal2(f1, 3.0f); - f1 = (double)1 * f1; - cmpVal2(f1, 3.0f); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3.0f); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3.0f); - - float2 fa1((unsigned char)1); - float2 fa2((unsigned char)1, (unsigned char)1); - float2 fb1((signed char)1); - float2 fb2((signed char)1, (signed char)1); - float2 fc1((unsigned short)1); - float2 fc2((unsigned short)1, (unsigned short)1); - float2 fd1((signed short)1); - float2 fd2((signed short)1, (signed short)1); - float2 fe1((unsigned int)1); - float2 fe2((unsigned int)1, (unsigned int)1); - float2 fg1((signed int)1); - float2 fg2((signed int)1, (signed int)1); - float2 fh1((float)1); - float2 fh2((float)1, (float)1); - float2 fi1((double)1); - float2 fi2((double)1, (double)1); - float2 fj1((unsigned long)1); - float2 fj2((unsigned long)1, (unsigned long)1); - float2 fk1((signed long)1); - float2 fk2((signed long)1, (signed long)1); - float2 fl1((unsigned long long)1); - float2 fl2((unsigned long long)1, (unsigned long long)1); - float2 fm1((signed long long)1); - float2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3.0f; - f1.y = 3.0f; - f2.x = 4.0f; - f2.y = 4.0f; - f3.x = 3.0f; - f3.y = 3.0f; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); + if (!constructor_tests()) return false; + f1 = V{3}; + f2 = V{4}; + f3 = V{3}; + if (f1 == f2) return false; + if (!(f1 != f2)) return false; return true; } -bool TestFloat3() { - float3 f1, f2, f3; - f1.x = 1.0f; - f1.y = 1.0f; - f1.z = 1.0f; - f2.x = 1.0f; - f2.y = 1.0f; - f2.z = 1.0f; - f3 = f1 + f2; - cmpVal3(f3, 2.0f); - f2 = f3 - f1; - cmpVal3(f2, 1.0f); - f1 = f2 * f3; - cmpVal3(f1, 2.0f); - f2 = f1 / f3; - cmpVal3(f2, 2.0f / 2.0f); - f1 += f2; - cmpVal3(f1, 3.0f); - f1 -= f2; - cmpVal3(f1, 2.0f); - f1 *= f2; - cmpVal3(f1, 2.0f); - f1 /= f2; - f2 = f1++; - cmpVal3(f1, 3.0f); - cmpVal3(f2, 2.0f); - f2 = f1--; - cmpVal3(f2, 3.0f); - cmpVal3(f1, 2.0f); - f2 = ++f1; - cmpVal3(f1, 3.0f); - cmpVal3(f2, 3.0f); - f2 = --f1; - cmpVal3(f1, 2.0f); - cmpVal3(f1, 2.0f); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - float3 fa1((unsigned char)1); - float3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - float3 fb1((signed char)1); - float3 fb2((signed char)1, (signed char)1, (signed char)1); - float3 fc1((unsigned short)1); - float3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - float3 fd1((signed short)1); - float3 fd2((signed short)1, (signed short)1, (signed short)1); - float3 fe1((unsigned int)1); - float3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - float3 fg1((signed int)1); - float3 fg2((signed int)1, (signed int)1, (signed int)1); - float3 fh1((float)1); - float3 fh2((float)1, (float)1, (float)1); - float3 fi1((double)1); - float3 fi2((double)1, (double)1, (double)1); - float3 fj1((unsigned long)1); - float3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - float3 fk1((signed long)1); - float3 fk2((signed long)1, (signed long)1, (signed long)1); - float3 fl1((unsigned long long)1); - float3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - float3 fm1((signed long long)1); - float3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3.0f; - f1.y = 3.0f; - f1.z = 3.0f; - f2.x = 4.0f; - f2.y = 4.0f; - f2.z = 4.0f; - f3.x = 3.0f; - f3.y = 3.0f; - f3.z = 3.0f; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - +template* = nullptr> +bool TestVectorTypes() { return true; } -bool TestFloat4() { - float4 f1, f2, f3; - f1.x = 1.0f; - f1.y = 1.0f; - f1.z = 1.0f; - f1.w = 1.0f; - f2.x = 1.0f; - f2.y = 1.0f; - f2.z = 1.0f; - f2.w = 1.0f; - f3 = f1 + f2; - cmpVal4(f3, 2.0f); - f2 = f3 - f1; - cmpVal4(f2, 1.0f); - f1 = f2 * f3; - cmpVal4(f1, 2.0f); - f2 = f1 / f3; - cmpVal4(f2, 2.0f / 2.0f); - f1 += f2; - cmpVal4(f1, 3.0f); - f1 -= f2; - cmpVal4(f1, 2.0f); - f1 *= f2; - cmpVal4(f1, 2.0f); - f1 /= f2; - f2 = f1++; - cmpVal4(f1, 3.0f); - cmpVal4(f2, 2.0f); - f2 = f1--; - cmpVal4(f2, 3.0f); - cmpVal4(f1, 2.0f); - f2 = ++f1; - cmpVal4(f1, 3.0f); - cmpVal4(f2, 3.0f); - f2 = --f1; - cmpVal4(f1, 2.0f); - cmpVal4(f1, 2.0f); - - f1.x = 3.0f; - f1.y = 3.0f; - f1.z = 3.0f; - f1.w = 3.0f; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3.0f); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3.0f); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3.0f); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3.0f); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3.0f); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3.0f); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (float)1; - cmpVal4(f1, 3.0f); - f1 = (float)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3.0f); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3.0f); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (double)1; - cmpVal4(f1, 3.0f); - f1 = (double)1 * f1; - cmpVal4(f1, 3.0f); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3.0f); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3.0f); - - float4 fa1((unsigned char)1); - float4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - float4 fb1((signed char)1); - float4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - float4 fc1((unsigned short)1); - float4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - float4 fd1((signed short)1); - float4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - float4 fe1((unsigned int)1); - float4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - float4 fg1((signed int)1); - float4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - float4 fh1((float)1); - float4 fh2((float)1, (float)1, (float)1, (float)1); - float4 fi1((double)1); - float4 fi2((double)1, (double)1, (double)1, (double)1); - float4 fj1((unsigned long)1); - float4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - float4 fk1((signed long)1); - float4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - float4 fl1((unsigned long long)1); - float4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - float4 fm1((signed long long)1); - float4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3.0f; - f1.y = 3.0f; - f1.z = 3.0f; - f1.w = 3.0f; - f2.x = 4.0f; - f2.y = 4.0f; - f2.z = 4.0f; - f2.w = 4.0f; - f3.x = 3.0f; - f3.y = 3.0f; - f3.z = 3.0f; - f3.w = 3.0f; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - return true; +template +bool TestVectorTypes() { + if (!TestVectorType()) return false; + return TestVectorTypes(); } - -bool TestULong1() { - ulong1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, 18446744073709551613UL); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - ulong1 fa((unsigned char)1); - ulong1 fb((signed char)1); - ulong1 fc((unsigned short)1); - ulong1 fd((signed short)1); - ulong1 fe((unsigned int)1); - ulong1 fg((signed int)1); - ulong1 fh((float)1); - ulong1 fi((double)1); - ulong1 fj((unsigned long)1); - ulong1 fk((signed long)1); - ulong1 fl((unsigned long long)1); - ulong1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestULong2() { - ulong2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, 18446744073709551613UL); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - ulong2 fa1((unsigned char)1); - ulong2 fa2((unsigned char)1, (unsigned char)1); - ulong2 fb1((signed char)1); - ulong2 fb2((signed char)1, (signed char)1); - ulong2 fc1((unsigned short)1); - ulong2 fc2((unsigned short)1, (unsigned short)1); - ulong2 fd1((signed short)1); - ulong2 fd2((signed short)1, (signed short)1); - ulong2 fe1((unsigned int)1); - ulong2 fe2((unsigned int)1, (unsigned int)1); - ulong2 fg1((signed int)1); - ulong2 fg2((signed int)1, (signed int)1); - ulong2 fh1((float)1); - ulong2 fh2((float)1, (float)1); - ulong2 fi1((double)1); - ulong2 fi2((double)1, (double)1); - ulong2 fj1((unsigned long)1); - ulong2 fj2((unsigned long)1, (unsigned long)1); - ulong2 fk1((signed long)1); - ulong2 fk2((signed long)1, (signed long)1); - ulong2 fl1((unsigned long long)1); - ulong2 fl2((unsigned long long)1, (unsigned long long)1); - ulong2 fm1((signed long long)1); - ulong2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestULong3() { - ulong3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, 18446744073709551613UL); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - ulong3 fa1((unsigned char)1); - ulong3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - ulong3 fb1((signed char)1); - ulong3 fb2((signed char)1, (signed char)1, (signed char)1); - ulong3 fc1((unsigned short)1); - ulong3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - ulong3 fd1((signed short)1); - ulong3 fd2((signed short)1, (signed short)1, (signed short)1); - ulong3 fe1((unsigned int)1); - ulong3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - ulong3 fg1((signed int)1); - ulong3 fg2((signed int)1, (signed int)1, (signed int)1); - ulong3 fh1((float)1); - ulong3 fh2((float)1, (float)1, (float)1); - ulong3 fi1((double)1); - ulong3 fi2((double)1, (double)1, (double)1); - ulong3 fj1((unsigned long)1); - ulong3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - ulong3 fk1((signed long)1); - ulong3 fk2((signed long)1, (signed long)1, (signed long)1); - ulong3 fl1((unsigned long long)1); - ulong3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - ulong3 fm1((signed long long)1); - ulong3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestULong4() { - ulong4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, 18446744073709551613UL); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - ulong4 fa1((unsigned char)1); - ulong4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - ulong4 fb1((signed char)1); - ulong4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - ulong4 fc1((unsigned short)1); - ulong4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - ulong4 fd1((signed short)1); - ulong4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - ulong4 fe1((unsigned int)1); - ulong4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - ulong4 fg1((signed int)1); - ulong4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - ulong4 fh1((float)1); - ulong4 fh2((float)1, (float)1, (float)1, (float)1); - ulong4 fi1((double)1); - ulong4 fi2((double)1, (double)1, (double)1, (double)1); - ulong4 fj1((unsigned long)1); - ulong4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - ulong4 fk1((signed long)1); - ulong4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - ulong4 fl1((unsigned long long)1); - ulong4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - ulong4 fm1((signed long long)1); - ulong4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestLong1() { - long1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - long1 fa((unsigned char)1); - long1 fb((signed char)1); - long1 fc((unsigned short)1); - long1 fd((signed short)1); - long1 fe((unsigned int)1); - long1 fg((signed int)1); - long1 fh((float)1); - long1 fi((double)1); - long1 fj((unsigned long)1); - long1 fk((signed long)1); - long1 fl((unsigned long long)1); - long1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestLong2() { - long2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - long2 fa1((unsigned char)1); - long2 fa2((unsigned char)1, (unsigned char)1); - long2 fb1((signed char)1); - long2 fb2((signed char)1, (signed char)1); - long2 fc1((unsigned short)1); - long2 fc2((unsigned short)1, (unsigned short)1); - long2 fd1((signed short)1); - long2 fd2((signed short)1, (signed short)1); - long2 fe1((unsigned int)1); - long2 fe2((unsigned int)1, (unsigned int)1); - long2 fg1((signed int)1); - long2 fg2((signed int)1, (signed int)1); - long2 fh1((float)1); - long2 fh2((float)1, (float)1); - long2 fi1((double)1); - long2 fi2((double)1, (double)1); - long2 fj1((unsigned long)1); - long2 fj2((unsigned long)1, (unsigned long)1); - long2 fk1((signed long)1); - long2 fk2((signed long)1, (signed long)1); - long2 fl1((unsigned long long)1); - long2 fl2((unsigned long long)1, (unsigned long long)1); - long2 fm1((signed long long)1); - long2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestLong3() { - long3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - - long3 fa1((unsigned char)1); - long3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - long3 fb1((signed char)1); - long3 fb2((signed char)1, (signed char)1, (signed char)1); - long3 fc1((unsigned short)1); - long3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - long3 fd1((signed short)1); - long3 fd2((signed short)1, (signed short)1, (signed short)1); - long3 fe1((unsigned int)1); - long3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - long3 fg1((signed int)1); - long3 fg2((signed int)1, (signed int)1, (signed int)1); - long3 fh1((float)1); - long3 fh2((float)1, (float)1, (float)1); - long3 fi1((double)1); - long3 fi2((double)1, (double)1, (double)1); - long3 fj1((unsigned long)1); - long3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - long3 fk1((signed long)1); - long3 fk2((signed long)1, (signed long)1, (signed long)1); - long3 fl1((unsigned long long)1); - long3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - long3 fm1((signed long long)1); - long3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestLong4() { - long4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - long4 fa1((unsigned char)1); - long4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - long4 fb1((signed char)1); - long4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - long4 fc1((unsigned short)1); - long4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - long4 fd1((signed short)1); - long4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - long4 fe1((unsigned int)1); - long4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - long4 fg1((signed int)1); - long4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - long4 fh1((float)1); - long4 fh2((float)1, (float)1, (float)1, (float)1); - long4 fi1((double)1); - long4 fi2((double)1, (double)1, (double)1, (double)1); - long4 fj1((unsigned long)1); - long4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - long4 fk1((signed long)1); - long4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - long4 fl1((unsigned long long)1); - long4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - long4 fm1((signed long long)1); - long4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestDouble1() { - double1 f1, f2, f3; - f1.x = 1.0; - f2.x = 1.0; - f3 = f1 + f2; - cmpVal1(f3, 2.0); - f2 = f3 - f1; - cmpVal1(f2, 1.0); - f1 = f2 * f3; - cmpVal1(f1, 2.0); - f2 = f1 / f3; - cmpVal1(f2, 2.0 / 2.0); - f1 += f2; - cmpVal1(f1, 3.0); - f1 -= f2; - cmpVal1(f1, 2.0); - f1 *= f2; - cmpVal1(f1, 2.0); - f1 /= f2; - cmpVal1(f1, 2.0); - f2 = f1++; - cmpVal1(f1, 3.0); - cmpVal1(f2, 2.0); - f2 = f1--; - cmpVal1(f2, 3.0); - cmpVal1(f1, 2.0); - f2 = ++f1; - cmpVal1(f1, 3.0); - cmpVal1(f2, 3.0); - f2 = --f1; - cmpVal1(f1, 2.0); - cmpVal1(f1, 2.0); - - f1.x = 3.0; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3.0); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3.0); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3.0); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3.0); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3.0); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3.0); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (float)1; - cmpVal1(f1, 3.0); - f1 = (float)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3.0); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3.0); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (double)1; - cmpVal1(f1, 3.0); - f1 = (double)1 * f1; - cmpVal1(f1, 3.0); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3.0); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3.0); - - double1 fa((unsigned char)1); - double1 fb((signed char)1); - double1 fc((unsigned short)1); - double1 fd((signed short)1); - double1 fe((unsigned int)1); - double1 fg((signed int)1); - double1 fh((float)1); - double1 fi((double)1); - double1 fj((unsigned long)1); - double1 fk((signed long)1); - double1 fl((unsigned long long)1); - double1 fm((signed long long)1); - - - f1.x = 3.0; - f2.x = 4.0; - f3.x = 3.0; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - return true; -} - -bool TestDouble2() { - double2 f1, f2, f3; - f1.x = 1.0; - f1.y = 1.0; - f2.x = 1.0; - f2.y = 1.0; - f3 = f1 + f2; - cmpVal2(f3, 2.0); - f2 = f3 - f1; - cmpVal2(f2, 1.0); - f1 = f2 * f3; - cmpVal2(f1, 2.0); - f2 = f1 / f3; - cmpVal2(f2, 2.0f / 2.0); - f1 += f2; - cmpVal2(f1, 3.0); - f1 -= f2; - cmpVal2(f1, 2.0); - f1 *= f2; - cmpVal2(f1, 2.0); - f1 /= f2; - cmpVal2(f1, 2.0); - - f2 = f1++; - cmpVal2(f1, 3.0); - cmpVal2(f2, 2.0); - f2 = f1--; - cmpVal2(f2, 3.0); - cmpVal2(f1, 2.0); - f2 = ++f1; - cmpVal2(f1, 3.0); - cmpVal2(f2, 3.0); - f2 = --f1; - cmpVal2(f1, 2.0); - cmpVal2(f1, 2.0); - - f1.x = 3.0; - f1.y = 3.0; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3.0); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3.0); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3.0); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3.0); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3.0); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3.0); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (float)1; - cmpVal2(f1, 3.0); - f1 = (float)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3.0); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3.0); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (double)1; - cmpVal2(f1, 3.0); - f1 = (double)1 * f1; - cmpVal2(f1, 3.0); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3.0); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3.0); - - double2 fa1((unsigned char)1); - double2 fa2((unsigned char)1, (unsigned char)1); - double2 fb1((signed char)1); - double2 fb2((signed char)1, (signed char)1); - double2 fc1((unsigned short)1); - double2 fc2((unsigned short)1, (unsigned short)1); - double2 fd1((signed short)1); - double2 fd2((signed short)1, (signed short)1); - double2 fe1((unsigned int)1); - double2 fe2((unsigned int)1, (unsigned int)1); - double2 fg1((signed int)1); - double2 fg2((signed int)1, (signed int)1); - double2 fh1((float)1); - double2 fh2((float)1, (float)1); - double2 fi1((double)1); - double2 fi2((double)1, (double)1); - double2 fj1((unsigned long)1); - double2 fj2((unsigned long)1, (unsigned long)1); - double2 fk1((signed long)1); - double2 fk2((signed long)1, (signed long)1); - double2 fl1((unsigned long long)1); - double2 fl2((unsigned long long)1, (unsigned long long)1); - double2 fm1((signed long long)1); - double2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3.0; - f1.y = 3.0; - f2.x = 4.0; - f2.y = 4.0; - f3.x = 3.0; - f3.y = 3.0; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - - return true; -} - -bool TestDouble3() { - double3 f1, f2, f3; - f1.x = 1.0; - f1.y = 1.0; - f1.z = 1.0; - f2.x = 1.0; - f2.y = 1.0; - f2.z = 1.0; - f3 = f1 + f2; - cmpVal3(f3, 2.0); - f2 = f3 - f1; - cmpVal3(f2, 1.0); - f1 = f2 * f3; - cmpVal3(f1, 2.0); - f2 = f1 / f3; - cmpVal3(f2, 2.0f / 2.0); - f1 += f2; - cmpVal3(f1, 3.0); - f1 -= f2; - cmpVal3(f1, 2.0); - f1 *= f2; - cmpVal3(f1, 2.0); - f1 /= f2; - f2 = f1++; - cmpVal3(f1, 3.0); - cmpVal3(f2, 2.0); - f2 = f1--; - cmpVal3(f2, 3.0); - cmpVal3(f1, 2.0); - f2 = ++f1; - cmpVal3(f1, 3.0); - cmpVal3(f2, 3.0); - f2 = --f1; - cmpVal3(f1, 2.0); - cmpVal3(f1, 2.0); - - f1.x = 3.0; - f1.y = 3.0; - f1.z = 3.0; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3.0); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3.0); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3.0); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3.0); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3.0); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3.0); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (float)1; - cmpVal3(f1, 3.0); - f1 = (float)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3.0); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3.0); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (double)1; - cmpVal3(f1, 3.0); - f1 = (double)1 * f1; - cmpVal3(f1, 3.0); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3.0); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3.0); - - double3 fa1((unsigned char)1); - double3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - double3 fb1((signed char)1); - double3 fb2((signed char)1, (signed char)1, (signed char)1); - double3 fc1((unsigned short)1); - double3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - double3 fd1((signed short)1); - double3 fd2((signed short)1, (signed short)1, (signed short)1); - double3 fe1((unsigned int)1); - double3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - double3 fg1((signed int)1); - double3 fg2((signed int)1, (signed int)1, (signed int)1); - double3 fh1((float)1); - double3 fh2((float)1, (float)1, (float)1); - double3 fi1((double)1); - double3 fi2((double)1, (double)1, (double)1); - double3 fj1((unsigned long)1); - double3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - double3 fk1((signed long)1); - double3 fk2((signed long)1, (signed long)1, (signed long)1); - double3 fl1((unsigned long long)1); - double3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - double3 fm1((signed long long)1); - double3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3.0; - f1.y = 3.0; - f1.z = 3.0; - f2.x = 4.0; - f2.y = 4.0; - f2.z = 4.0; - f3.x = 3.0; - f3.y = 3.0; - f3.z = 3.0; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - - return true; -} - -bool TestDouble4() { - double4 f1, f2, f3; - f1.x = 1.0; - f1.y = 1.0; - f1.z = 1.0; - f1.w = 1.0; - f2.x = 1.0; - f2.y = 1.0; - f2.z = 1.0; - f2.w = 1.0; - f3 = f1 + f2; - cmpVal4(f3, 2.0); - f2 = f3 - f1; - cmpVal4(f2, 1.0); - f1 = f2 * f3; - cmpVal4(f1, 2.0); - f2 = f1 / f3; - cmpVal4(f2, 2.0f / 2.0); - f1 += f2; - cmpVal4(f1, 3.0); - f1 -= f2; - cmpVal4(f1, 2.0); - f1 *= f2; - cmpVal4(f1, 2.0); - f1 /= f2; - f2 = f1++; - cmpVal4(f1, 3.0); - cmpVal4(f2, 2.0); - f2 = f1--; - cmpVal4(f2, 3.0); - cmpVal4(f1, 2.0); - f2 = ++f1; - cmpVal4(f1, 3.0); - cmpVal4(f2, 3.0); - f2 = --f1; - cmpVal4(f1, 2.0); - cmpVal4(f1, 2.0); - - f1.x = 3.0; - f1.y = 3.0; - f1.z = 3.0; - f1.w = 3.0; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3.0); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3.0); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3.0); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3.0); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3.0); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3.0); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (float)1; - cmpVal4(f1, 3.0); - f1 = (float)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3.0); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3.0); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (double)1; - cmpVal4(f1, 3.0); - f1 = (double)1 * f1; - cmpVal4(f1, 3.0); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3.0); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3.0); - - double4 fa1((unsigned char)1); - double4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - double4 fb1((signed char)1); - double4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - double4 fc1((unsigned short)1); - double4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - double4 fd1((signed short)1); - double4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - double4 fe1((unsigned int)1); - double4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - double4 fg1((signed int)1); - double4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - double4 fh1((float)1); - double4 fh2((float)1, (float)1, (float)1, (float)1); - double4 fi1((double)1); - double4 fi2((double)1, (double)1, (double)1, (double)1); - double4 fj1((unsigned long)1); - double4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - double4 fk1((signed long)1); - double4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - double4 fl1((unsigned long long)1); - double4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - double4 fm1((signed long long)1); - double4 fm2((signed long long)1, (signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3.0; - f1.y = 3.0; - f1.z = 3.0; - f1.w = 3.0; - f2.x = 4.0; - f2.y = 4.0; - f2.z = 4.0; - f2.w = 4.0; - f3.x = 3.0; - f3.y = 3.0; - f3.z = 3.0; - f3.w = 3.0; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - return true; -} - - -bool TestULongLong1() { - long1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - ulonglong1 fa((unsigned char)1); - ulonglong1 fb((signed char)1); - ulonglong1 fc((unsigned short)1); - ulonglong1 fd((signed short)1); - ulonglong1 fe((unsigned int)1); - ulonglong1 fg((signed int)1); - ulonglong1 fh((float)1); - ulonglong1 fi((double)1); - ulonglong1 fj((unsigned long)1); - ulonglong1 fk((signed long)1); - ulonglong1 fl((unsigned long long)1); - ulonglong1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestULongLong2() { - long2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - ulonglong2 fa1((unsigned char)1); - ulonglong2 fa2((unsigned char)1, (unsigned char)1); - ulonglong2 fb1((signed char)1); - ulonglong2 fb2((signed char)1, (signed char)1); - ulonglong2 fc1((unsigned short)1); - ulonglong2 fc2((unsigned short)1, (unsigned short)1); - ulonglong2 fd1((signed short)1); - ulonglong2 fd2((signed short)1, (signed short)1); - ulonglong2 fe1((unsigned int)1); - ulonglong2 fe2((unsigned int)1, (unsigned int)1); - ulonglong2 fg1((signed int)1); - ulonglong2 fg2((signed int)1, (signed int)1); - ulonglong2 fh1((float)1); - ulonglong2 fh2((float)1, (float)1); - ulonglong2 fi1((double)1); - ulonglong2 fi2((double)1, (double)1); - ulonglong2 fj1((unsigned long)1); - ulonglong2 fj2((unsigned long)1, (unsigned long)1); - ulonglong2 fk1((signed long)1); - ulonglong2 fk2((signed long)1, (signed long)1); - ulonglong2 fl1((unsigned long long)1); - ulonglong2 fl2((unsigned long long)1, (unsigned long long)1); - ulonglong2 fm1((signed long long)1); - ulonglong2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestULongLong3() { - long3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - ulonglong3 fa1((unsigned char)1); - ulonglong3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - ulonglong3 fb1((signed char)1); - ulonglong3 fb2((signed char)1, (signed char)1, (signed char)1); - ulonglong3 fc1((unsigned short)1); - ulonglong3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - ulonglong3 fd1((signed short)1); - ulonglong3 fd2((signed short)1, (signed short)1, (signed short)1); - ulonglong3 fe1((unsigned int)1); - ulonglong3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - ulonglong3 fg1((signed int)1); - ulonglong3 fg2((signed int)1, (signed int)1, (signed int)1); - ulonglong3 fh1((float)1); - ulonglong3 fh2((float)1, (float)1, (float)1); - ulonglong3 fi1((double)1); - ulonglong3 fi2((double)1, (double)1, (double)1); - ulonglong3 fj1((unsigned long)1); - ulonglong3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - ulonglong3 fk1((signed long)1); - ulonglong3 fk2((signed long)1, (signed long)1, (signed long)1); - ulonglong3 fl1((unsigned long long)1); - ulonglong3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - ulonglong3 fm1((signed long long)1); - ulonglong3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestULongLong4() { - long4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - ulonglong4 fa1((unsigned char)1); - ulonglong4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - ulonglong4 fb1((signed char)1); - ulonglong4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - ulonglong4 fc1((unsigned short)1); - ulonglong4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - ulonglong4 fd1((signed short)1); - ulonglong4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - ulonglong4 fe1((unsigned int)1); - ulonglong4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - ulonglong4 fg1((signed int)1); - ulonglong4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - ulonglong4 fh1((float)1); - ulonglong4 fh2((float)1, (float)1, (float)1, (float)1); - ulonglong4 fi1((double)1); - ulonglong4 fi2((double)1, (double)1, (double)1, (double)1); - ulonglong4 fj1((unsigned long)1); - ulonglong4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - ulonglong4 fk1((signed long)1); - ulonglong4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - ulonglong4 fl1((unsigned long long)1); - ulonglong4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - ulonglong4 fm1((signed long long)1); - ulonglong4 fm2((signed long long)1, (signed long long)1, (signed long long)1, - (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - - -bool TestLongLong1() { - long1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (double)1; - cmpVal1(f1, 3); - f1 = (double)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal1(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal1(f1, 3); - - longlong1 fa((unsigned char)1); - longlong1 fb((signed char)1); - longlong1 fc((unsigned short)1); - longlong1 fd((signed short)1); - longlong1 fe((unsigned int)1); - longlong1 fg((signed int)1); - longlong1 fh((float)1); - longlong1 fi((double)1); - longlong1 fj((unsigned long)1); - longlong1 fk((signed long)1); - longlong1 fl((unsigned long long)1); - longlong1 fm((signed long long)1); - - - f1.x = 3; - f2.x = 4; - f3.x = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestLongLong2() { - long2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1 = f1 * (unsigned char)1; - cmpVal2(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed char)1; - cmpVal2(f1, 3); - f1 = (signed char)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal2(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed short)1; - cmpVal2(f1, 3); - f1 = (signed short)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal2(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed int)1; - cmpVal2(f1, 3); - f1 = (signed int)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (float)1; - cmpVal2(f1, 3); - f1 = (float)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal2(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (signed long)1; - cmpVal2(f1, 3); - f1 = (signed long)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (double)1; - cmpVal2(f1, 3); - f1 = (double)1 * f1; - cmpVal2(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal2(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal2(f1, 3); - - longlong2 fa1((unsigned char)1); - longlong2 fa2((unsigned char)1, (unsigned char)1); - longlong2 fb1((signed char)1); - longlong2 fb2((signed char)1, (signed char)1); - longlong2 fc1((unsigned short)1); - longlong2 fc2((unsigned short)1, (unsigned short)1); - longlong2 fd1((signed short)1); - longlong2 fd2((signed short)1, (signed short)1); - longlong2 fe1((unsigned int)1); - longlong2 fe2((unsigned int)1, (unsigned int)1); - longlong2 fg1((signed int)1); - longlong2 fg2((signed int)1, (signed int)1); - longlong2 fh1((float)1); - longlong2 fh2((float)1, (float)1); - longlong2 fi1((double)1); - longlong2 fi2((double)1, (double)1); - longlong2 fj1((unsigned long)1); - longlong2 fj2((unsigned long)1, (unsigned long)1); - longlong2 fk1((signed long)1); - longlong2 fk2((signed long)1, (signed long)1); - longlong2 fl1((unsigned long long)1); - longlong2 fl2((unsigned long long)1, (unsigned long long)1); - longlong2 fm1((signed long long)1); - longlong2 fm2((signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestLongLong3() { - long3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1 = f1 * (unsigned char)1; - cmpVal3(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed char)1; - cmpVal3(f1, 3); - f1 = (signed char)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal3(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed short)1; - cmpVal3(f1, 3); - f1 = (signed short)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal3(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed int)1; - cmpVal3(f1, 3); - f1 = (signed int)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (float)1; - cmpVal3(f1, 3); - f1 = (float)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal3(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (signed long)1; - cmpVal3(f1, 3); - f1 = (signed long)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (double)1; - cmpVal3(f1, 3); - f1 = (double)1 * f1; - cmpVal3(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal3(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal3(f1, 3); - - longlong3 fa1((unsigned char)1); - longlong3 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1); - longlong3 fb1((signed char)1); - longlong3 fb2((signed char)1, (signed char)1, (signed char)1); - longlong3 fc1((unsigned short)1); - longlong3 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1); - longlong3 fd1((signed short)1); - longlong3 fd2((signed short)1, (signed short)1, (signed short)1); - longlong3 fe1((unsigned int)1); - longlong3 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1); - longlong3 fg1((signed int)1); - longlong3 fg2((signed int)1, (signed int)1, (signed int)1); - longlong3 fh1((float)1); - longlong3 fh2((float)1, (float)1, (float)1); - longlong3 fi1((double)1); - longlong3 fi2((double)1, (double)1, (double)1); - longlong3 fj1((unsigned long)1); - longlong3 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1); - longlong3 fk1((signed long)1); - longlong3 fk2((signed long)1, (signed long)1, (signed long)1); - longlong3 fl1((unsigned long long)1); - longlong3 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1); - longlong3 fm1((signed long long)1); - longlong3 fm2((signed long long)1, (signed long long)1, (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; -} - -bool TestLongLong4() { - long4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, -3); - assert(!f1 == false); - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f1 = f1 * (unsigned char)1; - cmpVal4(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed char)1; - cmpVal4(f1, 3); - f1 = (signed char)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal4(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed short)1; - cmpVal4(f1, 3); - f1 = (signed short)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal4(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed int)1; - cmpVal4(f1, 3); - f1 = (signed int)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (float)1; - cmpVal4(f1, 3); - f1 = (float)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal4(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (signed long)1; - cmpVal4(f1, 3); - f1 = (signed long)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (double)1; - cmpVal4(f1, 3); - f1 = (double)1 * f1; - cmpVal4(f1, 3); - f1 = f1 * (unsigned long long)1; - cmpVal4(f1, 3); - f1 = (unsigned long long)1 * f1; - cmpVal4(f1, 3); - - longlong4 fa1((unsigned char)1); - longlong4 fa2((unsigned char)1, (unsigned char)1, (unsigned char)1, (unsigned char)1); - longlong4 fb1((signed char)1); - longlong4 fb2((signed char)1, (signed char)1, (signed char)1, (signed char)1); - longlong4 fc1((unsigned short)1); - longlong4 fc2((unsigned short)1, (unsigned short)1, (unsigned short)1, (unsigned short)1); - longlong4 fd1((signed short)1); - longlong4 fd2((signed short)1, (signed short)1, (signed short)1, (signed short)1); - longlong4 fe1((unsigned int)1); - longlong4 fe2((unsigned int)1, (unsigned int)1, (unsigned int)1, (unsigned int)1); - longlong4 fg1((signed int)1); - longlong4 fg2((signed int)1, (signed int)1, (signed int)1, (signed int)1); - longlong4 fh1((float)1); - longlong4 fh2((float)1, (float)1, (float)1, (float)1); - longlong4 fi1((double)1); - longlong4 fi2((double)1, (double)1, (double)1, (double)1); - longlong4 fj1((unsigned long)1); - longlong4 fj2((unsigned long)1, (unsigned long)1, (unsigned long)1, (unsigned long)1); - longlong4 fk1((signed long)1); - longlong4 fk2((signed long)1, (signed long)1, (signed long)1, (signed long)1); - longlong4 fl1((unsigned long long)1); - longlong4 fl2((unsigned long long)1, (unsigned long long)1, (unsigned long long)1, - (unsigned long long)1); - longlong4 fm1((signed long long)1); - longlong4 fm2((signed long long)1, (signed long long)1, (signed long long)1, - (signed long long)1); - - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - assert((f1 == f2) == false); - assert((f1 != f2) == true); - assert((f1 < f2) == true); - assert((f2 > f1) == true); - assert((f1 >= f3) == true); - assert((f1 <= f3) == true); - - assert((f1 && f2) == true); - assert((f1 || f2) == true); - return true; +bool CheckVectorTypes() { + return TestVectorTypes< + char1, char2, char3, char4, + uchar1, uchar2, uchar3, uchar4, + short1, short2, short3, short4, + ushort1, ushort2, ushort3, ushort4, + int1, int2, int3, int4, + uint1, uint2, uint3, uint4, + long1, long2, long3, long4, + ulong1, ulong2, ulong3, ulong4, + longlong1, longlong2, longlong3, longlong4, + ulonglong1, ulonglong2, ulonglong3, ulonglong4, + float1, float2, float3, float4, + double1, double2, double3, double4>(); } int main() { - assert(sizeof(float1) == 4); - assert(sizeof(float2) == 8); - assert(sizeof(float3) == 12); - assert(sizeof(float4) == 16); - assert(TestFloat1() && TestFloat2() && TestFloat3() && TestFloat4() && TestDouble1() && - TestDouble2() && TestDouble3() && TestDouble4() && TestUChar1() && TestUChar2() && - TestUChar3() && TestUChar4() && TestChar1() && TestChar2() && TestChar3() && - TestChar4() && TestUShort1() && TestUShort2() && TestUShort3() && TestUShort4() && - TestShort1() && TestShort2() && TestShort3() && TestShort4() && TestUInt1() && - TestUInt2() && TestUInt3() && TestUInt4() && TestInt1() && TestInt2() && TestInt3() && - TestInt4() && TestULong1() && TestULong2() && TestULong3() && TestULong4() && - TestLong1() && TestLong2() && TestLong3() && TestLong4() && TestULongLong1() && - TestULongLong2() && TestULongLong3() && TestULongLong4() && TestLongLong1() && - TestLongLong2() && TestLongLong3() && TestLongLong4() == true); - passed(); - float1 f1 = make_float1(1.0f); -} + static_assert(sizeof(float1) == 4, ""); + static_assert(sizeof(float2) >= 8, ""); + static_assert(sizeof(float3) >= 12, ""); + static_assert(sizeof(float4) >= 16, ""); + + if (CheckVectorTypes()) { + float1 f1 = make_float1(1.0f); + passed(); + } + else { + failed("Failed some vector test on the host side."); + } +} \ No newline at end of file diff --git a/projects/hip/tests/src/deviceLib/hipVectorTypesDevice.cpp b/projects/hip/tests/src/deviceLib/hipVectorTypesDevice.cpp index 24ac3f4a02..03e8158a4e 100644 --- a/projects/hip/tests/src/deviceLib/hipVectorTypesDevice.cpp +++ b/projects/hip/tests/src/deviceLib/hipVectorTypesDevice.cpp @@ -26,4212 +26,177 @@ THE SOFTWARE. * HIT_END */ -#include #include + +#include "vector_test_common.h" #include "test_common.h" -#define cmpVal1(in, exp) \ - if (in.x != exp) { \ - } -#define cmpVal2(in, exp) \ - if (in.x != exp || in.y != exp) { \ - } +#include +#include +#include -#define cmpVal3(in, exp) \ - if (in.x != exp || in.y != exp || in.z != exp) { \ - } +using namespace std; -#define cmpVal4(in, exp) \ - if (in.x != exp || in.y != exp || in.z != exp || in.w != exp) { \ - } +template< + typename V, + Enable_if_t().x)>{}>* = nullptr> +constexpr +bool integer_unary_tests(const V&, const V&) { + return true; +} -__device__ bool TestUChar1() { - uchar1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); +template< + typename V, + Enable_if_t().x)>{}>* = nullptr> +__device__ +bool integer_unary_tests(V& f1, V& f2) { f1 %= f2; - cmpVal1(f1, 0); + if (f1 != V{0}) return false; + f1 &= f2; - cmpVal1(f1, 0); + if (f1 != V{0}) return false; f1 |= f2; - cmpVal1(f1, 1); + if (f1 != V{1}) return false; f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; + if (f1 != V{0}) return false; + f1 = V{1}; f1 <<= f2; - cmpVal1(f1, 2); + if (f1 != V{2}) return false; f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - + if (f1 != V{1}) return false; f2 = ~f1; - cmpVal1(f2, 253); + return f2 == V{~1}; - f1.x = 3; - f1 = f1 * (unsigned char)1; - cmpVal1(f1, 3); - f1 = (unsigned char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed char)1; - cmpVal1(f1, 3); - f1 = (signed char)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned short)1; - cmpVal1(f1, 3); - f1 = (unsigned short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed short)1; - cmpVal1(f1, 3); - f1 = (signed short)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned int)1; - cmpVal1(f1, 3); - f1 = (unsigned int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed int)1; - cmpVal1(f1, 3); - f1 = (signed int)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (float)1; - cmpVal1(f1, 3); - f1 = (float)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (unsigned long)1; - cmpVal1(f1, 3); - f1 = (unsigned long)1 * f1; - cmpVal1(f1, 3); - f1 = f1 * (signed long)1; - cmpVal1(f1, 3); - f1 = (signed long)1 * f1; - cmpVal1(f1, 3); - - // signed char sc = 1; - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } return true; } -__device__ bool TestUChar2() { - uchar2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); +template< + typename V, + Enable_if_t().x)>{}>* = nullptr> +constexpr +bool integer_binary_tests(const V&, const V&, const V&) { + return true; +} + +template< + typename V, + Enable_if_t().x)>{}>* = nullptr> +__device__ +bool integer_binary_tests(V& f1, V& f2, V& f3) { f3 = f1 % f2; - cmpVal2(f3, 0); + if (f3 != V{0}) return false; f1 = f3 & f2; - cmpVal2(f1, 0); + if (f1 != V{0}) return false; f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; + if (f2 != V{0}) return false; + f1 = V{1}; + f2 = V{2}; f3 = f1 << f2; - cmpVal2(f3, 4); + if (f3 != V{4}) return false; f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, 253); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; + return f2 == V{2}; } -__device__ bool TestUChar3() { - uchar3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); +template +__device__ +bool TestVectorType() { + V f1{1}; + V f2{1}; + V f3 = f1 + f2; + if (f3 != V{2}) return false; f2 = f3 - f1; - cmpVal3(f2, 1); + if (f2 != V{1}) return false; f1 = f2 * f3; - cmpVal3(f1, 2); + if (f1 != V{2}) return false; f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); + if (f2 != V{1}) return false; + if (!integer_binary_tests(f1, f2, f3)) return false; - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; + f1 = V{2}; + f2 = V{1}; f1 += f2; - cmpVal3(f1, 3); + if (f1 != V{3}) return false; f1 -= f2; - cmpVal3(f1, 2); + if (f1 != V{2}) return false; f1 *= f2; - cmpVal3(f1, 2); + if (f1 != V{2}) return false; f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); + if (f1 != V{2}) return false; + if (!integer_unary_tests(f1, f2)) return false; - f1.x = 2; - f1.y = 2; - f1.z = 2; + f1 = V{2}; f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); + if (f1 != V{3}) return false; + if (f2 != V{2}) return false; f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); + if (f2 != V{3}) return false; + if (f1 != V{2}) return false; f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); + if (f1 != V{3}) return false; + if (f2 != V{3}) return false; f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, 253); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUChar4() { - uchar4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, 253); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestChar1() { - char1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (char)253); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestChar2() { - char2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (char)253); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestChar3() { - char3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (char)253); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestChar4() { - char4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (char)253); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUShort1() { - ushort1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (unsigned short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUShort2() { - ushort2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (unsigned short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUShort3() { - ushort3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (unsigned short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUShort4() { - ushort4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (unsigned short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestShort1() { - short1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (signed short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestShort2() { - short2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (signed short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestShort3() { - short3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (signed short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestShort4() { - short4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (signed short)65533); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - - -__device__ bool TestUInt1() { - uint1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (unsigned int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUInt2() { - uint2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (unsigned int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUInt3() { - uint3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (unsigned int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestUInt4() { - uint4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (unsigned int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestInt1() { - int1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, (signed int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestInt2() { - int2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, (signed int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestInt3() { - int3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, (signed int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestInt4() { - int4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, (signed int)4294967293); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestULong1() { - ulong1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, 18446744073709551613UL); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestULong2() { - ulong2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, 18446744073709551613UL); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestULong3() { - ulong3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, 18446744073709551613UL); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestULong4() { - ulong4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, 18446744073709551613UL); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestLong1() { - long1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestLong2() { - long2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestLong3() { - long3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestLong4() { - long4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - - -__device__ bool TestFloat1() { - float1 f1, f2, f3; - // float1 f4(1); - // cmpVal1(f4, 1.0f); - // float1 f5(2.0f); - // cmpVal1(f5, 2.0f); - f1.x = 1.0f; - f2.x = 1.0f; - f3 = f1 + f2; - cmpVal1(f3, 2.0f); - f2 = f3 - f1; - cmpVal1(f2, 1.0f); - f1 = f2 * f3; - cmpVal1(f1, 2.0f); - f2 = f1 / f3; - cmpVal1(f2, 2.0f / 2.0f); - f1 += f2; - cmpVal1(f1, 3.0f); - f1 -= f2; - cmpVal1(f1, 2.0f); - f1 *= f2; - cmpVal1(f1, 2.0f); - f1 /= f2; - cmpVal1(f1, 2.0f); - f2 = f1++; - cmpVal1(f1, 3.0f); - cmpVal1(f2, 2.0f); - f2 = f1--; - cmpVal1(f2, 3.0f); - cmpVal1(f1, 2.0f); - f2 = ++f1; - cmpVal1(f1, 3.0f); - cmpVal1(f2, 3.0f); - f2 = --f1; - cmpVal1(f1, 2.0f); - cmpVal1(f1, 2.0f); - - f1.x = 3.0f; - f2.x = 4.0f; - f3.x = 3.0f; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } + if (f1 != V{2}) return false; + if (f2 != V{2}) return false; + + f1 = V{3}; + f2 = V{4}; + f3 = V{3}; + if (f1 == f2) return false; + if (!(f1 != f2)) return false; return true; } -__device__ bool TestFloat2() { - float2 f1, f2, f3; - f1.x = 1.0f; - f1.y = 1.0f; - f2.x = 1.0f; - f2.y = 1.0f; - f3 = f1 + f2; - cmpVal2(f3, 2.0f); - f2 = f3 - f1; - cmpVal2(f2, 1.0f); - f1 = f2 * f3; - cmpVal2(f1, 2.0f); - f2 = f1 / f3; - cmpVal2(f2, 2.0f / 2.0f); - f1 += f2; - cmpVal2(f1, 3.0f); - f1 -= f2; - cmpVal2(f1, 2.0f); - f1 *= f2; - cmpVal2(f1, 2.0f); - f1 /= f2; - cmpVal2(f1, 2.0f); - - f2 = f1++; - cmpVal2(f1, 3.0f); - cmpVal2(f2, 2.0f); - f2 = f1--; - cmpVal2(f2, 3.0f); - cmpVal2(f1, 2.0f); - f2 = ++f1; - cmpVal2(f1, 3.0f); - cmpVal2(f2, 3.0f); - f2 = --f1; - cmpVal2(f1, 2.0f); - cmpVal2(f1, 2.0f); - - f1.x = 3.0f; - f1.y = 3.0f; - f2.x = 4.0f; - f2.y = 4.0f; - f3.x = 3.0f; - f3.y = 3.0f; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - +template* = nullptr> +__device__ +bool TestVectorTypes() { return true; } -__device__ bool TestFloat3() { - float3 f1, f2, f3; - f1.x = 1.0f; - f1.y = 1.0f; - f1.z = 1.0f; - f2.x = 1.0f; - f2.y = 1.0f; - f2.z = 1.0f; - f3 = f1 + f2; - cmpVal3(f3, 2.0f); - f2 = f3 - f1; - cmpVal3(f2, 1.0f); - f1 = f2 * f3; - cmpVal3(f1, 2.0f); - f2 = f1 / f3; - cmpVal3(f2, 2.0f / 2.0f); - f1 += f2; - cmpVal3(f1, 3.0f); - f1 -= f2; - cmpVal3(f1, 2.0f); - f1 *= f2; - cmpVal3(f1, 2.0f); - f1 /= f2; - f2 = f1++; - cmpVal3(f1, 3.0f); - cmpVal3(f2, 2.0f); - f2 = f1--; - cmpVal3(f2, 3.0f); - cmpVal3(f1, 2.0f); - f2 = ++f1; - cmpVal3(f1, 3.0f); - cmpVal3(f2, 3.0f); - f2 = --f1; - cmpVal3(f1, 2.0f); - cmpVal3(f1, 2.0f); - - f1.x = 3.0f; - f1.y = 3.0f; - f1.z = 3.0f; - f2.x = 4.0f; - f2.y = 4.0f; - f2.z = 4.0f; - f3.x = 3.0f; - f3.y = 3.0f; - f3.z = 3.0f; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - - return true; +template +__device__ +bool TestVectorTypes() { + if (!TestVectorType()) return false; + return TestVectorTypes(); } - -__device__ bool TestFloat4() { - float4 f1, f2, f3; - f1.x = 1.0f; - f1.y = 1.0f; - f1.z = 1.0f; - f1.w = 1.0f; - f2.x = 1.0f; - f2.y = 1.0f; - f2.z = 1.0f; - f2.w = 1.0f; - f3 = f1 + f2; - cmpVal4(f3, 2.0f); - f2 = f3 - f1; - cmpVal4(f2, 1.0f); - f1 = f2 * f3; - cmpVal4(f1, 2.0f); - f2 = f1 / f3; - cmpVal4(f2, 2.0f / 2.0f); - f1 += f2; - cmpVal4(f1, 3.0f); - f1 -= f2; - cmpVal4(f1, 2.0f); - f1 *= f2; - cmpVal4(f1, 2.0f); - f1 /= f2; - f2 = f1++; - cmpVal4(f1, 3.0f); - cmpVal4(f2, 2.0f); - f2 = f1--; - cmpVal4(f2, 3.0f); - cmpVal4(f1, 2.0f); - f2 = ++f1; - cmpVal4(f1, 3.0f); - cmpVal4(f2, 3.0f); - f2 = --f1; - cmpVal4(f1, 2.0f); - cmpVal4(f1, 2.0f); - - f1.x = 3.0f; - f1.y = 3.0f; - f1.z = 3.0f; - f1.w = 3.0f; - f2.x = 4.0f; - f2.y = 4.0f; - f2.z = 4.0f; - f2.w = 4.0f; - f3.x = 3.0f; - f3.y = 3.0f; - f3.z = 3.0f; - f3.w = 3.0f; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - return true; -} - -__device__ bool TestULongLong1() { - ulonglong1 f1, f2, f3; - f1.x = 1; - f2.x = 1; - f3 = f1 + f2; - cmpVal1(f3, 2); - f2 = f3 - f1; - cmpVal1(f2, 1); - f1 = f2 * f3; - cmpVal1(f1, 2); - f2 = f1 / f3; - cmpVal1(f2, 2 / 2); - f3 = f1 % f2; - cmpVal1(f3, 0); - f1 = f3 & f2; - cmpVal1(f1, 0); - f2 = f1 ^ f3; - cmpVal1(f2, 0); - f1.x = 1; - f2.x = 2; - f3 = f1 << f2; - cmpVal1(f3, 4); - f2 = f3 >> f1; - cmpVal1(f2, 2); - - f1.x = 2; - f2.x = 1; - f1 += f2; - cmpVal1(f1, 3); - f1 -= f2; - cmpVal1(f1, 2); - f1 *= f2; - cmpVal1(f1, 2); - f1 /= f2; - cmpVal1(f1, 2); - f1 %= f2; - cmpVal1(f1, 0); - f1 &= f2; - cmpVal1(f1, 0); - f1 |= f2; - cmpVal1(f1, 1); - f1 ^= f2; - cmpVal1(f1, 0); - f1.x = 1; - f1 <<= f2; - cmpVal1(f1, 2); - f1 >>= f2; - cmpVal1(f1, 1); - - f1.x = 2; - f2 = f1++; - cmpVal1(f1, 3); - cmpVal1(f2, 2); - f2 = f1--; - cmpVal1(f2, 3); - cmpVal1(f1, 2); - f2 = ++f1; - cmpVal1(f1, 3); - cmpVal1(f2, 3); - f2 = --f1; - cmpVal1(f1, 2); - cmpVal1(f2, 2); - - f2 = ~f1; - cmpVal1(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f2.x = 4; - f3.x = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - - -__device__ bool TestULongLong2() { - ulonglong2 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f2.x = 1; - f2.y = 1; - f3 = f1 + f2; - cmpVal2(f3, 2); - f2 = f3 - f1; - cmpVal2(f2, 1); - f1 = f2 * f3; - cmpVal2(f1, 2); - f2 = f1 / f3; - cmpVal2(f2, 2 / 2); - f3 = f1 % f2; - cmpVal2(f3, 0); - f1 = f3 & f2; - cmpVal2(f1, 0); - f2 = f1 ^ f3; - cmpVal2(f2, 0); - f1.x = 1; - f1.y = 1; - f2.x = 2; - f2.y = 2; - f3 = f1 << f2; - cmpVal2(f3, 4); - f2 = f3 >> f1; - cmpVal2(f2, 2); - - f1.x = 2; - f1.y = 2; - f2.x = 1; - f2.y = 1; - f1 += f2; - cmpVal2(f1, 3); - f1 -= f2; - cmpVal2(f1, 2); - f1 *= f2; - cmpVal2(f1, 2); - f1 /= f2; - cmpVal2(f1, 2); - f1 %= f2; - cmpVal2(f1, 0); - f1 &= f2; - cmpVal2(f1, 0); - f1 |= f2; - cmpVal2(f1, 1); - f1 ^= f2; - cmpVal2(f1, 0); - f1.x = 1; - f1.y = 1; - f1 <<= f2; - cmpVal2(f1, 2); - f1 >>= f2; - cmpVal2(f1, 1); - - f1.x = 2; - f1.y = 2; - f2 = f1++; - cmpVal2(f1, 3); - cmpVal2(f2, 2); - f2 = f1--; - cmpVal2(f2, 3); - cmpVal2(f1, 2); - f2 = ++f1; - cmpVal2(f1, 3); - cmpVal2(f2, 3); - f2 = --f1; - cmpVal2(f1, 2); - cmpVal2(f2, 2); - - f2 = ~f1; - cmpVal2(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f2.x = 4; - f2.y = 4; - f3.x = 3; - f3.y = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestULongLong3() { - ulonglong3 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f3 = f1 + f2; - cmpVal3(f3, 2); - f2 = f3 - f1; - cmpVal3(f2, 1); - f1 = f2 * f3; - cmpVal3(f1, 2); - f2 = f1 / f3; - cmpVal3(f2, 2 / 2); - f3 = f1 % f2; - cmpVal3(f3, 0); - f1 = f3 & f2; - cmpVal3(f1, 0); - f2 = f1 ^ f3; - cmpVal3(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f3 = f1 << f2; - cmpVal3(f3, 4); - f2 = f3 >> f1; - cmpVal3(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f1 += f2; - cmpVal3(f1, 3); - f1 -= f2; - cmpVal3(f1, 2); - f1 *= f2; - cmpVal3(f1, 2); - f1 /= f2; - cmpVal3(f1, 2); - f1 %= f2; - cmpVal3(f1, 0); - f1 &= f2; - cmpVal3(f1, 0); - f1 |= f2; - cmpVal3(f1, 1); - f1 ^= f2; - cmpVal3(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1 <<= f2; - cmpVal3(f1, 2); - f1 >>= f2; - cmpVal3(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f2 = f1++; - cmpVal3(f1, 3); - cmpVal3(f2, 2); - f2 = f1--; - cmpVal3(f2, 3); - cmpVal3(f1, 2); - f2 = ++f1; - cmpVal3(f1, 3); - cmpVal3(f2, 3); - f2 = --f1; - cmpVal3(f1, 2); - cmpVal3(f2, 2); - - f2 = ~f1; - cmpVal3(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - -__device__ bool TestULongLong4() { - ulonglong4 f1, f2, f3; - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f3 = f1 + f2; - cmpVal4(f3, 2); - f2 = f3 - f1; - cmpVal4(f2, 1); - f1 = f2 * f3; - cmpVal4(f1, 2); - f2 = f1 / f3; - cmpVal4(f2, 2 / 2); - f3 = f1 % f2; - cmpVal4(f3, 0); - f1 = f3 & f2; - cmpVal4(f1, 0); - f2 = f1 ^ f3; - cmpVal4(f2, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f2.x = 2; - f2.y = 2; - f2.z = 2; - f2.w = 2; - f3 = f1 << f2; - cmpVal4(f3, 4); - f2 = f3 >> f1; - cmpVal4(f2, 2); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2.x = 1; - f2.y = 1; - f2.z = 1; - f2.w = 1; - f1 += f2; - cmpVal4(f1, 3); - f1 -= f2; - cmpVal4(f1, 2); - f1 *= f2; - cmpVal4(f1, 2); - f1 /= f2; - cmpVal4(f1, 2); - f1 %= f2; - cmpVal4(f1, 0); - f1 &= f2; - cmpVal4(f1, 0); - f1 |= f2; - cmpVal4(f1, 1); - f1 ^= f2; - cmpVal4(f1, 0); - f1.x = 1; - f1.y = 1; - f1.z = 1; - f1.w = 1; - f1 <<= f2; - cmpVal4(f1, 2); - f1 >>= f2; - cmpVal4(f1, 1); - - f1.x = 2; - f1.y = 2; - f1.z = 2; - f1.w = 2; - f2 = f1++; - cmpVal4(f1, 3); - cmpVal4(f2, 2); - f2 = f1--; - cmpVal4(f2, 3); - cmpVal4(f1, 2); - f2 = ++f1; - cmpVal4(f1, 3); - cmpVal4(f2, 3); - f2 = --f1; - cmpVal4(f1, 2); - cmpVal4(f2, 2); - - f2 = ~f1; - cmpVal4(f2, -3); - if (!f1 == false) { - } - - f1.x = 3; - f1.y = 3; - f1.z = 3; - f1.w = 3; - f2.x = 4; - f2.y = 4; - f2.z = 4; - f2.w = 4; - f3.x = 3; - f3.y = 3; - f3.z = 3; - f3.w = 3; - if ((f1 == f2) == false) { - } - if ((f1 != f2) == true) { - } - if ((f1 < f2) == true) { - } - if ((f2 > f1) == true) { - } - if ((f1 >= f3) == true) { - } - if ((f1 <= f3) == true) { - } - - if ((f1 && f2) == true) { - } - if ((f1 || f2) == true) { - } - return true; -} - - -__global__ void CheckVectorTypes(hipLaunchParm lp, bool* ptr) { - if (TestFloat1() && TestFloat2() && TestFloat3() && TestFloat4() && TestUChar1() && - TestUChar2() && TestUChar3() && TestUChar4() && TestChar1() && TestChar2() && TestChar3() && - TestChar4() && TestUShort1() && TestUShort2() && TestUShort3() && TestUShort4() && - TestShort1() && TestShort2() && TestShort3() && TestShort4() && TestUInt1() && - TestUInt2() && TestUInt3() && TestUInt4() && TestInt1() && TestInt2() && TestInt3() && - TestInt4() && TestULong1() && TestULong2() && TestULong3() && TestULong4() && TestLong1() && - TestLong2() && TestLong3() && TestLong4() && TestULongLong1() && TestULongLong2() && - TestULongLong3() && TestULongLong4() == true) { - ptr[0] = true; - } +__global__ +void CheckVectorTypes(bool* ptr) { + ptr[0] = TestVectorTypes< + char1, char2, char3, char4, + uchar1, uchar2, uchar3, uchar4, + short1, short2, short3, short4, + ushort1, ushort2, ushort3, ushort4, + int1, int2, int3, int4, + uint1, uint2, uint3, uint4, + long1, long2, long3, long4, + ulong1, ulong2, ulong3, ulong4, + longlong1, longlong2, longlong3, longlong4, + ulonglong1, ulonglong2, ulonglong3, ulonglong4, + float1, float2, float3, float4, + double1, double2, double3, double4>(); } int main() { - assert(sizeof(float1) == 4); - assert(sizeof(float2) == 8); - assert(sizeof(float3) == 12); - assert(sizeof(float4) == 16); + static_assert(sizeof(float1) == 4, ""); + static_assert(sizeof(float2) >= 8, ""); + static_assert(sizeof(float3) >= 12, ""); + static_assert(sizeof(float4) >= 16, ""); bool* ptr = nullptr; if (hipMalloc(&ptr, sizeof(bool)) != HIP_SUCCESS) return EXIT_FAILURE; - std::unique_ptr correct{ptr, hipFree}; - hipLaunchKernel(CheckVectorTypes, dim3(1, 1, 1), dim3(1, 1, 1), 0, 0, correct.get()); - bool passed = false; + unique_ptr correct{ptr, hipFree}; + hipLaunchKernelGGL( + CheckVectorTypes, dim3(1, 1, 1), dim3(1, 1, 1), 0, 0, correct.get()); + bool passed = true; if (hipMemcpyDtoH(&passed, correct.get(), sizeof(bool)) != HIP_SUCCESS) { return EXIT_FAILURE; } if (passed == true) { - std::cout << "PASSED" << std::endl; - return 0; - } else - return EXIT_FAILURE; -} + passed(); + } + else { + failed("Failed some vector test."); + } +} \ No newline at end of file diff --git a/projects/hip/tests/src/deviceLib/vector_test_common.h b/projects/hip/tests/src/deviceLib/vector_test_common.h new file mode 100644 index 0000000000..fac5ab84a1 --- /dev/null +++ b/projects/hip/tests/src/deviceLib/vector_test_common.h @@ -0,0 +1,69 @@ +/* +Copyright (c) 2015-2017 Advanced Micro Devices, Inc. All rights reserved. + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. +*/ +#pragma once + +#include + +template +using Enable_if_t = typename std::enable_if::type; + +__host__ __device__ +std::false_type is_vec4(...); +__host__ __device__ +std::false_type is_vec3(...); +__host__ __device__ +std::false_type is_vec2(...); +__host__ __device__ +std::false_type is_vec1(...); + +template +__host__ __device__ +auto is_vec4(const T&) -> decltype(std::declval().xyzw, std::true_type{}); +template< + typename T, Enable_if_t())){}>* = nullptr> +__host__ __device__ +auto is_vec3(const T&) -> decltype(std::declval().xyz, std::true_type{}); +template< + typename T, + Enable_if_t< + !decltype(is_vec4(std::declval())){} && + !decltype(is_vec3(std::declval())){}>* = nullptr> +__host__ __device__ +auto is_vec2(const T&) -> decltype(std::declval().xy, std::true_type{}); +template< + typename T, + Enable_if_t< + !decltype(is_vec4(std::declval())){} && + !decltype(is_vec3(std::declval())){} && + !decltype(is_vec2(std::declval())){}>* = nullptr> +__host__ __device__ +auto is_vec1(const T&) -> decltype(std::declval().x, std::true_type{}); + +template +__host__ __device__ +constexpr +bool is_vec() { + return (dimension == 1) ? decltype(is_vec1(std::declval())){} : + ((dimension == 2) ? decltype(is_vec2(std::declval())){} : + ((dimension == 3) ? decltype(is_vec3(std::declval())){} : + decltype(is_vec4(std::declval())){})); +} \ No newline at end of file