//Eyes decals.
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16 on Sat May 22 18:20:32 2021
//
//
// Note: shader requires additional functionality:
//       Early depth-stencil
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// TEXCOORD                10   xyzw        0     NONE   float   xyz
// TEXCOORD                11   xyzw        1     NONE   float   xyzw
// COLOR                    0   xyzw        2     NONE   float
// TEXCOORD                 0   xy          3     NONE   float   xy
// TEXCOORD                12   x           4     NONE    uint
// SV_IsFrontFace           0    y          4    FFACE    uint
// TEXCOORD                 7   xyz         5     NONE   float   xyz
// TEXCOORD                 8   xyzw        6     NONE   float   xyzw
// TEXCOORD                 9   xyzw        7     NONE   float   xyzw
// SV_POSITION              0   xyzw        8      POS   float   xy
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_Target                0   xyzw        0   TARGET   float   xyzw
//
ps_5_0
dcl_globalFlags refactoringAllowed | forceEarlyDepthStencil
dcl_constantbuffer cb0[3], immediateIndexed
dcl_constantbuffer cb1[81], immediateIndexed
dcl_constantbuffer cb2[86], dynamicIndexed
dcl_constantbuffer cb3[40], immediateIndexed
dcl_constantbuffer cb4[17], dynamicIndexed
dcl_constantbuffer cb5[50], dynamicIndexed
dcl_constantbuffer cb6[14], 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 s5, mode_default
dcl_sampler s6, mode_comparison
dcl_sampler s7, mode_default
dcl_resource_texture2d (uint,uint,uint,uint) t0
dcl_resource_texture2d (uint,uint,uint,uint) 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_texturecube (float,float,float,float) t5
dcl_resource_texture2d (float,float,float,float) t6
dcl_resource_texture2darray (float,float,float,float) t7
dcl_resource_texture2d (float,float,float,float) t8
dcl_resource_texture3d (float,float,float,float) t9
dcl_resource_texture3d (float,float,float,float) t10
dcl_resource_texture3d (float,float,float,float) t11
dcl_resource_texture3d (float,float,float,float) t12
dcl_resource_texture3d (float,float,float,float) t13
dcl_resource_texture2d (float,float,float,float) t14
dcl_resource_texture2d (float,float,float,float) t15
dcl_resource_texture2darray (float,float,float,float) t16
dcl_resource_texture2d (float,float,float,float) t17
dcl_resource_texture2d (float,float,float,float) t18
dcl_resource_texture3d (float,float,float,float) t19
dcl_resource_texture3d (float,float,float,float) t20
dcl_resource_texture2d (float,float,float,float) t21
dcl_resource_texture2d (float,float,float,float) t22
dcl_resource_texture2d (float,float,float,float) t23
dcl_resource_texture2d (float,float,float,float) t24
dcl_resource_texture2d (float,float,float,float) t25
dcl_input_ps linear centroid v0.xyz
dcl_input_ps linear centroid v1.xyzw
dcl_input_ps linear v3.xy
dcl_input_ps linear v5.xyz
dcl_input_ps linear v6.xyzw
dcl_input_ps linear v7.xyzw
dcl_input_ps_siv linear noperspective v8.xy, position
dcl_output o0.xyzw
dcl_temps 40
dcl_resource_texture2d (float,float,float,float) t125
ld_indexable(texture2d)(float,float,float,float) r25.xyzw, l(0, 0, 0, 0), t125.xyzw
ld_indexable(texture2d)(float,float,float,float) r26.xyzw, l(2, 0, 0, 0), t125.xyzw
dcl_resource_texture1d (float,float,float,float) t120
ld_indexable(texture1d)(float,float,float,float) r35.xyzw, l(10, 0, 0, 0), t120.xyzw

mov r23.xyz, v5.xyzx

mul r30.xyz, v5.yyyy, cb5[41].xyzx
mad r30.xyz, r23.xxxx, cb5[40].xyzx, r30.xyzx
mad r30.xyz, v5.zzzz, cb5[42].xyzx, r30.xyzx
add r30.xyz, r30.xyzx, cb5[43].xyzx

//mul r25.w, r26.x, l(0.5)
//mul r25.w, r25.w, r35.x
//mad r23.x, -r25.x, l(0.0), r23.x

mul r31.xyz, v5.yyyy, cb5[41].xyzx
mad r31.xyz, r23.xxxx, cb5[40].xyzx, r31.xyzx
mad r31.xyz, v5.zzzz, cb5[42].xyzx, r31.xyzx
add r31.xyz, r31.xyzx, cb5[43].xyzx

//div r25.w, r26.x, r26.x
//mul r25.w, r25.w, r35.x
//mul r25.w, r25.w, r30.z
//mul r25.w, r25.w, -r25.y
//mul r25.w, r25.w, l(0.0625)
//mad r23.x, r25.x, r25.w, r23.x

mul r0.xyz, v5.yyyy, cb5[41].xyzx
mad r0.xyz, r23.xxxx, cb5[40].xyzx, r0.xyzx
mad r0.xyz, v5.zzzz, cb5[42].xyzx, r0.xyzx
add r0.xyz, r0.xyzx, cb5[43].xyzx
mul r1.xyz, v5.yyyy, cb5[45].xyzx
mad r1.xyz, v5.xxxx, cb5[44].xyzx, r1.xyzx
mad r1.xyz, v5.zzzz, cb5[46].xyzx, r1.xyzx
add r1.xyz, r1.xyzx, cb5[47].xyzx
dp3 r0.w, r0.xyzx, r0.xyzx
dp3 r1.w, r1.xyzx, r1.xyzx
lt r0.w, r0.w, r1.w
movc r0.xyz, r0.wwww, r0.xyzx, r1.xyzx
movc r1.xy, r0.wwww, l(0,0,0,0), l(8,1,0,0)
mov r2.xyz, cb5[r1.x + 0].xyzx
mov r3.xyz, cb5[r1.x + 16].xyzx
mov r1.z, cb5[r1.x + 16].w
mov r1.w, l(0)
mov r4.x, l(0)
mov r5.xyz, l(0,0,0,0)
mov r2.w, l(7)
loop
  ilt r3.w, r2.w, l(0)
  breakc_nz r3.w
  iadd r3.w, r1.x, r2.w
  add r6.xyz, -r2.zxyz, cb5[r3.w + 0].zxyz
  add r7.xyz, cb5[r3.w + 0].xyzx, -cb5[r1.y + 48].xyzx
  mul r8.xyz, r6.xyzx, r7.yzxy
  mad r8.xyz, r6.zxyz, r7.zxyz, -r8.xyzx
  dp3 r6.w, r0.xyzx, r8.xyzx
  dp3 r7.w, cb5[r3.w + 0].xyzx, r8.xyzx
  div r6.w, r7.w, r6.w
  mul r8.xyz, r0.xyzx, r6.wwww
  lt r7.w, l(0.000000), r6.w
  mul r9.xyz, r6.xyzx, r8.yzxy
  mad r6.xyz, r6.zxyz, r8.zxyz, -r9.xyzx
  dp3 r7.x, r6.xyzx, r7.xyzx
  mad r8.xyz, -r0.xyzx, r6.wwww, cb5[r3.w + 0].xyzx
  dp3 r6.x, r6.xyzx, r8.xyzx
  add r6.x, -r6.x, r7.x
  div r6.x, r7.x, r6.x
  lt r6.y, l(0.000000), r6.x
  mad r8.yzw, r0.xxyz, r6.wwww, -cb5[r1.y + 48].xxyz
  mad r6.xzw, r8.yyzw, r6.xxxx, cb5[r1.y + 48].xxyz
  add r6.xzw, r6.xxzw, -cb5[r3.w + 0].xxyz
  add r7.xyz, r2.xyzx, -cb5[r3.w + 0].xyzx
  dp3 r6.x, r6.xzwx, r7.xyzx
  dp3 r6.z, r7.xyzx, r7.xyzx
  div r6.x, r6.x, r6.z
  ge r6.z, r6.x, l(0.000000)
  lt r6.w, r6.x, l(1.000000)
  and r6.z, r6.w, r6.z
  if_nz r6.z
    mul r6.z, r6.x, r6.x
    mul r6.w, r6.x, r6.z
    mul r7.x, r6.z, l(3.000000)
    mad r7.y, r6.w, l(2.000000), -r7.x
    add r7.y, r7.y, l(1.000000)
    mad r7.x, r6.w, l(-2.000000), r7.x
    mad r6.w, -r6.z, l(2.000000), r6.w
    add r6.w, r6.x, r6.w
    mad r6.z, r6.z, r6.x, -r6.z
    add r7.z, r1.z, -cb5[r3.w + 16].w
    mad r7.z, r6.x, r7.z, cb5[r3.w + 16].w
    add r9.x, -r6.x, l(1.000000)
    add r7.y, r7.y, -r9.x
    mad r7.y, r7.z, r7.y, r9.x
    add r7.x, -r6.x, r7.x
    mad r7.x, r7.z, r7.x, r6.x
    mul r6.zw, r6.zzzw, r7.zzzz
    mul r9.xyz, r2.xyzx, r7.xxxx
    mad r7.xyz, r7.yyyy, cb5[r3.w + 0].xyzx, r9.xyzx
    mad r7.xyz, r6.wwww, cb5[r3.w + 16].xyzx, r7.xyzx
    mad r7.xyz, r6.zzzz, r3.xyzx, r7.xyzx
    add r7.xyz, r7.xyzx, -cb5[r1.y + 48].xyzx
    dp3 r6.z, r8.yzwy, r7.xyzx
    dp3 r6.w, r7.xyzx, r7.xyzx
    div r8.x, r6.z, r6.w
    itof r6.z, r2.w
    add r6.x, r6.z, r6.x
  else
    mov r6.x, r1.w
    mov r8.x, r4.x
    mov r8.yzw, r5.xxyz
  endif
  movc r6.x, r6.y, r6.x, r1.w
  mov r4.yzw, r5.xxyz
  movc r8.xyzw, r6.yyyy, r8.xyzw, r4.xyzw
  movc r1.w, r7.w, r6.x, r1.w
  movc r5.xyzw, r7.wwww, r8.xywz, r4.xywz
  iadd r2.w, r2.w, l(-1)
  mov r2.xyz, cb5[r3.w + 0].xyzx
  mov r3.xyz, cb5[r3.w + 16].xyzx
  mov r1.z, cb5[r3.w + 16].w
  mov r4.x, r5.x
  mov r5.x, r5.y
  mov r5.yz, r5.wwzw
endloop
mad r1.x, r1.w, l(0.250000), l(-1.000000)
mov r4.y, |r1.x|

mov r36.xyzw, v6.xyzw
add r25.w, r26.w, -r25.y
//mad r36.x, r25.x, r25.w, r36.x

div r1.xyz, r36.xyzx, v6.wwww
add r2.x, r1.z, cb1[51].w
mul r2.x, r2.x, cb1[51].z
div r2.x, l(1.000000, 1.000000, 1.000000, 1.000000), r2.x
add r2.x, r2.x, l(0.500000)
mad r2.x, r2.x, cb1[51].z, -cb1[51].w
div r2.x, l(1.000000, 1.000000, 1.000000, 1.000000), r2.x
add r2.x, -r1.z, r2.x
ftou r3.xy, v8.xyxx
mov r3.zw, l(0,0,0,0)
ld_indexable(texture2d)(float,float,float,float) r2.y, r3.xyww, t17.yxzw
mul r2.y, r2.y, r2.y
ld_indexable(texture2d)(uint,uint,uint,uint) r2.z, r3.xyww, t0.yzxw
ubfe r2.z, l(11), l(20), r2.z
utof r2.z, r2.z
mad r2.z, r2.z, l(0.00782013685), l(-8.000000)
mul r2.w, cb1[30].w, cb2[44].z
mul r4.z, r2.w, r2.y
max r4.z, r4.z, cb2[44].w
mad r4.z, r2.z, r4.z, l(1.000000)
div r2.y, r2.y, r4.z
add r2.y, -r1.z, r2.y
div r2.y, |r2.y|, |r2.x|
add_sat r2.y, -r2.y, l(2.000000)
eq r4.z, r2.y, l(0.000000)
sample_indexable(texture2d)(float,float,float,float) r4.y, r4.yxyy, t24.yxzw, s0
if_nz r4.z
  mov o0.xyzw, l(0,0,0,0)
  ret
endif
mul r6.xyz, v0.yzxy, v1.zxyz
mad r6.xyz, v1.yzxy, v0.zxyz, -r6.xyzx
mul r6.xyz, r6.xyzx, v1.wwww
mul r4.zw, v3.xxxy, l(0.000000, 0.000000, 6.28318548, 3.14159274)
sincos r7.x, r8.x, r4.z
mov r7.y, r8.x
sincos r8.x, r9.x, r4.w
mul r7.xy, -r7.xyxx, r8.xxxx
mov r7.z, r9.x
dp3 r4.z, r7.xyzx, r7.xyzx
rsq r4.z, r4.z
mul r7.xyz, r4.zzzz, r7.xyzx
dp3 r4.z, cb6[2].xyzx, cb6[2].xyzx
rsq r4.z, r4.z
mul r8.xyz, r4.zzzz, cb6[2].xyzx
add r4.z, -|cb6[12].z|, l(1.000000)
sqrt r4.z, r4.z
mad r4.w, |cb6[12].z|, l(-0.0187292993), l(0.074261)
mad r4.w, r4.w, |cb6[12].z|, l(-0.212114394)
mad r4.w, r4.w, |cb6[12].z|, l(1.57072878)
mul r5.w, r4.z, r4.w
mad r5.w, r5.w, l(-2.000000), l(3.14159274)
lt r6.w, cb6[12].z, -cb6[12].z
and r5.w, r5.w, r6.w
mad r4.z, r4.w, r4.z, r5.w
add r4.z, -r4.z, l(1.57079637)
sincos null, r4.z, r4.z
dp3 r4.w, r7.xyzx, r8.xyzx
add_sat r4.z, -r4.z, r4.w
max r4.w, r4.w, l(0.000010)
div r4.z, r4.z, r4.w
mul_sat r4.z, r4.z, cb6[13].y
mul r4.z, r4.z, r4.z
sample_indexable(texture2d)(float,float,float,float) r7.xyz, v3.xyxx, t21.xyzw, s7
mad r7.xyz, r7.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(-1.000000, -1.000000, -1.000000, 0.000000)
sample_indexable(texture2d)(float,float,float,float) r8.xyz, v3.xyxx, t22.xyzw, s3
mad r8.xyz, r8.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(-1.000000, -1.000000, -1.000000, 0.000000)
mul r8.xy, r8.xyxx, cb6[13].zzzz
add r8.xyz, -r7.xyzx, r8.xyzx
mad r7.xyz, r4.zzzz, r8.xyzx, r7.xyzx
mad r7.xyz, r7.xyzx, cb3[7].wwww, cb3[7].xyzx
dp3 r4.z, r7.xyzx, r7.xyzx
rsq r4.z, r4.z
mul r7.xyz, r4.zzzz, r7.xyzx
mul r6.xyz, r6.xyzx, r7.yyyy
mad r6.xyz, r7.xxxx, v0.xyzx, r6.xyzx
mad r6.xyz, r7.zzzz, v1.xyzx, r6.xyzx
dp3 r4.z, r6.xyzx, r6.xyzx
rsq r4.z, r4.z
mul r6.xyz, r4.zzzz, r6.xyzx
mad r1.w, r1.w, l(0.125000), l(-0.250000)
mad_sat r1.w, |r1.w|, l(8.000000), l(-1.000000)
add r4.z, -cb0[0].z, cb0[0].w
mad r4.z, r1.w, r4.z, cb0[0].z
add r1.w, -r1.w, l(1.000000)
add r7.xyzw, -cb0[1].xyzw, l(1.000000, 1.000000, 1.000000, 1.000000)
mad r1.w, r1.w, r7.w, cb0[1].w
ld_indexable(texture2d)(float,float,float,float) r3.xyz, r3.xyzw, t23.xyzw
ge r2.z, r2.z, l(0.000000)
mul r1.w, r1.w, r4.x
mad_sat r7.xyz, -r1.wwww, r7.xyzx, l(1.000000, 1.000000, 1.000000, 0.000000)
add r8.xyz, -r7.xyzx, l(1.000000, 1.000000, 1.000000, 0.000000)
mul r8.xyz, r8.xyzx, v7.xyzx
mad r3.xyz, r3.xyzx, r7.xyzx, r8.xyzx
mad r0.xyz, r5.xyzx, cb0[0].yyyy, r0.xyzx
movc r0.w, r0.w, l(0), l(4)

mul r27.xzw, r0.yyyy, cb5[r0.w + 33].xxyz
mad r27.xzw, r0.xxxx, cb5[r0.w + 32].xxyz, r27.xxzw
mad r20.xyz, r0.zzzz, cb5[r0.w + 34].xyzx, r27.xzwx
add r20.xyz, r20.xyzx, cb5[r0.w + 35].xyzx

//mul r25.w, r26.x, l(0.5)
//mul r25.w, r25.w, r35.x
//mad r0.x, -r25.x, r0.z, r0.x
//
//mul r25.w, r26.x, l(0.5)
//mul r25.w, r25.w, r35.x
//mul r25.w, r25.w, r0.z
//mul r25.w, r25.w, r25.y
//mad r0.x, r25.x, r25.y, r0.x

mul r7.xzw, r0.yyyy, cb5[r0.w + 33].xxyz
mad r7.xzw, r0.xxxx, cb5[r0.w + 32].xxyz, r7.xxzw
mad r0.xyz, r0.zzzz, cb5[r0.w + 34].xyzx, r7.xzwx
add r0.xyz, r0.xyzx, cb5[r0.w + 35].xyzx



mul r8.xyzw, r0.yyyy, cb1[1].xyzw
mad r8.xyzw, r0.xxxx, cb1[0].xyzw, r8.xyzw
mad r8.xyzw, r0.zzzz, cb1[2].xyzw, r8.xyzw
add r8.xyzw, r8.xyzw, cb1[3].xyzw

add r25.w, r8.w, -r25.y
mad r8.x, r25.x, r25.w, r8.x

div r0.xyz, r8.xyzx, r8.wwww
mad r8.xy, r1.xyxx, cb1[52].xyxx, cb1[52].wzww
mad r0.xy, r0.xyxx, cb1[52].xyxx, cb1[52].wzww

//add r0.x, -r25.x, r0.x

mov r8.z, r1.z
add r0.xyz, r0.xyzx, -r8.xyzx
mad r7.xzw, -r0.xxyz, l(0.500000, 0.000000, 0.500000, 0.500000), r8.xxyz
mov r9.zw, l(0,0,0,0)
mov r10.w, l(1.000000)
mov r11.xyz, r7.xzwx
mov r13.xyz, l(0,0,0,0)
mov r12.xyzw, l(0,0,0,0)
mov r1.w, l(0)
mov r3.w, l(0)
loop
  ige r4.w, r3.w, l(16)
  breakc_nz r4.w
  mad r11.xyz, r0.xyzx, l(0.062500, 0.062500, 0.062500, 0.000000), r11.xyzx
  sample_l_indexable(texture2d)(float,float,float,float) r10.xyz, r11.xyxx, t23.xyzw, s0, l(0.000000)
  sample_l_indexable(texture2d)(float,float,float,float) r4.w, r11.xyxx, t17.yzwx, s1, l(0.000000)
  mul r4.w, r4.w, r4.w
  mad r14.xy, r11.xyxx, cb3[3].xyxx, l(0.500000, 0.500000, 0.000000, 0.000000)
  ftou r9.xy, r14.xyxx
  ld_indexable(texture2d)(uint,uint,uint,uint) r5.w, r9.xyzw, t0.yzwx
  and r6.w, r5.w, l(1023)
  utof r14.x, r6.w
  ubfe r9.xy, l(10, 11, 0, 0), l(10, 20, 0, 0), r5.wwww
  utof r14.yz, r9.xxyx
  mad r14.xyz, r14.xyzx, l(0.00195503421, 0.00195503421, 0.00782013685, 0.000000), l(-1.000000, -1.000000, -8.000000, 0.000000)
  dp2 r5.w, l(1.000000, 1.000000, 0.000000, 0.000000), |r14.xyxx|
  add r15.z, -r5.w, l(1.000000)
  add r9.xy, -|r14.yxyy|, l(1.000000, 1.000000, 0.000000, 0.000000)
  ge r16.xyz, r14.xyzx, l(0.000000, 0.000000, 0.000000, 0.000000)
  movc r9.xy, r16.xyxx, r9.xyxx, -r9.xyxx
  lt r5.w, r15.z, l(0.000000)
  movc r15.xy, r5.wwww, r9.xyxx, r14.xyxx
  dp3 r5.w, r15.xyzx, r15.xyzx
  rsq r5.w, r5.w
  mul r14.xyw, r5.wwww, r15.xyxz
  mul r5.w, r2.w, r4.w
  max r5.w, r5.w, cb2[44].w
  mad r5.w, r14.z, r5.w, l(1.000000)
  div r4.w, r4.w, r5.w
  add r4.w, -r11.z, r4.w
  div r4.w, |r4.w|, |r2.x|
  add_sat r4.w, -r4.w, l(2.000000)
  and r5.w, r4.w, r16.z
  mad r12.xyzw, r10.xyzw, r5.wwww, r12.xyzw
  mad r13.xyz, r14.xywx, r5.wwww, r13.xyzx
  movc r4.w, r16.z, l(0), r4.w
  add r1.w, r1.w, r4.w
  iadd r3.w, r3.w, l(1)
endloop
max r0.x, r1.w, l(0.000001)
mul r0.yz, r0.xxxx, l(0.000000, 0.062500, 0.125000, 0.000000)
mad r1.w, -r0.x, l(0.062500), l(1.000000)
mul r0.y, r0.y, r1.w
mul r0.y, r4.z, r0.y
min r0.z, r0.z, l(1.000000)
min r9.xyz, r0.zzzz, r2.yyyy
mad r2.xyw, r6.xyxz, r0.xxxx, r13.xyxz
dp3 r0.z, r2.xywx, r2.xywx
rsq r0.z, r0.z
mul r2.xyw, r0.zzzz, r2.xyxw
mad r3.xyz, r3.xyzx, r0.xxxx, r12.xyzx
add r0.x, r0.x, r12.w
div r0.x, l(1.000000, 1.000000, 1.000000, 1.000000), r0.x
mad r10.yz, r0.yyyy, l(0.000000, 1.200000, 0.400000, 0.000000), l(0.000000, 0.300000, 0.050000, 0.000000)
mul r7.xzw, r2.xxyw, cb2[6].xxyz
mad r7.xzw, r7.xxzw, l(1.500000, 0.000000, 1.500000, 1.500000), v5.xxyz
mad r11.xy, r7.xzxx, cb2[7].xyxx, cb2[7].zwzz
mov_sat r4.zw, r11.xxxy
eq r4.zw, r4.zzzw, r11.xxxy
and r1.w, r4.w, r4.z
if_nz r1.w
  mad r11.z, r7.w, cb2[8].x, cb2[8].y
  sample_l_indexable(texture3d)(float,float,float,float) r1.w, r11.xyzx, t11.yzwx, s5, l(0.000000)
  mul r3.w, r1.w, cb2[6].w
  ge r4.z, l(1.000000), r3.w
  mad r1.w, r1.w, cb2[6].w, l(0.750000)
  movc r1.w, r4.z, r1.w, r3.w
  round_ni r1.w, r1.w
  sample_l_indexable(texture3d)(float,float,float,float) r12.xyzw, r11.xyzx, t9.xyzw, s0, r1.w
  sample_l_indexable(texture3d)(float,float,float,float) r11.xyzw, r11.xyzx, t10.xyzw, s0, r1.w
  mul r13.xyzw, r12.xyzw, r12.xyzw
  mad r14.xyzw, r12.xyzw, l(0.335721463, 0.335721463, 0.335721463, 0.335721463), l(-0.00358909299, -0.00358909299, -0.00358909299, -0.00358909299)
  mad r14.xyzw, r13.xyzw, l(2.67030215, 2.67030215, 2.67030215, 2.67030215), r14.xyzw
  mul r12.xyzw, r12.xyzw, r13.xyzw
  mad r12.xyzw, r12.xyzw, l(-2.01957369, -2.01957369, -2.01957369, -2.01957369), r14.xyzw
  mul r13.xyzw, r11.xyzw, r11.xyzw
  mad r14.xyzw, r11.xyzw, l(0.335721463, 0.335721463, 0.335721463, 0.335721463), l(-0.00358909299, -0.00358909299, -0.00358909299, -0.00358909299)
  mad r14.xyzw, r13.xyzw, l(2.67030215, 2.67030215, 2.67030215, 2.67030215), r14.xyzw
  mul r11.xyzw, r11.xyzw, r13.xyzw
  mad r11.xyzw, r11.xyzw, l(-2.01957369, -2.01957369, -2.01957369, -2.01957369), r14.xyzw
else
  mov r12.xyzw, l(0,0,0,0)
  mov r11.xyzw, l(0,0,0,0)
endif
add r12.xyzw, -r12.xyzw, l(1.000000, 1.000000, 1.000000, 1.000000)
add r11.xyzw, -r11.xyzw, l(1.000000, 1.000000, 1.000000, 1.000000)
mad r13.xy, r1.xyxx, l(0.500000, -0.500000, 0.000000, 0.000000), l(0.500000, 0.500000, 0.000000, 0.000000)
mul r4.zw, r13.xxxy, l(0.000000, 0.000000, 128.000000, 64.000000)
ftou r14.xy, r4.zwzz
mov r14.zw, l(0,0,0,0)
ld_indexable(texture2d)(uint,uint,uint,uint) r1.w, r14.xyzw, t1.yzwx
dp3 r14.w, r2.xywx, l(-1.000000, -1.000000, 1.000000, 0.000000)
dp3 r14.z, r2.yxwy, l(-1.000000, 1.000000, 1.000000, 0.000000)
dp3 r14.y, r2.xywx, l(-1.000000, 1.000000, 1.000000, 0.000000)
dp3 r14.x, r2.xywx, l(1.000000, 1.000000, 1.000000, 0.000000)
mul r15.xyzw, r14.wzyx, r14.wzyx
dp4 r3.w, l(1.000000, 1.000000, 1.000000, 1.000000), r15.xyzw
mul r3.w, r3.w, l(0.250000)
add r4.z, -cb2[5].w, l(1.000000)
mad r12.xyzw, r12.xyzw, cb2[5].wwww, r4.zzzz
mad r11.xyzw, r11.xyzw, cb2[5].wwww, r4.zzzz
mad r15.xyzw, r2.xyxy, l(64.000000, 64.000000, 256.000000, 256.000000), v5.xyxy
mad r4.zw, r15.xxxy, cb2[0].xxxy, -cb2[1].xxxy
mad r16.xy, r4.zwzz, l(2.000000, 2.000000, 0.000000, 0.000000), l(-0.500000, -0.500000, 0.000000, 0.000000)
sample_l_indexable(texture2d)(float,float,float,float) r17.xyzw, r16.xyxx, t3.xyzw, s0, l(0.000000)
mad r4.z, r17.w, cb2[0].z, cb2[1].z
add r4.z, r4.z, -v5.z
mad r4.z, |r4.z|, l(0.000156249997), r17.x
add r7.xz, r17.yyzy, l(-0.500000, 0.000000, -0.500000, 0.000000)
add r17.z, r4.z, -r7.x
add r17.w, r4.z, r7.x
add_sat r18.xy, -r7.zzzz, r17.zwzz
add_sat r18.zw, r7.zzzz, r17.zzzw
mad r4.zw, v5.xxxy, cb2[9].xxxy, cb2[9].zzzw
mad r17.zw, v5.zzzz, cb2[8].xxxz, cb2[8].yyyw
max r4.z, |r4.w|, |r4.z|
max r4.z, |r17.w|, r4.z
mad_sat r4.z, -cb2[5].x, r4.z, cb2[5].x
if_nz r1.w
  ushr r1.w, r1.w, l(8)
  mov r19.xyz, v5.xyzx
  mov r19.w, l(1.000000)
  mov r7.xzw, l(0,0,0,0)
  mov r15.xy, l(1.000000,1.000000,0,0)
  mov r4.w, r1.w
  loop
    breakc_z r4.w
    firstbit_lo r5.w, r4.w
    ishl r6.w, l(1), r5.w
    xor r4.w, r4.w, r6.w
    ishl r6.w, r5.w, l(1)
    bfi r10.w, l(31), l(1), r5.w, l(1)
    imul null, r13.w, r5.w, l(3)
    imad r20.xy, r5.wwww, l(3, 3, 0, 0), l(1, 2, 0, 0)
    dp4 r21.x, cb2[r13.w + 46].xyzw, r19.xyzw
    dp4 r21.y, cb2[r20.x + 46].xyzw, r19.xyzw
    dp4 r21.z, cb2[r20.y + 46].xyzw, r19.xyzw
    add r20.xyz, -|r21.xyzx|, l(1.000000, 1.000000, 1.000000, 0.000000)
    mul_sat r20.xyz, r20.xyzx, cb2[r6.w + 70].xyzx
    min r5.w, r20.z, r20.y
    min r5.w, r5.w, r20.x
    add r5.w, -r5.w, l(1.000000)
    mul r13.w, r5.w, r5.w
    add r20.xy, l(1.000000, 1.000000, 0.000000, 0.000000), -cb2[r10.w + 70].xyxx
    mad r20.xy, r13.wwww, r20.xyxx, cb2[r10.w + 70].xyxx
    min r15.xy, r15.xyxx, r20.xyxx
    mad r5.w, -r5.w, r5.w, l(1.000000)
    mul r20.xy, r5.wwww, cb2[r10.w + 70].zwzz
    max r7.xz, r7.xxzx, r20.xxyx
    mul r5.w, r5.w, cb2[r6.w + 70].w
    max r7.w, r5.w, r7.w
  endloop
else
  mov r7.xzw, l(0,0,0,0)
  mov r15.xy, l(1.000000,1.000000,0,0)
endif
mul r1.w, r4.z, r15.y
add r4.w, -r4.z, l(1.000000)
mul r4.w, r4.w, r15.x
mad r15.xy, r15.zwzz, cb2[2].xyxx, -cb2[2].zwzz
sample_l_indexable(texture2d)(float,float,float,float) r5.w, r15.xyxx, t4.yzwx, s5, l(0.000000)
mad r5.w, r5.w, cb2[3].x, cb2[4].x
add r5.w, r5.w, -v5.z
mad_sat r5.w, r5.w, l(-0.00195312500), l(1.000000)
add r5.w, r5.w, l(0.500000)
min r5.w, r5.w, l(1.000000)
mul r4.w, r4.w, r5.w
mad r12.xyzw, r12.xyzw, r1.wwww, r4.wwww
mad r11.xyzw, r11.xyzw, r1.wwww, r4.wwww
mul r15.xyzw, r14.wzyx, l(0.577350259, 0.577350259, 0.577350259, 0.577350259)
mul r19.xyzw, r15.wzyx, r15.wzyx
mul r20.xyzw, r15.xyzw, r19.wzyx
mul r21.xyzw, r19.xyzw, l(0.089800, 0.089800, 0.089800, 0.089800)
mad r20.xyzw, r20.xyzw, l(-0.015700, -0.015700, -0.015700, -0.015700), r21.wzyx
mad r20.xyzw, r14.wzyx, l(0.118991889, 0.118991889, 0.118991889, 0.118991889), r20.xyzw
add r20.xyzw, r20.xyzw, l(0.102900, 0.102900, 0.102900, 0.102900)
mul r15.xyzw, -r15.wzyx, r19.xyzw
mad r15.xyzw, r15.xyzw, l(-0.015700, -0.015700, -0.015700, -0.015700), r21.xyzw
mad r14.xyzw, r14.xyzw, l(-0.118991889, -0.118991889, -0.118991889, -0.118991889), r15.xyzw
add r14.xyzw, r14.xyzw, l(0.102900, 0.102900, 0.102900, 0.102900)
mov r16.zw, l(0,0,3.000000,2.000000)
sample_l_indexable(texture2darray)(float,float,float,float) r15.xyz, r16.xyzx, t7.xyzw, s0, l(0.000000)
sample_l_indexable(texture2darray)(float,float,float,float) r19.xyz, r16.xywx, t7.xyzw, s0, l(0.000000)
mov r16.zw, l(0,0,1.000000,0)
sample_l_indexable(texture2darray)(float,float,float,float) r21.xyz, r16.xyzx, t7.xyzw, s0, l(0.000000)
sample_l_indexable(texture2darray)(float,float,float,float) r16.xyz, r16.xywx, t7.xyzw, s0, l(0.000000)
mul r20.xyzw, r12.xyzw, r20.xyzw
mul r11.xyzw, r11.xyzw, r14.xyzw
mul r14.xyzw, r18.xyzw, r12.xyzw
mad r12.xyzw, -r12.xyzw, r18.xyzw, l(1.000000, 1.000000, 1.000000, 1.000000)
mul r12.xyzw, r12.xyzw, r20.xyzw
mad r11.xyzw, r11.xyzw, r18.xyzw, r12.xyzw
mul r12.xyzw, r18.xyzw, r14.xyzw
mul r1.w, r7.x, l(0.050000)
mul r14.xyzw, r1.wwww, r11.xyzw
mad r12.xyzw, r20.xyzw, r12.xyzw, r14.xyzw
add r1.w, -r7.x, l(1.000000)
mul r14.xyzw, r1.wwww, r11.xyzw

//mad r12.x, -r25.x, l(1280.0), r12.x

mul r18.xyz, r12.yyyy, cb3[32].xyzx
mad r18.xyz, cb3[31].xyzx, r12.xxxx, r18.xyzx
mad r18.xyz, cb3[33].xyzx, r12.zzzz, r18.xyzx
mad r18.xyz, cb3[34].xyzx, r12.wwww, r18.xyzx
mad r15.xyz, r15.xyzx, r14.xxxx, r18.xyzx
mad r15.xyz, r19.xyzx, r14.yyyy, r15.xyzx
mad r14.xyz, r21.xyzx, r14.zzzz, r15.xyzx
mad r14.yzw, r16.xxyz, r14.wwww, r14.xxyz
add r14.x, r7.w, r14.y
dp3 r4.w, v5.xyzx, r2.xywx
add r4.w, r4.w, r4.w
mad r15.xyz, r2.xywx, -r4.wwww, v5.xyzx
dp3 r4.w, r15.xyzx, r15.xyzx
rsq r4.w, r4.w
mul r16.xyz, r4.wwww, r15.xyzx
add r4.w, r12.y, r12.x
add r4.w, r12.z, r4.w
add r4.w, r12.w, r4.w
mad r4.w, r11.x, r1.w, r4.w
mad r4.w, r11.y, r1.w, r4.w
mad r4.w, r11.z, r1.w, r4.w
mad r1.w, r11.w, r1.w, r4.w
mad r17.xy, v5.xyxx, cb2[7].xyxx, cb2[7].zwzz
sample_l_indexable(texture3d)(float,float,float,float) r11.xyz, r17.xyzx, t13.xyzw, s0, l(0.000000)
mad r11.xyz, r11.xyzx, l(4.000000, 4.000000, 4.000000, 0.000000), l(-2.000000, -2.000000, -2.000000, 0.000000)
mad r11.xyz, r2.xywx, l(3.000000, 3.000000, 3.000000, 0.000000), r11.xyzx
mad r11.xyz, r11.xyzx, cb2[6].xyzx, v5.xyzx
mad r12.xy, r11.xyxx, cb2[7].xyxx, cb2[7].zwzz
mad r12.z, r11.z, cb2[8].x, cb2[8].y
sample_l_indexable(texture3d)(float,float,float,float) r11.xyz, r12.xyzx, t12.xyzw, s0, l(0.000000)
mul r4.z, r3.w, r4.z
mul r4.z, r4.z, cb2[43].z
mad r11.xyz, r11.xyzx, r4.zzzz, r14.xzwx
log r4.z, r10.y
mad r4.z, r4.z, l(1.200000), l(5.000000)
sample_l_indexable(texturecube)(float,float,float,float) r12.xyz, r15.xyzx, t5.xyzw, s2, r4.z
frc r4.w, r15.y
mad r4.w, r4.w, l(347834.531250), r15.x
frc r4.w, r4.w
dp3 r5.w, r16.xyzx, cb1[48].xyzx
add_sat r5.w, r5.w, r5.w
mad r1.w, r1.w, l(4096.000000), l(64.000000)
mul r6.w, r3.w, r3.w
mul r1.w, r1.w, r6.w
mad r14.xyz, r16.xyzx, r1.wwww, r23.xyzx
add r14.xyz, r14.xyzx, cb3[10].xyzx
mul r15.xyz, r14.yyyy, cb1[78].xywx
mad r14.xyw, r14.xxxx, cb1[77].xyxw, r15.xyxz
mad r14.xyz, r14.zzzz, cb1[79].xywx, r14.xywx
add r14.xyz, r14.xyzx, cb1[80].xywx

add r25.w, r14.z, -r25.y
mad r14.x, r25.x, r25.w, r14.x

div r7.xw, r14.xxxy, r14.zzzz
mad_sat r14.yz, r7.xxwx, cb3[39].xxyx, cb3[39].zzwz
mul r1.w, r3.w, r5.w
mad r15.xyz, r4.wwww, l(-0.166500, -0.016500, -0.015500, 0.000000), l(0.200000, 0.035000, 0.020000, 0.000000)
lt r15.xyz, r1.zzzz, r15.xyzx
and r15.xyz, r15.xyzx, l(0x3e800000, 0x3e800000, 0x3e800000, 0)
add r6.w, r15.y, r15.x
add r6.w, r15.z, r6.w
mad r14.x, r14.y, l(0.250000), r6.w
mad r3.w, r4.z, r3.w, r4.w
add r3.w, r3.w, l(-0.500000)
sample_l_indexable(texture2d)(float,float,float,float) r14.xyzw, r14.xzxx, t6.xyzw, s5, r3.w
mul r14.xyz, r14.xyzx, r14.xyzx
dp3 r3.w, r14.xzyx, l(-0.250000, -0.250000, -0.500000, 0.000000)
add r3.w, r3.w, l(1.000000)
rcp r3.w, r3.w
mul r1.w, r1.w, r3.w
mul r1.w, r1.w, cb2[42].z
mul r1.w, r1.w, l(4.000000)
mul r14.xyz, r1.wwww, r14.xyzx
mad r1.w, -r5.w, r14.w, l(1.000000)
mul r11.xyz, r11.xyzx, r12.xyzx
mad r11.xyz, r11.xyzx, r1.wwww, r14.xyzx
dp3 r1.w, v5.xyzx, v5.xyzx
rsq r1.w, r1.w
mul r12.xyz, r1.wwww, v5.xyzx
dp3_sat r10.x, r2.xywx, -r12.xyzx
sample_l_indexable(texture2d)(float,float,float,float) r4.zw, r10.xyxx, t8.zwxy, s0, l(0.000000)
add r1.w, -r4.w, r4.z
mad r1.w, r10.z, r1.w, r4.w
mul r10.xyz, r1.wwww, r11.xyzx
mul r11.xyz, r5.yyyy, cb5[r0.w + 33].xyzx
mad r5.xyw, r5.xxxx, cb5[r0.w + 32].xyxz, r11.xyxz
mad r5.xyz, r5.zzzz, cb5[r0.w + 34].xyzx, r5.xywx
dp3 r0.w, v5.xyzx, r6.xyzx
add r0.zw, r0.yyyw, r0.yyyw
mad r6.xyz, r6.xyzx, -r0.wwww, v5.xyzx
dp3 r0.w, r6.xyzx, r6.xyzx
rsq r0.w, r0.w
mul r6.xyz, r0.wwww, r6.xyzx
dp3 r0.w, r16.xyzx, v1.xyzx
add r0.w, r0.w, r4.y
mad_sat r0.w, r0.w, l(8.000000), l(-6.000000)
mul r0.w, r0.w, r7.y
add r1.w, -r7.z, l(1.000000)
mad r4.zw, v5.xxxy, cb2[0].xxxy, -cb2[1].xxxy
sample_l_indexable(texture2d)(float,float,float,float) r4.zw, r4.zwzz, t2.zwxy, s0, l(0.000000)
mad r3.w, r4.z, cb2[0].z, cb2[1].z
add r3.w, -r3.w, v5.z
mad_sat r3.w, r3.w, cb2[0].w, l(1.000000)
mul r3.w, r4.w, r3.w
mul r7.xyz, v5.yyyy, cb2[29].xyzx
mad r7.xyz, v5.xxxx, cb2[28].xyzx, r7.xyzx
mad r7.xyz, v5.zzzz, cb2[30].xyzx, r7.xyzx
add r7.xyz, r7.xyzx, cb2[31].xyzx
dp3 r11.x, v5.xyzx, cb2[18].xyzx
dp3 r11.y, v5.xyzx, cb2[19].xyzx
dp3 r11.z, v5.xyzx, cb2[20].xyzx
add r4.z, |r11.z|, l(0.100000)
max r4.z, r4.z, |r11.y|
max r4.z, r4.z, |r11.x|
div r12.xyz, l(1.000000, 1.000000, 1.000000, 1.000000), cb2[19].wwww
add r11.xyz, r11.xyzx, cb2[21].xyzx
lt r4.w, cb2[18].w, r4.z
mad r14.xyz, r11.xyzx, r12.zzzz, cb2[22].xyzx
mov r14.w, l(1.000000)
mov r11.w, l(0)
movc r11.xyzw, r4.wwww, r14.xyzw, r11.xyzw
movc r14.z, r4.w, cb2[19].w, l(1.000000)
mul r4.w, cb2[18].w, cb2[19].w
lt r4.w, r4.w, r4.z
mov r5.w, l(1.000000)
mad r12.xyz, r11.xyzx, r12.xyzx, cb2[23].xyzx
mad r15.x, r11.w, r5.w, l(1.000000)
max r5.w, |r12.y|, |r12.x|
mad_sat r5.w, -r5.w, l(8.000000), l(7.000000)
mad r6.w, r12.z, l(0.500000), l(0.500000)
mul_sat r6.w, r6.w, l(32.000000)
mul r15.y, r5.w, r6.w
mul r15.z, r14.z, cb2[19].w
movc r11.xyz, r4.wwww, r12.xyzx, r11.xyzx
mov r14.x, r11.w
mov r14.y, l(1.000000)
movc r12.xyz, r4.wwww, r15.xyzx, r14.xyzx
mad r11.xyz, r11.xyzx, l(0.500000, 0.500000, 0.500000, 0.000000), l(0.500000, 0.500000, 0.500000, 0.000000)
mad r4.z, -r4.z, l(0.250000), l(1.000000)
max r4.z, r4.z, l(0.000000)
add r4.z, r4.z, l(0.250000)
min r4.z, r4.z, l(1.000000)
mul r4.w, r12.y, r12.z
mul r4.z, r4.z, r4.w
mul r4.zw, r4.zzzz, l(0.000000, 0.000000, 64.000000, 4.000000)
mov r11.w, r12.x
sample_l_indexable(texture2darray)(float,float,float,float) r12.xyzw, r11.xywx, t16.xyzw, s0, l(0.000000)
add r11.xy, -r11.zzzz, r12.xyxx
mul_sat r4.zw, r4.zzzw, r11.xxxy
mad r4.z, -r4.z, r12.z, l(1.000000)
add r5.w, -r12.w, l(1.000000)
add r5.w, -r4.z, r5.w
mad r4.z, r4.w, r5.w, r4.z
mul r3.w, r3.w, r4.z
add r4.zw, r7.xxxy, -cb2[34].xxxy
add r11.xy, r7.xyxx, -cb2[35].xyxx
max r5.w, |r4.w|, |r4.z|
max r6.w, |r11.y|, |r11.x|
mad r4.zw, r4.zzzw, cb2[34].zzzz, l(0.000000, 0.000000, 1.500000, 0.500000)
mul r7.w, cb2[34].z, cb2[34].z
mad r11.xy, r11.xyxx, r7.wwww, l(2.500000, 0.500000, 0.000000, 0.000000)
lt r5.w, r5.w, cb2[34].w
movc r4.zw, r5.wwww, r4.zzzw, r7.xxxy
lt r5.w, r6.w, cb2[35].w
movc r11.yz, r5.wwww, r11.xxyx, r4.zzwz
mul r11.x, r11.y, cb2[35].z
mov_sat r4.zw, r11.xxxz
ne r4.zw, r4.zzzw, r11.xxxz
or r4.z, r4.w, r4.z
lt r4.w, l(1.000000), r7.z
or r4.z, r4.w, r4.z
if_nz r4.z
  mov r4.w, l(0)
endif
if_z r4.z
  mad r7.xy, r11.xzxx, cb2[36].xyxx, l(0.500000, 0.500000, 0.000000, 0.000000)
  frc r11.xy, r7.xyxx
  round_ni r7.xy, r7.xyxx
  add r7.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
  mul r7.xy, r7.xyxx, cb2[36].zwzz
  mad r4.z, r7.z, l(2048.000000), l(-1.000000)
  add r12.y, -r11.y, l(1.000000)
  add r11.z, -r11.x, l(1.000000)
  mov r12.z, l(1.000000)
  mul r12.xyzw, r11.zxxz, r12.zzyy
  mov r11.w, l(1.000000)
  mul r11.xyzw, r11.yyww, r12.xyzw
  gather4_aoffimmi_indexable(0,0,0)(texture2d)(float,float,float,float) r7.xyzw, r7.xyxx, t14.xyzw, s0.x
  mad_sat r7.xyzw, r7.xyzw, l(2048.000000, 2048.000000, 2048.000000, 2048.000000), -r4.zzzz
  dp4 r4.z, r7.xyzw, r11.xyzw
  min r4.z, r4.z, l(1.000000)
  mov r4.w, l(-1)
else
  mov r4.z, l(1.000000)
endif
if_z r4.w
  mul r7.xyzw, v5.yyyy, cb2[25].xyzz
  mad r7.xyzw, v5.xxxx, cb2[24].xyzz, r7.xyzw
  mad r7.xyzw, v5.zzzz, cb2[26].xyzz, r7.xyzw
  add r7.xyzw, r7.xyzw, cb2[27].xyzz
  add r11.xyzw, r7.xyzw, l(-0.500000, -0.500000, -0.500000, -0.000244140625)
  max r4.w, |r11.z|, |r11.y|
  max r4.w, r4.w, |r11.x|
  mad_sat r4.w, -r4.w, l(16.000000), l(8.000000)
  sample_c_lz_indexable(texture2d)(float,float,float,float) r5.w, r7.xyxx, t15.xxxx, s6, r11.w
  add r5.w, r5.w, r5.w
  min r5.w, r5.w, l(1.000000)
  mad r5.w, r4.z, r5.w, -r4.z
  mad r4.z, r4.w, r5.w, r4.z
endif
mul r3.w, r3.w, r4.z
mul_sat r1.w, r1.w, r3.w
dp3_sat r3.w, -cb2[32].xyzx, r16.xyzx
log r3.w, r3.w
mul r3.w, r3.w, l(12.000000)
exp r3.w, r3.w
mul r3.w, r0.z, r3.w
dp3_sat r4.z, -cb2[32].xyzx, r6.xyzx
lt r4.z, l(0.980000), r4.z
and r4.z, r4.z, l(0x3f000000)
movc r7.xyz, r2.zzzz, l(0,0,0,0), l(1.000000,1.000000,1.000000,0)
mad r0.y, -r0.y, l(2.000000), l(1.000000)
mul r0.y, r0.y, r0.y
mul r0.y, r0.y, r7.z
mul r2.z, r0.y, r4.z
mad r2.z, r3.w, l(0.500000), r2.z
dp3 r3.w, -cb2[32].xyzx, r5.xyzx
add r3.w, -r3.w, r4.y
mad_sat r3.w, r3.w, l(4.000000), l(1.000000)
mad r4.z, r1.z, cb1[51].z, -cb1[51].w
div r4.z, l(1.000000, 1.000000, 1.000000, 1.000000), r4.z
lt r4.w, r4.z, l(2500.000000)
if_nz r4.w
  mul r5.w, r4.z, l(0.015625)
  mad r11.xyz, -cb2[32].xyzx, r5.wwww, r23.xyzx
  mul r12.xyzw, r11.yyyy, cb1[1].xyzw
  mad r12.xyzw, r11.xxxx, cb1[0].xyzw, r12.xyzw
  mad r11.xyzw, r11.zzzz, cb1[2].xyzw, r12.xyzw
  add r11.xyzw, r11.xyzw, cb1[3].xyzw
  
  add r25.w, r11.w, -r25.y
  mad r11.x, r25.x, r25.w, r11.x
  
  div r11.xyz, r11.xyzx, r11.wwww
  add r11.xyz, -r1.xyzx, r11.xyzx
  mul r12.xy, |r11.xyxx|, cb3[2].xyxx
  max r5.w, r12.y, r12.x
  div r11.xyz, r11.xyzx, r5.wwww
  mul r11.xy, r11.xyxx, cb1[52].xyxx
  add r5.w, r11.z, r11.z
  mad_sat r6.w, -r4.z, l(0.000400), l(1.000000)
  mul r6.w, r6.w, r6.w
  add r10.w, r4.z, cb1[51].w
  add r10.w, r10.w, l(8.000000)
  mul r10.w, r10.w, cb1[51].z
  div r10.w, l(1.000000, 1.000000, 1.000000, 1.000000), r10.w
  add r10.w, r1.z, -r10.w
  min r12.x, |r5.w|, r10.w
  mad r10.w, r12.x, l(16.000000), r10.w
  div r10.w, l(1.000000, 1.000000, 1.000000, 1.000000), r10.w
  add r8.w, r1.z, |r5.w|
  mul r12.xyz, r11.xyzx, l(8.000000, 8.000000, 8.000000, 0.000000)
  mad r14.xyz, r11.xyzx, l(-4.000000, -4.000000, -4.000000, 0.000000), r8.xywx
  mul r5.w, r10.w, l(4.000000)
  mul r8.w, r6.w, l(4.000000)
  add r6.w, r6.w, r6.w
  mul r12.w, r5.w, r12.z
  mad r10.w, r14.z, r5.w, l(2.000000)
  mov r15.xy, r14.xyxx
  mov r15.z, r10.w
  mov r11.z, l(1.000000)
  mov r12.z, l(0)
  loop
    ige r13.w, r12.z, l(4)
    breakc_nz r13.w
    add r15.xyz, r12.xywx, r15.xyzx
    sample_l_indexable(texture2d)(float,float,float,float) r13.w, r15.xyxx, t17.yzwx, s4, l(0.000000)
    mul r13.w, r13.w, r13.w
    mad r13.w, r13.w, r5.w, -r15.z
    mad_sat r13.w, -|r13.w|, r6.w, r8.w
    mad r11.z, -r13.w, r11.z, r11.z
    iadd r12.z, r12.z, l(1)
  endloop
  mov r11.w, r12.w
  mad r12.xyz, r11.xywx, l(-8.000000, -8.000000, -1.000000, 0.000000), r15.xyzx
  mov r14.xyz, r12.xyzx
  mov r15.x, r6.w
  mov r15.y, r8.w
  mov r10.w, r11.z
  mov r12.w, l(0)
  loop
    ige r13.w, r12.w, l(8)
    breakc_nz r13.w
    mul r15.xy, r15.xyxx, l(0.749894202, 0.749894202, 0.000000, 0.000000)
    mad r14.xyz, r11.xywx, l(16.000000, 16.000000, 2.000000, 0.000000), r14.xyzx
    sample_l_indexable(texture2d)(float,float,float,float) r13.w, r14.xyxx, t18.yzwx, s4, l(0.000000)
    mul r13.w, r13.w, r13.w
    mad r13.w, r13.w, r5.w, -r14.z
    mad_sat r13.w, -|r13.w|, r15.x, r15.y
    mad r10.w, -r13.w, r10.w, r10.w
    iadd r12.w, r12.w, l(1)
  endloop
else
  mov r10.w, l(1.000000)
endif
mul r1.w, r1.w, r10.w
mul r1.w, r1.w, r2.z
mul r1.w, r3.w, r1.w
dp3 r2.z, v5.xyzx, cb1[48].xyzx
mul r13.z, r2.z, cb3[30].w
sample_l_indexable(texture3d)(float,float,float,float) r11.xyz, r13.xyzx, t19.xyzw, s0, l(0.000000)
mul r11.xyz, r11.xyzx, cb2[43].yyyy
sample_l_indexable(texture3d)(float,float,float,float) r12.xyz, r13.xyzx, t20.xyzw, s0, l(0.000000)
mad r12.xyz, r12.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(-1.000000, -1.000000, -1.000000, 0.000000)
dp3 r2.x, r12.xyzx, r2.xywx
add r2.x, r2.x, l(1.000000)
dp3 r2.y, r12.xyzx, r12.xyzx
min r2.z, r2.y, l(1.000000)
mad r2.z, -r2.z, l(0.500000), l(1.000000)
mul r2.x, r2.z, r2.x
mul r2.x, r2.x, r2.x
dp2 r2.x, r2.xxxx, r2.yyyy
rsq r2.y, r2.y
mul r2.yzw, r2.yyyy, r12.xxyz
dp3_sat r3.w, r2.yzwy, r16.xyzx
log r3.w, r3.w
mul r3.w, r3.w, l(12.000000)
exp r3.w, r3.w
mul r3.w, r0.z, r3.w
dp3_sat r5.w, r2.yzwy, r6.xyzx
lt r5.w, l(0.980000), r5.w
and r5.w, r5.w, l(0x3f000000)
mul r5.w, r0.y, r5.w
mad r3.w, r3.w, l(0.500000), r5.w
dp3 r5.w, r2.yzwy, r5.xyzx
add r5.w, r4.y, -r5.w
mad_sat r5.w, r5.w, l(4.000000), l(1.000000)
if_nz r4.w
  mul r6.w, r4.z, l(0.015625)
  mad r2.yzw, r2.yyzw, r6.wwww, r23.xxyz
  mul r12.xyzw, r2.zzzz, cb1[1].xyzw
  mad r12.xyzw, r2.yyyy, cb1[0].xyzw, r12.xyzw
  mad r12.xyzw, r2.wwww, cb1[2].xyzw, r12.xyzw
  add r12.xyzw, r12.xyzw, cb1[3].xyzw
  
  add r25.w, r12.w, -r25.y
  mad r12.x, r25.x, r25.w, r12.x
  
  div r2.yzw, r12.xxyz, r12.wwww
  add r2.yzw, -r1.xxyz, r2.yyzw
  mul r12.xy, |r2.yzyy|, cb3[2].xyxx
  max r6.w, r12.y, r12.x
  div r12.xyz, r2.yzwy, r6.wwww
  mul r12.xy, r12.xyxx, cb1[52].xyxx
  add r2.y, r12.z, r12.z
  mad_sat r2.z, -r4.z, l(0.000400), l(1.000000)
  mul r2.z, r2.z, r2.z
  add r2.w, r4.z, cb1[51].w
  add r2.w, r2.w, l(8.000000)
  mul r2.w, r2.w, cb1[51].z
  div r2.w, l(1.000000, 1.000000, 1.000000, 1.000000), r2.w
  add r2.w, r1.z, -r2.w
  min r6.w, r2.w, |r2.y|
  mad r2.w, r6.w, l(16.000000), r2.w
  div r2.w, l(1.000000, 1.000000, 1.000000, 1.000000), r2.w
  add r13.z, r1.z, |r2.y|
  mul r14.xyz, r12.xyzx, l(8.000000, 8.000000, 8.000000, 0.000000)
  mov r13.xy, r8.xyxx
  mad r13.xyz, r12.xyzx, l(-4.000000, -4.000000, -4.000000, 0.000000), r13.xyzx
  mul r2.y, r2.w, l(4.000000)
  mul r2.w, r2.z, l(4.000000)
  add r2.z, r2.z, r2.z
  mul r14.w, r2.y, r14.z
  mad r6.w, r13.z, r2.y, l(2.000000)
  mov r15.xy, r13.xyxx
  mov r15.z, r6.w
  mov r8.w, l(1.000000)
  mov r10.w, l(0)
  loop
    ige r11.w, r10.w, l(4)
    breakc_nz r11.w
    add r15.xyz, r14.xywx, r15.xyzx
    sample_l_indexable(texture2d)(float,float,float,float) r11.w, r15.xyxx, t17.yzwx, s4, l(0.000000)
    mul r11.w, r11.w, r11.w
    mad r11.w, r11.w, r2.y, -r15.z
    mad_sat r11.w, -|r11.w|, r2.z, r2.w
    mad r8.w, -r11.w, r8.w, r8.w
    iadd r10.w, r10.w, l(1)
  endloop
  mov r12.w, r14.w
  mad r13.xyz, r12.xywx, l(-8.000000, -8.000000, -1.000000, 0.000000), r15.xyzx
  mov r14.xyz, r13.xyzx
  mov r15.xy, r2.zwzz
  mov r6.w, r8.w
  mov r10.w, l(0)
  loop
    ige r11.w, r10.w, l(8)
    breakc_nz r11.w
    mul r15.xy, r15.xyxx, l(0.749894202, 0.749894202, 0.000000, 0.000000)
    mad r14.xyz, r12.xywx, l(16.000000, 16.000000, 2.000000, 0.000000), r14.xyzx
    sample_l_indexable(texture2d)(float,float,float,float) r11.w, r14.xyxx, t18.yzwx, s4, l(0.000000)
    mul r11.w, r11.w, r11.w
    mad r11.w, r11.w, r2.y, -r14.z
    mad_sat r11.w, -|r11.w|, r15.x, r15.y
    mad r6.w, -r11.w, r6.w, r6.w
    iadd r10.w, r10.w, l(1)
  endloop
else
  mov r6.w, l(1.000000)
endif
mul r2.x, r2.x, r6.w
mul r2.x, r2.x, r3.w
mul r2.x, r5.w, r2.x
mul r2.y, r4.z, l(0.015625)
mad_sat r2.z, -r4.z, l(0.000400), l(1.000000)
mul r2.z, r2.z, r2.z
add r2.w, r4.z, cb1[51].w
add r2.w, r2.w, l(8.000000)
mul r2.w, r2.w, cb1[51].z
div r2.w, l(1.000000, 1.000000, 1.000000, 1.000000), r2.w
add r2.w, r1.z, -r2.w
mul r3.w, r2.z, l(4.000000)
add r2.z, r2.z, r2.z
mov r12.xyz, l(0,0,0,0)
mov r13.x, r1.w
mov r13.y, r2.x
mov r4.z, l(0)
loop
  ige r5.w, r4.z, cb4[16].x
  breakc_nz r5.w
  add r14.xyz, -v5.xyzx, cb4[r4.z + 8].xyzx
  dp3 r5.w, r14.xyzx, r14.xyzx
  rsq r5.w, r5.w
  mul r15.xyz, r5.wwww, r14.xyzx
  dp3_sat r6.w, r15.xyzx, r16.xyzx
  log r6.w, r6.w
  mul r6.w, r6.w, l(12.000000)
  exp r6.w, r6.w
  mul r6.w, r0.z, r6.w
  mul r17.xyz, r15.yzxy, l(0.000000, 0.000000, 1.000000, 0.000000)
  mad r17.xyz, r15.xyzx, l(0.000000, 1.000000, 0.000000, 0.000000), -r17.xyzx
  dp2 r8.w, r17.yzyy, r17.yzyy
  rsq r8.w, r8.w
  mul r17.xyz, r8.wwww, r17.xyzx
  mul r18.xyz, r15.yzxy, r17.xyzx
  mad r18.xyz, r17.zxyz, r15.zxyz, -r18.xyzx
  dp3 r8.w, r18.xyzx, r18.xyzx
  rsq r8.w, r8.w
  mul r18.xyz, r8.wwww, r18.xyzx
  mul r8.w, l(0.500000), |cb4[r4.z + 8].w|
  div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
  mad r14.xyz, r14.xyzx, r5.wwww, -r6.xyzx
  dp3 r5.w, r15.xyzx, r6.xyzx
  lt r5.w, l(0.000000), r5.w
  dp2 r10.w, r14.xyxx, r17.yzyy
  mul r10.w, r8.w, r10.w
  mad_sat r10.w, r10.w, l(0.500000), l(0.500000)
  dp3 r11.w, r14.xyzx, r18.xyzx
  mul r8.w, r8.w, r11.w
  mad_sat r14.z, r8.w, l(0.500000), l(0.500000)
  add r8.w, r10.w, cb4[r4.z + 0].w
  div r14.x, r8.w, cb0[2].x
  sample_l_indexable(texture2d)(float,float,float,float) r8.w, r14.xzxx, t25.yzwx, s0, l(0.000000)
  and r5.w, r5.w, r8.w
  mul r5.w, r0.y, r5.w
  mad r5.w, r6.w, l(0.500000), r5.w
  dp3 r6.w, r15.xyzx, r5.xyzx
  add r6.w, r4.y, -r6.w
  mad_sat r6.w, r6.w, l(4.000000), l(1.000000)
  if_nz r4.w
    mad r14.xyz, r15.xyzx, r2.yyyy, r23.xyzx
    mul r15.xyzw, r14.yyyy, cb1[1].xyzw
    mad r15.xyzw, r14.xxxx, cb1[0].xyzw, r15.xyzw
    mad r14.xyzw, r14.zzzz, cb1[2].xyzw, r15.xyzw
    add r14.xyzw, r14.xyzw, cb1[3].xyzw
	
	add r25.w, r14.w, -r25.y
	mad r14.x, r25.x, r25.w, r14.x
	
    div r14.xyz, r14.xyzx, r14.wwww
    add r14.xyz, -r1.xyzx, r14.xyzx
    mul r13.zw, |r14.xxxy|, cb3[2].xxxy
    max r8.w, r13.w, r13.z
    div r14.xyz, r14.xyzx, r8.wwww
    mul r14.xy, r14.xyxx, cb1[52].xyxx
    add r8.w, r14.z, r14.z
    min r10.w, r2.w, |r8.w|
    mad r10.w, r10.w, l(16.000000), r2.w
    div r10.w, l(1.000000, 1.000000, 1.000000, 1.000000), r10.w
    add r8.z, r1.z, |r8.w|
    mul r15.xyz, r14.xyzx, l(8.000000, 8.000000, 8.000000, 0.000000)
    mad r17.xyz, r14.xyzx, l(-4.000000, -4.000000, -4.000000, 0.000000), r8.xyzx
    mul r8.z, r10.w, l(4.000000)
    mul r15.w, r8.z, r15.z
    mad r8.w, r17.z, r8.z, l(2.000000)
    mov r18.xy, r17.xyxx
    mov r18.z, r8.w
    mov r10.w, l(1.000000)
    mov r11.w, l(0)
    loop
      ige r12.w, r11.w, l(4)
      breakc_nz r12.w
      add r18.xyz, r15.xywx, r18.xyzx
      sample_l_indexable(texture2d)(float,float,float,float) r12.w, r18.xyxx, t17.yzwx, s4, l(0.000000)
      mul r12.w, r12.w, r12.w
      mad r12.w, r12.w, r8.z, -r18.z
      mad_sat r12.w, -|r12.w|, r2.z, r3.w
      mad r10.w, -r12.w, r10.w, r10.w
      iadd r11.w, r11.w, l(1)
    endloop
    mov r14.w, r15.w
    mad r15.xyz, r14.xywx, l(-8.000000, -8.000000, -1.000000, 0.000000), r18.xyzx
    mov r17.xyz, r15.xyzx
    mov r19.x, r2.z
    mov r19.y, r3.w
    mov r8.w, r10.w
    mov r11.w, l(0)
    loop
      ige r12.w, r11.w, l(8)
      breakc_nz r12.w
      mul r19.xy, r19.xyxx, l(0.749894202, 0.749894202, 0.000000, 0.000000)
      mad r17.xyz, r14.xywx, l(16.000000, 16.000000, 2.000000, 0.000000), r17.xyzx
      sample_l_indexable(texture2d)(float,float,float,float) r12.w, r17.xyxx, t18.yzwx, s4, l(0.000000)
      mul r12.w, r12.w, r12.w
      mad r12.w, r12.w, r8.z, -r17.z
      mad_sat r12.w, -|r12.w|, r19.x, r19.y
      mad r8.w, -r12.w, r8.w, r8.w
      iadd r11.w, r11.w, l(1)
    endloop
  else
    mov r8.w, l(1.000000)
  endif
  mul r5.w, r5.w, r8.w
  mul r5.w, r6.w, r5.w
  mad r12.xyz, cb4[r4.z + 0].xyzx, r5.wwww, r12.xyzx
  lt r5.w, cb4[r4.z + 8].w, l(0.000000)
  movc r13.xy, r5.wwww, l(0,0,0,0), r13.xyxx
  iadd r4.z, r4.z, l(1)
endloop
mul r0.yzw, r0.wwww, r10.xxyz
mad r0.yzw, r13.xxxx, cb2[33].xxyz, r0.yyzw
add r0.yzw, r12.xxyz, r0.yyzw
mul r1.xyz, r11.xyzx, r13.yyyy
mad r0.yzw, r0.yyzw, cb2[43].yyyy, r1.xxyz
add r1.x, cb0[2].y, l(1.000000)
mul r1.x, r1.x, v7.w
mul r0.yzw, r0.yyzw, r1.xxxx
mad r0.xyz, r3.xyzx, r0.xxxx, r0.yzwy
lt r1.xyz, l(0.250000, 0.500000, 0.750000, 0.000000), cb0[0].xxxx
add r0.w, r4.x, l(-1.000000)
mad r0.w, -|r0.w|, l(4.000000), l(1.000000)
max r0.w, r0.w, l(0.000000)
movc r0.xyz, r1.xxxx, r0.wwww, r0.xyzx
mov r9.w, l(1.000000)
mov r0.w, r9.z
movc r0.xyzw, r1.yyyy, r9.xyzw, r0.xyzw
mov r7.w, l(1.000000)
movc o0.xyzw, r1.zzzz, r7.xyzw, r0.xyzw
ret
// Approximately 0 instruction slots used

///////////////////////////////// HLSL Code /////////////////////////////////
// // ---- Created with 3Dmigoto v1.3.16 on Sat May 22 18:20:31 2021
// Texture2D<float4> t25 : register(t25);
//
// Texture2D<float4> t24 : register(t24);
//
// Texture2D<float4> t23 : register(t23);
//
// Texture2D<float4> t22 : register(t22);
//
// Texture2D<float4> t21 : register(t21);
//
// Texture3D<float4> t20 : register(t20);
//
// Texture3D<float4> t19 : register(t19);
//
// Texture2D<float4> t18 : register(t18);
//
// Texture2D<float4> t17 : register(t17);
//
// Texture2DArray<float4> t16 : register(t16);
//
// Texture2D<float4> t15 : register(t15);
//
// Texture2D<float4> t14 : register(t14);
//
// Texture3D<float4> t13 : register(t13);
//
// Texture3D<float4> t12 : register(t12);
//
// Texture3D<float4> t11 : register(t11);
//
// Texture3D<float4> t10 : register(t10);
//
// Texture3D<float4> t9 : register(t9);
//
// Texture2D<float4> t8 : register(t8);
//
// Texture2DArray<float4> t7 : register(t7);
//
// Texture2D<float4> t6 : register(t6);
//
// TextureCube<float4> t5 : register(t5);
//
// Texture2D<float4> t4 : register(t4);
//
// Texture2D<float4> t3 : register(t3);
//
// Texture2D<float4> t2 : register(t2);
//
// Texture2D<uint4> t1 : register(t1);
//
// Texture2D<uint4> t0 : register(t0);
//
// SamplerState s7_s : register(s7);
//
// SamplerComparisonState s6_s : register(s6);
//
// SamplerState s5_s : register(s5);
//
// 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 cb6 : register(b6)
// {
//   float4 cb6[14];
// }
//
// cbuffer cb5 : register(b5)
// {
//   float4 cb5[50];
// }
//
// cbuffer cb4 : register(b4)
// {
//   float4 cb4[17];
// }
//
// cbuffer cb3 : register(b3)
// {
//   float4 cb3[40];
// }
//
// cbuffer cb2 : register(b2)
// {
//   float4 cb2[86];
// }
//
// cbuffer cb1 : register(b1)
// {
//   float4 cb1[81];
// }
//
// cbuffer cb0 : register(b0)
// {
//   float4 cb0[3];
// }
//
//
//
//
// // 3Dmigoto declarations
// #define cmp -
// Texture1D<float4> IniParams : register(t120);
// Texture2D<float4> StereoParams : register(t125);
//
//
// void main(
//   linear centroid float4 v0 : TEXCOORD10,
//   linear centroid float4 v1 : TEXCOORD11,
//   float4 v2 : COLOR0,
//   float4 v3 : TEXCOORD0,
//   uint v4 : TEXCOORD12,
//   uint w4 : SV_IsFrontFace0,
//   float4 v5 : TEXCOORD7,
//   float4 v6 : TEXCOORD8,
//   float4 v7 : TEXCOORD9,
//   float4 v8 : SV_POSITION0,
//   out float4 o0 : SV_Target0)
// {
//   float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11,r12,r13,r14,r15,r16,r17,r18,r19,r20,r21;
//   uint4 bitmask, uiDest;
//   float4 fDest;
//
//   r0.xyz = cb5[41].xyz * v5.yyy;
//   r0.xyz = v5.xxx * cb5[40].xyz + r0.xyz;
//   r0.xyz = v5.zzz * cb5[42].xyz + r0.xyz;
//   r0.xyz = cb5[43].xyz + r0.xyz;
//   r1.xyz = cb5[45].xyz * v5.yyy;
//   r1.xyz = v5.xxx * cb5[44].xyz + r1.xyz;
//   r1.xyz = v5.zzz * cb5[46].xyz + r1.xyz;
//   r1.xyz = cb5[47].xyz + r1.xyz;
//   r0.w = dot(r0.xyz, r0.xyz);
//   r1.w = dot(r1.xyz, r1.xyz);
//   r0.w = cmp(r0.w < r1.w);
//   r0.xyz = r0.www ? r0.xyz : r1.xyz;
//   r1.xy = r0.ww ? float2(0,0) : float2(8,1);
//   r2.xyz = cb5[r1.x+0].xyz;
//   r3.xyz = cb5[r1.x+16].xyz;
//   r1.z = cb5[r1.x+16].w;
//   r1.w = 0;
//   r4.x = 0;
//   r5.xyz = float3(0,0,0);
//   r2.w = 7;
//   while (true) {
//     r3.w = cmp((int)r2.w < 0);
//     if (r3.w != 0) break;
//     r3.w = (int)r1.x + (int)r2.w;
//     r6.xyz = cb5[r3.w+0].zxy + -r2.zxy;
//     r7.xyz = -cb5[r1.y+48].xyz + cb5[r3.w+0].xyz;
//     r8.xyz = r7.yzx * r6.xyz;
//     r8.xyz = r6.zxy * r7.zxy + -r8.xyz;
//     r6.w = dot(r0.xyz, r8.xyz);
//     r7.w = dot(cb5[r3.w+0].xyz, r8.xyz);
//     r6.w = r7.w / r6.w;
//     r8.xyz = r6.www * r0.xyz;
//     r7.w = cmp(0 < r6.w);
//     r9.xyz = r8.yzx * r6.xyz;
//     r6.xyz = r6.zxy * r8.zxy + -r9.xyz;
//     r7.x = dot(r6.xyz, r7.xyz);
//     r8.xyz = -r0.xyz * r6.www + cb5[r3.w+0].xyz;
//     r6.x = dot(r6.xyz, r8.xyz);
//     r6.x = r7.x + -r6.x;
//     r6.x = r7.x / r6.x;
//     r6.y = cmp(0 < r6.x);
//     r8.yzw = r0.xyz * r6.www + -cb5[r1.y+48].xyz;
//     r6.xzw = r8.yzw * r6.xxx + cb5[r1.y+48].xyz;
//     r6.xzw = -cb5[r3.w+0].xyz + r6.xzw;
//     r7.xyz = -cb5[r3.w+0].xyz + r2.xyz;
//     r6.x = dot(r6.xzw, r7.xyz);
//     r6.z = dot(r7.xyz, r7.xyz);
//     r6.x = r6.x / r6.z;
//     r6.z = cmp(r6.x >= 0);
//     r6.w = cmp(r6.x < 1);
//     r6.z = r6.w ? r6.z : 0;
//     if (r6.z != 0) {
//       r6.z = r6.x * r6.x;
//       r6.w = r6.z * r6.x;
//       r7.x = 3 * r6.z;
//       r7.y = r6.w * 2 + -r7.x;
//       r7.y = 1 + r7.y;
//       r7.x = r6.w * -2 + r7.x;
//       r6.w = -r6.z * 2 + r6.w;
//       r6.w = r6.w + r6.x;
//       r6.z = r6.z * r6.x + -r6.z;
//       r7.z = -cb5[r3.w+16].w + r1.z;
//       r7.z = r6.x * r7.z + cb5[r3.w+16].w;
//       r9.x = 1 + -r6.x;
//       r7.y = -r9.x + r7.y;
//       r7.y = r7.z * r7.y + r9.x;
//       r7.x = r7.x + -r6.x;
//       r7.x = r7.z * r7.x + r6.x;
//       r6.zw = r7.zz * r6.zw;
//       r9.xyz = r7.xxx * r2.xyz;
//       r7.xyz = r7.yyy * cb5[r3.w+0].xyz + r9.xyz;
//       r7.xyz = r6.www * cb5[r3.w+16].xyz + r7.xyz;
//       r7.xyz = r6.zzz * r3.xyz + r7.xyz;
//       r7.xyz = -cb5[r1.y+48].xyz + r7.xyz;
//       r6.z = dot(r8.yzw, r7.xyz);
//       r6.w = dot(r7.xyz, r7.xyz);
//       r8.x = r6.z / r6.w;
//       r6.z = (int)r2.w;
//       r6.x = r6.x + r6.z;
//     } else {
//       r6.x = r1.w;
//       r8.x = r4.x;
//       r8.yzw = r5.xyz;
//     }
//     r6.x = r6.y ? r6.x : r1.w;
//     r4.yzw = r5.xyz;
//     r8.xyzw = r6.yyyy ? r8.xyzw : r4.xyzw;
//     r1.w = r7.w ? r6.x : r1.w;
//     r5.xyzw = r7.wwww ? r8.xywz : r4.xywz;
//     r2.w = (int)r2.w + -1;
//     r2.xyz = cb5[r3.w+0].xyz;
//     r3.xyz = cb5[r3.w+16].xyz;
//     r1.z = cb5[r3.w+16].w;
//     r4.x = r5.x;
//     r5.x = r5.y;
//     r5.yz = r5.wz;
//   }
//   r1.x = r1.w * 0.25 + -1;
//   r4.y = abs(r1.x);
//   r1.xyz = v6.xyz / v6.www;
//   r2.x = cb1[51].w + r1.z;
//   r2.x = cb1[51].z * r2.x;
//   r2.x = 1 / r2.x;
//   r2.x = 0.5 + r2.x;
//   r2.x = r2.x * cb1[51].z + -cb1[51].w;
//   r2.x = 1 / r2.x;
//   r2.x = r2.x + -r1.z;
//   r3.xy = (uint2)v8.xy;
//   r3.zw = float2(0,0);
//   r2.y = t17.Load(r3.xyw).x;
//   r2.y = r2.y * r2.y;
//   r2.z = t0.Load(r3.xyw).x;
//   if (11 == 0) r2.z = 0; else if (11+20 < 32) {   r2.z = (uint)r2.z << (32-(11 + 20)); r2.z = (uint)r2.z >> (32-11);  } else r2.z = (uint)r2.z >> 20;
//   r2.z = (uint)r2.z;
//   r2.z = r2.z * 0.00782013685 + -8;
//   r2.w = cb2[44].z * cb1[30].w;
//   r4.z = r2.y * r2.w;
//   r4.z = max(cb2[44].w, r4.z);
//   r4.z = r2.z * r4.z + 1;
//   r2.y = r2.y / r4.z;
//   r2.y = r2.y + -r1.z;
//   r2.y = abs(r2.y) / abs(r2.x);
//   r2.y = saturate(2 + -r2.y);
//   r4.z = cmp(r2.y == 0.000000);
//   r4.y = t24.Sample(s0_s, r4.yx).x;
//   if (r4.z != 0) {
//     o0.xyzw = float4(0,0,0,0);
//     return;
//   }
//   r6.xyz = v1.zxy * v0.yzx;
//   r6.xyz = v1.yzx * v0.zxy + -r6.xyz;
//   r6.xyz = v1.www * r6.xyz;
//   r4.zw = float2(6.28318548,3.14159274) * v3.xy;
//   sincos(r4.z, r7.x, r8.x);
//   r7.y = r8.x;
//   sincos(r4.w, r8.x, r9.x);
//   r7.xy = r8.xx * -r7.xy;
//   r7.z = r9.x;
//   r4.z = dot(r7.xyz, r7.xyz);
//   r4.z = rsqrt(r4.z);
//   r7.xyz = r7.xyz * r4.zzz;
//   r4.z = dot(cb6[2].xyz, cb6[2].xyz);
//   r4.z = rsqrt(r4.z);
//   r8.xyz = cb6[2].xyz * r4.zzz;
//   r4.z = 1 + -abs(cb6[12].z);
//   r4.z = sqrt(r4.z);
//   r4.w = abs(cb6[12].z) * -0.0187292993 + 0.0742610022;
//   r4.w = r4.w * abs(cb6[12].z) + -0.212114394;
//   r4.w = r4.w * abs(cb6[12].z) + 1.57072878;
//   r5.w = r4.w * r4.z;
//   r5.w = r5.w * -2 + 3.14159274;
//   r6.w = cmp(cb6[12].z < -cb6[12].z);
//   r5.w = r6.w ? r5.w : 0;
//   r4.z = r4.w * r4.z + r5.w;
//   r4.z = 1.57079637 + -r4.z;
//   r4.z = cos(r4.z);
//   r4.w = dot(r7.xyz, r8.xyz);
//   r4.z = saturate(r4.w + -r4.z);
//   r4.w = max(9.99999975e-006, r4.w);
//   r4.z = r4.z / r4.w;
//   r4.z = saturate(cb6[13].y * r4.z);
//   r4.z = r4.z * r4.z;
//   r7.xyz = t21.Sample(s7_s, v3.xy).xyz;
//   r7.xyz = r7.xyz * float3(2,2,2) + float3(-1,-1,-1);
//   r8.xyz = t22.Sample(s3_s, v3.xy).xyz;
//   r8.xyz = r8.xyz * float3(2,2,2) + float3(-1,-1,-1);
//   r8.xy = cb6[13].zz * r8.xy;
//   r8.xyz = r8.xyz + -r7.xyz;
//   r7.xyz = r4.zzz * r8.xyz + r7.xyz;
//   r7.xyz = r7.xyz * cb3[7].www + cb3[7].xyz;
//   r4.z = dot(r7.xyz, r7.xyz);
//   r4.z = rsqrt(r4.z);
//   r7.xyz = r7.xyz * r4.zzz;
//   r6.xyz = r7.yyy * r6.xyz;
//   r6.xyz = r7.xxx * v0.xyz + r6.xyz;
//   r6.xyz = r7.zzz * v1.xyz + r6.xyz;
//   r4.z = dot(r6.xyz, r6.xyz);
//   r4.z = rsqrt(r4.z);
//   r6.xyz = r6.xyz * r4.zzz;
//   r1.w = r1.w * 0.125 + -0.25;
//   r1.w = saturate(abs(r1.w) * 8 + -1);
//   r4.z = cb0[0].w + -cb0[0].z;
//   r4.z = r1.w * r4.z + cb0[0].z;
//   r1.w = 1 + -r1.w;
//   r7.xyzw = float4(1,1,1,1) + -cb0[1].xyzw;
//   r1.w = r1.w * r7.w + cb0[1].w;
//   r3.xyz = t23.Load(r3.xyz).xyz;
//   r2.z = cmp(r2.z >= 0);
//   r1.w = r4.x * r1.w;
//   r7.xyz = saturate(-r1.www * r7.xyz + float3(1,1,1));
//   r8.xyz = float3(1,1,1) + -r7.xyz;
//   r8.xyz = v7.xyz * r8.xyz;
//   r3.xyz = r3.xyz * r7.xyz + r8.xyz;
//   r0.xyz = r5.xyz * cb0[0].yyy + r0.xyz;
//   r0.w = r0.w ? 0 : 4;
//   r7.xzw = cb5[r0.w+33].xyz * r0.yyy;
//   r7.xzw = r0.xxx * cb5[r0.w+32].xyz + r7.xzw;
//   r0.xyz = r0.zzz * cb5[r0.w+34].xyz + r7.xzw;
//   r0.xyz = cb5[r0.w+35].xyz + r0.xyz;
//   r8.xyzw = cb1[1].xyzw * r0.yyyy;
//   r8.xyzw = r0.xxxx * cb1[0].xyzw + r8.xyzw;
//   r8.xyzw = r0.zzzz * cb1[2].xyzw + r8.xyzw;
//   r8.xyzw = cb1[3].xyzw + r8.xyzw;
//   r0.xyz = r8.xyz / r8.www;
//   r8.xy = r1.xy * cb1[52].xy + cb1[52].wz;
//   r0.xy = r0.xy * cb1[52].xy + cb1[52].wz;
//   r8.z = r1.z;
//   r0.xyz = -r8.xyz + r0.xyz;
//   r7.xzw = -r0.xyz * float3(0.5,0.5,0.5) + r8.xyz;
//   r9.zw = float2(0,0);
//   r10.w = 1;
//   r11.xyz = r7.xzw;
//   r13.xyz = float3(0,0,0);
//   r12.xyzw = float4(0,0,0,0);
//   r1.w = 0;
//   r3.w = 0;
//   while (true) {
//     r4.w = cmp((int)r3.w >= 16);
//     if (r4.w != 0) break;
//     r11.xyz = r0.xyz * float3(0.0625,0.0625,0.0625) + r11.xyz;
//     r10.xyz = t23.SampleLevel(s0_s, r11.xy, 0).xyz;
//     r4.w = t17.SampleLevel(s1_s, r11.xy, 0).x;
//     r4.w = r4.w * r4.w;
//     r14.xy = r11.xy * cb3[3].xy + float2(0.5,0.5);
//     r9.xy = (uint2)r14.xy;
//     r5.w = t0.Load(r9.xyz).x;
//     r6.w = (int)r5.w & 1023;
//     r14.x = (uint)r6.w;
//     if (10 == 0) r9.x = 0; else if (10+10 < 32) {     r9.x = (uint)r5.w << (32-(10 + 10)); r9.x = (uint)r9.x >> (32-10);    } else r9.x = (uint)r5.w >> 10;
//     if (11 == 0) r9.y = 0; else if (11+20 < 32) {     r9.y = (uint)r5.w << (32-(11 + 20)); r9.y = (uint)r9.y >> (32-11);    } else r9.y = (uint)r5.w >> 20;
//     r14.yz = (uint2)r9.xy;
//     r14.xyz = r14.xyz * float3(0.00195503421,0.00195503421,0.00782013685) + float3(-1,-1,-8);
//     r5.w = dot(float2(1,1), abs(r14.xy));
//     r15.z = 1 + -r5.w;
//     r9.xy = float2(1,1) + -abs(r14.yx);
//     r16.xyz = cmp(r14.xyz >= float3(0,0,0));
//     r9.xy = r16.xy ? r9.xy : -r9.xy;
//     r5.w = cmp(r15.z < 0);
//     r15.xy = r5.ww ? r9.xy : r14.xy;
//     r5.w = dot(r15.xyz, r15.xyz);
//     r5.w = rsqrt(r5.w);
//     r14.xyw = r15.xyz * r5.www;
//     r5.w = r4.w * r2.w;
//     r5.w = max(cb2[44].w, r5.w);
//     r5.w = r14.z * r5.w + 1;
//     r4.w = r4.w / r5.w;
//     r4.w = r4.w + -r11.z;
//     r4.w = abs(r4.w) / abs(r2.x);
//     r4.w = saturate(2 + -r4.w);
//     r5.w = r16.z ? r4.w : 0;
//     r12.xyzw = r10.xyzw * r5.wwww + r12.xyzw;
//     r13.xyz = r14.xyw * r5.www + r13.xyz;
//     r4.w = r16.z ? 0 : r4.w;
//     r1.w = r4.w + r1.w;
//     r3.w = (int)r3.w + 1;
//   }
//   r0.x = max(9.99999997e-007, r1.w);
//   r0.yz = float2(0.0625,0.125) * r0.xx;
//   r1.w = -r0.x * 0.0625 + 1;
//   r0.y = r1.w * r0.y;
//   r0.y = r0.y * r4.z;
//   r0.z = min(1, r0.z);
//   r9.xyz = min(r2.yyy, r0.zzz);
//   r2.xyw = r6.xyz * r0.xxx + r13.xyz;
//   r0.z = dot(r2.xyw, r2.xyw);
//   r0.z = rsqrt(r0.z);
//   r2.xyw = r2.xyw * r0.zzz;
//   r3.xyz = r3.xyz * r0.xxx + r12.xyz;
//   r0.x = r12.w + r0.x;
//   r0.x = 1 / r0.x;
//   r10.yz = r0.yy * float2(1.20000005,0.400000006) + float2(0.300000012,0.0500000007);
//   r7.xzw = cb2[6].xyz * r2.xyw;
//   r7.xzw = r7.xzw * float3(1.5,1.5,1.5) + v5.xyz;
//   r11.xy = r7.xz * cb2[7].xy + cb2[7].zw;
//   r4.zw = saturate(r11.xy);
//   r4.zw = cmp(r4.zw == r11.xy);
//   r1.w = r4.w ? r4.z : 0;
//   if (r1.w != 0) {
//     r11.z = r7.w * cb2[8].x + cb2[8].y;
//     r1.w = t11.SampleLevel(s5_s, r11.xyz, 0).x;
//     r3.w = cb2[6].w * r1.w;
//     r4.z = cmp(1 >= r3.w);
//     r1.w = r1.w * cb2[6].w + 0.75;
//     r1.w = r4.z ? r1.w : r3.w;
//     r1.w = floor(r1.w);
//     r12.xyzw = t9.SampleLevel(s0_s, r11.xyz, r1.w).xyzw;
//     r11.xyzw = t10.SampleLevel(s0_s, r11.xyz, r1.w).xyzw;
//     r13.xyzw = r12.xyzw * r12.xyzw;
//     r14.xyzw = r12.xyzw * float4(0.335721463,0.335721463,0.335721463,0.335721463) + float4(-0.00358909299,-0.00358909299,-0.00358909299,-0.00358909299);
//     r14.xyzw = r13.xyzw * float4(2.67030215,2.67030215,2.67030215,2.67030215) + r14.xyzw;
//     r12.xyzw = r13.xyzw * r12.xyzw;
//     r12.xyzw = r12.xyzw * float4(-2.01957369,-2.01957369,-2.01957369,-2.01957369) + r14.xyzw;
//     r13.xyzw = r11.xyzw * r11.xyzw;
//     r14.xyzw = r11.xyzw * float4(0.335721463,0.335721463,0.335721463,0.335721463) + float4(-0.00358909299,-0.00358909299,-0.00358909299,-0.00358909299);
//     r14.xyzw = r13.xyzw * float4(2.67030215,2.67030215,2.67030215,2.67030215) + r14.xyzw;
//     r11.xyzw = r13.xyzw * r11.xyzw;
//     r11.xyzw = r11.xyzw * float4(-2.01957369,-2.01957369,-2.01957369,-2.01957369) + r14.xyzw;
//   } else {
//     r12.xyzw = float4(0,0,0,0);
//     r11.xyzw = float4(0,0,0,0);
//   }
//   r12.xyzw = float4(1,1,1,1) + -r12.xyzw;
//   r11.xyzw = float4(1,1,1,1) + -r11.xyzw;
//   r13.xy = r1.xy * float2(0.5,-0.5) + float2(0.5,0.5);
//   r4.zw = float2(128,64) * r13.xy;
//   r14.xy = (uint2)r4.zw;
//   r14.zw = float2(0,0);
//   r1.w = t1.Load(r14.xyz).x;
//   r14.w = dot(r2.xyw, float3(-1,-1,1));
//   r14.z = dot(r2.yxw, float3(-1,1,1));
//   r14.y = dot(r2.xyw, float3(-1,1,1));
//   r14.x = dot(r2.xyw, float3(1,1,1));
//   r15.xyzw = r14.wzyx * r14.wzyx;
//   r3.w = dot(float4(1,1,1,1), r15.xyzw);
//   r3.w = 0.25 * r3.w;
//   r4.z = 1 + -cb2[5].w;
//   r12.xyzw = r12.xyzw * cb2[5].wwww + r4.zzzz;
//   r11.xyzw = r11.xyzw * cb2[5].wwww + r4.zzzz;
//   r15.xyzw = r2.xyxy * float4(64,64,256,256) + v5.xyxy;
//   r4.zw = r15.xy * cb2[0].xy + -cb2[1].xy;
//   r16.xy = r4.zw * float2(2,2) + float2(-0.5,-0.5);
//   r17.xyzw = t3.SampleLevel(s0_s, r16.xy, 0).xyzw;
//   r4.z = r17.w * cb2[0].z + cb2[1].z;
//   r4.z = -v5.z + r4.z;
//   r4.z = abs(r4.z) * 0.000156249997 + r17.x;
//   r7.xz = float2(-0.5,-0.5) + r17.yz;
//   r17.z = -r7.x + r4.z;
//   r17.w = r7.x + r4.z;
//   r18.xy = saturate(r17.zw + -r7.zz);
//   r18.zw = saturate(r17.zw + r7.zz);
//   r4.zw = v5.xy * cb2[9].xy + cb2[9].zw;
//   r17.zw = v5.zz * cb2[8].xz + cb2[8].yw;
//   r4.z = max(abs(r4.z), abs(r4.w));
//   r4.z = max(r4.z, abs(r17.w));
//   r4.z = saturate(-cb2[5].x * r4.z + cb2[5].x);
//   if (r1.w != 0) {
//     r1.w = (uint)r1.w >> 8;
//     r19.xyz = v5.xyz;
//     r19.w = 1;
//     r7.xzw = float3(0,0,0);
//     r15.xy = float2(1,1);
//     r4.w = r1.w;
//     while (true) {
//       if (r4.w == 0) break;
//       r5.w = firstbitlow((uint)r4.w);
//       r6.w = 1 << (int)r5.w;
//       r4.w = (int)r4.w ^ (int)r6.w;
//       r6.w = (uint)r5.w << 1;
//       bitmask.w = ((~(-1 << 31)) << 1) & 0xffffffff;  r10.w = (((uint)r5.w << 1) & bitmask.w) | ((uint)1 & ~bitmask.w);
//       r13.w = (int)r5.w * 3;
//       r20.xy = mad((int2)r5.ww, int2(3,3), int2(1,2));
//       r21.x = dot(cb2[r13.w+46].xyzw, r19.xyzw);
//       r21.y = dot(cb2[r20.x+46].xyzw, r19.xyzw);
//       r21.z = dot(cb2[r20.y+46].xyzw, r19.xyzw);
//       r20.xyz = float3(1,1,1) + -abs(r21.xyz);
//       r20.xyz = saturate(cb2[r6.w+70].xyz * r20.xyz);
//       r5.w = min(r20.y, r20.z);
//       r5.w = min(r20.x, r5.w);
//       r5.w = 1 + -r5.w;
//       r13.w = r5.w * r5.w;
//       r20.xy = -cb2[r10.w+70].xy + float2(1,1);
//       r20.xy = r13.ww * r20.xy + cb2[r10.w+70].xy;
//       r15.xy = min(r20.xy, r15.xy);
//       r5.w = -r5.w * r5.w + 1;
//       r20.xy = cb2[r10.w+70].zw * r5.ww;
//       r7.xz = max(r20.xy, r7.xz);
//       r5.w = cb2[r6.w+70].w * r5.w;
//       r7.w = max(r7.w, r5.w);
//     }
//   } else {
//     r7.xzw = float3(0,0,0);
//     r15.xy = float2(1,1);
//   }
//   r1.w = r15.y * r4.z;
//   r4.w = 1 + -r4.z;
//   r4.w = r15.x * r4.w;
//   r15.xy = r15.zw * cb2[2].xy + -cb2[2].zw;
//   r5.w = t4.SampleLevel(s5_s, r15.xy, 0).x;
//   r5.w = r5.w * cb2[3].x + cb2[4].x;
//   r5.w = -v5.z + r5.w;
//   r5.w = saturate(r5.w * -0.001953125 + 1);
//   r5.w = 0.5 + r5.w;
//   r5.w = min(1, r5.w);
//   r4.w = r5.w * r4.w;
//   r12.xyzw = r12.xyzw * r1.wwww + r4.wwww;
//   r11.xyzw = r11.xyzw * r1.wwww + r4.wwww;
//   r15.xyzw = float4(0.577350259,0.577350259,0.577350259,0.577350259) * r14.wzyx;
//   r19.xyzw = r15.wzyx * r15.wzyx;
//   r20.xyzw = r19.wzyx * r15.xyzw;
//   r21.xyzw = float4(0.0898000002,0.0898000002,0.0898000002,0.0898000002) * r19.xyzw;
//   r20.xyzw = r20.xyzw * float4(-0.0156999994,-0.0156999994,-0.0156999994,-0.0156999994) + r21.wzyx;
//   r20.xyzw = r14.wzyx * float4(0.118991889,0.118991889,0.118991889,0.118991889) + r20.xyzw;
//   r20.xyzw = float4(0.102899998,0.102899998,0.102899998,0.102899998) + r20.xyzw;
//   r15.xyzw = r19.xyzw * -r15.wzyx;
//   r15.xyzw = r15.xyzw * float4(-0.0156999994,-0.0156999994,-0.0156999994,-0.0156999994) + r21.xyzw;
//   r14.xyzw = r14.xyzw * float4(-0.118991889,-0.118991889,-0.118991889,-0.118991889) + r15.xyzw;
//   r14.xyzw = float4(0.102899998,0.102899998,0.102899998,0.102899998) + r14.xyzw;
//   r16.zw = float2(3,2);
//   r15.xyz = t7.SampleLevel(s0_s, r16.xyz, 0).xyz;
//   r19.xyz = t7.SampleLevel(s0_s, r16.xyw, 0).xyz;
//   r16.zw = float2(1,0);
//   r21.xyz = t7.SampleLevel(s0_s, r16.xyz, 0).xyz;
//   r16.xyz = t7.SampleLevel(s0_s, r16.xyw, 0).xyz;
//   r20.xyzw = r20.xyzw * r12.xyzw;
//   r11.xyzw = r14.xyzw * r11.xyzw;
//   r14.xyzw = r12.xyzw * r18.xyzw;
//   r12.xyzw = -r12.xyzw * r18.xyzw + float4(1,1,1,1);
//   r12.xyzw = r20.xyzw * r12.xyzw;
//   r11.xyzw = r11.xyzw * r18.xyzw + r12.xyzw;
//   r12.xyzw = r14.xyzw * r18.xyzw;
//   r1.w = 0.0500000007 * r7.x;
//   r14.xyzw = r11.xyzw * r1.wwww;
//   r12.xyzw = r20.xyzw * r12.xyzw + r14.xyzw;
//   r1.w = 1 + -r7.x;
//   r14.xyzw = r11.xyzw * r1.wwww;
//   r18.xyz = cb3[32].xyz * r12.yyy;
//   r18.xyz = cb3[31].xyz * r12.xxx + r18.xyz;
//   r18.xyz = cb3[33].xyz * r12.zzz + r18.xyz;
//   r18.xyz = cb3[34].xyz * r12.www + r18.xyz;
//   r15.xyz = r15.xyz * r14.xxx + r18.xyz;
//   r15.xyz = r19.xyz * r14.yyy + r15.xyz;
//   r14.xyz = r21.xyz * r14.zzz + r15.xyz;
//   r14.yzw = r16.xyz * r14.www + r14.xyz;
//   r14.x = r14.y + r7.w;
//   r4.w = dot(v5.xyz, r2.xyw);
//   r4.w = r4.w + r4.w;
//   r15.xyz = r2.xyw * -r4.www + v5.xyz;
//   r4.w = dot(r15.xyz, r15.xyz);
//   r4.w = rsqrt(r4.w);
//   r16.xyz = r15.xyz * r4.www;
//   r4.w = r12.x + r12.y;
//   r4.w = r4.w + r12.z;
//   r4.w = r4.w + r12.w;
//   r4.w = r11.x * r1.w + r4.w;
//   r4.w = r11.y * r1.w + r4.w;
//   r4.w = r11.z * r1.w + r4.w;
//   r1.w = r11.w * r1.w + r4.w;
//   r17.xy = v5.xy * cb2[7].xy + cb2[7].zw;
//   r11.xyz = t13.SampleLevel(s0_s, r17.xyz, 0).xyz;
//   r11.xyz = r11.xyz * float3(4,4,4) + float3(-2,-2,-2);
//   r11.xyz = r2.xyw * float3(3,3,3) + r11.xyz;
//   r11.xyz = r11.xyz * cb2[6].xyz + v5.xyz;
//   r12.xy = r11.xy * cb2[7].xy + cb2[7].zw;
//   r12.z = r11.z * cb2[8].x + cb2[8].y;
//   r11.xyz = t12.SampleLevel(s0_s, r12.xyz, 0).xyz;
//   r4.z = r4.z * r3.w;
//   r4.z = cb2[43].z * r4.z;
//   r11.xyz = r11.xyz * r4.zzz + r14.xzw;
//   r4.z = log2(r10.y);
//   r4.z = r4.z * 1.20000005 + 5;
//   r12.xyz = t5.SampleLevel(s2_s, r15.xyz, r4.z).xyz;
//   r4.w = frac(r15.y);
//   r4.w = r4.w * 347834.531 + r15.x;
//   r4.w = frac(r4.w);
//   r5.w = dot(r16.xyz, cb1[48].xyz);
//   r5.w = saturate(r5.w + r5.w);
//   r1.w = r1.w * 4096 + 64;
//   r6.w = r3.w * r3.w;
//   r1.w = r6.w * r1.w;
//   r14.xyz = r16.xyz * r1.www + v5.xyz;
//   r14.xyz = cb3[10].xyz + r14.xyz;
//   r15.xyz = cb1[78].xyw * r14.yyy;
//   r14.xyw = r14.xxx * cb1[77].xyw + r15.xyz;
//   r14.xyz = r14.zzz * cb1[79].xyw + r14.xyw;
//   r14.xyz = cb1[80].xyw + r14.xyz;
//   r7.xw = r14.xy / r14.zz;
//   r14.yz = saturate(r7.xw * cb3[39].xy + cb3[39].zw);
//   r1.w = r5.w * r3.w;
//   r15.xyz = r4.www * float3(-0.166500002,-0.0164999999,-0.0154999997) + float3(0.200000003,0.0350000001,0.0199999996);
//   r15.xyz = cmp(r1.zzz < r15.xyz);
//   r15.xyz = r15.xyz ? float3(0.25,0.25,0.25) : 0;
//   r6.w = r15.x + r15.y;
//   r6.w = r6.w + r15.z;
//   r14.x = r14.y * 0.25 + r6.w;
//   r3.w = r4.z * r3.w + r4.w;
//   r3.w = -0.5 + r3.w;
//   r14.xyzw = t6.SampleLevel(s5_s, r14.xz, r3.w).xyzw;
//   r14.xyz = r14.xyz * r14.xyz;
//   r3.w = dot(r14.xzy, float3(-0.25,-0.25,-0.5));
//   r3.w = 1 + r3.w;
//   r3.w = rcp(r3.w);
//   r1.w = r3.w * r1.w;
//   r1.w = cb2[42].z * r1.w;
//   r1.w = 4 * r1.w;
//   r14.xyz = r14.xyz * r1.www;
//   r1.w = -r5.w * r14.w + 1;
//   r11.xyz = r12.xyz * r11.xyz;
//   r11.xyz = r11.xyz * r1.www + r14.xyz;
//   r1.w = dot(v5.xyz, v5.xyz);
//   r1.w = rsqrt(r1.w);
//   r12.xyz = v5.xyz * r1.www;
//   r10.x = saturate(dot(r2.xyw, -r12.xyz));
//   r4.zw = t8.SampleLevel(s0_s, r10.xy, 0).xy;
//   r1.w = r4.z + -r4.w;
//   r1.w = r10.z * r1.w + r4.w;
//   r10.xyz = r11.xyz * r1.www;
//   r11.xyz = cb5[r0.w+33].xyz * r5.yyy;
//   r5.xyw = r5.xxx * cb5[r0.w+32].xyz + r11.xyz;
//   r5.xyz = r5.zzz * cb5[r0.w+34].xyz + r5.xyw;
//   r0.w = dot(v5.xyz, r6.xyz);
//   r0.zw = r0.yw + r0.yw;
//   r6.xyz = r6.xyz * -r0.www + v5.xyz;
//   r0.w = dot(r6.xyz, r6.xyz);
//   r0.w = rsqrt(r0.w);
//   r6.xyz = r6.xyz * r0.www;
//   r0.w = dot(r16.xyz, v1.xyz);
//   r0.w = r4.y + r0.w;
//   r0.w = saturate(r0.w * 8 + -6);
//   r0.w = r7.y * r0.w;
//   r1.w = 1 + -r7.z;
//   r4.zw = v5.xy * cb2[0].xy + -cb2[1].xy;
//   r4.zw = t2.SampleLevel(s0_s, r4.zw, 0).xy;
//   r3.w = r4.z * cb2[0].z + cb2[1].z;
//   r3.w = v5.z + -r3.w;
//   r3.w = saturate(r3.w * cb2[0].w + 1);
//   r3.w = r3.w * r4.w;
//   r7.xyz = cb2[29].xyz * v5.yyy;
//   r7.xyz = v5.xxx * cb2[28].xyz + r7.xyz;
//   r7.xyz = v5.zzz * cb2[30].xyz + r7.xyz;
//   r7.xyz = cb2[31].xyz + r7.xyz;
//   r11.x = dot(v5.xyz, cb2[18].xyz);
//   r11.y = dot(v5.xyz, cb2[19].xyz);
//   r11.z = dot(v5.xyz, cb2[20].xyz);
//   r4.z = 0.100000001 + abs(r11.z);
//   r4.z = max(abs(r11.y), r4.z);
//   r4.z = max(abs(r11.x), r4.z);
//   r12.xyz = float3(1,1,1) / cb2[19].www;
//   r11.xyz = cb2[21].xyz + r11.xyz;
//   r4.w = cmp(cb2[18].w < r4.z);
//   r14.xyz = r11.xyz * r12.zzz + cb2[22].xyz;
//   r14.w = 1;
//   r11.w = 0;
//   r11.xyzw = r4.wwww ? r14.xyzw : r11.xyzw;
//   r14.z = r4.w ? cb2[19].w : 1;
//   r4.w = cb2[19].w * cb2[18].w;
//   r4.w = cmp(r4.w < r4.z);
//   r5.w = 1;
//   r12.xyz = r11.xyz * r12.xyz + cb2[23].xyz;
//   r15.x = r11.w * r5.w + 1;
//   r5.w = max(abs(r12.x), abs(r12.y));
//   r5.w = saturate(-r5.w * 8 + 7);
//   r6.w = r12.z * 0.5 + 0.5;
//   r6.w = saturate(32 * r6.w);
//   r15.y = r6.w * r5.w;
//   r15.z = cb2[19].w * r14.z;
//   r11.xyz = r4.www ? r12.xyz : r11.xyz;
//   r14.x = r11.w;
//   r14.y = 1;
//   r12.xyz = r4.www ? r15.xyz : r14.xyz;
//   r11.xyz = r11.xyz * float3(0.5,0.5,0.5) + float3(0.5,0.5,0.5);
//   r4.z = -r4.z * 0.25 + 1;
//   r4.z = max(0, r4.z);
//   r4.z = 0.25 + r4.z;
//   r4.z = min(1, r4.z);
//   r4.w = r12.z * r12.y;
//   r4.z = r4.w * r4.z;
//   r4.zw = float2(64,4) * r4.zz;
//   r11.w = r12.x;
//   r12.xyzw = t16.SampleLevel(s0_s, r11.xyw, 0).xyzw;
//   r11.xy = r12.xy + -r11.zz;
//   r4.zw = saturate(r11.xy * r4.zw);
//   r4.z = -r4.z * r12.z + 1;
//   r5.w = 1 + -r12.w;
//   r5.w = r5.w + -r4.z;
//   r4.z = r4.w * r5.w + r4.z;
//   r3.w = r4.z * r3.w;
//   r4.zw = -cb2[34].xy + r7.xy;
//   r11.xy = -cb2[35].xy + r7.xy;
//   r5.w = max(abs(r4.z), abs(r4.w));
//   r6.w = max(abs(r11.x), abs(r11.y));
//   r4.zw = r4.zw * cb2[34].zz + float2(1.5,0.5);
//   r7.w = cb2[34].z * cb2[34].z;
//   r11.xy = r11.xy * r7.ww + float2(2.5,0.5);
//   r5.w = cmp(r5.w < cb2[34].w);
//   r4.zw = r5.ww ? r4.zw : r7.xy;
//   r5.w = cmp(r6.w < cb2[35].w);
//   r11.yz = r5.ww ? r11.xy : r4.zw;
//   r11.x = cb2[35].z * r11.y;
//   r4.zw = saturate(r11.xz);
//   r4.zw = cmp(r4.zw != r11.xz);
//   r4.z = (int)r4.w | (int)r4.z;
//   r4.w = cmp(1 < r7.z);
//   r4.z = (int)r4.w | (int)r4.z;
//   if (r4.z != 0) {
//     r4.w = 0;
//   }
//   if (r4.z == 0) {
//     r7.xy = r11.xz * cb2[36].xy + float2(0.5,0.5);
//     r11.xy = frac(r7.xy);
//     r7.xy = floor(r7.xy);
//     r7.xy = float2(-0.5,-0.5) + r7.xy;
//     r7.xy = cb2[36].zw * r7.xy;
//     r4.z = r7.z * 2048 + -1;
//     r12.y = 1 + -r11.y;
//     r11.z = 1 + -r11.x;
//     r12.z = 1;
//     r12.xyzw = r12.zzyy * r11.zxxz;
//     r11.w = 1;
//     r11.xyzw = r12.xyzw * r11.yyww;
//     r7.xyzw = t14.Gather(s0_s, r7.xy, int2(0, 0)).xyzw;
//     r7.xyzw = saturate(r7.xyzw * float4(2048,2048,2048,2048) + -r4.zzzz);
//     r4.z = dot(r7.xyzw, r11.xyzw);
//     r4.z = min(1, r4.z);
//     r4.w = -1;
//   } else {
//     r4.z = 1;
//   }
//   if (r4.w == 0) {
//     r7.xyzw = cb2[25].xyzz * v5.yyyy;
//     r7.xyzw = v5.xxxx * cb2[24].xyzz + r7.xyzw;
//     r7.xyzw = v5.zzzz * cb2[26].xyzz + r7.xyzw;
//     r7.xyzw = cb2[27].xyzz + r7.xyzw;
//     r11.xyzw = float4(-0.5,-0.5,-0.5,-0.000244140625) + r7.xyzw;
//     r4.w = max(abs(r11.y), abs(r11.z));
//     r4.w = max(abs(r11.x), r4.w);
//     r4.w = saturate(-r4.w * 16 + 8);
//     r5.w = t15.SampleCmpLevelZero(s6_s, r7.xy, r11.w).x;
//     r5.w = r5.w + r5.w;
//     r5.w = min(1, r5.w);
//     r5.w = r4.z * r5.w + -r4.z;
//     r4.z = r4.w * r5.w + r4.z;
//   }
//   r3.w = r4.z * r3.w;
//   r1.w = saturate(r3.w * r1.w);
//   r3.w = saturate(dot(-cb2[32].xyz, r16.xyz));
//   r3.w = log2(r3.w);
//   r3.w = 12 * r3.w;
//   r3.w = exp2(r3.w);
//   r3.w = r3.w * r0.z;
//   r4.z = saturate(dot(-cb2[32].xyz, r6.xyz));
//   r4.z = cmp(0.980000019 < r4.z);
//   r4.z = r4.z ? 0.500000 : 0;
//   r7.xyz = r2.zzz ? float3(0,0,0) : float3(1,1,1);
//   r0.y = -r0.y * 2 + 1;
//   r0.y = r0.y * r0.y;
//   r0.y = r7.z * r0.y;
//   r2.z = r4.z * r0.y;
//   r2.z = r3.w * 0.5 + r2.z;
//   r3.w = dot(-cb2[32].xyz, r5.xyz);
//   r3.w = r4.y + -r3.w;
//   r3.w = saturate(r3.w * 4 + 1);
//   r4.z = r1.z * cb1[51].z + -cb1[51].w;
//   r4.z = 1 / r4.z;
//   r4.w = cmp(r4.z < 2500);
//   if (r4.w != 0) {
//     r5.w = 0.015625 * r4.z;
//     r11.xyz = -cb2[32].xyz * r5.www + v5.xyz;
//     r12.xyzw = cb1[1].xyzw * r11.yyyy;
//     r12.xyzw = r11.xxxx * cb1[0].xyzw + r12.xyzw;
//     r11.xyzw = r11.zzzz * cb1[2].xyzw + r12.xyzw;
//     r11.xyzw = cb1[3].xyzw + r11.xyzw;
//     r11.xyz = r11.xyz / r11.www;
//     r11.xyz = r11.xyz + -r1.xyz;
//     r12.xy = cb3[2].xy * abs(r11.xy);
//     r5.w = max(r12.x, r12.y);
//     r11.xyz = r11.xyz / r5.www;
//     r11.xy = cb1[52].xy * r11.xy;
//     r5.w = r11.z + r11.z;
//     r6.w = saturate(-r4.z * 0.00039999999 + 1);
//     r6.w = r6.w * r6.w;
//     r10.w = cb1[51].w + r4.z;
//     r10.w = 8 + r10.w;
//     r10.w = cb1[51].z * r10.w;
//     r10.w = 1 / r10.w;
//     r10.w = -r10.w + r1.z;
//     r12.x = min(r10.w, abs(r5.w));
//     r10.w = r12.x * 16 + r10.w;
//     r10.w = 1 / r10.w;
//     r8.w = abs(r5.w) + r1.z;
//     r12.xyz = float3(8,8,8) * r11.xyz;
//     r14.xyz = r11.xyz * float3(-4,-4,-4) + r8.xyw;
//     r5.w = 4 * r10.w;
//     r8.w = 4 * r6.w;
//     r6.w = r6.w + r6.w;
//     r12.w = r12.z * r5.w;
//     r10.w = r14.z * r5.w + 2;
//     r15.xy = r14.xy;
//     r15.z = r10.w;
//     r11.z = 1;
//     r12.z = 0;
//     while (true) {
//       r13.w = cmp((int)r12.z >= 4);
//       if (r13.w != 0) break;
//       r15.xyz = r15.xyz + r12.xyw;
//       r13.w = t17.SampleLevel(s4_s, r15.xy, 0).x;
//       r13.w = r13.w * r13.w;
//       r13.w = r13.w * r5.w + -r15.z;
//       r13.w = saturate(-abs(r13.w) * r6.w + r8.w);
//       r11.z = -r13.w * r11.z + r11.z;
//       r12.z = (int)r12.z + 1;
//     }
//     r11.w = r12.w;
//     r12.xyz = r11.xyw * float3(-8,-8,-1) + r15.xyz;
//     r14.xyz = r12.xyz;
//     r15.x = r6.w;
//     r15.y = r8.w;
//     r10.w = r11.z;
//     r12.w = 0;
//     while (true) {
//       r13.w = cmp((int)r12.w >= 8);
//       if (r13.w != 0) break;
//       r15.xy = float2(0.749894202,0.749894202) * r15.xy;
//       r14.xyz = r11.xyw * float3(16,16,2) + r14.xyz;
//       r13.w = t18.SampleLevel(s4_s, r14.xy, 0).x;
//       r13.w = r13.w * r13.w;
//       r13.w = r13.w * r5.w + -r14.z;
//       r13.w = saturate(-abs(r13.w) * r15.x + r15.y);
//       r10.w = -r13.w * r10.w + r10.w;
//       r12.w = (int)r12.w + 1;
//     }
//   } else {
//     r10.w = 1;
//   }
//   r1.w = r10.w * r1.w;
//   r1.w = r2.z * r1.w;
//   r1.w = r1.w * r3.w;
//   r2.z = dot(v5.xyz, cb1[48].xyz);
//   r13.z = cb3[30].w * r2.z;
//   r11.xyz = t19.SampleLevel(s0_s, r13.xyz, 0).xyz;
//   r11.xyz = cb2[43].yyy * r11.xyz;
//   r12.xyz = t20.SampleLevel(s0_s, r13.xyz, 0).xyz;
//   r12.xyz = r12.xyz * float3(2,2,2) + float3(-1,-1,-1);
//   r2.x = dot(r12.xyz, r2.xyw);
//   r2.x = 1 + r2.x;
//   r2.y = dot(r12.xyz, r12.xyz);
//   r2.z = min(1, r2.y);
//   r2.z = -r2.z * 0.5 + 1;
//   r2.x = r2.x * r2.z;
//   r2.x = r2.x * r2.x;
//   r2.x = dot(r2.xx, r2.yy);
//   r2.y = rsqrt(r2.y);
//   r2.yzw = r12.xyz * r2.yyy;
//   r3.w = saturate(dot(r2.yzw, r16.xyz));
//   r3.w = log2(r3.w);
//   r3.w = 12 * r3.w;
//   r3.w = exp2(r3.w);
//   r3.w = r3.w * r0.z;
//   r5.w = saturate(dot(r2.yzw, r6.xyz));
//   r5.w = cmp(0.980000019 < r5.w);
//   r5.w = r5.w ? 0.500000 : 0;
//   r5.w = r5.w * r0.y;
//   r3.w = r3.w * 0.5 + r5.w;
//   r5.w = dot(r2.yzw, r5.xyz);
//   r5.w = -r5.w + r4.y;
//   r5.w = saturate(r5.w * 4 + 1);
//   if (r4.w != 0) {
//     r6.w = 0.015625 * r4.z;
//     r2.yzw = r2.yzw * r6.www + v5.xyz;
//     r12.xyzw = cb1[1].xyzw * r2.zzzz;
//     r12.xyzw = r2.yyyy * cb1[0].xyzw + r12.xyzw;
//     r12.xyzw = r2.wwww * cb1[2].xyzw + r12.xyzw;
//     r12.xyzw = cb1[3].xyzw + r12.xyzw;
//     r2.yzw = r12.xyz / r12.www;
//     r2.yzw = r2.yzw + -r1.xyz;
//     r12.xy = cb3[2].xy * abs(r2.yz);
//     r6.w = max(r12.x, r12.y);
//     r12.xyz = r2.yzw / r6.www;
//     r12.xy = cb1[52].xy * r12.xy;
//     r2.y = r12.z + r12.z;
//     r2.z = saturate(-r4.z * 0.00039999999 + 1);
//     r2.z = r2.z * r2.z;
//     r2.w = cb1[51].w + r4.z;
//     r2.w = 8 + r2.w;
//     r2.w = cb1[51].z * r2.w;
//     r2.w = 1 / r2.w;
//     r2.w = -r2.w + r1.z;
//     r6.w = min(abs(r2.y), r2.w);
//     r2.w = r6.w * 16 + r2.w;
//     r2.w = 1 / r2.w;
//     r13.z = abs(r2.y) + r1.z;
//     r14.xyz = float3(8,8,8) * r12.xyz;
//     r13.xy = r8.xy;
//     r13.xyz = r12.xyz * float3(-4,-4,-4) + r13.xyz;
//     r2.y = 4 * r2.w;
//     r2.w = 4 * r2.z;
//     r2.z = r2.z + r2.z;
//     r14.w = r14.z * r2.y;
//     r6.w = r13.z * r2.y + 2;
//     r15.xy = r13.xy;
//     r15.z = r6.w;
//     r8.w = 1;
//     r10.w = 0;
//     while (true) {
//       r11.w = cmp((int)r10.w >= 4);
//       if (r11.w != 0) break;
//       r15.xyz = r15.xyz + r14.xyw;
//       r11.w = t17.SampleLevel(s4_s, r15.xy, 0).x;
//       r11.w = r11.w * r11.w;
//       r11.w = r11.w * r2.y + -r15.z;
//       r11.w = saturate(-abs(r11.w) * r2.z + r2.w);
//       r8.w = -r11.w * r8.w + r8.w;
//       r10.w = (int)r10.w + 1;
//     }
//     r12.w = r14.w;
//     r13.xyz = r12.xyw * float3(-8,-8,-1) + r15.xyz;
//     r14.xyz = r13.xyz;
//     r15.xy = r2.zw;
//     r6.w = r8.w;
//     r10.w = 0;
//     while (true) {
//       r11.w = cmp((int)r10.w >= 8);
//       if (r11.w != 0) break;
//       r15.xy = float2(0.749894202,0.749894202) * r15.xy;
//       r14.xyz = r12.xyw * float3(16,16,2) + r14.xyz;
//       r11.w = t18.SampleLevel(s4_s, r14.xy, 0).x;
//       r11.w = r11.w * r11.w;
//       r11.w = r11.w * r2.y + -r14.z;
//       r11.w = saturate(-abs(r11.w) * r15.x + r15.y);
//       r6.w = -r11.w * r6.w + r6.w;
//       r10.w = (int)r10.w + 1;
//     }
//   } else {
//     r6.w = 1;
//   }
//   r2.x = r6.w * r2.x;
//   r2.x = r3.w * r2.x;
//   r2.x = r2.x * r5.w;
//   r2.y = 0.015625 * r4.z;
//   r2.z = saturate(-r4.z * 0.00039999999 + 1);
//   r2.z = r2.z * r2.z;
//   r2.w = cb1[51].w + r4.z;
//   r2.w = 8 + r2.w;
//   r2.w = cb1[51].z * r2.w;
//   r2.w = 1 / r2.w;
//   r2.w = -r2.w + r1.z;
//   r3.w = 4 * r2.z;
//   r2.z = r2.z + r2.z;
//   r12.xyz = float3(0,0,0);
//   r13.x = r1.w;
//   r13.y = r2.x;
//   r4.z = 0;
//   while (true) {
//     r5.w = cmp((int)r4.z >= asint(cb4[16].x));
//     if (r5.w != 0) break;
//     r14.xyz = cb4[r4.z+8].xyz + -v5.xyz;
//     r5.w = dot(r14.xyz, r14.xyz);
//     r5.w = rsqrt(r5.w);
//     r15.xyz = r14.xyz * r5.www;
//     r6.w = saturate(dot(r15.xyz, r16.xyz));
//     r6.w = log2(r6.w);
//     r6.w = 12 * r6.w;
//     r6.w = exp2(r6.w);
//     r6.w = r6.w * r0.z;
//     r17.xyz = float3(0,0,1) * r15.yzx;
//     r17.xyz = r15.xyz * float3(0,1,0) + -r17.xyz;
//     r8.w = dot(r17.yz, r17.yz);
//     r8.w = rsqrt(r8.w);
//     r17.xyz = r17.xyz * r8.www;
//     r18.xyz = r17.xyz * r15.yzx;
//     r18.xyz = r17.zxy * r15.zxy + -r18.xyz;
//     r8.w = dot(r18.xyz, r18.xyz);
//     r8.w = rsqrt(r8.w);
//     r18.xyz = r18.xyz * r8.www;
//     r8.w = abs(cb4[r4.z+8].w) * 0.5;
//     r8.w = 1 / r8.w;
//     r14.xyz = r14.xyz * r5.www + -r6.xyz;
//     r5.w = dot(r15.xyz, r6.xyz);
//     r5.w = cmp(0 < r5.w);
//     r10.w = dot(r14.xy, r17.yz);
//     r10.w = r10.w * r8.w;
//     r10.w = saturate(r10.w * 0.5 + 0.5);
//     r11.w = dot(r14.xyz, r18.xyz);
//     r8.w = r11.w * r8.w;
//     r14.z = saturate(r8.w * 0.5 + 0.5);
//     r8.w = cb4[r4.z+0].w + r10.w;
//     r14.x = r8.w / cb0[2].x;
//     r8.w = t25.SampleLevel(s0_s, r14.xz, 0).x;
//     r5.w = r5.w ? r8.w : 0;
//     r5.w = r5.w * r0.y;
//     r5.w = r6.w * 0.5 + r5.w;
//     r6.w = dot(r15.xyz, r5.xyz);
//     r6.w = -r6.w + r4.y;
//     r6.w = saturate(r6.w * 4 + 1);
//     if (r4.w != 0) {
//       r14.xyz = r15.xyz * r2.yyy + v5.xyz;
//       r15.xyzw = cb1[1].xyzw * r14.yyyy;
//       r15.xyzw = r14.xxxx * cb1[0].xyzw + r15.xyzw;
//       r14.xyzw = r14.zzzz * cb1[2].xyzw + r15.xyzw;
//       r14.xyzw = cb1[3].xyzw + r14.xyzw;
//       r14.xyz = r14.xyz / r14.www;
//       r14.xyz = r14.xyz + -r1.xyz;
//       r13.zw = cb3[2].xy * abs(r14.xy);
//       r8.w = max(r13.z, r13.w);
//       r14.xyz = r14.xyz / r8.www;
//       r14.xy = cb1[52].xy * r14.xy;
//       r8.w = r14.z + r14.z;
//       r10.w = min(abs(r8.w), r2.w);
//       r10.w = r10.w * 16 + r2.w;
//       r10.w = 1 / r10.w;
//       r8.z = abs(r8.w) + r1.z;
//       r15.xyz = float3(8,8,8) * r14.xyz;
//       r17.xyz = r14.xyz * float3(-4,-4,-4) + r8.xyz;
//       r8.z = 4 * r10.w;
//       r15.w = r15.z * r8.z;
//       r8.w = r17.z * r8.z + 2;
//       r18.xy = r17.xy;
//       r18.z = r8.w;
//       r10.w = 1;
//       r11.w = 0;
//       while (true) {
//         r12.w = cmp((int)r11.w >= 4);
//         if (r12.w != 0) break;
//         r18.xyz = r18.xyz + r15.xyw;
//         r12.w = t17.SampleLevel(s4_s, r18.xy, 0).x;
//         r12.w = r12.w * r12.w;
//         r12.w = r12.w * r8.z + -r18.z;
//         r12.w = saturate(-abs(r12.w) * r2.z + r3.w);
//         r10.w = -r12.w * r10.w + r10.w;
//         r11.w = (int)r11.w + 1;
//       }
//       r14.w = r15.w;
//       r15.xyz = r14.xyw * float3(-8,-8,-1) + r18.xyz;
//       r17.xyz = r15.xyz;
//       r19.x = r2.z;
//       r19.y = r3.w;
//       r8.w = r10.w;
//       r11.w = 0;
//       while (true) {
//         r12.w = cmp((int)r11.w >= 8);
//         if (r12.w != 0) break;
//         r19.xy = float2(0.749894202,0.749894202) * r19.xy;
//         r17.xyz = r14.xyw * float3(16,16,2) + r17.xyz;
//         r12.w = t18.SampleLevel(s4_s, r17.xy, 0).x;
//         r12.w = r12.w * r12.w;
//         r12.w = r12.w * r8.z + -r17.z;
//         r12.w = saturate(-abs(r12.w) * r19.x + r19.y);
//         r8.w = -r12.w * r8.w + r8.w;
//         r11.w = (int)r11.w + 1;
//       }
//     } else {
//       r8.w = 1;
//     }
//     r5.w = r8.w * r5.w;
//     r5.w = r5.w * r6.w;
//     r12.xyz = cb4[r4.z+0].xyz * r5.www + r12.xyz;
//     r5.w = cmp(cb4[r4.z+8].w < 0);
//     r13.xy = r5.ww ? float2(0,0) : r13.xy;
//     r4.z = (int)r4.z + 1;
//   }
//   r0.yzw = r10.xyz * r0.www;
//   r0.yzw = r13.xxx * cb2[33].xyz + r0.yzw;
//   r0.yzw = r0.yzw + r12.xyz;
//   r1.xyz = r13.yyy * r11.xyz;
//   r0.yzw = r0.yzw * cb2[43].yyy + r1.xyz;
//   r1.x = 1 + cb0[2].y;
//   r1.x = v7.w * r1.x;
//   r0.yzw = r1.xxx * r0.yzw;
//   r0.xyz = r3.xyz * r0.xxx + r0.yzw;
//   r1.xyz = cmp(float3(0.25,0.5,0.75) < cb0[0].xxx);
//   r0.w = -1 + r4.x;
//   r0.w = -abs(r0.w) * 4 + 1;
//   r0.w = max(0, r0.w);
//   r0.xyz = r1.xxx ? r0.www : r0.xyz;
//   r9.w = 1;
//   r0.w = r9.z;
//   r0.xyzw = r1.yyyy ? r9.xyzw : r0.xyzw;
//   r7.w = 1;
//   o0.xyzw = r1.zzzz ? r7.xyzw : r0.xyzw;
//   return;
// }
//////////////////////////////// HLSL Errors ////////////////////////////////
// F:\SteamLibrary\steamapps\common\Days Gone\BendGame\Binaries\Win64\ShaderFixes\1a546b5dea000f14-ps_replace.txt(121,10-11): error X4576: Non system-generated input signature parameter (TEXCOORD) cannot appear after a system generated value.
// F:\SteamLibrary\steamapps\common\Days Gone\BendGame\Binaries\Win64\ShaderFixes\1a546b5dea000f14-ps_replace.txt(122,10-11): error X4576: Non system-generated input signature parameter (TEXCOORD) cannot appear after a system generated value.
// F:\SteamLibrary\steamapps\common\Days Gone\BendGame\Binaries\Win64\ShaderFixes\1a546b5dea000f14-ps_replace.txt(123,10-11): error X4576: Non system-generated input signature parameter (TEXCOORD) cannot appear after a system generated value.
// F:\SteamLibrary\steamapps\common\Days Gone\BendGame\Binaries\Win64\ShaderFixes\1a546b5dea000f14-ps_replace.txt(124,10-11): error X4576: Non system-generated input signature parameter (SV_POSITION) cannot appear after a system generated value.
/////////////////////////////////////////////////////////////////////////////
