//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16.58 on Tue Jan 31 01:12:50 2023
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float   xy
// COLOR                    0   xyzw        1     NONE   float   xyzw
// COLOR                    1   xyzw        2     NONE   float   xyzw
// TEXCOORD                 0   xyzw        3     NONE   float   xyzw
// TEXCOORD                 1   xyz         4     NONE   float   xyz
// TEXCOORD                 2   xy          5     NONE   float   xy
// TEXCOORD                 3     zw        5     NONE   float     zw
// TEXCOORD                 4   xy          6     NONE   float   xy
// TEXCOORD                 7     zw        6     NONE   float     zw
// TEXCOORD                 8   xy          7     NONE   float   xy
// TEXCOORD                 9     zw        7     NONE   float     zw
// TEXCOORD                 6   xy          8     NONE   float   xy
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_TARGET                0   xyzw        0   TARGET   float   xyzw
// SV_COVERAGE              0    N/A    oMask COVERAGE    uint    YES
//
ps_5_0
dcl_globalFlags refactoringAllowed
dcl_constantbuffer cb5[131], dynamicIndexed
dcl_constantbuffer cb6[2], immediateIndexed
dcl_constantbuffer cb7[2], immediateIndexed
dcl_constantbuffer cb8[9], immediateIndexed
dcl_constantbuffer cb0[24], immediateIndexed
dcl_constantbuffer cb2[2], immediateIndexed
dcl_sampler s0, mode_default
dcl_sampler s1, mode_default
dcl_sampler s2, mode_default
dcl_sampler s3, mode_default
dcl_sampler s4, mode_default
dcl_sampler s11, mode_default
dcl_sampler s12, mode_default
dcl_sampler s13, mode_default
dcl_resource_texture2d (float,float,float,float) t0
dcl_resource_texture2d (float,float,float,float) t1
dcl_resource_texture2d (float,float,float,float) t2
dcl_resource_texture2d (float,float,float,float) t3
dcl_resource_texture2d (float,float,float,float) t4
dcl_resource_texture2d (float,float,float,float) t11
dcl_resource_texture2d (float,float,float,float) t12
dcl_resource_texture3d (float,float,float,float) t16
dcl_resource_texture2d (float,float,float,float) t17
dcl_resource_texture2d (float,float,float,float) t18
dcl_resource_texture2d (float,float,float,float) t19
dcl_resource_texture2d (float,float,float,float) t20
dcl_input_ps_siv linear noperspective v0.xy, position
dcl_input_ps linear v1.xyzw
dcl_input_ps linear v2.xyzw
dcl_input_ps linear v3.xyzw
dcl_input_ps linear v4.xyz
dcl_input_ps linear v5.xy
dcl_input_ps linear v5.zw
dcl_input_ps linear v6.xy
dcl_input_ps linear v6.zw
dcl_input_ps linear v7.xy
dcl_input_ps linear v7.zw
dcl_input_ps linear v8.xy
dcl_output o0.xyzw
dcl_output oMask
dcl_temps 14
ieq r0.xyzw, cb0[23].xxxx, l(4, 2, 3, 5)
and r0.w, r0.w, l(3)
movc r0.z, r0.z, l(2), r0.w
ieq r0.w, r0.z, l(3)
movc r0.w, r0.y, l(0), r0.w
or r0.y, r0.w, r0.y
movc r0.y, r0.y, l(1), r0.z
ieq r0.z, r0.y, l(2)
if_nz r0.z
  mov r0.zw, l(0,0,0,0)
  loop
    itof r1.x, r0.w
    ge r1.x, r1.x, cb0[3].x
    breakc_nz r1.x
    eval_sample_index r1.xy, v5.xyxx, r0.w
    switch cb2[0].x
      case l(0x00008717)
      mov r1.z, l(1.000000)
      break
      case l(0)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(1)
      mov r1.z, l(1.000000)
      break
      case l(2)
      mov r1.z, l(1.000000)
      break
      case l(3)
      mov r1.z, l(1.000000)
      break
      case l(4)
      mov r1.z, l(1.000000)
      break
      case l(5)
      mov r1.z, l(1.000000)
      break
      case l(6)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(7)
      mov r1.z, l(1.000000)
      break
      case l(8)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(9)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(10)
      mov r1.z, l(1.000000)
      break
      case l(11)
      mov r1.z, l(1.000000)
      break
      case l(12)
      mov r1.z, l(1.000000)
      break
      case l(13)
      mov r1.z, l(1.000000)
      break
      case l(14)
      mov r1.z, l(1.000000)
      break
      case l(15)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(16)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(17)
      mov r1.z, l(1.000000)
      break
      case l(18)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(19)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(20)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(21)
      sample_indexable(texture2d)(float,float,float,float) r1.z, r1.xyxx, t0.xywz, s0
      break
      case l(22)
      mov r1.z, l(1.000000)
      break
      case l(23)
      mov r1.z, l(1.000000)
      break
      default
      mov r1.z, l(1.000000)
      break
    endswitch
    add r1.x, r1.z, l(-0.501960814)
    ge r1.x, r1.x, l(0.000000)
    ishl r1.y, l(1), r0.w
    and r1.x, r1.y, r1.x
    or r0.z, r0.z, r1.x
    iadd r0.w, r0.w, l(1)
  endloop
  discard_z r0.z
  lt r0.w, l(0.000000), cb0[4].y
  dp3 r1.x, v3.xyzx, v3.xyzx
  rsq r1.x, r1.x
  mul r1.xyz, r1.xxxx, v3.xyzx
  dp3 r1.w, -r1.xyzx, v4.xyzx
  add r1.w, r1.w, r1.w
  mad r2.xyz, -r1.wwww, v4.xyzx, -r1.xyzx
  add r2.w, r2.z, l(1.000000)
  dp3 r1.w, r2.xywx, r2.xywx
  rsq r1.w, r1.w
  mul r2.xy, r1.wwww, r2.xyxx
  mad r2.xy, r2.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000), l(0.500000, 0.500000, 0.000000, 0.000000)
  eq r3.xy, cb0[4].yyyy, l(1.000000, 2.000000, 0.000000, 0.000000)
  mov r2.zw, v5.xxxy
  movc r4.xyzw, r3.yyyy, r2.zwxy, r2.xyxy
  mov r2.zw, v5.zzzw
  movc r3.xyzw, r3.xxxx, r2.xyzw, r4.xyzw
  movc r3.xyzw, r0.wwww, r3.xyzw, v5.xyzw
  switch cb2[0].x
    case l(0x00008717)
    mov r4.xyz, l(0,0,0,0)
    mov r5.xyz, l(0,0,0,0)
    mov r6.xyz, v2.xyzx
    mov r7.x, l(0)
    break
    case l(0)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(1)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(2)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(3)
    sample_indexable(texture2d)(float,float,float,float) r4.xyzw, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.zwzz, t1.xyzw, s1
    mul r5.xyz, r4.wwww, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.x, l(1.000000)
    break
    case l(4)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(5)
    sample_indexable(texture2d)(float,float,float,float) r4.xyzw, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.zwzz, t1.xyzw, s1
    mul r9.xyz, r4.wwww, r4.xyzx
    mul r5.xyz, r8.xyzx, r9.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.x, l(1.000000)
    break
    case l(6)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r3.zwzz, t1.xyzw, s1
    add r9.xyz, -r8.xyzx, r9.xyzx
    mad r9.xyz, r9.wwww, r9.xyzx, r8.xyzx
    add r8.xyz, r8.xyzx, -r9.xyzx
    mad r4.xyz, v2.wwww, r8.xyzx, r9.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(7)
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r3.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r10.xyz, v6.xyxx, t2.xyzw, s2
    add r8.xyzw, r8.xyzw, -r9.xyzw
    mad r4.xyzw, v2.wwww, r8.xyzw, r9.xyzw
    mul r8.xyz, r4.wwww, r4.xyzx
    mul r5.xyz, r10.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.x, l(1.000000)
    break
    case l(8)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyz, r3.zwzz, t1.xyzw, s1
    add r8.xyz, r8.xyzx, -r9.xyzx
    mad r4.xyz, v2.wwww, r8.xyzx, r9.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(9)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r3.zwzz, t1.xyzw, s1
    mul r8.xyz, r8.wwww, r8.xyzx
    mul r5.xyz, r8.xyzx, v2.wwww
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.x, l(0)
    break
    case l(10)
    mov r4.xyz, l(0,0,0,0)
    mov r5.xyz, l(0,0,0,0)
    mov r6.xyz, v2.xyzx
    mov r7.x, l(0)
    break
    case l(11)
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyz, r3.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r10.xyzw, v6.xyxx, t2.xyzw, s2
    mul r9.xyz, r8.xyzx, r9.xyzx
    add r11.xyz, r9.xyzx, r9.xyzx
    mul_sat r0.w, r10.w, v2.w
    mad r9.xyz, -r9.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), r10.xyzx
    mad r9.xyz, r0.wwww, r9.xyzx, r11.xyzx
    add r8.xyz, r8.xyzx, -r9.xyzx
    mad r4.xyz, r8.wwww, r8.xyzx, r9.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(12)
    sample_indexable(texture2d)(float,float,float,float) r4.xyzw, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, v6.xyxx, t2.xyzw, s2
    mul r10.xyz, r4.wwww, r4.xyzx
    mul r9.xyz, r9.wwww, r9.xyzx
    mul r9.xyz, r9.xyzx, v2.wwww
    mad r5.xyz, r10.xyzx, r8.xyzx, r9.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.x, l(0)
    break
    case l(13)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyz, r3.zwzz, t1.xyzw, s1
    add r8.xyz, r8.xyzx, -r9.xyzx
    mad r4.xyz, v2.wwww, r8.xyzx, r9.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(14)
    mov r4.xyz, l(0,0,0,0)
    mov r5.xyz, l(0,0,0,0)
    mov r6.xyz, v2.xyzx
    mov r7.x, l(0)
    break
    case l(15)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r3.zwzz, t1.xyzw, s1
    add r0.w, -r9.w, l(1.000000)
    mul r10.xyz, r0.wwww, r9.xyzx
    mad r8.xyz, -r9.xyzx, r0.wwww, r8.xyzx
    mad r4.xyz, v2.wwww, r8.xyzx, r10.xyzx
    mul r8.xyz, r9.wwww, r9.xyzx
    add r0.w, -v2.w, l(1.000000)
    mul r5.xyz, r0.wwww, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.x, l(0)
    break
    case l(16)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(17)
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyz, r3.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r10.xyzw, v6.xyxx, t2.xyzw, s2
    mul r9.xyz, r8.xyzx, r9.xyzx
    add r9.xyz, r9.xyzx, r9.xyzx
    mul_sat r0.w, r10.w, v2.w
    mad r9.xyz, r10.xyzx, r0.wwww, r9.xyzx
    add r8.xyz, r8.xyzx, -r9.xyzx
    mad r4.xyz, r8.wwww, r8.xyzx, r9.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(18)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r3.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r10.xyz, v6.xyxx, t2.xyzw, s2
    add r9.xyz, -r8.xyzx, r9.xyzx
    mad r9.xyz, r9.wwww, r9.xyzx, r8.xyzx
    add r8.xyz, r8.xyzx, -r9.xyzx
    mad r8.xyz, v2.wwww, r8.xyzx, r9.xyzx
    mul r8.xyz, r10.xyzx, r8.xyzx
    add r4.xyz, r8.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(19)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyz, r3.zwzz, t1.xyzw, s1
    mul r9.xyz, r8.xyzx, r9.xyzx
    mad r9.xyz, r9.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), -r8.xyzx
    mad r4.xyz, v2.wwww, r9.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(20)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r3.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r10.xyzw, v6.xyxx, t2.xyzw, s2
    add r9.xyz, -r8.xyzx, r9.xyzx
    mad r9.xyz, r9.wwww, r9.xyzx, r8.xyzx
    add r8.xyz, r8.xyzx, -r9.xyzx
    mad r8.xyz, r10.wwww, r8.xyzx, r9.xyzx
    mul r8.xyz, r10.xyzx, r8.xyzx
    add r4.xyz, r8.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(21)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.xyxx, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r5.xyz, r3.xyxx, t2.xyzw, s2
    add r6.xyz, r8.xyzx, r8.xyzx
    mov r7.x, l(0)
    break
    case l(22)
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.zwzz, t17.xyzw, s3
    deriv_rtx_coarse r9.xyz, v3.yzxy
    deriv_rty_coarse r10.xyz, v3.zxyz
    deriv_rtx_coarse r2.zw, r3.zzzw
    deriv_rty_coarse r11.xy, r3.zwzz
    mul r12.xyz, r10.xyzx, v4.yzxy
    mad r10.xyz, r10.zxyz, v4.zxyz, -r12.xyzx
    mul r12.xyz, r9.xyzx, v4.zxyz
    mad r9.xyz, v4.yzxy, r9.yzxy, -r12.xyzx
    mul r11.xzw, r11.xxxx, r9.xxyz
    mad r11.xzw, r10.xxyz, r2.zzzz, r11.xxzw
    mul r9.xyz, r11.yyyy, r9.xyzx
    mad r9.xyz, r10.xyzx, r2.wwww, r9.xyzx
    dp3 r0.w, r11.xzwx, r11.xzwx
    dp3 r1.w, r9.xyzx, r9.xyzx
    max r0.w, r0.w, r1.w
    rsq r0.w, r0.w
    mul r10.xyz, r11.xzwx, r0.wwww
    mul r9.xyz, r9.xyzx, r0.wwww
    dp3 r10.x, r10.xyzx, r1.xyzx
    dp3 r10.y, r9.xyzx, r1.xyzx
    dp3 r0.w, v4.xyzx, r1.xyzx
    mul r1.xyzw, r8.xxxx, l(0.250000, 0.250000, 0.500000, 0.500000)
    div r9.xyzw, r10.xyxy, r0.wwww
    mad r1.xy, -r9.xyxx, r1.xyxx, r3.zwzz
    sample_indexable(texture2d)(float,float,float,float) r10.xyzw, r1.xyxx, t3.xyzw, s3
    mad r1.xy, -r9.zwzz, r1.zwzz, v6.xyxx
    sample_indexable(texture2d)(float,float,float,float) r1.xyzw, r1.xyxx, t4.xyzw, s3
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r3.zwzz, t2.xyzw, s3
    mad r10.xyz, r10.xyzx, r10.wwww, r1.xyzx
    add r11.xyz, r9.xyzx, -r10.xyzx
    mad r4.xyz, r8.yyyy, r11.xyzx, r10.xyzx
    mul r1.xyz, r1.wwww, r1.xyzx
    add r0.w, -r8.y, l(1.000000)
    mul r1.xyz, r0.wwww, r1.xyzx
    mad r1.xyz, r9.xyzx, r8.zzzz, r1.xyzx
    mad r1.xyz, v2.wwww, -r1.xyzx, r1.xyzx
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, v7.xyxx, t1.xyzw, s3
    mul r9.xyz, r9.wwww, r9.xyzx
    lt r0.w, l(0.000000), v2.w
    if_nz r0.w
      sample_indexable(texture2d)(float,float,float,float) r10.xyzw, r3.xyxx, t0.xyzw, s3
      add r11.xyz, -r4.xyzx, r10.xyzx
      mad r4.xyz, v2.wwww, r11.xyzx, r4.xyzx
      mad r10.xyz, r10.xyzx, r10.wwww, -r9.xyzx
      mad r9.xyz, v2.wwww, r10.xyzx, r9.xyzx
    endif
    mad r5.xyz, r8.xyzx, r9.xyzx, r1.xyzx
    mov r6.xyz, v2.xyzx
    mov r7.x, l(1.000000)
    break
    case l(23)
    sample_indexable(texture2d)(float,float,float,float) r1.xyz, r2.xyxx, t0.xyzw, s0
    dp3_sat r0.w, v7.xyzx, l(1.000000, 1.000000, 1.000000, 0.000000)
    add r2.w, -r0.w, l(1.000000)
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r3.xyxx, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r3.zwzz, t2.xyzw, s2
    sample_indexable(texture2d)(float,float,float,float) r10.xyzw, v6.xyxx, t3.xyzw, s3
    sample_indexable(texture2d)(float,float,float,float) r11.xyzw, v6.zwzz, t4.xyzw, s4
    sample_indexable(texture2d)(float,float,float,float) r0.w, r3.xyxx, t17.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r1.w, r3.zwzz, t18.xyzw, s2
    sample_indexable(texture2d)(float,float,float,float) r3.z, v6.xyxx, t19.xywz, s3
    sample_indexable(texture2d)(float,float,float,float) r3.w, v6.zwzz, t20.xyzw, s4
    max r12.x, r0.w, l(0.004000)
    max r12.y, r1.w, l(0.004000)
    max r12.zw, r3.zzzw, l(0.000000, 0.000000, 0.004000, 0.004000)
    mov r2.xyz, v7.xyzx
    mul r13.xyzw, r2.xyzw, r12.xyzw
    max r0.w, r13.y, r13.x
    max r0.w, r13.z, r0.w
    max r0.w, r13.w, r0.w
    mad_sat r2.xyzw, -r2.xyzw, r12.xyzw, r0.wwww
    add r2.xyzw, -r2.xyzw, l(1.000000, 1.000000, 1.000000, 1.000000)
    mul r2.xyzw, r2.xyzw, r13.xyzw
    dp4 r0.w, l(1.000000, 1.000000, 1.000000, 1.000000), r2.xyzw
    rcp r0.w, r0.w
    mul r2.xyzw, r0.wwww, r2.xyzw
    mul r9.xyzw, r2.yyyy, r9.xyzw
    mad r8.xyzw, r8.xyzw, r2.xxxx, r9.xyzw
    mad r8.xyzw, r10.xyzw, r2.zzzz, r8.xyzw
    mad r2.xyzw, r11.xyzw, r2.wwww, r8.xyzw
    mul r8.xyz, r2.wwww, r2.xyzx
    mul r5.xyz, r1.xyzx, r8.xyzx
    add r1.xyz, -r2.xyzx, cb2[1].xyzx
    mad r4.xyz, v7.wwww, r1.xyzx, r2.xyzx
    mov r6.xyz, v2.xyzx
    mov r7.x, l(1.000000)
    break
    default
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r3.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
  endswitch
  mov r0.w, l(1.000000)
  mov oMask, r0.z
else
  lt r0.z, l(0.000000), cb0[4].y
  dp3 r1.x, v3.xyzx, v3.xyzx
  rsq r1.x, r1.x
  mul r1.xyz, r1.xxxx, v3.xyzx
  dp3 r1.w, -r1.xyzx, v4.xyzx
  add r1.w, r1.w, r1.w
  mad r1.xyz, -r1.wwww, v4.xyzx, -r1.xyzx
  add r1.w, r1.z, l(1.000000)
  dp3 r1.z, r1.xywx, r1.xywx
  rsq r1.z, r1.z
  mul r1.xy, r1.zzzz, r1.xyxx
  mad r1.xy, r1.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000), l(0.500000, 0.500000, 0.000000, 0.000000)
  eq r2.xy, cb0[4].yyyy, l(1.000000, 2.000000, 0.000000, 0.000000)
  dp3 r2.z, v3.xyzx, v3.xyzx
  rsq r2.z, r2.z
  mul r3.xyz, r2.zzzz, v3.xyzx
  dp3 r2.z, -r3.xyzx, v4.xyzx
  add r2.z, r2.z, r2.z
  mad r3.xyz, -r2.zzzz, v4.xyzx, -r3.xyzx
  add r3.w, r3.z, l(1.000000)
  dp3 r2.z, r3.xywx, r3.xywx
  rsq r2.z, r2.z
  mul r2.zw, r2.zzzz, r3.xxxy
  mad r3.zw, r2.zzzw, l(0.000000, 0.000000, 0.500000, 0.500000), l(0.000000, 0.000000, 0.500000, 0.500000)
  mov r3.xy, v5.xyxx
  movc r3.xyzw, r2.yyyy, r3.xyzw, r3.zwzw
  mov r1.zw, v5.zzzw
  movc r2.xyzw, r2.xxxx, r1.xyzw, r3.xyzw
  movc r2.xyzw, r0.zzzz, r2.xyzw, v5.xyzw
  switch cb2[0].x
    case l(0x00008717)
    mov r4.xyz, l(0,0,0,0)
    mov r5.xyz, l(0,0,0,0)
    mov r6.xyz, v2.xyzx
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(0)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r4.xyz, r7.xzwx
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(1)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r2.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(2)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r2.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(3)
    sample_indexable(texture2d)(float,float,float,float) r4.xyzw, r2.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.zwzz, t1.xyzw, s1
    mul r5.xyz, r3.xyzx, r4.wwww
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.xy, l(1.000000,1.000000,0,0)
    break
    case l(4)
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r2.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(5)
    sample_indexable(texture2d)(float,float,float,float) r4.xyzw, r2.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.zwzz, t1.xyzw, s1
    mul r8.xyz, r4.wwww, r4.xyzx
    mul r5.xyz, r3.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.xy, l(1.000000,1.000000,0,0)
    break
    case l(6)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.zwzz, t1.xyzw, s1
    add r3.xyz, -r7.xzwx, r3.xyzx
    mad r3.xyz, r3.wwww, r3.xyzx, r7.xzwx
    add r8.xyz, -r3.xyzx, r7.xzwx
    mad r4.xyz, v2.wwww, r8.xyzx, r3.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(7)
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r2.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r9.xyz, v6.xyxx, t2.xyzw, s2
    add r3.xyzw, r3.xyzw, -r8.xyzw
    mad r4.xyzw, v2.wwww, r3.xyzw, r8.xyzw
    mul r3.xyz, r4.wwww, r4.xyzx
    mul r5.xyz, r9.xyzx, r3.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.xy, l(1.000000,1.000000,0,0)
    break
    case l(8)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.zwzz, t1.xyzw, s1
    add r8.xyz, -r3.xyzx, r7.xzwx
    mad r4.xyz, v2.wwww, r8.xyzx, r3.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(9)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.zwzz, t1.xyzw, s1
    mul r3.xyz, r3.wwww, r3.xyzx
    mul r5.xyz, r3.xyzx, v2.wwww
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r4.xyz, r7.xzwx
    mov r7.x, l(0)
    break
    case l(10)
    mov r4.xyz, l(0,0,0,0)
    mov r5.xyz, l(0,0,0,0)
    mov r6.xyz, v2.xyzx
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(11)
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r2.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, v6.xyxx, t2.xyzw, s2
    mul r8.xyz, r3.xyzx, r8.xyzx
    add r10.xyz, r8.xyzx, r8.xyzx
    mul_sat r0.z, r9.w, v2.w
    mad r8.xyz, -r8.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), r9.xyzx
    mad r8.xyz, r0.zzzz, r8.xyzx, r10.xyzx
    add r3.xyz, r3.xyzx, -r8.xyzx
    mad r4.xyz, r3.wwww, r3.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(12)
    sample_indexable(texture2d)(float,float,float,float) r4.xyzw, r2.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, v6.xyxx, t2.xyzw, s2
    mul r9.xyz, r4.wwww, r4.xyzx
    mul r8.xyz, r8.wwww, r8.xyzx
    mul r8.xyz, r8.xyzx, v2.wwww
    mad r5.xyz, r9.xyzx, r3.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(13)
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r2.zwzz, t1.xyzw, s1
    add r3.xyz, r3.xyzx, -r8.xyzx
    mad r4.xyz, v2.wwww, r3.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(14)
    mov r4.xyz, l(0,0,0,0)
    mov r5.xyz, l(0,0,0,0)
    mov r6.xyz, v2.xyzx
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(15)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.zwzz, t1.xyzw, s1
    add r0.z, -r3.w, l(1.000000)
    mul r8.xyz, r0.zzzz, r3.xyzx
    mad r9.xyz, -r3.xyzx, r0.zzzz, r7.xzwx
    mad r4.xyz, v2.wwww, r9.xyzx, r8.xyzx
    mul r3.xyz, r3.wwww, r3.xyzx
    add r0.z, -v2.w, l(1.000000)
    mul r5.xyz, r0.zzzz, r3.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r7.x, l(0)
    break
    case l(16)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r4.xyz, r7.xzwx
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(17)
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.xyxx, t0.xyzw, s0
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, r2.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, v6.xyxx, t2.xyzw, s2
    mul r8.xyz, r3.xyzx, r8.xyzx
    add r8.xyz, r8.xyzx, r8.xyzx
    mul_sat r0.z, r9.w, v2.w
    mad r8.xyz, r9.xyzx, r0.zzzz, r8.xyzx
    add r3.xyz, r3.xyzx, -r8.xyzx
    mad r4.xyz, r3.wwww, r3.xyzx, r8.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.xy, l(0,1.000000,0,0)
    break
    case l(18)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, v6.xyxx, t2.xyzw, s2
    add r3.xyz, -r7.xzwx, r3.xyzx
    mad r3.xyz, r3.wwww, r3.xyzx, r7.xzwx
    add r9.xyz, -r3.xyzx, r7.xzwx
    mad r3.xyz, v2.wwww, r9.xyzx, r3.xyzx
    mul r3.xyz, r8.xyzx, r3.xyzx
    add r4.xyz, r3.xyzx, r3.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(19)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.zwzz, t1.xyzw, s1
    mul r3.xyz, r3.xyzx, r7.xzwx
    mad r3.xyz, r3.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), -r7.xzwx
    mad r4.xyz, v2.wwww, r3.xyzx, r7.xzwx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(20)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.zwzz, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, v6.xyxx, t2.xyzw, s2
    add r3.xyz, -r7.xzwx, r3.xyzx
    mad r3.xyz, r3.wwww, r3.xyzx, r7.xzwx
    add r9.xyz, -r3.xyzx, r7.xzwx
    mad r3.xyz, r8.wwww, r9.xyzx, r3.xyzx
    mul r3.xyz, r8.xyzx, r3.xyzx
    add r4.xyz, r3.xyzx, r3.xyzx
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.x, l(0)
    break
    case l(21)
    sample_indexable(texture2d)(float,float,float,float) r7.xyzw, r2.xyxx, t0.xwyz, s0
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.xyxx, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r5.xyz, r2.xyxx, t2.xyzw, s2
    add r6.xyz, r3.xyzx, r3.xyzx
    mov r4.xyz, r7.xzwx
    mov r7.x, l(0)
    break
    case l(22)
    sample_indexable(texture2d)(float,float,float,float) r3.xyz, r2.zwzz, t17.xyzw, s3
    deriv_rtx_coarse r8.xyz, v3.yzxy
    deriv_rty_coarse r9.xyz, v3.zxyz
    deriv_rtx_coarse r1.zw, r2.zzzw
    deriv_rty_coarse r7.zw, r2.zzzw
    mul r10.xyz, r9.xyzx, v4.yzxy
    mad r9.xyz, r9.zxyz, v4.zxyz, -r10.xyzx
    mul r10.xyz, r8.xyzx, v4.zxyz
    mad r8.xyz, v4.yzxy, r8.yzxy, -r10.xyzx
    mul r10.xyz, r7.zzzz, r8.xyzx
    mad r10.xyz, r9.xyzx, r1.zzzz, r10.xyzx
    mul r8.xyz, r7.wwww, r8.xyzx
    mad r8.xyz, r9.xyzx, r1.wwww, r8.xyzx
    dp3 r0.z, r10.xyzx, r10.xyzx
    dp3 r1.z, r8.xyzx, r8.xyzx
    max r0.z, r0.z, r1.z
    rsq r0.z, r0.z
    mul r9.xyz, r10.xyzx, r0.zzzz
    mul r8.xyz, r8.xyzx, r0.zzzz
    dp3 r0.z, v3.xyzx, v3.xyzx
    rsq r0.z, r0.z
    mul r10.xyz, r0.zzzz, v3.xyzx
    dp3 r9.x, r9.xyzx, r10.xyzx
    dp3 r9.y, r8.xyzx, r10.xyzx
    dp3 r0.z, v4.xyzx, r10.xyzx
    mul r8.xyzw, r3.xxxx, l(0.250000, 0.250000, 0.500000, 0.500000)
    div r9.xyzw, r9.xyxy, r0.zzzz
    mad r1.zw, -r9.xxxy, r8.xxxy, r2.zzzw
    sample_indexable(texture2d)(float,float,float,float) r10.xyzw, r1.zwzz, t3.xyzw, s3
    mad r1.zw, -r9.zzzw, r8.zzzw, v6.xxxy
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r1.zwzz, t4.xyzw, s3
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r2.zwzz, t2.xyzw, s3
    mad r10.xyz, r10.xyzx, r10.wwww, r8.xyzx
    add r11.xyz, r9.xyzx, -r10.xyzx
    mad r4.xyz, r3.yyyy, r11.xyzx, r10.xyzx
    mul r8.xyz, r8.wwww, r8.xyzx
    add r0.z, -r3.y, l(1.000000)
    mul r3.xyw, r0.zzzz, r8.xyxz
    mad r3.xyz, r9.xyzx, r3.zzzz, r3.xywx
    mad r3.xyz, v2.wwww, -r3.xyzx, r3.xyzx
    sample_indexable(texture2d)(float,float,float,float) r8.xyz, v7.xyxx, t1.xyzw, s3
    mul r9.xyz, r9.wwww, r9.xyzx
    lt r0.z, l(0.000000), v2.w
    if_nz r0.z
      sample_indexable(texture2d)(float,float,float,float) r10.xyzw, r2.xyxx, t0.xyzw, s3
      add r11.xyz, -r4.xyzx, r10.xyzx
      mad r4.xyz, v2.wwww, r11.xyzx, r4.xyzx
      mad r10.xyz, r10.xyzx, r10.wwww, -r9.xyzx
      mad r9.xyz, v2.wwww, r10.xyzx, r9.xyzx
    endif
    mad r5.xyz, r8.xyzx, r9.xyzx, r3.xyzx
    mov r6.xyz, v2.xyzx
    mov r7.xy, l(1.000000,1.000000,0,0)
    break
    case l(23)
    sample_indexable(texture2d)(float,float,float,float) r1.xyz, r1.xyxx, t0.xyzw, s0
    dp3_sat r0.z, v7.xyzx, l(1.000000, 1.000000, 1.000000, 0.000000)
    add r3.w, -r0.z, l(1.000000)
    sample_indexable(texture2d)(float,float,float,float) r8.xyzw, r2.xyxx, t1.xyzw, s1
    sample_indexable(texture2d)(float,float,float,float) r9.xyzw, r2.zwzz, t2.xyzw, s2
    sample_indexable(texture2d)(float,float,float,float) r10.xyzw, v6.xyxx, t3.xyzw, s3
    sample_indexable(texture2d)(float,float,float,float) r11.xyzw, v6.zwzz, t4.xyzw, s4
    sample_indexable(texture2d)(float,float,float,float) r0.z, r2.xyxx, t17.xywz, s1
    sample_indexable(texture2d)(float,float,float,float) r1.w, r2.zwzz, t18.xyzw, s2
    sample_indexable(texture2d)(float,float,float,float) r2.z, v6.xyxx, t19.xywz, s3
    sample_indexable(texture2d)(float,float,float,float) r2.w, v6.zwzz, t20.xyzw, s4
    max r12.x, r0.z, l(0.004000)
    max r12.y, r1.w, l(0.004000)
    max r12.zw, r2.zzzw, l(0.000000, 0.000000, 0.004000, 0.004000)
    mov r3.xyz, v7.xyzx
    mul r13.xyzw, r3.xyzw, r12.xyzw
    max r0.z, r13.y, r13.x
    max r0.z, r13.z, r0.z
    max r0.z, r13.w, r0.z
    mad_sat r3.xyzw, -r3.xyzw, r12.xyzw, r0.zzzz
    add r3.xyzw, -r3.xyzw, l(1.000000, 1.000000, 1.000000, 1.000000)
    mul r3.xyzw, r3.xyzw, r13.xyzw
    dp4 r0.z, l(1.000000, 1.000000, 1.000000, 1.000000), r3.xyzw
    rcp r0.z, r0.z
    mul r3.xyzw, r0.zzzz, r3.xyzw
    mul r9.xyzw, r3.yyyy, r9.xyzw
    mad r8.xyzw, r8.xyzw, r3.xxxx, r9.xyzw
    mad r8.xyzw, r10.xyzw, r3.zzzz, r8.xyzw
    mad r3.xyzw, r11.xyzw, r3.wwww, r8.xyzw
    mul r8.xyz, r3.wwww, r3.xyzx
    mul r5.xyz, r1.xyzx, r8.xyzx
    add r1.xyz, -r3.xyzx, cb2[1].xyzx
    mad r4.xyz, v7.wwww, r1.xyzx, r3.xyzx
    mov r6.xyz, v2.xyzx
    mov r7.xy, l(1.000000,1.000000,0,0)
    break
    default
    sample_indexable(texture2d)(float,float,float,float) r4.xyz, r2.xyxx, t0.xyzw, s0
    mul r6.xyz, v2.xyzx, cb8[6].wwww
    mov r5.xyz, l(0,0,0,0)
    mov r7.xy, l(0,1.000000,0,0)
    break
  endswitch
  ine r0.z, r0.y, l(0)
  add r1.x, r7.y, l(-0.501960814)
  lt r1.x, r1.x, l(0.000000)
  and r0.z, r0.z, r1.x
  discard_nz r0.z
  ieq r0.z, cb0[23].x, l(1)
  movc r0.z, r0.z, l(1.000000), r7.y
  movc r0.w, r0.y, l(1.000000), r0.z
  mov oMask, l(-1)
endif
dp3 r0.y, v4.xyzx, v4.xyzx
rsq r0.y, r0.y
mul r1.xyz, r0.yyyy, v4.xyzx
dp3 r0.y, r1.xyzx, -cb8[3].xyzx
dp3 r0.z, r1.xyzx, cb8[8].xyzx
mad r1.xy, v0.xyxx, cb5[127].xyxx, cb5[127].zwzz
sample_indexable(texture2d)(float,float,float,float) r1.xy, r1.xyxx, t12.xyzw, s12
mad r1.zw, v0.xxxy, cb5[126].xxxy, cb5[126].zzzw
sample_indexable(texture2d)(float,float,float,float) r2.xyz, r1.zwzz, t11.xyzw, s11
mul r3.xyz, r4.xyzx, v1.xyzx
add r3.xyz, r3.xyzx, r3.xyzx
mad r1.z, r1.x, l(0.500000), l(0.500000)
mad r7.yzw, r6.xxyz, r1.zzzz, cb8[0].xxyz
mad r8.xyz, r6.xyzx, r1.zzzz, cb8[1].xyzx
mad r6.xyz, r6.xyzx, r1.zzzz, cb8[2].xyzx
ge r1.z, r0.z, l(0.000000)
add r7.yzw, r7.yyzw, -r8.xxyz
mad r7.yzw, r0.zzzz, r7.yyzw, r8.xxyz
add r6.xyz, -r8.xyzx, r6.xyzx
mad r6.xyz, -r0.zzzz, r6.xyzx, r8.xyzx
movc r6.xyz, r1.zzzz, r7.yzwy, r6.xyzx
mad r0.y, r0.y, l(0.500000), l(0.500000)
mul r7.yzw, r0.yyyy, r6.xxyz
mul r7.yzw, r7.yyzw, l(0.000000, 0.400000036, 0.400000036, 0.400000036)
mad r6.xyz, r6.xyzx, l(0.700000, 0.700000, 0.700000, 0.000000), r7.yzwy
dp3_sat r0.y, v4.xyzx, -cb8[3].xyzx
mul r7.yzw, r0.yyyy, cb8[4].xxyz
mul r1.xzw, r1.xxxx, r7.yyzw
mad r1.xyz, r6.xyzx, r1.yyyy, r1.xzwx
mul r1.xyz, r1.xyzx, r3.xyzx
mul r3.xyz, r3.xyzx, r3.xyzx
mul r2.xyz, r2.xyzx, r3.xyzx
mul r3.w, r0.w, v1.w
add r0.y, -v3.w, l(1.000000)
mul r0.y, r0.y, r0.y
mul r6.xyz, r4.xyzx, cb7[1].xyzx
mul r6.xyz, r6.xyzx, cb7[0].wwww
dp3 r0.z, v4.xyzx, cb7[0].xyzx
mov_sat r0.w, r0.z
mul r3.xyz, r0.wwww, r6.xyzx
lt r0.w, cb7[0].w, l(0.000000)
mov_sat r0.z, -r0.z
mad r1.w, cb7[1].w, l(-0.750000), l(0.800000)
mul_sat r1.w, r1.w, -cb7[0].w
mov_sat r2.w, r3.w
mul r2.w, r2.w, cb7[1].w
mad r2.w, -r2.w, r2.w, l(1.000000)
mul r0.z, r0.z, r2.w
mul_sat r2.w, r0.z, l(5.000000)
mad r1.w, -r1.w, r2.w, l(1.000000)
mul r6.w, r1.w, r3.w
mul r4.xyz, r0.zzzz, r4.xyzx
mul r4.xyz, r4.xyzx, cb7[1].xyzx
mul r6.xyz, r4.xyzx, -cb7[0].wwww
movc r4.xyzw, r0.wwww, r6.xyzw, r3.xyzw
mul r6.xyz, r0.yyyy, r4.xyzx
mad r0.z, r0.y, r4.w, -r3.w
mad r0.y, r0.y, r0.z, r3.w
mad_sat r0.z, v3.z, v8.x, v8.y
add r0.z, r0.z, l(-1.000000)
mad r0.z, r7.x, r0.z, l(1.000000)
mad r1.xyz, r1.xyzx, r1.xyzx, r2.xyzx
sqrt r1.xyz, r1.xyzx
mad r1.xyz, r5.xyzx, r0.zzzz, r1.xyzx
mul r1.w, r0.y, cb0[4].x
mov r6.w, l(0)
add r1.xyzw, r1.xyzw, r6.xyzw
ne r0.y, cb0[16].w, l(0.000000)
if_nz r0.y
  add r0.yzw, -r1.xxyz, cb0[16].xxyz
  mad r1.xyz, cb0[16].wwww, r0.yzwy, r1.xyzx
endif
mul r0.yzw, r1.xxyz, cb0[4].xxxx
movc r0.yzw, r0.xxxx, r0.yyzw, r1.xxyz
ftou r1.xy, cb0[0].xzxx
imul null, r1.xy, r1.xyxx, l(14, 14, 0, 0)
dp3 r1.z, v3.xyzx, v3.xyzx
sqrt r1.z, r1.z
ne r2.x, l(0.000000, 0.000000, 0.000000, 0.000000), cb5[r1.x + 1].x
if_z r2.x
  dp3 r2.x, cb5[130].xyzx, v3.xyzx
  lt r2.y, l(0.000000), r2.x
  max r2.z, l(0.000000), cb5[r1.x + 8].w
  min r2.z, r2.x, r2.z
  mad r3.xyz, -cb5[130].xyzx, r2.zzzz, v3.xyzx
  max r2.x, r2.x, -cb5[r1.x + 8].w
  min r2.x, r2.x, l(0.000000)
  mad r2.xzw, -cb5[130].xxyz, r2.xxxx, v3.xxyz
  movc r2.xyz, r2.yyyy, r3.xyzx, r2.xzwx
  dp3 r2.x, r2.xyzx, r2.xyzx
  sqrt r2.x, r2.x
  add r2.y, r2.x, -cb5[r1.x + 0].x
  max r2.y, r2.y, l(0.000000)
  mul r2.z, r2.y, cb5[r1.x + 4].x
  mul r2.z, r2.z, l(1.442695)
  exp r2.z, r2.z
  dp3 r2.w, cb5[r1.x + 2].xyzx, v3.xyzx
  add r2.w, r2.w, cb5[r1.x + 2].w
  mul_sat r2.w, r2.w, cb5[r1.x + 3].w
  add r2.w, -r2.w, l(1.000000)
  mul r3.x, r2.w, r2.w
  mul r3.y, r2.w, r3.x
  mul r3.x, r3.x, cb5[r1.x + 9].y
  mad r3.x, cb5[r1.x + 9].x, r3.y, r3.x
  mad r2.w, cb5[r1.x + 9].z, r2.w, r3.x
  add_sat r2.w, r2.w, cb5[r1.x + 9].w
  add r2.w, -r2.w, l(1.000000)
  div r3.x, r2.x, cb5[r1.x + 0].y
  mul r2.y, r2.y, cb5[r1.x + 0].z
  mul r2.y, r2.y, l(1.442695)
  exp r2.y, r2.y
  rcp r2.yz, r2.yyzy
  add r2.z, -r2.y, r2.z
  mad r2.y, r2.w, r2.z, r2.y
  add r2.y, -r2.y, l(1.000000)
  mad r2.y, -r2.y, cb0[22].z, l(1.000000)
  add r2.z, -r3.x, l(1.000000)
  mul_sat r2.z, r2.z, l(1.42857146)
  min r2.y, r2.z, r2.y
  add r2.z, r2.x, -cb5[r1.x + 12].y
  add r3.x, -cb5[r1.x + 12].y, cb5[r1.x + 12].x
  div_sat r2.z, r2.z, r3.x
  div_sat r2.x, r2.x, cb5[r1.x + 12].x
  mul r3.x, r2.z, r2.z
  mul r3.y, r2.z, r3.x
  mul r3.z, r3.x, cb5[r1.x + 10].y
  mad r3.z, cb5[r1.x + 10].x, r3.y, r3.z
  mad r3.z, cb5[r1.x + 10].z, r2.z, r3.z
  add_sat r3.z, r3.z, cb5[r1.x + 10].w
  add r3.z, -r3.z, l(1.000000)
  mul r3.x, r3.x, cb5[r1.x + 11].y
  mad r3.x, cb5[r1.x + 11].x, r3.y, r3.x
  mad r2.z, cb5[r1.x + 11].z, r2.z, r3.x
  add_sat r2.z, r2.z, cb5[r1.x + 11].w
  add r2.z, -r2.z, l(1.000000)
  add r2.z, -r3.z, r2.z
  mad r2.z, r2.w, r2.z, r3.z
  add r2.z, -r2.z, l(1.000000)
  mad r2.z, -r2.z, cb0[22].z, l(1.000000)
  div_sat r3.x, cb5[r1.x + 0].y, cb5[r1.x + 12].x
  add r3.x, r3.x, l(-0.300000)
  mul r3.y, r3.x, r3.x
  mul r3.z, r3.x, r3.y
  mul r3.w, r3.y, cb5[r1.x + 10].y
  mad r3.w, cb5[r1.x + 10].x, r3.z, r3.w
  mad r3.w, cb5[r1.x + 10].z, r3.x, r3.w
  add_sat r3.w, r3.w, cb5[r1.x + 10].w
  mul r3.y, r3.y, cb5[r1.x + 11].y
  mad r3.y, cb5[r1.x + 11].x, r3.z, r3.y
  mad r3.y, cb5[r1.x + 11].z, r3.x, r3.y
  add_sat r3.y, r3.y, cb5[r1.x + 11].w
  add r3.y, -r3.w, r3.y
  mad r3.y, r2.w, r3.y, r3.w
  add r2.x, r2.x, -r3.x
  mul_sat r2.x, r2.x, l(3.33333325)
  add r3.x, -r3.y, l(1.000000)
  mad r3.x, r2.x, r3.x, r3.y
  add_sat r3.x, -r3.x, l(1.000000)
  add r3.x, -r2.z, r3.x
  mad r2.x, r2.x, r3.x, r2.z
  min r2.x, r2.x, r2.z
  add r2.y, -r2.x, r2.y
  mad r2.x, cb5[r1.x + 12].z, r2.y, r2.x
else
  add r2.y, -r1.z, cb5[r1.x + 1].y
  mul r2.y, r2.y, cb5[r1.x + 1].z
  max r2.y, r2.y, l(0.000000)
  log r2.y, r2.y
  mul r2.y, r2.y, cb5[r1.x + 1].w
  exp r2.y, r2.y
  min r2.x, r2.y, l(1.000000)
  mov r2.w, l(0)
endif
dp3 r2.y, v3.xyzx, v3.xyzx
rsq r2.y, r2.y
mul r3.xyz, r2.yyyy, v3.xyzx
add r1.z, r1.z, -cb5[r1.x + 13].w
div_sat r1.z, r1.z, cb5[r1.x + 6].w
mul r2.y, r1.z, r1.z
mul r2.y, r1.z, r2.y
add r4.xyz, -cb5[r1.y + 6].xyzx, cb5[r1.y + 13].xyzx
mad r4.xyz, r1.zzzz, r4.xyzx, cb5[r1.y + 6].xyzx
add r5.xyz, -cb5[r1.y + 3].xyzx, cb5[r1.y + 4].yzwy
mad r5.xyz, r2.yyyy, r5.xyzx, cb5[r1.y + 3].xyzx
add r4.xyz, r4.xyzx, -r5.xyzx
mad r2.yzw, r2.wwww, r4.xxyz, r5.xxyz
dp3_sat r1.z, r3.xyzx, cb5[r1.x + 8].xyzx
add r3.xyz, -r2.yzwy, cb5[r1.y + 5].yzwy
mul r3.xyz, r3.xyzx, cb5[r1.x + 7].xxxx
add_sat r1.y, r1.z, -cb5[r1.x + 5].x
lt r1.z, l(0.000000), r1.y
add r3.w, l(1.000000), -cb5[r1.x + 5].x
div r3.w, l(1.000000, 1.000000, 1.000000, 1.000000), r3.w
mul r1.y, r1.y, r3.w
mul r3.w, r1.y, r1.y
mul r1.y, r1.y, r3.w
mad r3.xyz, r1.yyyy, r3.xyzx, r2.yzwy
movc r2.yzw, r1.zzzz, r3.xxyz, r2.yyzw
mul r1.y, r1.w, r2.x
movc o0.w, r0.x, r1.y, r1.w
add r0.xyz, r0.yzwy, -r2.yzwy
mad r0.xyz, r2.xxxx, r0.xyzx, r2.yzwy
ne r0.w, l(0.000000, 0.000000, 0.000000, 0.000000), cb0[1].w
if_nz r0.w
  mad r2.xy, v0.xyxx, cb6[1].xyxx, cb6[1].zwzz
  div_sat r0.w, v3.z, cb5[r1.x + 0].y
  rsq r0.w, r0.w
  div r0.w, l(1.000000, 1.000000, 1.000000, 1.000000), r0.w
  add_sat r2.z, r0.w, l(-0.00390625000)
  sample_indexable(texture3d)(float,float,float,float) r1.xyzw, r2.xyzx, t16.xyzw, s13
  add r0.w, -r1.w, l(1.000000)
  min r1.w, v3.w, cb5[129].x
  add r2.xy, -r1.wwww, l(1.000000, 1.000001, 0.000000, 0.000000)
  mul r1.xyz, r1.xyzx, r2.xxxx
  log r0.w, |r0.w|
  mul r0.w, r0.w, r2.y
  exp r0.w, r0.w
  mad o0.xyz, r0.xyzx, r0.wwww, r1.xyzx
else
  mov o0.xyz, r0.xyzx
endif
ret
// Approximately 0 instruction slots used

///////////////////////////////// HLSL Code /////////////////////////////////
// // ---- Created with 3Dmigoto v1.3.16.58 on Tue Jan 31 01:12:50 2023
// Texture2D<float4> t20 : register(t20);
//
// Texture2D<float4> t19 : register(t19);
//
// Texture2D<float4> t18 : register(t18);
//
// Texture2D<float4> t17 : register(t17);
//
// Texture3D<float4> t16 : register(t16);
//
// Texture2D<float4> t12 : register(t12);
//
// Texture2D<float4> t11 : register(t11);
//
// Texture2D<float4> t4 : register(t4);
//
// Texture2D<float4> t3 : register(t3);
//
// Texture2D<float4> t2 : register(t2);
//
// Texture2D<float4> t1 : register(t1);
//
// Texture2D<float4> t0 : register(t0);
//
// SamplerState s13_s : register(s13);
//
// SamplerState s12_s : register(s12);
//
// SamplerState s11_s : register(s11);
//
// SamplerState s4_s : register(s4);
//
// SamplerState s3_s : register(s3);
//
// SamplerState s2_s : register(s2);
//
// SamplerState s1_s : register(s1);
//
// SamplerState s0_s : register(s0);
//
// cbuffer cb2 : register(b2)
// {
//   float4 cb2[2];
// }
//
// cbuffer cb0 : register(b0)
// {
//   float4 cb0[24];
// }
//
// cbuffer cb8 : register(b8)
// {
//   float4 cb8[9];
// }
//
// cbuffer cb7 : register(b7)
// {
//   float4 cb7[2];
// }
//
// cbuffer cb6 : register(b6)
// {
//   float4 cb6[2];
// }
//
// cbuffer cb5 : register(b5)
// {
//   float4 cb5[131];
// }
//
//
//
//
// // 3Dmigoto declarations
// #define cmp -
// Texture1D<float4> IniParams : register(t120);
// Texture2D<float4> StereoParams : register(t125);
//
//
// void main(
//   float4 v0 : SV_POSITION0,
//   float4 v1 : COLOR0,
//   float4 v2 : COLOR1,
//   float4 v3 : TEXCOORD0,
//   float4 v4 : TEXCOORD1,
//   float2 v5 : TEXCOORD2,
//   float2 w5 : TEXCOORD3,
//   float2 v6 : TEXCOORD4,
//   float2 w6 : TEXCOORD7,
//   float2 v7 : TEXCOORD8,
//   float2 w7 : TEXCOORD9,
//   float2 v8 : TEXCOORD6,
//   out float4 o0 : SV_TARGET0,
//   out uint oMask : SV_COVERAGE)
// {
//   float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11,r12,r13;
//   uint4 bitmask, uiDest;
//   float4 fDest;
//
//   r0.xyzw = cmp(asint(cb0[23].xxxx) == int4(4,2,3,5));
//   r0.w = r0.w ? 0.000000 : 0;
//   r0.z = r0.z ? 2 : r0.w;
//   r0.w = cmp((int)r0.z == 3);
//   r0.w = r0.y ? 0 : r0.w;
//   r0.y = (int)r0.w | (int)r0.y;
//   r0.y = r0.y ? 1 : r0.z;
//   r0.z = cmp((int)r0.y == 2);
//   if (r0.z != 0) {
//     r0.zw = float2(0,0);
//     while (true) {
//       r1.x = (int)r0.w;
//       r1.x = cmp(r1.x >= cb0[3].x);
//       if (r1.x != 0) break;
//       r1.xy = EvaluateAttributeAtSample(v5.xy, r0.w);
//       switch (cb2[0].x) {
//         case 0 :        r1.z = 1;
//         break;
//         case 0 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 1 :        r1.z = 1;
//         break;
//         case 2 :        r1.z = 1;
//         break;
//         case 3 :        r1.z = 1;
//         break;
//         case 4 :        r1.z = 1;
//         break;
//         case 5 :        r1.z = 1;
//         break;
//         case 6 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 7 :        r1.z = 1;
//         break;
//         case 8 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 9 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 1 :        r1.z = 1;
//         break;
//         case 1 :        r1.z = 1;
//         break;
//         case 1 :        r1.z = 1;
//         break;
//         case 1 :        r1.z = 1;
//         break;
//         case 1 :        r1.z = 1;
//         break;
//         case 1 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 1 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 1 :        r1.z = 1;
//         break;
//         case 1 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 1 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 2 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 2 :        r1.z = t0.Sample(s0_s, r1.xy).w;
//         break;
//         case 2 :        r1.z = 1;
//         break;
//         case 2 :        r1.z = 1;
//         break;
//         default :
//         r1.z = 1;
//         break;
//       }
//       r1.x = -0.501960814 + r1.z;
//       r1.x = cmp(r1.x >= 0);
//       r1.y = 1 << (int)r0.w;
//       r1.x = r1.x ? r1.y : 0;
//       r0.z = (int)r0.z | (int)r1.x;
//       r0.w = (int)r0.w + 1;
//     }
//     if (r0.z == 0) discard;
//     r0.w = cmp(0 < cb0[4].y);
//     r1.x = dot(v3.xyz, v3.xyz);
//     r1.x = rsqrt(r1.x);
//     r1.xyz = v3.xyz * r1.xxx;
//     r1.w = dot(-r1.xyz, v4.xyz);
//     r1.w = r1.w + r1.w;
//     r2.xyz = -r1.www * v4.xyz + -r1.xyz;
//     r2.w = 1 + r2.z;
//     r1.w = dot(r2.xyw, r2.xyw);
//     r1.w = rsqrt(r1.w);
//     r2.xy = r2.xy * r1.ww;
//     r2.xy = r2.xy * float2(0.5,0.5) + float2(0.5,0.5);
//     r3.xy = cmp(cb0[4].yy == float2(1,2));
//     r2.zw = v5.xy;
//     r4.xyzw = r3.yyyy ? r2.zwxy : r2.xyxy;
//     r2.zw = w5.xy;
//     r3.xyzw = r3.xxxx ? r2.xyzw : r4.xyzw;
//     r3.xyzw = r0.wwww ? r3.xyzw : v5.xyzw;
//     switch (cb2[0].x) {
//       case 0 :      r4.xyz = float3(0,0,0);
//       r5.xyz = float3(0,0,0);
//       r6.xyz = v2.xyz;
//       r7.x = 0;
//       break;
//       case 0 :      r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 2 :      r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 3 :      r4.xyzw = t0.Sample(s0_s, r3.xy).xyzw;
//       r8.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r5.xyz = r8.xyz * r4.www;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.x = 1;
//       break;
//       case 4 :      r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 5 :      r4.xyzw = t0.Sample(s0_s, r3.xy).xyzw;
//       r8.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r9.xyz = r4.xyz * r4.www;
//       r5.xyz = r9.xyz * r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.x = 1;
//       break;
//       case 6 :      r8.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r9.xyzw = t1.Sample(s1_s, r3.zw).xyzw;
//       r9.xyz = r9.xyz + -r8.xyz;
//       r9.xyz = r9.www * r9.xyz + r8.xyz;
//       r8.xyz = -r9.xyz + r8.xyz;
//       r4.xyz = v2.www * r8.xyz + r9.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 7 :      r8.xyzw = t0.Sample(s0_s, r3.xy).xyzw;
//       r9.xyzw = t1.Sample(s1_s, r3.zw).xyzw;
//       r10.xyz = t2.Sample(s2_s, v6.xy).xyz;
//       r8.xyzw = -r9.xyzw + r8.xyzw;
//       r4.xyzw = v2.wwww * r8.xyzw + r9.xyzw;
//       r8.xyz = r4.xyz * r4.www;
//       r5.xyz = r8.xyz * r10.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.x = 1;
//       break;
//       case 8 :      r8.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r9.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r8.xyz = -r9.xyz + r8.xyz;
//       r4.xyz = v2.www * r8.xyz + r9.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 9 :      r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r8.xyzw = t1.Sample(s1_s, r3.zw).xyzw;
//       r8.xyz = r8.xyz * r8.www;
//       r5.xyz = v2.www * r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.x = 0;
//       break;
//       case 1 :      r4.xyz = float3(0,0,0);
//       r5.xyz = float3(0,0,0);
//       r6.xyz = v2.xyz;
//       r7.x = 0;
//       break;
//       case 1 :      r8.xyzw = t0.Sample(s0_s, r3.xy).xyzw;
//       r9.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r10.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r9.xyz = r9.xyz * r8.xyz;
//       r11.xyz = r9.xyz + r9.xyz;
//       r0.w = saturate(v2.w * r10.w);
//       r9.xyz = -r9.xyz * float3(2,2,2) + r10.xyz;
//       r9.xyz = r0.www * r9.xyz + r11.xyz;
//       r8.xyz = -r9.xyz + r8.xyz;
//       r4.xyz = r8.www * r8.xyz + r9.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r4.xyzw = t0.Sample(s0_s, r3.xy).xyzw;
//       r8.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r9.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r10.xyz = r4.xyz * r4.www;
//       r9.xyz = r9.xyz * r9.www;
//       r9.xyz = v2.www * r9.xyz;
//       r5.xyz = r10.xyz * r8.xyz + r9.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.x = 0;
//       break;
//       case 1 :      r8.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r9.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r8.xyz = -r9.xyz + r8.xyz;
//       r4.xyz = v2.www * r8.xyz + r9.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r4.xyz = float3(0,0,0);
//       r5.xyz = float3(0,0,0);
//       r6.xyz = v2.xyz;
//       r7.x = 0;
//       break;
//       case 1 :      r8.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r9.xyzw = t1.Sample(s1_s, r3.zw).xyzw;
//       r0.w = 1 + -r9.w;
//       r10.xyz = r9.xyz * r0.www;
//       r8.xyz = -r9.xyz * r0.www + r8.xyz;
//       r4.xyz = v2.www * r8.xyz + r10.xyz;
//       r8.xyz = r9.xyz * r9.www;
//       r0.w = 1 + -v2.w;
//       r5.xyz = r8.xyz * r0.www;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.x = 0;
//       break;
//       case 1 :      r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r8.xyzw = t0.Sample(s0_s, r3.xy).xyzw;
//       r9.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r10.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r9.xyz = r9.xyz * r8.xyz;
//       r9.xyz = r9.xyz + r9.xyz;
//       r0.w = saturate(v2.w * r10.w);
//       r9.xyz = r10.xyz * r0.www + r9.xyz;
//       r8.xyz = -r9.xyz + r8.xyz;
//       r4.xyz = r8.www * r8.xyz + r9.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r8.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r9.xyzw = t1.Sample(s1_s, r3.zw).xyzw;
//       r10.xyz = t2.Sample(s2_s, v6.xy).xyz;
//       r9.xyz = r9.xyz + -r8.xyz;
//       r9.xyz = r9.www * r9.xyz + r8.xyz;
//       r8.xyz = -r9.xyz + r8.xyz;
//       r8.xyz = v2.www * r8.xyz + r9.xyz;
//       r8.xyz = r8.xyz * r10.xyz;
//       r4.xyz = r8.xyz + r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r8.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r9.xyz = t1.Sample(s1_s, r3.zw).xyz;
//       r9.xyz = r9.xyz * r8.xyz;
//       r9.xyz = r9.xyz * float3(2,2,2) + -r8.xyz;
//       r4.xyz = v2.www * r9.xyz + r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 2 :      r8.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r9.xyzw = t1.Sample(s1_s, r3.zw).xyzw;
//       r10.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r9.xyz = r9.xyz + -r8.xyz;
//       r9.xyz = r9.www * r9.xyz + r8.xyz;
//       r8.xyz = -r9.xyz + r8.xyz;
//       r8.xyz = r10.www * r8.xyz + r9.xyz;
//       r8.xyz = r8.xyz * r10.xyz;
//       r4.xyz = r8.xyz + r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 2 :      r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r8.xyz = t1.Sample(s1_s, r3.xy).xyz;
//       r5.xyz = t2.Sample(s2_s, r3.xy).xyz;
//       r6.xyz = r8.xyz + r8.xyz;
//       r7.x = 0;
//       break;
//       case 2 :      r8.xyz = t17.Sample(s3_s, r3.zw).xyz;
//       r9.xyz = ddx_coarse(v3.yzx);
//       r10.xyz = ddy_coarse(v3.zxy);
//       r2.zw = ddx_coarse(r3.zw);
//       r11.xy = ddy_coarse(r3.zw);
//       r12.xyz = v4.yzx * r10.xyz;
//       r10.xyz = r10.zxy * v4.zxy + -r12.xyz;
//       r12.xyz = v4.zxy * r9.xyz;
//       r9.xyz = v4.yzx * r9.yzx + -r12.xyz;
//       r11.xzw = r9.xyz * r11.xxx;
//       r11.xzw = r10.xyz * r2.zzz + r11.xzw;
//       r9.xyz = r9.xyz * r11.yyy;
//       r9.xyz = r10.xyz * r2.www + r9.xyz;
//       r0.w = dot(r11.xzw, r11.xzw);
//       r1.w = dot(r9.xyz, r9.xyz);
//       r0.w = max(r1.w, r0.w);
//       r0.w = rsqrt(r0.w);
//       r10.xyz = r0.www * r11.xzw;
//       r9.xyz = r0.www * r9.xyz;
//       r10.x = dot(r10.xyz, r1.xyz);
//       r10.y = dot(r9.xyz, r1.xyz);
//       r0.w = dot(v4.xyz, r1.xyz);
//       r1.xyzw = float4(0.25,0.25,0.5,0.5) * r8.xxxx;
//       r9.xyzw = r10.xyxy / r0.wwww;
//       r1.xy = -r9.xy * r1.xy + r3.zw;
//       r10.xyzw = t3.Sample(s3_s, r1.xy).xyzw;
//       r1.xy = -r9.zw * r1.zw + v6.xy;
//       r1.xyzw = t4.Sample(s3_s, r1.xy).xyzw;
//       r9.xyzw = t2.Sample(s3_s, r3.zw).xyzw;
//       r10.xyz = r10.xyz * r10.www + r1.xyz;
//       r11.xyz = -r10.xyz + r9.xyz;
//       r4.xyz = r8.yyy * r11.xyz + r10.xyz;
//       r1.xyz = r1.xyz * r1.www;
//       r0.w = 1 + -r8.y;
//       r1.xyz = r1.xyz * r0.www;
//       r1.xyz = r9.xyz * r8.zzz + r1.xyz;
//       r1.xyz = v2.www * -r1.xyz + r1.xyz;
//       r8.xyz = t1.Sample(s3_s, v7.xy).xyz;
//       r9.xyz = r9.xyz * r9.www;
//       r0.w = cmp(0 < v2.w);
//       if (r0.w != 0) {
//         r10.xyzw = t0.Sample(s3_s, r3.xy).xyzw;
//         r11.xyz = r10.xyz + -r4.xyz;
//         r4.xyz = v2.www * r11.xyz + r4.xyz;
//         r10.xyz = r10.xyz * r10.www + -r9.xyz;
//         r9.xyz = v2.www * r10.xyz + r9.xyz;
//       }
//       r5.xyz = r8.xyz * r9.xyz + r1.xyz;
//       r6.xyz = v2.xyz;
//       r7.x = 1;
//       break;
//       case 2 :      r1.xyz = t0.Sample(s0_s, r2.xy).xyz;
//       r0.w = saturate(dot(v7.xyz, float3(1,1,1)));
//       r2.w = 1 + -r0.w;
//       r8.xyzw = t1.Sample(s1_s, r3.xy).xyzw;
//       r9.xyzw = t2.Sample(s2_s, r3.zw).xyzw;
//       r10.xyzw = t3.Sample(s3_s, v6.xy).xyzw;
//       r11.xyzw = t4.Sample(s4_s, w6.xy).xyzw;
//       r0.w = t17.Sample(s1_s, r3.xy).w;
//       r1.w = t18.Sample(s2_s, r3.zw).w;
//       r3.z = t19.Sample(s3_s, v6.xy).w;
//       r3.w = t20.Sample(s4_s, w6.xy).w;
//       r12.x = max(0.00400000019, r0.w);
//       r12.y = max(0.00400000019, r1.w);
//       r12.zw = max(float2(0.00400000019,0.00400000019), r3.zw);
//       r2.xyz = v7.xyz;
//       r13.xyzw = r12.xyzw * r2.xyzw;
//       r0.w = max(r13.x, r13.y);
//       r0.w = max(r0.w, r13.z);
//       r0.w = max(r0.w, r13.w);
//       r2.xyzw = saturate(-r2.xyzw * r12.xyzw + r0.wwww);
//       r2.xyzw = float4(1,1,1,1) + -r2.xyzw;
//       r2.xyzw = r13.xyzw * r2.xyzw;
//       r0.w = dot(float4(1,1,1,1), r2.xyzw);
//       r0.w = rcp(r0.w);
//       r2.xyzw = r2.xyzw * r0.wwww;
//       r9.xyzw = r9.xyzw * r2.yyyy;
//       r8.xyzw = r8.xyzw * r2.xxxx + r9.xyzw;
//       r8.xyzw = r10.xyzw * r2.zzzz + r8.xyzw;
//       r2.xyzw = r11.xyzw * r2.wwww + r8.xyzw;
//       r8.xyz = r2.xyz * r2.www;
//       r5.xyz = r8.xyz * r1.xyz;
//       r1.xyz = cb2[1].xyz + -r2.xyz;
//       r4.xyz = w7.yww * r1.xyz + r2.xyz;
//       r6.xyz = v2.xyz;
//       r7.x = 1;
//       break;
//       default :
//       r4.xyz = t0.Sample(s0_s, r3.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//     }
//     r0.w = 1;
//     oMask = r0.z;
//   } else {
//     r0.z = cmp(0 < cb0[4].y);
//     r1.x = dot(v3.xyz, v3.xyz);
//     r1.x = rsqrt(r1.x);
//     r1.xyz = v3.xyz * r1.xxx;
//     r1.w = dot(-r1.xyz, v4.xyz);
//     r1.w = r1.w + r1.w;
//     r1.xyz = -r1.www * v4.xyz + -r1.xyz;
//     r1.w = 1 + r1.z;
//     r1.z = dot(r1.xyw, r1.xyw);
//     r1.z = rsqrt(r1.z);
//     r1.xy = r1.xy * r1.zz;
//     r1.xy = r1.xy * float2(0.5,0.5) + float2(0.5,0.5);
//     r2.xy = cmp(cb0[4].yy == float2(1,2));
//     r2.z = dot(v3.xyz, v3.xyz);
//     r2.z = rsqrt(r2.z);
//     r3.xyz = v3.xyz * r2.zzz;
//     r2.z = dot(-r3.xyz, v4.xyz);
//     r2.z = r2.z + r2.z;
//     r3.xyz = -r2.zzz * v4.xyz + -r3.xyz;
//     r3.w = 1 + r3.z;
//     r2.z = dot(r3.xyw, r3.xyw);
//     r2.z = rsqrt(r2.z);
//     r2.zw = r3.xy * r2.zz;
//     r3.zw = r2.zw * float2(0.5,0.5) + float2(0.5,0.5);
//     r3.xy = v5.xy;
//     r3.xyzw = r2.yyyy ? r3.xyzw : r3.zwzw;
//     r1.zw = w5.xy;
//     r2.xyzw = r2.xxxx ? r1.xyzw : r3.xyzw;
//     r2.xyzw = r0.zzzz ? r2.xyzw : v5.xyzw;
//     switch (cb2[0].x) {
//       case 0 :      r4.xyz = float3(0,0,0);
//       r5.xyz = float3(0,0,0);
//       r6.xyz = v2.xyz;
//       r7.xy = float2(0,1);
//       break;
//       case 0 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r4.xyz = r7.xzw;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r4.xyz = t0.Sample(s0_s, r2.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.xy = float2(0,1);
//       break;
//       case 2 :      r4.xyz = t0.Sample(s0_s, r2.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.xy = float2(0,1);
//       break;
//       case 3 :      r4.xyzw = t0.Sample(s0_s, r2.xy).xyzw;
//       r3.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r5.xyz = r4.www * r3.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.xy = float2(1,1);
//       break;
//       case 4 :      r4.xyz = t0.Sample(s0_s, r2.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.xy = float2(0,1);
//       break;
//       case 5 :      r4.xyzw = t0.Sample(s0_s, r2.xy).xyzw;
//       r3.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r8.xyz = r4.xyz * r4.www;
//       r5.xyz = r8.xyz * r3.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.xy = float2(1,1);
//       break;
//       case 6 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyzw = t1.Sample(s1_s, r2.zw).xyzw;
//       r3.xyz = r3.xyz + -r7.xzw;
//       r3.xyz = r3.www * r3.xyz + r7.xzw;
//       r8.xyz = r7.xzw + -r3.xyz;
//       r4.xyz = v2.www * r8.xyz + r3.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 7 :      r3.xyzw = t0.Sample(s0_s, r2.xy).xyzw;
//       r8.xyzw = t1.Sample(s1_s, r2.zw).xyzw;
//       r9.xyz = t2.Sample(s2_s, v6.xy).xyz;
//       r3.xyzw = -r8.xyzw + r3.xyzw;
//       r4.xyzw = v2.wwww * r3.xyzw + r8.xyzw;
//       r3.xyz = r4.xyz * r4.www;
//       r5.xyz = r3.xyz * r9.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.xy = float2(1,1);
//       break;
//       case 8 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r8.xyz = r7.xzw + -r3.xyz;
//       r4.xyz = v2.www * r8.xyz + r3.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 9 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyzw = t1.Sample(s1_s, r2.zw).xyzw;
//       r3.xyz = r3.xyz * r3.www;
//       r5.xyz = v2.www * r3.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r4.xyz = r7.xzw;
//       r7.x = 0;
//       break;
//       case 1 :      r4.xyz = float3(0,0,0);
//       r5.xyz = float3(0,0,0);
//       r6.xyz = v2.xyz;
//       r7.xy = float2(0,1);
//       break;
//       case 1 :      r3.xyzw = t0.Sample(s0_s, r2.xy).xyzw;
//       r8.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r9.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r8.xyz = r8.xyz * r3.xyz;
//       r10.xyz = r8.xyz + r8.xyz;
//       r0.z = saturate(v2.w * r9.w);
//       r8.xyz = -r8.xyz * float3(2,2,2) + r9.xyz;
//       r8.xyz = r0.zzz * r8.xyz + r10.xyz;
//       r3.xyz = -r8.xyz + r3.xyz;
//       r4.xyz = r3.www * r3.xyz + r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.xy = float2(0,1);
//       break;
//       case 1 :      r4.xyzw = t0.Sample(s0_s, r2.xy).xyzw;
//       r3.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r8.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r9.xyz = r4.xyz * r4.www;
//       r8.xyz = r8.xyz * r8.www;
//       r8.xyz = v2.www * r8.xyz;
//       r5.xyz = r9.xyz * r3.xyz + r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.xy = float2(0,1);
//       break;
//       case 1 :      r3.xyz = t0.Sample(s0_s, r2.xy).xyz;
//       r8.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r3.xyz = -r8.xyz + r3.xyz;
//       r4.xyz = v2.www * r3.xyz + r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.xy = float2(0,1);
//       break;
//       case 1 :      r4.xyz = float3(0,0,0);
//       r5.xyz = float3(0,0,0);
//       r6.xyz = v2.xyz;
//       r7.xy = float2(0,1);
//       break;
//       case 1 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyzw = t1.Sample(s1_s, r2.zw).xyzw;
//       r0.z = 1 + -r3.w;
//       r8.xyz = r3.xyz * r0.zzz;
//       r9.xyz = -r3.xyz * r0.zzz + r7.xzw;
//       r4.xyz = v2.www * r9.xyz + r8.xyz;
//       r3.xyz = r3.xyz * r3.www;
//       r0.z = 1 + -v2.w;
//       r5.xyz = r3.xyz * r0.zzz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r7.x = 0;
//       break;
//       case 1 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r4.xyz = r7.xzw;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r3.xyzw = t0.Sample(s0_s, r2.xy).xyzw;
//       r8.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r9.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r8.xyz = r8.xyz * r3.xyz;
//       r8.xyz = r8.xyz + r8.xyz;
//       r0.z = saturate(v2.w * r9.w);
//       r8.xyz = r9.xyz * r0.zzz + r8.xyz;
//       r3.xyz = -r8.xyz + r3.xyz;
//       r4.xyz = r3.www * r3.xyz + r8.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.xy = float2(0,1);
//       break;
//       case 1 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyzw = t1.Sample(s1_s, r2.zw).xyzw;
//       r8.xyz = t2.Sample(s2_s, v6.xy).xyz;
//       r3.xyz = r3.xyz + -r7.xzw;
//       r3.xyz = r3.www * r3.xyz + r7.xzw;
//       r9.xyz = r7.xzw + -r3.xyz;
//       r3.xyz = v2.www * r9.xyz + r3.xyz;
//       r3.xyz = r3.xyz * r8.xyz;
//       r4.xyz = r3.xyz + r3.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 1 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyz = t1.Sample(s1_s, r2.zw).xyz;
//       r3.xyz = r7.xzw * r3.xyz;
//       r3.xyz = r3.xyz * float3(2,2,2) + -r7.xzw;
//       r4.xyz = v2.www * r3.xyz + r7.xzw;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 2 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyzw = t1.Sample(s1_s, r2.zw).xyzw;
//       r8.xyzw = t2.Sample(s2_s, v6.xy).xyzw;
//       r3.xyz = r3.xyz + -r7.xzw;
//       r3.xyz = r3.www * r3.xyz + r7.xzw;
//       r9.xyz = r7.xzw + -r3.xyz;
//       r3.xyz = r8.www * r9.xyz + r3.xyz;
//       r3.xyz = r3.xyz * r8.xyz;
//       r4.xyz = r3.xyz + r3.xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.x = 0;
//       break;
//       case 2 :      r7.xyzw = t0.Sample(s0_s, r2.xy).xwyz;
//       r3.xyz = t1.Sample(s1_s, r2.xy).xyz;
//       r5.xyz = t2.Sample(s2_s, r2.xy).xyz;
//       r6.xyz = r3.xyz + r3.xyz;
//       r4.xyz = r7.xzw;
//       r7.x = 0;
//       break;
//       case 2 :      r3.xyz = t17.Sample(s3_s, r2.zw).xyz;
//       r8.xyz = ddx_coarse(v3.yzx);
//       r9.xyz = ddy_coarse(v3.zxy);
//       r1.zw = ddx_coarse(r2.zw);
//       r7.zw = ddy_coarse(r2.zw);
//       r10.xyz = v4.yzx * r9.xyz;
//       r9.xyz = r9.zxy * v4.zxy + -r10.xyz;
//       r10.xyz = v4.zxy * r8.xyz;
//       r8.xyz = v4.yzx * r8.yzx + -r10.xyz;
//       r10.xyz = r8.xyz * r7.zzz;
//       r10.xyz = r9.xyz * r1.zzz + r10.xyz;
//       r8.xyz = r8.xyz * r7.www;
//       r8.xyz = r9.xyz * r1.www + r8.xyz;
//       r0.z = dot(r10.xyz, r10.xyz);
//       r1.z = dot(r8.xyz, r8.xyz);
//       r0.z = max(r1.z, r0.z);
//       r0.z = rsqrt(r0.z);
//       r9.xyz = r0.zzz * r10.xyz;
//       r8.xyz = r0.zzz * r8.xyz;
//       r0.z = dot(v3.xyz, v3.xyz);
//       r0.z = rsqrt(r0.z);
//       r10.xyz = v3.xyz * r0.zzz;
//       r9.x = dot(r9.xyz, r10.xyz);
//       r9.y = dot(r8.xyz, r10.xyz);
//       r0.z = dot(v4.xyz, r10.xyz);
//       r8.xyzw = float4(0.25,0.25,0.5,0.5) * r3.xxxx;
//       r9.xyzw = r9.xyxy / r0.zzzz;
//       r1.zw = -r9.xy * r8.xy + r2.zw;
//       r10.xyzw = t3.Sample(s3_s, r1.zw).xyzw;
//       r1.zw = -r9.zw * r8.zw + v6.xy;
//       r8.xyzw = t4.Sample(s3_s, r1.zw).xyzw;
//       r9.xyzw = t2.Sample(s3_s, r2.zw).xyzw;
//       r10.xyz = r10.xyz * r10.www + r8.xyz;
//       r11.xyz = -r10.xyz + r9.xyz;
//       r4.xyz = r3.yyy * r11.xyz + r10.xyz;
//       r8.xyz = r8.xyz * r8.www;
//       r0.z = 1 + -r3.y;
//       r3.xyw = r8.xyz * r0.zzz;
//       r3.xyz = r9.xyz * r3.zzz + r3.xyw;
//       r3.xyz = v2.www * -r3.xyz + r3.xyz;
//       r8.xyz = t1.Sample(s3_s, v7.xy).xyz;
//       r9.xyz = r9.xyz * r9.www;
//       r0.z = cmp(0 < v2.w);
//       if (r0.z != 0) {
//         r10.xyzw = t0.Sample(s3_s, r2.xy).xyzw;
//         r11.xyz = r10.xyz + -r4.xyz;
//         r4.xyz = v2.www * r11.xyz + r4.xyz;
//         r10.xyz = r10.xyz * r10.www + -r9.xyz;
//         r9.xyz = v2.www * r10.xyz + r9.xyz;
//       }
//       r5.xyz = r8.xyz * r9.xyz + r3.xyz;
//       r6.xyz = v2.xyz;
//       r7.xy = float2(1,1);
//       break;
//       case 2 :      r1.xyz = t0.Sample(s0_s, r1.xy).xyz;
//       r0.z = saturate(dot(v7.xyz, float3(1,1,1)));
//       r3.w = 1 + -r0.z;
//       r8.xyzw = t1.Sample(s1_s, r2.xy).xyzw;
//       r9.xyzw = t2.Sample(s2_s, r2.zw).xyzw;
//       r10.xyzw = t3.Sample(s3_s, v6.xy).xyzw;
//       r11.xyzw = t4.Sample(s4_s, w6.xy).xyzw;
//       r0.z = t17.Sample(s1_s, r2.xy).w;
//       r1.w = t18.Sample(s2_s, r2.zw).w;
//       r2.z = t19.Sample(s3_s, v6.xy).w;
//       r2.w = t20.Sample(s4_s, w6.xy).w;
//       r12.x = max(0.00400000019, r0.z);
//       r12.y = max(0.00400000019, r1.w);
//       r12.zw = max(float2(0.00400000019,0.00400000019), r2.zw);
//       r3.xyz = v7.xyz;
//       r13.xyzw = r12.xyzw * r3.xyzw;
//       r0.z = max(r13.x, r13.y);
//       r0.z = max(r0.z, r13.z);
//       r0.z = max(r0.z, r13.w);
//       r3.xyzw = saturate(-r3.xyzw * r12.xyzw + r0.zzzz);
//       r3.xyzw = float4(1,1,1,1) + -r3.xyzw;
//       r3.xyzw = r13.xyzw * r3.xyzw;
//       r0.z = dot(float4(1,1,1,1), r3.xyzw);
//       r0.z = rcp(r0.z);
//       r3.xyzw = r3.xyzw * r0.zzzz;
//       r9.xyzw = r9.xyzw * r3.yyyy;
//       r8.xyzw = r8.xyzw * r3.xxxx + r9.xyzw;
//       r8.xyzw = r10.xyzw * r3.zzzz + r8.xyzw;
//       r3.xyzw = r11.xyzw * r3.wwww + r8.xyzw;
//       r8.xyz = r3.xyz * r3.www;
//       r5.xyz = r8.xyz * r1.xyz;
//       r1.xyz = cb2[1].xyz + -r3.xyz;
//       r4.xyz = w7.yww * r1.xyz + r3.xyz;
//       r6.xyz = v2.xyz;
//       r7.xy = float2(1,1);
//       break;
//       default :
//       r4.xyz = t0.Sample(s0_s, r2.xy).xyz;
//       r6.xyz = cb8[6].www * v2.xyz;
//       r5.xyz = float3(0,0,0);
//       r7.xy = float2(0,1);
//       break;
//     }
//     r0.z = cmp((int)r0.y != 0);
//     r1.x = -0.501960814 + r7.y;
//     r1.x = cmp(r1.x < 0);
//     r0.z = r0.z ? r1.x : 0;
//     if (r0.z != 0) discard;
//     r0.z = cmp(asint(cb0[23].x) == 1);
//     r0.z = r0.z ? 1 : r7.y;
//     r0.w = r0.y ? 1 : r0.z;
//     oMask = -1;
//   }
//   r0.y = dot(v4.xyz, v4.xyz);
//   r0.y = rsqrt(r0.y);
//   r1.xyz = v4.xyz * r0.yyy;
//   r0.y = dot(r1.xyz, -cb8[3].xyz);
//   r0.z = dot(r1.xyz, cb8[8].xyz);
//   r1.xy = v0.xy * cb5[127].xy + cb5[127].zw;
//   r1.xy = t12.Sample(s12_s, r1.xy).xy;
//   r1.zw = v0.xy * cb5[126].xy + cb5[126].zw;
//   r2.xyz = t11.Sample(s11_s, r1.zw).xyz;
//   r3.xyz = v1.xyz * r4.xyz;
//   r3.xyz = r3.xyz + r3.xyz;
//   r1.z = r1.x * 0.5 + 0.5;
//   r7.yzw = r6.xyz * r1.zzz + cb8[0].xyz;
//   r8.xyz = r6.xyz * r1.zzz + cb8[1].xyz;
//   r6.xyz = r6.xyz * r1.zzz + cb8[2].xyz;
//   r1.z = cmp(r0.z >= 0);
//   r7.yzw = -r8.xyz + r7.yzw;
//   r7.yzw = r0.zzz * r7.yzw + r8.xyz;
//   r6.xyz = r6.xyz + -r8.xyz;
//   r6.xyz = -r0.zzz * r6.xyz + r8.xyz;
//   r6.xyz = r1.zzz ? r7.yzw : r6.xyz;
//   r0.y = r0.y * 0.5 + 0.5;
//   r7.yzw = r6.xyz * r0.yyy;
//   r7.yzw = float3(0.400000036,0.400000036,0.400000036) * r7.yzw;
//   r6.xyz = r6.xyz * float3(0.699999988,0.699999988,0.699999988) + r7.yzw;
//   r0.y = saturate(dot(v4.xyz, -cb8[3].xyz));
//   r7.yzw = cb8[4].xyz * r0.yyy;
//   r1.xzw = r7.yzw * r1.xxx;
//   r1.xyz = r6.xyz * r1.yyy + r1.xzw;
//   r1.xyz = r3.xyz * r1.xyz;
//   r3.xyz = r3.xyz * r3.xyz;
//   r2.xyz = r3.xyz * r2.xyz;
//   r3.w = v1.w * r0.w;
//   r0.y = 1 + -v3.w;
//   r0.y = r0.y * r0.y;
//   r6.xyz = cb7[1].xyz * r4.xyz;
//   r6.xyz = cb7[0].www * r6.xyz;
//   r0.z = dot(v4.xyz, cb7[0].xyz);
//   r0.w = saturate(r0.z);
//   r3.xyz = r6.xyz * r0.www;
//   r0.w = cmp(cb7[0].w < 0);
//   r0.z = saturate(-r0.z);
//   r1.w = cb7[1].w * -0.75 + 0.800000012;
//   r1.w = saturate(-cb7[0].w * r1.w);
//   r2.w = saturate(r3.w);
//   r2.w = cb7[1].w * r2.w;
//   r2.w = -r2.w * r2.w + 1;
//   r0.z = r2.w * r0.z;
//   r2.w = saturate(5 * r0.z);
//   r1.w = -r1.w * r2.w + 1;
//   r6.w = r3.w * r1.w;
//   r4.xyz = r4.xyz * r0.zzz;
//   r4.xyz = cb7[1].xyz * r4.xyz;
//   r6.xyz = -cb7[0].www * r4.xyz;
//   r4.xyzw = r0.wwww ? r6.xyzw : r3.xyzw;
//   r6.xyz = r4.xyz * r0.yyy;
//   r0.z = r0.y * r4.w + -r3.w;
//   r0.y = r0.y * r0.z + r3.w;
//   r0.z = saturate(v3.z * v8.x + v8.y);
//   r0.z = -1 + r0.z;
//   r0.z = r7.x * r0.z + 1;
//   r1.xyz = r1.xyz * r1.xyz + r2.xyz;
//   r1.xyz = sqrt(r1.xyz);
//   r1.xyz = r5.xyz * r0.zzz + r1.xyz;
//   r1.w = cb0[4].x * r0.y;
//   r6.w = 0;
//   r1.xyzw = r6.xyzw + r1.xyzw;
//   r0.y = cmp(cb0[16].w != 0.000000);
//   if (r0.y != 0) {
//     r0.yzw = cb0[16].xyz + -r1.xyz;
//     r1.xyz = cb0[16].www * r0.yzw + r1.xyz;
//   }
//   r0.yzw = cb0[4].xxx * r1.xyz;
//   r0.yzw = r0.xxx ? r0.yzw : r1.xyz;
//   r1.xy = (uint2)cb0[0].xz;
//   r1.xy = (int2)r1.xy * int2(14,14);
//   r1.z = dot(v3.xyz, v3.xyz);
//   r1.z = sqrt(r1.z);
//   r2.x = cmp(0 != cb5[r1.x+1].x);
//   if (r2.x == 0) {
//     r2.x = dot(cb5[130].xyz, v3.xyz);
//     r2.y = cmp(0 < r2.x);
//     r2.z = max(cb5[r1.x+8].w, 0);
//     r2.z = min(r2.z, r2.x);
//     r3.xyz = -cb5[130].xyz * r2.zzz + v3.xyz;
//     r2.x = max(-cb5[r1.x+8].w, r2.x);
//     r2.x = min(0, r2.x);
//     r2.xzw = -cb5[130].xyz * r2.xxx + v3.xyz;
//     r2.xyz = r2.yyy ? r3.xyz : r2.xzw;
//     r2.x = dot(r2.xyz, r2.xyz);
//     r2.x = sqrt(r2.x);
//     r2.y = -cb5[r1.x+0].x + r2.x;
//     r2.y = max(0, r2.y);
//     r2.z = cb5[r1.x+4].x * r2.y;
//     r2.z = 1.44269502 * r2.z;
//     r2.z = exp2(r2.z);
//     r2.w = dot(cb5[r1.x+2].xyz, v3.xyz);
//     r2.w = cb5[r1.x+2].w + r2.w;
//     r2.w = saturate(cb5[r1.x+3].w * r2.w);
//     r2.w = 1 + -r2.w;
//     r3.x = r2.w * r2.w;
//     r3.y = r3.x * r2.w;
//     r3.x = cb5[r1.x+9].y * r3.x;
//     r3.x = cb5[r1.x+9].x * r3.y + r3.x;
//     r2.w = cb5[r1.x+9].z * r2.w + r3.x;
//     r2.w = saturate(cb5[r1.x+9].w + r2.w);
//     r2.w = 1 + -r2.w;
//     r3.x = r2.x / cb5[r1.x+0].y;
//     r2.y = cb5[r1.x+0].z * r2.y;
//     r2.y = 1.44269502 * r2.y;
//     r2.y = exp2(r2.y);
//     r2.yz = rcp(r2.yz);
//     r2.z = r2.z + -r2.y;
//     r2.y = r2.w * r2.z + r2.y;
//     r2.y = 1 + -r2.y;
//     r2.y = -r2.y * cb0[22].z + 1;
//     r2.z = 1 + -r3.x;
//     r2.z = saturate(1.42857146 * r2.z);
//     r2.y = min(r2.y, r2.z);
//     r2.z = -cb5[r1.x+12].y + r2.x;
//     r3.x = cb5[r1.x+12].x + -cb5[r1.x+12].y;
//     r2.z = saturate(r2.z / r3.x);
//     r2.x = saturate(r2.x / cb5[r1.x+12].x);
//     r3.x = r2.z * r2.z;
//     r3.y = r3.x * r2.z;
//     r3.z = cb5[r1.x+10].y * r3.x;
//     r3.z = cb5[r1.x+10].x * r3.y + r3.z;
//     r3.z = cb5[r1.x+10].z * r2.z + r3.z;
//     r3.z = saturate(cb5[r1.x+10].w + r3.z);
//     r3.z = 1 + -r3.z;
//     r3.x = cb5[r1.x+11].y * r3.x;
//     r3.x = cb5[r1.x+11].x * r3.y + r3.x;
//     r2.z = cb5[r1.x+11].z * r2.z + r3.x;
//     r2.z = saturate(cb5[r1.x+11].w + r2.z);
//     r2.z = 1 + -r2.z;
//     r2.z = r2.z + -r3.z;
//     r2.z = r2.w * r2.z + r3.z;
//     r2.z = 1 + -r2.z;
//     r2.z = -r2.z * cb0[22].z + 1;
//     r3.x = saturate(cb5[r1.x+0].y / cb5[r1.x+12].x);
//     r3.x = -0.300000012 + r3.x;
//     r3.y = r3.x * r3.x;
//     r3.z = r3.y * r3.x;
//     r3.w = cb5[r1.x+10].y * r3.y;
//     r3.w = cb5[r1.x+10].x * r3.z + r3.w;
//     r3.w = cb5[r1.x+10].z * r3.x + r3.w;
//     r3.w = saturate(cb5[r1.x+10].w + r3.w);
//     r3.y = cb5[r1.x+11].y * r3.y;
//     r3.y = cb5[r1.x+11].x * r3.z + r3.y;
//     r3.y = cb5[r1.x+11].z * r3.x + r3.y;
//     r3.y = saturate(cb5[r1.x+11].w + r3.y);
//     r3.y = r3.y + -r3.w;
//     r3.y = r2.w * r3.y + r3.w;
//     r2.x = -r3.x + r2.x;
//     r2.x = saturate(3.33333325 * r2.x);
//     r3.x = 1 + -r3.y;
//     r3.x = r2.x * r3.x + r3.y;
//     r3.x = saturate(1 + -r3.x);
//     r3.x = r3.x + -r2.z;
//     r2.x = r2.x * r3.x + r2.z;
//     r2.x = min(r2.z, r2.x);
//     r2.y = r2.y + -r2.x;
//     r2.x = cb5[r1.x+12].z * r2.y + r2.x;
//   } else {
//     r2.y = cb5[r1.x+1].y + -r1.z;
//     r2.y = cb5[r1.x+1].z * r2.y;
//     r2.y = max(0, r2.y);
//     r2.y = log2(r2.y);
//     r2.y = cb5[r1.x+1].w * r2.y;
//     r2.y = exp2(r2.y);
//     r2.x = min(1, r2.y);
//     r2.w = 0;
//   }
//   r2.y = dot(v3.xyz, v3.xyz);
//   r2.y = rsqrt(r2.y);
//   r3.xyz = v3.xyz * r2.yyy;
//   r1.z = -cb5[r1.x+13].w + r1.z;
//   r1.z = saturate(r1.z / cb5[r1.x+6].w);
//   r2.y = r1.z * r1.z;
//   r2.y = r2.y * r1.z;
//   r4.xyz = cb5[r1.y+13].xyz + -cb5[r1.y+6].xyz;
//   r4.xyz = r1.zzz * r4.xyz + cb5[r1.y+6].xyz;
//   r5.xyz = cb5[r1.y+4].yzw + -cb5[r1.y+3].xyz;
//   r5.xyz = r2.yyy * r5.xyz + cb5[r1.y+3].xyz;
//   r4.xyz = -r5.xyz + r4.xyz;
//   r2.yzw = r2.www * r4.xyz + r5.xyz;
//   r1.z = saturate(dot(r3.xyz, cb5[r1.x+8].xyz));
//   r3.xyz = cb5[r1.y+5].yzw + -r2.yzw;
//   r3.xyz = cb5[r1.x+7].xxx * r3.xyz;
//   r1.y = saturate(-cb5[r1.x+5].x + r1.z);
//   r1.z = cmp(0 < r1.y);
//   r3.w = -cb5[r1.x+5].x + 1;
//   r3.w = 1 / r3.w;
//   r1.y = r3.w * r1.y;
//   r3.w = r1.y * r1.y;
//   r1.y = r3.w * r1.y;
//   r3.xyz = r1.yyy * r3.xyz + r2.yzw;
//   r2.yzw = r1.zzz ? r3.xyz : r2.yzw;
//   r1.y = r2.x * r1.w;
//   o0.w = r0.x ? r1.y : r1.w;
//   r0.xyz = -r2.yzw + r0.yzw;
//   r0.xyz = r2.xxx * r0.xyz + r2.yzw;
//   r0.w = cmp(0 != cb0[1].w);
//   if (r0.w != 0) {
//     r2.xy = v0.xy * cb6[1].xy + cb6[1].zw;
//     r0.w = saturate(v3.z / cb5[r1.x+0].y);
//     r0.w = rsqrt(r0.w);
//     r0.w = 1 / r0.w;
//     r2.z = saturate(-0.00390625 + r0.w);
//     r1.xyzw = t16.Sample(s13_s, r2.xyz).xyzw;
//     r0.w = 1 + -r1.w;
//     r1.w = min(cb5[129].x, v3.w);
//     r2.xy = float2(1,1.00000095) + -r1.ww;
//     r1.xyz = r2.xxx * r1.xyz;
//     r0.w = log2(abs(r0.w));
//     r0.w = r2.y * r0.w;
//     r0.w = exp2(r0.w);
//     o0.xyz = r0.xyz * r0.www + r1.xyz;
//   } else {
//     o0.xyz = r0.xyz;
//   }
//   return;
// }
//////////////////////////////// HLSL Errors ////////////////////////////////
// C:\Games\World of Warcraft\_retail_\ShaderFixes\93523a6e15f7402b-ps_replace.txt(196,35-41): error X3018: invalid subscript 'xyzw'
/////////////////////////////////////////////////////////////////////////////
