binary-op.arithmetic.matrix.hlsl 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. // Run: %dxc -T vs_6_0 -E main
  2. void main() {
  3. // CHECK-LABEL: %bb_entry = OpLabel
  4. // 1x1
  5. float1x1 a, b, c;
  6. // CHECK: [[a0:%\d+]] = OpLoad %float %a
  7. // CHECK-NEXT: [[b0:%\d+]] = OpLoad %float %b
  8. // CHECK-NEXT: [[c0:%\d+]] = OpFAdd %float [[a0]] [[b0]]
  9. // CHECK-NEXT: OpStore %c [[c0]]
  10. c = a + b;
  11. // CHECK-NEXT: [[a1:%\d+]] = OpLoad %float %a
  12. // CHECK-NEXT: [[b1:%\d+]] = OpLoad %float %b
  13. // CHECK-NEXT: [[c1:%\d+]] = OpFSub %float [[a1]] [[b1]]
  14. // CHECK-NEXT: OpStore %c [[c1]]
  15. c = a - b;
  16. // CHECK-NEXT: [[a2:%\d+]] = OpLoad %float %a
  17. // CHECK-NEXT: [[b2:%\d+]] = OpLoad %float %b
  18. // CHECK-NEXT: [[c2:%\d+]] = OpFMul %float [[a2]] [[b2]]
  19. // CHECK-NEXT: OpStore %c [[c2]]
  20. c = a * b;
  21. // CHECK-NEXT: [[a3:%\d+]] = OpLoad %float %a
  22. // CHECK-NEXT: [[b3:%\d+]] = OpLoad %float %b
  23. // CHECK-NEXT: [[c3:%\d+]] = OpFDiv %float [[a3]] [[b3]]
  24. // CHECK-NEXT: OpStore %c [[c3]]
  25. c = a / b;
  26. // CHECK-NEXT: [[a4:%\d+]] = OpLoad %float %a
  27. // CHECK-NEXT: [[b4:%\d+]] = OpLoad %float %b
  28. // CHECK-NEXT: [[c4:%\d+]] = OpFRem %float [[a4]] [[b4]]
  29. // CHECK-NEXT: OpStore %c [[c4]]
  30. c = a % b;
  31. // Mx1
  32. float2x1 h, i, j;
  33. // CHECK-NEXT: [[h0:%\d+]] = OpLoad %v2float %h
  34. // CHECK-NEXT: [[i0:%\d+]] = OpLoad %v2float %i
  35. // CHECK-NEXT: [[j0:%\d+]] = OpFAdd %v2float [[h0]] [[i0]]
  36. // CHECK-NEXT: OpStore %j [[j0]]
  37. j = h + i;
  38. // CHECK-NEXT: [[h1:%\d+]] = OpLoad %v2float %h
  39. // CHECK-NEXT: [[i1:%\d+]] = OpLoad %v2float %i
  40. // CHECK-NEXT: [[j1:%\d+]] = OpFSub %v2float [[h1]] [[i1]]
  41. // CHECK-NEXT: OpStore %j [[j1]]
  42. j = h - i;
  43. // CHECK-NEXT: [[h2:%\d+]] = OpLoad %v2float %h
  44. // CHECK-NEXT: [[i2:%\d+]] = OpLoad %v2float %i
  45. // CHECK-NEXT: [[j2:%\d+]] = OpFMul %v2float [[h2]] [[i2]]
  46. // CHECK-NEXT: OpStore %j [[j2]]
  47. j = h * i;
  48. // CHECK-NEXT: [[h3:%\d+]] = OpLoad %v2float %h
  49. // CHECK-NEXT: [[i3:%\d+]] = OpLoad %v2float %i
  50. // CHECK-NEXT: [[j3:%\d+]] = OpFDiv %v2float [[h3]] [[i3]]
  51. // CHECK-NEXT: OpStore %j [[j3]]
  52. j = h / i;
  53. // CHECK-NEXT: [[h4:%\d+]] = OpLoad %v2float %h
  54. // CHECK-NEXT: [[i4:%\d+]] = OpLoad %v2float %i
  55. // CHECK-NEXT: [[j4:%\d+]] = OpFRem %v2float [[h4]] [[i4]]
  56. // CHECK-NEXT: OpStore %j [[j4]]
  57. j = h % i;
  58. // 1xN
  59. float1x3 o, p, q;
  60. // CHECK-NEXT: [[o0:%\d+]] = OpLoad %v3float %o
  61. // CHECK-NEXT: [[p0:%\d+]] = OpLoad %v3float %p
  62. // CHECK-NEXT: [[q0:%\d+]] = OpFAdd %v3float [[o0]] [[p0]]
  63. // CHECK-NEXT: OpStore %q [[q0]]
  64. q = o + p;
  65. // CHECK-NEXT: [[o1:%\d+]] = OpLoad %v3float %o
  66. // CHECK-NEXT: [[p1:%\d+]] = OpLoad %v3float %p
  67. // CHECK-NEXT: [[q1:%\d+]] = OpFSub %v3float [[o1]] [[p1]]
  68. // CHECK-NEXT: OpStore %q [[q1]]
  69. q = o - p;
  70. // CHECK-NEXT: [[o2:%\d+]] = OpLoad %v3float %o
  71. // CHECK-NEXT: [[p2:%\d+]] = OpLoad %v3float %p
  72. // CHECK-NEXT: [[q2:%\d+]] = OpFMul %v3float [[o2]] [[p2]]
  73. // CHECK-NEXT: OpStore %q [[q2]]
  74. q = o * p;
  75. // CHECK-NEXT: [[o3:%\d+]] = OpLoad %v3float %o
  76. // CHECK-NEXT: [[p3:%\d+]] = OpLoad %v3float %p
  77. // CHECK-NEXT: [[q3:%\d+]] = OpFDiv %v3float [[o3]] [[p3]]
  78. // CHECK-NEXT: OpStore %q [[q3]]
  79. q = o / p;
  80. // CHECK-NEXT: [[o4:%\d+]] = OpLoad %v3float %o
  81. // CHECK-NEXT: [[p4:%\d+]] = OpLoad %v3float %p
  82. // CHECK-NEXT: [[q4:%\d+]] = OpFRem %v3float [[o4]] [[p4]]
  83. // CHECK-NEXT: OpStore %q [[q4]]
  84. q = o % p;
  85. // MxN
  86. float2x3 r, s, t;
  87. // CHECK-NEXT: [[r0:%\d+]] = OpLoad %mat2v3float %r
  88. // CHECK-NEXT: [[s0:%\d+]] = OpLoad %mat2v3float %s
  89. // CHECK-NEXT: [[r0v0:%\d+]] = OpCompositeExtract %v3float [[r0]] 0
  90. // CHECK-NEXT: [[s0v0:%\d+]] = OpCompositeExtract %v3float [[s0]] 0
  91. // CHECK-NEXT: [[t0v0:%\d+]] = OpFAdd %v3float [[r0v0]] [[s0v0]]
  92. // CHECK-NEXT: [[r0v1:%\d+]] = OpCompositeExtract %v3float [[r0]] 1
  93. // CHECK-NEXT: [[s0v1:%\d+]] = OpCompositeExtract %v3float [[s0]] 1
  94. // CHECK-NEXT: [[t0v1:%\d+]] = OpFAdd %v3float [[r0v1]] [[s0v1]]
  95. // CHECK-NEXT: [[t0:%\d+]] = OpCompositeConstruct %mat2v3float [[t0v0]] [[t0v1]]
  96. // CHECK-NEXT: OpStore %t [[t0]]
  97. t = r + s;
  98. // CHECK-NEXT: [[r1:%\d+]] = OpLoad %mat2v3float %r
  99. // CHECK-NEXT: [[s1:%\d+]] = OpLoad %mat2v3float %s
  100. // CHECK-NEXT: [[r1v0:%\d+]] = OpCompositeExtract %v3float [[r1]] 0
  101. // CHECK-NEXT: [[s1v0:%\d+]] = OpCompositeExtract %v3float [[s1]] 0
  102. // CHECK-NEXT: [[t1v0:%\d+]] = OpFSub %v3float [[r1v0]] [[s1v0]]
  103. // CHECK-NEXT: [[r1v1:%\d+]] = OpCompositeExtract %v3float [[r1]] 1
  104. // CHECK-NEXT: [[s1v1:%\d+]] = OpCompositeExtract %v3float [[s1]] 1
  105. // CHECK-NEXT: [[t1v1:%\d+]] = OpFSub %v3float [[r1v1]] [[s1v1]]
  106. // CHECK-NEXT: [[t1:%\d+]] = OpCompositeConstruct %mat2v3float [[t1v0]] [[t1v1]]
  107. // CHECK-NEXT: OpStore %t [[t1]]
  108. t = r - s;
  109. // CHECK-NEXT: [[r2:%\d+]] = OpLoad %mat2v3float %r
  110. // CHECK-NEXT: [[s2:%\d+]] = OpLoad %mat2v3float %s
  111. // CHECK-NEXT: [[r2v0:%\d+]] = OpCompositeExtract %v3float [[r2]] 0
  112. // CHECK-NEXT: [[s2v0:%\d+]] = OpCompositeExtract %v3float [[s2]] 0
  113. // CHECK-NEXT: [[t2v0:%\d+]] = OpFMul %v3float [[r2v0]] [[s2v0]]
  114. // CHECK-NEXT: [[r2v1:%\d+]] = OpCompositeExtract %v3float [[r2]] 1
  115. // CHECK-NEXT: [[s2v1:%\d+]] = OpCompositeExtract %v3float [[s2]] 1
  116. // CHECK-NEXT: [[t2v1:%\d+]] = OpFMul %v3float [[r2v1]] [[s2v1]]
  117. // CHECK-NEXT: [[t2:%\d+]] = OpCompositeConstruct %mat2v3float [[t2v0]] [[t2v1]]
  118. // CHECK-NEXT: OpStore %t [[t2]]
  119. t = r * s;
  120. // CHECK-NEXT: [[r3:%\d+]] = OpLoad %mat2v3float %r
  121. // CHECK-NEXT: [[s3:%\d+]] = OpLoad %mat2v3float %s
  122. // CHECK-NEXT: [[r3v0:%\d+]] = OpCompositeExtract %v3float [[r3]] 0
  123. // CHECK-NEXT: [[s3v0:%\d+]] = OpCompositeExtract %v3float [[s3]] 0
  124. // CHECK-NEXT: [[t3v0:%\d+]] = OpFDiv %v3float [[r3v0]] [[s3v0]]
  125. // CHECK-NEXT: [[r3v1:%\d+]] = OpCompositeExtract %v3float [[r3]] 1
  126. // CHECK-NEXT: [[s3v1:%\d+]] = OpCompositeExtract %v3float [[s3]] 1
  127. // CHECK-NEXT: [[t3v1:%\d+]] = OpFDiv %v3float [[r3v1]] [[s3v1]]
  128. // CHECK-NEXT: [[t3:%\d+]] = OpCompositeConstruct %mat2v3float [[t3v0]] [[t3v1]]
  129. // CHECK-NEXT: OpStore %t [[t3]]
  130. t = r / s;
  131. // CHECK-NEXT: [[r4:%\d+]] = OpLoad %mat2v3float %r
  132. // CHECK-NEXT: [[s4:%\d+]] = OpLoad %mat2v3float %s
  133. // CHECK-NEXT: [[r4v0:%\d+]] = OpCompositeExtract %v3float [[r4]] 0
  134. // CHECK-NEXT: [[s4v0:%\d+]] = OpCompositeExtract %v3float [[s4]] 0
  135. // CHECK-NEXT: [[t4v0:%\d+]] = OpFRem %v3float [[r4v0]] [[s4v0]]
  136. // CHECK-NEXT: [[r4v1:%\d+]] = OpCompositeExtract %v3float [[r4]] 1
  137. // CHECK-NEXT: [[s4v1:%\d+]] = OpCompositeExtract %v3float [[s4]] 1
  138. // CHECK-NEXT: [[t4v1:%\d+]] = OpFRem %v3float [[r4v1]] [[s4v1]]
  139. // CHECK-NEXT: [[t4:%\d+]] = OpCompositeConstruct %mat2v3float [[t4v0]] [[t4v1]]
  140. // CHECK-NEXT: OpStore %t [[t4]]
  141. t = r % s;
  142. }