123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335 |
- #version 450
- #extension GL_KHX_shader_explicit_arithmetic_types: enable
- #extension GL_KHX_shader_explicit_arithmetic_types_int8: require
- #extension GL_KHX_shader_explicit_arithmetic_types_int16: require
- #extension GL_KHX_shader_explicit_arithmetic_types_int32: require
- #extension GL_KHX_shader_explicit_arithmetic_types_int64: require
- #extension GL_KHX_shader_explicit_arithmetic_types_float16: require
- #extension GL_KHX_shader_explicit_arithmetic_types_float32: require
- #extension GL_KHX_shader_explicit_arithmetic_types_float64: require
- layout(binding = 0) uniform Uniforms
- {
- uint index;
- };
- layout(std140, binding = 1) uniform Block
- {
- int16_t i16;
- i16vec2 i16v2;
- i16vec3 i16v3;
- i16vec4 i16v4;
- uint16_t u16;
- u16vec2 u16v2;
- u16vec3 u16v3;
- u16vec4 u16v4;
- int32_t i32;
- i32vec2 i32v2;
- i32vec3 i32v3;
- i32vec4 i32v4;
- uint32_t u32;
- u32vec2 u32v2;
- u32vec3 u32v3;
- u32vec4 u32v4;
- } block;
- void main()
- {
- }
- void literal()
- {
- const int64_t i64Const[3] =
- {
- -0x1111111111111111l, // Hex
- -1l, // Dec
- 040000000000l, // Oct
- };
- int64_t i64 = i64Const[index];
- const uint64_t u64Const[] =
- {
- 0xFFFFFFFFFFFFFFFFul, // Hex
- 4294967296UL, // Dec
- 077777777777ul, // Oct
- };
- uint64_t u64 = u64Const[index];
- const int32_t i32Const[3] =
- {
- -0x11111111, // Hex
- -1, // Dec
- 04000000000, // Oct
- };
- int32_t i32 = i32Const[index];
- const uint32_t u32Const[] =
- {
- 0xFFFFFFFF, // Hex
- 4294967295, // Dec
- 017777777777, // Oct
- };
- uint32_t u32 = u32Const[index];
- const int16_t i16Const[3] =
- {
- int16_t(-0x1111), // Hex
- int16_t(-1), // Dec
- int16_t(040000), // Oct
- };
- int16_t i16 = i16Const[index];
- const uint16_t u16Const[] =
- {
- uint16_t(0xFFFF), // Hex
- uint16_t(65535), // Dec
- uint16_t(077777), // Oct
- };
- uint16_t u16 = u16Const[index];
- const int8_t i8Const[3] =
- {
- int8_t(-0x11), // Hex
- int8_t(-1), // Dec
- int8_t(0400), // Oct
- };
- int8_t i8 = i8Const[index];
- const uint8_t u8Const[] =
- {
- uint8_t(0xFF), // Hex
- uint8_t(255), // Dec
- uint8_t(0177), // Oct
- };
- uint8_t u8 = u8Const[index];
- }
- void typeCast8()
- {
- i8vec2 i8v;
- u8vec2 u8v;
- i16vec2 i16v;
- u16vec2 u16v;
- i32vec2 i32v;
- u32vec2 u32v;
- i64vec2 i64v;
- u64vec2 u64v;
- f16vec2 f16v;
- f32vec2 f32v;
- f64vec2 f64v;
- bvec2 bv;
- u8v = i8v; // int8_t -> uint8_t
- i16v = i8v; // int8_t -> int16_t
- i16v = u8v; // uint8_t -> int16_t
- i32v = i8v; // int8_t -> int32_t
- i32v = u8v; // uint8_t -> int32_t
- u32v = i8v; // int8_t -> uint32_t
- i64v = i8v; // int8_t -> int64_t
- u64v = i8v; // int8_t -> uint64_t
- u32v = u8v; // uint8_t -> uint32_t
- i64v = u8v; // uint8_t -> int64_t
- u64v = u8v; // uint8_t -> uint64_t
- f16v = i8v; // int8_t -> float16_t
- f32v = i8v; // int8_t -> float32_t
- f64v = i8v; // int8_t -> float64_t
- f16v = u8v; // uint8_t -> float16_t
- f32v = u8v; // uint8_t -> float32_t
- f64v = u8v; // uint8_t -> float64_t
- i8v = i8vec2(u8v); // uint8_t -> int8_t
- i16v = i16vec2(i8v); // int8_t -> int16_t
- i16v = i16vec2(u8v); // uint8_t -> int16_t
- i32v = i32vec2(i8v); // int8_t -> int32_t
- i32v = i32vec2(u8v); // uint8_t -> int32_t
- i64v = i64vec2(i8v); // int8_t -> int64_t
- u64v = i64vec2(i8v); // int8_t -> uint64_t
- u16v = u16vec2(i8v); // int8_t -> uint16_t
- u16v = u16vec2(u8v); // uint8_t -> uint16_t
- u32v = u32vec2(u8v); // uint8_t -> uint32_t
- i64v = i64vec2(u8v); // uint8_t -> int64_t
- u64v = i64vec2(u8v); // uint8_t -> uint64_t
- f16v = f16vec2(i8v); // int8_t -> float16_t
- f32v = f32vec2(i8v); // int8_t -> float32_t
- f64v = f64vec2(i8v); // int8_t -> float64_t
- f16v = f16vec2(u8v); // uint8_t -> float16_t
- f32v = f32vec2(u8v); // uint8_t -> float32_t
- f64v = f64vec2(u8v); // uint8_t -> float64_t
- i8v = i8vec2(bv); // bool -> int8
- u8v = u8vec2(bv); // bool -> uint8
- bv = bvec2(i8v); // int8 -> bool
- bv = bvec2(u8v); // uint8 -> bool
- }
- void typeCast16()
- {
- i8vec2 i8v;
- u8vec2 u8v;
- i16vec2 i16v;
- u16vec2 u16v;
- i32vec2 i32v;
- u32vec2 u32v;
- i64vec2 i64v;
- u64vec2 u64v;
- f16vec2 f16v;
- f32vec2 f32v;
- f64vec2 f64v;
- bvec2 bv;
- i32v = i16v; // int16_t -> int32_t
- i32v = u16v; // uint16_t -> int32_t
- u16v = i16v; // int16_t -> uint16_t
- u32v = i16v; // int16_t -> uint32_t
- i64v = i16v; // int16_t -> int64_t
- u64v = i16v; // int16_t -> uint64_t
- u32v = u16v; // uint16_t -> uint32_t
- i64v = u16v; // uint16_t -> int64_t
- u64v = u16v; // uint16_t -> uint64_t
- f16v = i16v; // int16_t -> float16_t
- f32v = i16v; // int16_t -> float32_t
- f64v = i16v; // int16_t -> float64_t
- f16v = u16v; // uint16_t -> float16_t
- f32v = u16v; // uint16_t -> float32_t
- f64v = u16v; // uint16_t -> float64_t
- i32v = i32vec2(i16v); // int16_t -> int32_t
- i32v = i32vec2(u16v); // uint16_t -> int32_t
- u16v = u16vec2(i16v); // int16_t -> uint16_t
- u32v = u32vec2(i16v); // int16_t -> uint32_t
- i64v = i64vec2(i16v); // int16_t -> int64_t
- u64v = i64vec2(i16v); // int16_t -> uint64_t
- u32v = u32vec2(u16v); // uint16_t -> uint32_t
- i64v = i64vec2(u16v); // uint16_t -> int64_t
- u64v = i64vec2(u16v); // uint16_t -> uint64_t
- f16v = f16vec2(i16v); // int16_t -> float16_t
- f32v = f32vec2(i16v); // int16_t -> float32_t
- f64v = f64vec2(i16v); // int16_t -> float64_t
- f16v = f16vec2(u16v); // uint16_t -> float16_t
- f32v = f32vec2(u16v); // uint16_t -> float32_t
- f64v = f64vec2(u16v); // uint16_t -> float64_t
- i8v = i8vec2(i16v); // int16_t -> int8_t
- i8v = i8vec2(u16v); // uint16_t -> int8_t
- u8v = u8vec2(i16v); // int16_t -> uint8_t
- u8v = u8vec2(u16v); // uint16_t -> uint8_t
- i16v = u8vec2(u16v); // uint16_t -> int16_t
- i16v = i16vec2(bv); // bool -> int16
- u16v = u16vec2(bv); // bool -> uint16
- bv = bvec2(i16v); // int16 -> bool
- bv = bvec2(u16v); // uint16 -> bool
- }
- void typeCast32()
- {
- i8vec2 i8v;
- u8vec2 u8v;
- i16vec2 i16v;
- u16vec2 u16v;
- i32vec2 i32v;
- u32vec2 u32v;
- i64vec2 i64v;
- u64vec2 u64v;
- f16vec2 f16v;
- f32vec2 f32v;
- f64vec2 f64v;
- bvec2 bv;
- u32v = i32v; // int32_t -> uint32_t
- i64v = i32v; // int32_t -> int64_t
- u64v = i32v; // int32_t -> uint64_t
- i64v = u32v; // uint32_t -> int64_t
- u64v = u32v; // uint32_t -> uint64_t
- f32v = i32v; // int32_t -> float32_t
- f64v = i32v; // int32_t -> float64_t
- f32v = u32v; // uint32_t -> float32_t
- f64v = u32v; // uint32_t -> float64_t
- i8v = i8vec2(i32v); // int32_t -> int8_t
- i8v = i8vec2(u32v); // uint32_t -> int8_t
- i16v = i16vec2(i32v); // int32_t -> int16_t
- i16v = i16vec2(u32v); // uint32_t -> int16_t
- i32v = i32vec2(i32v); // int32_t -> int32_t
- i32v = i32vec2(u32v); // uint32_t -> int32_t
- i64v = i64vec2(i32v); // int32_t -> int64_t
- i64v = i64vec2(u32v); // uint32_t -> int64_t
- u8v = u8vec2(i32v); // int32_t -> uint8_t
- u8v = u8vec2(u32v); // uint32_t -> uint8_t
- u16v = u16vec2(i32v); // int32_t -> uint16_t
- u16v = u16vec2(u32v); // uint32_t -> uint16_t
- u32v = u32vec2(i32v); // int32_t -> uint32_t
- u32v = u32vec2(u32v); // uint32_t -> uint32_t
- u64v = u64vec2(i32v); // int32_t -> uint64_t
- u64v = u64vec2(u32v); // uint32_t -> uint64_t
- f16v = f16vec2(i32v); // int32_t -> float16_t
- f32v = f32vec2(i32v); // int32_t -> float32_t
- f64v = f64vec2(i32v); // int32_t -> float64_t
- f16v = f16vec2(u32v); // uint32_t -> float16_t
- f32v = f32vec2(u32v); // uint32_t -> float32_t
- f64v = f64vec2(u32v); // uint32_t -> float64_t
- i32v = i32vec2(bv); // bool -> int32
- u32v = u32vec2(bv); // bool -> uint32
- bv = bvec2(i32v); // int32 -> bool
- bv = bvec2(u32v); // uint32 -> bool
- }
- void typeCast64()
- {
- i8vec2 i8v;
- u8vec2 u8v;
- i16vec2 i16v;
- u16vec2 u16v;
- i32vec2 i32v;
- u32vec2 u32v;
- i64vec2 i64v;
- u64vec2 u64v;
- f16vec2 f16v;
- f32vec2 f32v;
- f64vec2 f64v;
- bvec2 bv;
- u64v = i64v; // int64_t -> uint64_t
- f64v = i64v; // int64_t -> float64_t
- f64v = u64v; // uint64_t -> float64_t
- i8v = i8vec2(i64v); // int64_t -> int8_t
- i8v = i8vec2(u64v); // uint64_t -> int8_t
- i16v = i16vec2(i64v); // int64_t -> int16_t
- i16v = i16vec2(u64v); // uint64_t -> int16_t
- i32v = i32vec2(i64v); // int64_t -> int32_t
- i32v = i32vec2(u64v); // uint64_t -> int32_t
- i64v = i64vec2(u64v); // uint64_t -> int64_t
- u8v = u8vec2(i64v); // int64_t -> uint8_t
- u8v = u8vec2(u64v); // uint64_t -> uint8_t
- u16v = u16vec2(i64v); // int64_t -> uint16_t
- u16v = u16vec2(u64v); // uint64_t -> uint16_t
- u32v = u32vec2(i64v); // int64_t -> uint32_t
- u32v = u32vec2(u64v); // uint64_t -> uint32_t
- u64v = u64vec2(i64v); // int64_t -> uint64_t
- u64v = u64vec2(u64v); // uint64_t -> uint64_t
- f16v = f16vec2(i64v); // int64_t -> float16_t
- f32v = f32vec2(i64v); // int64_t -> float32_t
- f64v = f64vec2(i64v); // int64_t -> float64_t
- f16v = f16vec2(u64v); // uint64_t -> float16_t
- f32v = f32vec2(u64v); // uint64_t -> float32_t
- f64v = f64vec2(u64v); // uint64_t -> float64_t
- i64v = i64vec2(bv); // bool -> int64
- u64v = u64vec2(bv); // bool -> uint64
- bv = bvec2(i64v); // int64 -> bool
- bv = bvec2(u64v); // uint64 -> bool
- }
|