spv.subgroupArithmetic.comp 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394
  1. #version 450
  2. #extension GL_KHR_shader_subgroup_arithmetic: enable
  3. layout (local_size_x = 8) in;
  4. layout(binding = 0) buffer Buffers
  5. {
  6. vec4 f4;
  7. ivec4 i4;
  8. uvec4 u4;
  9. dvec4 d4;
  10. } data[4];
  11. void main()
  12. {
  13. uint invocation = (gl_SubgroupInvocationID + gl_SubgroupSize) % 4;
  14. data[invocation].f4.x = subgroupAdd(data[0].f4.x);
  15. data[invocation].f4.xy = subgroupAdd(data[1].f4.xy);
  16. data[invocation].f4.xyz = subgroupAdd(data[2].f4.xyz);
  17. data[invocation].f4 = subgroupAdd(data[3].f4);
  18. data[invocation].i4.x = subgroupAdd(data[0].i4.x);
  19. data[invocation].i4.xy = subgroupAdd(data[1].i4.xy);
  20. data[invocation].i4.xyz = subgroupAdd(data[2].i4.xyz);
  21. data[invocation].i4 = subgroupAdd(data[3].i4);
  22. data[invocation].u4.x = subgroupAdd(data[0].u4.x);
  23. data[invocation].u4.xy = subgroupAdd(data[1].u4.xy);
  24. data[invocation].u4.xyz = subgroupAdd(data[2].u4.xyz);
  25. data[invocation].u4 = subgroupAdd(data[3].u4);
  26. data[invocation].d4.x = subgroupAdd(data[0].d4.x);
  27. data[invocation].d4.xy = subgroupAdd(data[1].d4.xy);
  28. data[invocation].d4.xyz = subgroupAdd(data[2].d4.xyz);
  29. data[invocation].d4 = subgroupAdd(data[3].d4);
  30. data[invocation].f4.x = subgroupMul(data[0].f4.x);
  31. data[invocation].f4.xy = subgroupMul(data[1].f4.xy);
  32. data[invocation].f4.xyz = subgroupMul(data[2].f4.xyz);
  33. data[invocation].f4 = subgroupMul(data[3].f4);
  34. data[invocation].i4.x = subgroupMul(data[0].i4.x);
  35. data[invocation].i4.xy = subgroupMul(data[1].i4.xy);
  36. data[invocation].i4.xyz = subgroupMul(data[2].i4.xyz);
  37. data[invocation].i4 = subgroupMul(data[3].i4);
  38. data[invocation].u4.x = subgroupMul(data[0].u4.x);
  39. data[invocation].u4.xy = subgroupMul(data[1].u4.xy);
  40. data[invocation].u4.xyz = subgroupMul(data[2].u4.xyz);
  41. data[invocation].u4 = subgroupMul(data[3].u4);
  42. data[invocation].d4.x = subgroupMul(data[0].d4.x);
  43. data[invocation].d4.xy = subgroupMul(data[1].d4.xy);
  44. data[invocation].d4.xyz = subgroupMul(data[2].d4.xyz);
  45. data[invocation].d4 = subgroupMul(data[3].d4);
  46. data[invocation].f4.x = subgroupMin(data[0].f4.x);
  47. data[invocation].f4.xy = subgroupMin(data[1].f4.xy);
  48. data[invocation].f4.xyz = subgroupMin(data[2].f4.xyz);
  49. data[invocation].f4 = subgroupMin(data[3].f4);
  50. data[invocation].i4.x = subgroupMin(data[0].i4.x);
  51. data[invocation].i4.xy = subgroupMin(data[1].i4.xy);
  52. data[invocation].i4.xyz = subgroupMin(data[2].i4.xyz);
  53. data[invocation].i4 = subgroupMin(data[3].i4);
  54. data[invocation].u4.x = subgroupMin(data[0].u4.x);
  55. data[invocation].u4.xy = subgroupMin(data[1].u4.xy);
  56. data[invocation].u4.xyz = subgroupMin(data[2].u4.xyz);
  57. data[invocation].u4 = subgroupMin(data[3].u4);
  58. data[invocation].d4.x = subgroupMin(data[0].d4.x);
  59. data[invocation].d4.xy = subgroupMin(data[1].d4.xy);
  60. data[invocation].d4.xyz = subgroupMin(data[2].d4.xyz);
  61. data[invocation].d4 = subgroupMin(data[3].d4);
  62. data[invocation].f4.x = subgroupMax(data[0].f4.x);
  63. data[invocation].f4.xy = subgroupMax(data[1].f4.xy);
  64. data[invocation].f4.xyz = subgroupMax(data[2].f4.xyz);
  65. data[invocation].f4 = subgroupMax(data[3].f4);
  66. data[invocation].i4.x = subgroupMax(data[0].i4.x);
  67. data[invocation].i4.xy = subgroupMax(data[1].i4.xy);
  68. data[invocation].i4.xyz = subgroupMax(data[2].i4.xyz);
  69. data[invocation].i4 = subgroupMax(data[3].i4);
  70. data[invocation].u4.x = subgroupMax(data[0].u4.x);
  71. data[invocation].u4.xy = subgroupMax(data[1].u4.xy);
  72. data[invocation].u4.xyz = subgroupMax(data[2].u4.xyz);
  73. data[invocation].u4 = subgroupMax(data[3].u4);
  74. data[invocation].d4.x = subgroupMax(data[0].d4.x);
  75. data[invocation].d4.xy = subgroupMax(data[1].d4.xy);
  76. data[invocation].d4.xyz = subgroupMax(data[2].d4.xyz);
  77. data[invocation].d4 = subgroupMax(data[3].d4);
  78. data[invocation].i4.x = subgroupAnd(data[0].i4.x);
  79. data[invocation].i4.xy = subgroupAnd(data[1].i4.xy);
  80. data[invocation].i4.xyz = subgroupAnd(data[2].i4.xyz);
  81. data[invocation].i4 = subgroupAnd(data[3].i4);
  82. data[invocation].u4.x = subgroupAnd(data[0].u4.x);
  83. data[invocation].u4.xy = subgroupAnd(data[1].u4.xy);
  84. data[invocation].u4.xyz = subgroupAnd(data[2].u4.xyz);
  85. data[invocation].u4 = subgroupAnd(data[3].u4);
  86. data[invocation].i4.x = int(subgroupAnd(data[0].i4.x < 0));
  87. data[invocation].i4.xy = ivec2(subgroupAnd(lessThan(data[1].i4.xy, ivec2(0))));
  88. data[invocation].i4.xyz = ivec3(subgroupAnd(lessThan(data[1].i4.xyz, ivec3(0))));
  89. data[invocation].i4 = ivec4(subgroupAnd(lessThan(data[1].i4, ivec4(0))));
  90. data[invocation].i4.x = subgroupOr(data[0].i4.x);
  91. data[invocation].i4.xy = subgroupOr(data[1].i4.xy);
  92. data[invocation].i4.xyz = subgroupOr(data[2].i4.xyz);
  93. data[invocation].i4 = subgroupOr(data[3].i4);
  94. data[invocation].u4.x = subgroupOr(data[0].u4.x);
  95. data[invocation].u4.xy = subgroupOr(data[1].u4.xy);
  96. data[invocation].u4.xyz = subgroupOr(data[2].u4.xyz);
  97. data[invocation].u4 = subgroupOr(data[3].u4);
  98. data[invocation].i4.x = int(subgroupOr(data[0].i4.x < 0));
  99. data[invocation].i4.xy = ivec2(subgroupOr(lessThan(data[1].i4.xy, ivec2(0))));
  100. data[invocation].i4.xyz = ivec3(subgroupOr(lessThan(data[1].i4.xyz, ivec3(0))));
  101. data[invocation].i4 = ivec4(subgroupOr(lessThan(data[1].i4, ivec4(0))));
  102. data[invocation].i4.x = subgroupXor(data[0].i4.x);
  103. data[invocation].i4.xy = subgroupXor(data[1].i4.xy);
  104. data[invocation].i4.xyz = subgroupXor(data[2].i4.xyz);
  105. data[invocation].i4 = subgroupXor(data[3].i4);
  106. data[invocation].u4.x = subgroupXor(data[0].u4.x);
  107. data[invocation].u4.xy = subgroupXor(data[1].u4.xy);
  108. data[invocation].u4.xyz = subgroupXor(data[2].u4.xyz);
  109. data[invocation].u4 = subgroupXor(data[3].u4);
  110. data[invocation].i4.x = int(subgroupXor(data[0].i4.x < 0));
  111. data[invocation].i4.xy = ivec2(subgroupXor(lessThan(data[1].i4.xy, ivec2(0))));
  112. data[invocation].i4.xyz = ivec3(subgroupXor(lessThan(data[1].i4.xyz, ivec3(0))));
  113. data[invocation].i4 = ivec4(subgroupXor(lessThan(data[1].i4, ivec4(0))));
  114. data[invocation].f4.x = subgroupInclusiveAdd(data[0].f4.x);
  115. data[invocation].f4.xy = subgroupInclusiveAdd(data[1].f4.xy);
  116. data[invocation].f4.xyz = subgroupInclusiveAdd(data[2].f4.xyz);
  117. data[invocation].f4 = subgroupInclusiveAdd(data[3].f4);
  118. data[invocation].i4.x = subgroupInclusiveAdd(data[0].i4.x);
  119. data[invocation].i4.xy = subgroupInclusiveAdd(data[1].i4.xy);
  120. data[invocation].i4.xyz = subgroupInclusiveAdd(data[2].i4.xyz);
  121. data[invocation].i4 = subgroupInclusiveAdd(data[3].i4);
  122. data[invocation].u4.x = subgroupInclusiveAdd(data[0].u4.x);
  123. data[invocation].u4.xy = subgroupInclusiveAdd(data[1].u4.xy);
  124. data[invocation].u4.xyz = subgroupInclusiveAdd(data[2].u4.xyz);
  125. data[invocation].u4 = subgroupInclusiveAdd(data[3].u4);
  126. data[invocation].d4.x = subgroupInclusiveAdd(data[0].d4.x);
  127. data[invocation].d4.xy = subgroupInclusiveAdd(data[1].d4.xy);
  128. data[invocation].d4.xyz = subgroupInclusiveAdd(data[2].d4.xyz);
  129. data[invocation].d4 = subgroupInclusiveAdd(data[3].d4);
  130. data[invocation].f4.x = subgroupInclusiveMul(data[0].f4.x);
  131. data[invocation].f4.xy = subgroupInclusiveMul(data[1].f4.xy);
  132. data[invocation].f4.xyz = subgroupInclusiveMul(data[2].f4.xyz);
  133. data[invocation].f4 = subgroupInclusiveMul(data[3].f4);
  134. data[invocation].i4.x = subgroupInclusiveMul(data[0].i4.x);
  135. data[invocation].i4.xy = subgroupInclusiveMul(data[1].i4.xy);
  136. data[invocation].i4.xyz = subgroupInclusiveMul(data[2].i4.xyz);
  137. data[invocation].i4 = subgroupInclusiveMul(data[3].i4);
  138. data[invocation].u4.x = subgroupInclusiveMul(data[0].u4.x);
  139. data[invocation].u4.xy = subgroupInclusiveMul(data[1].u4.xy);
  140. data[invocation].u4.xyz = subgroupInclusiveMul(data[2].u4.xyz);
  141. data[invocation].u4 = subgroupInclusiveMul(data[3].u4);
  142. data[invocation].d4.x = subgroupInclusiveMul(data[0].d4.x);
  143. data[invocation].d4.xy = subgroupInclusiveMul(data[1].d4.xy);
  144. data[invocation].d4.xyz = subgroupInclusiveMul(data[2].d4.xyz);
  145. data[invocation].d4 = subgroupInclusiveMul(data[3].d4);
  146. data[invocation].f4.x = subgroupInclusiveMin(data[0].f4.x);
  147. data[invocation].f4.xy = subgroupInclusiveMin(data[1].f4.xy);
  148. data[invocation].f4.xyz = subgroupInclusiveMin(data[2].f4.xyz);
  149. data[invocation].f4 = subgroupInclusiveMin(data[3].f4);
  150. data[invocation].i4.x = subgroupInclusiveMin(data[0].i4.x);
  151. data[invocation].i4.xy = subgroupInclusiveMin(data[1].i4.xy);
  152. data[invocation].i4.xyz = subgroupInclusiveMin(data[2].i4.xyz);
  153. data[invocation].i4 = subgroupInclusiveMin(data[3].i4);
  154. data[invocation].u4.x = subgroupInclusiveMin(data[0].u4.x);
  155. data[invocation].u4.xy = subgroupInclusiveMin(data[1].u4.xy);
  156. data[invocation].u4.xyz = subgroupInclusiveMin(data[2].u4.xyz);
  157. data[invocation].u4 = subgroupInclusiveMin(data[3].u4);
  158. data[invocation].d4.x = subgroupInclusiveMin(data[0].d4.x);
  159. data[invocation].d4.xy = subgroupInclusiveMin(data[1].d4.xy);
  160. data[invocation].d4.xyz = subgroupInclusiveMin(data[2].d4.xyz);
  161. data[invocation].d4 = subgroupInclusiveMin(data[3].d4);
  162. data[invocation].f4.x = subgroupInclusiveMax(data[0].f4.x);
  163. data[invocation].f4.xy = subgroupInclusiveMax(data[1].f4.xy);
  164. data[invocation].f4.xyz = subgroupInclusiveMax(data[2].f4.xyz);
  165. data[invocation].f4 = subgroupInclusiveMax(data[3].f4);
  166. data[invocation].i4.x = subgroupInclusiveMax(data[0].i4.x);
  167. data[invocation].i4.xy = subgroupInclusiveMax(data[1].i4.xy);
  168. data[invocation].i4.xyz = subgroupInclusiveMax(data[2].i4.xyz);
  169. data[invocation].i4 = subgroupInclusiveMax(data[3].i4);
  170. data[invocation].u4.x = subgroupInclusiveMax(data[0].u4.x);
  171. data[invocation].u4.xy = subgroupInclusiveMax(data[1].u4.xy);
  172. data[invocation].u4.xyz = subgroupInclusiveMax(data[2].u4.xyz);
  173. data[invocation].u4 = subgroupInclusiveMax(data[3].u4);
  174. data[invocation].d4.x = subgroupInclusiveMax(data[0].d4.x);
  175. data[invocation].d4.xy = subgroupInclusiveMax(data[1].d4.xy);
  176. data[invocation].d4.xyz = subgroupInclusiveMax(data[2].d4.xyz);
  177. data[invocation].d4 = subgroupInclusiveMax(data[3].d4);
  178. data[invocation].i4.x = subgroupInclusiveAnd(data[0].i4.x);
  179. data[invocation].i4.xy = subgroupInclusiveAnd(data[1].i4.xy);
  180. data[invocation].i4.xyz = subgroupInclusiveAnd(data[2].i4.xyz);
  181. data[invocation].i4 = subgroupInclusiveAnd(data[3].i4);
  182. data[invocation].u4.x = subgroupInclusiveAnd(data[0].u4.x);
  183. data[invocation].u4.xy = subgroupInclusiveAnd(data[1].u4.xy);
  184. data[invocation].u4.xyz = subgroupInclusiveAnd(data[2].u4.xyz);
  185. data[invocation].u4 = subgroupInclusiveAnd(data[3].u4);
  186. data[invocation].i4.x = int(subgroupInclusiveAnd(data[0].i4.x < 0));
  187. data[invocation].i4.xy = ivec2(subgroupInclusiveAnd(lessThan(data[1].i4.xy, ivec2(0))));
  188. data[invocation].i4.xyz = ivec3(subgroupInclusiveAnd(lessThan(data[1].i4.xyz, ivec3(0))));
  189. data[invocation].i4 = ivec4(subgroupInclusiveAnd(lessThan(data[1].i4, ivec4(0))));
  190. data[invocation].i4.x = subgroupInclusiveOr(data[0].i4.x);
  191. data[invocation].i4.xy = subgroupInclusiveOr(data[1].i4.xy);
  192. data[invocation].i4.xyz = subgroupInclusiveOr(data[2].i4.xyz);
  193. data[invocation].i4 = subgroupInclusiveOr(data[3].i4);
  194. data[invocation].u4.x = subgroupInclusiveOr(data[0].u4.x);
  195. data[invocation].u4.xy = subgroupInclusiveOr(data[1].u4.xy);
  196. data[invocation].u4.xyz = subgroupInclusiveOr(data[2].u4.xyz);
  197. data[invocation].u4 = subgroupInclusiveOr(data[3].u4);
  198. data[invocation].i4.x = int(subgroupInclusiveOr(data[0].i4.x < 0));
  199. data[invocation].i4.xy = ivec2(subgroupInclusiveOr(lessThan(data[1].i4.xy, ivec2(0))));
  200. data[invocation].i4.xyz = ivec3(subgroupInclusiveOr(lessThan(data[1].i4.xyz, ivec3(0))));
  201. data[invocation].i4 = ivec4(subgroupInclusiveOr(lessThan(data[1].i4, ivec4(0))));
  202. data[invocation].i4.x = subgroupInclusiveXor(data[0].i4.x);
  203. data[invocation].i4.xy = subgroupInclusiveXor(data[1].i4.xy);
  204. data[invocation].i4.xyz = subgroupInclusiveXor(data[2].i4.xyz);
  205. data[invocation].i4 = subgroupInclusiveXor(data[3].i4);
  206. data[invocation].u4.x = subgroupInclusiveXor(data[0].u4.x);
  207. data[invocation].u4.xy = subgroupInclusiveXor(data[1].u4.xy);
  208. data[invocation].u4.xyz = subgroupInclusiveXor(data[2].u4.xyz);
  209. data[invocation].u4 = subgroupInclusiveXor(data[3].u4);
  210. data[invocation].i4.x = int(subgroupInclusiveXor(data[0].i4.x < 0));
  211. data[invocation].i4.xy = ivec2(subgroupInclusiveXor(lessThan(data[1].i4.xy, ivec2(0))));
  212. data[invocation].i4.xyz = ivec3(subgroupInclusiveXor(lessThan(data[1].i4.xyz, ivec3(0))));
  213. data[invocation].i4 = ivec4(subgroupInclusiveXor(lessThan(data[1].i4, ivec4(0))));
  214. data[invocation].f4.x = subgroupExclusiveAdd(data[0].f4.x);
  215. data[invocation].f4.xy = subgroupExclusiveAdd(data[1].f4.xy);
  216. data[invocation].f4.xyz = subgroupExclusiveAdd(data[2].f4.xyz);
  217. data[invocation].f4 = subgroupExclusiveAdd(data[3].f4);
  218. data[invocation].i4.x = subgroupExclusiveAdd(data[0].i4.x);
  219. data[invocation].i4.xy = subgroupExclusiveAdd(data[1].i4.xy);
  220. data[invocation].i4.xyz = subgroupExclusiveAdd(data[2].i4.xyz);
  221. data[invocation].i4 = subgroupExclusiveAdd(data[3].i4);
  222. data[invocation].u4.x = subgroupExclusiveAdd(data[0].u4.x);
  223. data[invocation].u4.xy = subgroupExclusiveAdd(data[1].u4.xy);
  224. data[invocation].u4.xyz = subgroupExclusiveAdd(data[2].u4.xyz);
  225. data[invocation].u4 = subgroupExclusiveAdd(data[3].u4);
  226. data[invocation].d4.x = subgroupExclusiveAdd(data[0].d4.x);
  227. data[invocation].d4.xy = subgroupExclusiveAdd(data[1].d4.xy);
  228. data[invocation].d4.xyz = subgroupExclusiveAdd(data[2].d4.xyz);
  229. data[invocation].d4 = subgroupExclusiveAdd(data[3].d4);
  230. data[invocation].f4.x = subgroupExclusiveMul(data[0].f4.x);
  231. data[invocation].f4.xy = subgroupExclusiveMul(data[1].f4.xy);
  232. data[invocation].f4.xyz = subgroupExclusiveMul(data[2].f4.xyz);
  233. data[invocation].f4 = subgroupExclusiveMul(data[3].f4);
  234. data[invocation].i4.x = subgroupExclusiveMul(data[0].i4.x);
  235. data[invocation].i4.xy = subgroupExclusiveMul(data[1].i4.xy);
  236. data[invocation].i4.xyz = subgroupExclusiveMul(data[2].i4.xyz);
  237. data[invocation].i4 = subgroupExclusiveMul(data[3].i4);
  238. data[invocation].u4.x = subgroupExclusiveMul(data[0].u4.x);
  239. data[invocation].u4.xy = subgroupExclusiveMul(data[1].u4.xy);
  240. data[invocation].u4.xyz = subgroupExclusiveMul(data[2].u4.xyz);
  241. data[invocation].u4 = subgroupExclusiveMul(data[3].u4);
  242. data[invocation].d4.x = subgroupExclusiveMul(data[0].d4.x);
  243. data[invocation].d4.xy = subgroupExclusiveMul(data[1].d4.xy);
  244. data[invocation].d4.xyz = subgroupExclusiveMul(data[2].d4.xyz);
  245. data[invocation].d4 = subgroupExclusiveMul(data[3].d4);
  246. data[invocation].f4.x = subgroupExclusiveMin(data[0].f4.x);
  247. data[invocation].f4.xy = subgroupExclusiveMin(data[1].f4.xy);
  248. data[invocation].f4.xyz = subgroupExclusiveMin(data[2].f4.xyz);
  249. data[invocation].f4 = subgroupExclusiveMin(data[3].f4);
  250. data[invocation].i4.x = subgroupExclusiveMin(data[0].i4.x);
  251. data[invocation].i4.xy = subgroupExclusiveMin(data[1].i4.xy);
  252. data[invocation].i4.xyz = subgroupExclusiveMin(data[2].i4.xyz);
  253. data[invocation].i4 = subgroupExclusiveMin(data[3].i4);
  254. data[invocation].u4.x = subgroupExclusiveMin(data[0].u4.x);
  255. data[invocation].u4.xy = subgroupExclusiveMin(data[1].u4.xy);
  256. data[invocation].u4.xyz = subgroupExclusiveMin(data[2].u4.xyz);
  257. data[invocation].u4 = subgroupExclusiveMin(data[3].u4);
  258. data[invocation].d4.x = subgroupExclusiveMin(data[0].d4.x);
  259. data[invocation].d4.xy = subgroupExclusiveMin(data[1].d4.xy);
  260. data[invocation].d4.xyz = subgroupExclusiveMin(data[2].d4.xyz);
  261. data[invocation].d4 = subgroupExclusiveMin(data[3].d4);
  262. data[invocation].f4.x = subgroupExclusiveMax(data[0].f4.x);
  263. data[invocation].f4.xy = subgroupExclusiveMax(data[1].f4.xy);
  264. data[invocation].f4.xyz = subgroupExclusiveMax(data[2].f4.xyz);
  265. data[invocation].f4 = subgroupExclusiveMax(data[3].f4);
  266. data[invocation].i4.x = subgroupExclusiveMax(data[0].i4.x);
  267. data[invocation].i4.xy = subgroupExclusiveMax(data[1].i4.xy);
  268. data[invocation].i4.xyz = subgroupExclusiveMax(data[2].i4.xyz);
  269. data[invocation].i4 = subgroupExclusiveMax(data[3].i4);
  270. data[invocation].u4.x = subgroupExclusiveMax(data[0].u4.x);
  271. data[invocation].u4.xy = subgroupExclusiveMax(data[1].u4.xy);
  272. data[invocation].u4.xyz = subgroupExclusiveMax(data[2].u4.xyz);
  273. data[invocation].u4 = subgroupExclusiveMax(data[3].u4);
  274. data[invocation].d4.x = subgroupExclusiveMax(data[0].d4.x);
  275. data[invocation].d4.xy = subgroupExclusiveMax(data[1].d4.xy);
  276. data[invocation].d4.xyz = subgroupExclusiveMax(data[2].d4.xyz);
  277. data[invocation].d4 = subgroupExclusiveMax(data[3].d4);
  278. data[invocation].i4.x = subgroupExclusiveAnd(data[0].i4.x);
  279. data[invocation].i4.xy = subgroupExclusiveAnd(data[1].i4.xy);
  280. data[invocation].i4.xyz = subgroupExclusiveAnd(data[2].i4.xyz);
  281. data[invocation].i4 = subgroupExclusiveAnd(data[3].i4);
  282. data[invocation].u4.x = subgroupExclusiveAnd(data[0].u4.x);
  283. data[invocation].u4.xy = subgroupExclusiveAnd(data[1].u4.xy);
  284. data[invocation].u4.xyz = subgroupExclusiveAnd(data[2].u4.xyz);
  285. data[invocation].u4 = subgroupExclusiveAnd(data[3].u4);
  286. data[invocation].i4.x = int(subgroupExclusiveAnd(data[0].i4.x < 0));
  287. data[invocation].i4.xy = ivec2(subgroupExclusiveAnd(lessThan(data[1].i4.xy, ivec2(0))));
  288. data[invocation].i4.xyz = ivec3(subgroupExclusiveAnd(lessThan(data[1].i4.xyz, ivec3(0))));
  289. data[invocation].i4 = ivec4(subgroupExclusiveAnd(lessThan(data[1].i4, ivec4(0))));
  290. data[invocation].i4.x = subgroupExclusiveOr(data[0].i4.x);
  291. data[invocation].i4.xy = subgroupExclusiveOr(data[1].i4.xy);
  292. data[invocation].i4.xyz = subgroupExclusiveOr(data[2].i4.xyz);
  293. data[invocation].i4 = subgroupExclusiveOr(data[3].i4);
  294. data[invocation].u4.x = subgroupExclusiveOr(data[0].u4.x);
  295. data[invocation].u4.xy = subgroupExclusiveOr(data[1].u4.xy);
  296. data[invocation].u4.xyz = subgroupExclusiveOr(data[2].u4.xyz);
  297. data[invocation].u4 = subgroupExclusiveOr(data[3].u4);
  298. data[invocation].i4.x = int(subgroupExclusiveOr(data[0].i4.x < 0));
  299. data[invocation].i4.xy = ivec2(subgroupExclusiveOr(lessThan(data[1].i4.xy, ivec2(0))));
  300. data[invocation].i4.xyz = ivec3(subgroupExclusiveOr(lessThan(data[1].i4.xyz, ivec3(0))));
  301. data[invocation].i4 = ivec4(subgroupExclusiveOr(lessThan(data[1].i4, ivec4(0))));
  302. data[invocation].i4.x = subgroupExclusiveXor(data[0].i4.x);
  303. data[invocation].i4.xy = subgroupExclusiveXor(data[1].i4.xy);
  304. data[invocation].i4.xyz = subgroupExclusiveXor(data[2].i4.xyz);
  305. data[invocation].i4 = subgroupExclusiveXor(data[3].i4);
  306. data[invocation].u4.x = subgroupExclusiveXor(data[0].u4.x);
  307. data[invocation].u4.xy = subgroupExclusiveXor(data[1].u4.xy);
  308. data[invocation].u4.xyz = subgroupExclusiveXor(data[2].u4.xyz);
  309. data[invocation].u4 = subgroupExclusiveXor(data[3].u4);
  310. data[invocation].i4.x = int(subgroupExclusiveXor(data[0].i4.x < 0));
  311. data[invocation].i4.xy = ivec2(subgroupExclusiveXor(lessThan(data[1].i4.xy, ivec2(0))));
  312. data[invocation].i4.xyz = ivec3(subgroupExclusiveXor(lessThan(data[1].i4.xyz, ivec3(0))));
  313. data[invocation].i4 = ivec4(subgroupExclusiveXor(lessThan(data[1].i4, ivec4(0))));
  314. }