//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16.58 on Fri Feb 03 15:00:00 2023
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float   xy
// NORMAL                   0   xyz         1     NONE   float   xyz
// TEXCOORD                 0   xyzw        2     NONE   float   xy w
// TEXCOORD                 1   xy          3     NONE   float   xy
// TEXCOORD                 2     zw        3     NONE   float     zw
// TEXCOORD                 3   xy          4     NONE   float   xy
// TEXCOORD                 4   xyzw        5     NONE   float   xyz
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_TARGET                0   xyzw        0   TARGET   float   xyzw
//
ps_5_0
dcl_globalFlags refactoringAllowed
dcl_immediateConstantBuffer { { 0, 0, -1.000000, -1.000000},
                              { 0.418000, 0.355000, -1.000000, 1.000000},
                              { 0.865000, 0.148000, 1.000000, -1.000000},
                              { 0.651000, 0.752000, 1.000000, 1.000000} }
dcl_constantbuffer cb5[131], dynamicIndexed
dcl_constantbuffer cb6[2], immediateIndexed
dcl_constantbuffer cb1[17], 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 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) t5
dcl_resource_texture3d (float,float,float,float) t16
dcl_input_ps_siv linear noperspective v0.xy, position
dcl_input_ps linear v1.xyz
dcl_input_ps linear centroid v2.xyw
dcl_input_ps linear v3.xy
dcl_input_ps linear v3.zw
dcl_input_ps linear v4.xy
dcl_input_ps linear v5.xyz
dcl_output o0.xyzw
dcl_temps 10
div r0.xy, v2.xyxx, v2.wwww
mad r0.xy, r0.xyxx, cb1[0].xyxx, cb1[0].zwzz
dp3 r0.z, v5.xyzx, v5.xyzx
sqrt r0.w, r0.z
div r1.xyz, v5.xyzx, r0.wwww
sample_indexable(texture2d)(float,float,float,float) r1.w, r0.xyxx, t5.yzwx, s5
add r2.x, r1.w, -v5.z
sample_indexable(texture2d)(float,float,float,float) r2.yz, v3.zwzz, t4.zxyw, s4
mad r2.yz, r2.yyzy, l(0.000000, 2.000000, 2.000000, 0.000000), l(0.000000, -1.000000, -1.000000, 0.000000)
mul r2.w, cb1[14].x, l(100.000000)
mul r2.yz, r2.wwww, r2.yyzy
deriv_rtx_coarse r3.xyz, v5.xyzx
deriv_rty_coarse r4.xyz, v5.zxyz
dp3 r2.w, v1.xyzx, v1.xyzx
rsq r2.w, r2.w
mul r5.xyz, r2.wwww, v1.xyzx
mul r6.xyz, r4.xyzx, r5.yzxy
mad r4.xyz, r4.zxyz, r5.zxyz, -r6.xyzx
mul r6.xyz, r3.yzxy, r5.zxyz
mad r6.xyz, r5.yzxy, r3.zxyz, -r6.xyzx
dp3 r2.w, r3.xyzx, r4.xyzx
deriv_rtx_coarse r3.xy, v3.zwzz
deriv_rty_coarse r3.zw, v3.zzzw
dp2 r3.x, r2.yzyy, r3.xyxx
dp2 r2.y, r2.yzyy, r3.zwzz
lt r2.z, l(0.000000), r2.w
lt r3.y, r2.w, l(0.000000)
iadd r2.z, -r2.z, r3.y
itof r2.z, r2.z
mul r3.yzw, r6.xxyz, r2.yyyy
mad r3.xyz, r3.xxxx, r4.xyzx, r3.yzwy
mul r3.xyz, r2.zzzz, r3.xyzx
mad r2.yzw, |r2.wwww|, r5.xxyz, -r3.xxyz
dp3 r3.x, r2.yzwy, r2.yzwy
rsq r3.x, r3.x
mul r2.yzw, r2.yyzw, r3.xxxx
div r3.xy, v4.xyxx, cb1[12].xxxx
mov r3.zw, l(0,0,0,0)
loop
  ige r4.x, r3.w, l(4)
  breakc_nz r4.x
  add r4.xy, r3.xyxx, icb[r3.w + 0].xyxx
  mad r4.xy, cb1[12].zzzz, icb[r3.w + 0].zwzz, r4.xyxx
  add r4.y, r4.y, -cb1[13].z
  sample_indexable(texture2d)(float,float,float,float) r4.x, r4.xyxx, t2.xyzw, s2
  add r3.z, r3.z, r4.x
  iadd r3.w, r3.w, l(1)
endloop
mul r3.x, r3.z, l(0.250000)
mul r3.y, cb1[11].x, l(2.200000)
log r3.x, |r3.x|
mul r3.x, r3.x, r3.y
exp r3.x, r3.x
mul_sat r3.x, r3.x, cb1[11].y
sample_indexable(texture2d)(float,float,float,float) r4.xyzw, v3.zwzz, t1.xyzw, s1
dp2 r3.x, r4.wwww, r3.xxxx
sample_indexable(texture2d)(float,float,float,float) r3.yzw, v3.xyxx, t0.yxzw, s0
add r5.xy, -r3.zwzz, l(1.000000, 1.000000, 0.000000, 0.000000)
mov r6.x, v3.x
add r6.y, v3.y, cb1[14].z
sample_indexable(texture2d)(float,float,float,float) r3.z, r6.xyxx, t0.xzyw, s1
dp2 r3.y, r3.yyyy, r3.zzzz
add r3.x, -r3.y, r3.x
add r3.x, r3.x, cb1[11].z
mad r3.y, cb1[11].w, l(2.000000), l(1.000000)
mad_sat r3.x, r3.x, r3.y, -cb1[11].w
dp3_sat r3.y, cb1[1].xyzx, r2.yzwy
mad r3.yzw, cb1[3].xxyz, r3.yyyy, cb1[2].xxyz
mul r3.yzw, r3.yyzw, cb1[16].xxyz
add r4.xyz, r4.xyzx, -cb1[16].xyzx
mad r4.xyz, r3.xxxx, r4.xyzx, cb1[16].xyzx
mad r3.yzw, r4.xxyz, r3.yyzw, -r4.xxyz
mad r4.yzw, cb1[14].wwww, r3.yyzw, r4.xxyz
mul_sat r3.y, r5.y, cb1[12].w
add r3.x, r3.y, r3.x
min r3.x, r3.x, l(1.000000)
dp3_sat r2.w, -r1.xyzx, r2.yzwy
add r2.w, -r2.w, l(1.000000)
mul r3.y, r2.w, r2.w
ne r3.z, l(0.000000, 0.000000, 0.000000, 0.000000), cb1[13].y
if_nz r3.z
  div r3.w, r2.x, v5.z
  mul r2.yz, r2.yyzy, l(0.000000, 0.025000, 0.025000, 0.000000)
  mul r3.w, r3.w, l(100.000000)
  mad r2.w, -r2.w, r2.w, l(1.200000)
  mul_sat r2.w, r2.w, r3.w
  mul r6.xy, r2.wwww, r2.yzyy
  mad r2.yz, r2.yyzy, r2.wwww, r0.xxyx
  sample_indexable(texture2d)(float,float,float,float) r2.y, r2.yzyy, t5.yxzw, s5
  ne r2.z, l(0.000000, 0.000000, 0.000000, 0.000000), cb1[15].x
  lt r2.w, l(10000.000000), r2.y
  and r2.z, r2.w, r2.z
  if_nz r2.z
    ftou r2.z, cb1[5].z
    imul null, r2.z, r2.z, l(14)
    mov r7.xyz, cb5[r2.z + 4].yzwy
  else
    lt r2.y, v5.z, r2.y
    and r2.y, r2.y, l(0x3f800000)
    mul r2.yz, r6.xxyx, r2.yyyy
    mul r2.w, r3.x, l(1.53846157)
    min r2.w, r2.w, l(1.000000)
    mad r0.xy, r2.wwww, r2.yzyy, r0.xyxx
    sample_indexable(texture2d)(float,float,float,float) r7.xyz, r0.xyxx, t3.xyzw, s3
  endif
  ne r0.x, l(0.000000, 0.000000, 0.000000, 0.000000), cb1[13].x
  if_nz r0.x
    dp3 r0.x, v1.xyzx, r1.xyzx
    lt r0.x, l(0.000000), r0.x
    if_nz r0.x
      mul r1.z, v5.z, cb1[14].y
      mov r1.xy, v5.xyxx
      dp3 r0.x, r1.xyzx, r1.xyzx
      sqrt r0.y, r0.x
      ne r2.y, l(0.000000, 0.000000, 0.000000, 0.000000), cb5[57].x
      if_z r2.y
        dp3 r2.y, cb5[130].xyzx, r1.xyzx
        lt r2.z, l(0.000000), r2.y
        max r2.w, l(0.000000), cb5[64].w
        min r2.w, r2.y, r2.w
        mad r6.xyz, -cb5[130].xyzx, r2.wwww, r1.xyzx
        max r2.y, r2.y, -cb5[64].w
        min r2.y, r2.y, l(0.000000)
        mad r8.xyz, -cb5[130].xyzx, r2.yyyy, r1.xyzx
        movc r2.yzw, r2.zzzz, r6.xxyz, r8.xxyz
        dp3 r2.y, r2.yzwy, r2.yzwy
        sqrt r2.y, r2.y
        add r2.z, r2.y, -cb5[56].x
        max r2.z, r2.z, l(0.000000)
        mul r2.w, r2.z, cb5[60].x
        mul r2.w, r2.w, l(1.442695)
        exp r2.w, r2.w
        dp3 r3.w, cb5[58].xyzx, r1.xyzx
        add r3.w, r3.w, cb5[58].w
        mul_sat r3.w, r3.w, cb5[59].w
        add r3.w, -r3.w, l(1.000000)
        mul r6.x, r3.w, r3.w
        mul r6.y, r3.w, r6.x
        mul r6.x, r6.x, cb5[65].y
        mad r6.x, cb5[65].x, r6.y, r6.x
        mad r3.w, cb5[65].z, r3.w, r6.x
        add_sat r3.w, r3.w, cb5[65].w
        add r3.w, -r3.w, l(1.000000)
        div r6.x, r2.y, cb5[56].y
        mul r2.z, r2.z, cb5[56].z
        mul r2.z, r2.z, l(1.442695)
        exp r2.z, r2.z
        rcp r2.zw, r2.zzzw
        add r2.w, -r2.z, r2.w
        mad r2.z, r3.w, r2.w, r2.z
        add r2.z, -r2.z, l(1.000000)
        add r2.z, -r2.z, l(1.000000)
        add r2.w, -r6.x, l(1.000000)
        mul_sat r2.w, r2.w, l(1.42857146)
        min r2.z, r2.w, r2.z
        add r2.w, r2.y, -cb5[68].y
        add r6.x, -cb5[68].y, cb5[68].x
        div_sat r2.w, r2.w, r6.x
        div_sat r2.y, r2.y, cb5[68].x
        mul r6.x, r2.w, r2.w
        mul r6.y, r2.w, r6.x
        mul r6.z, r6.x, cb5[66].y
        mad r6.z, cb5[66].x, r6.y, r6.z
        mad r6.z, cb5[66].z, r2.w, r6.z
        add_sat r6.z, r6.z, cb5[66].w
        add r6.z, -r6.z, l(1.000000)
        mul r6.x, r6.x, cb5[67].y
        mad r6.x, cb5[67].x, r6.y, r6.x
        mad r2.w, cb5[67].z, r2.w, r6.x
        add_sat r2.w, r2.w, cb5[67].w
        add r2.w, -r2.w, l(1.000000)
        add r2.w, -r6.z, r2.w
        mad r2.w, r3.w, r2.w, r6.z
        add r2.w, -r2.w, l(1.000000)
        add r2.w, -r2.w, l(1.000000)
        div_sat r6.x, cb5[56].y, cb5[68].x
        add r6.x, r6.x, l(-0.300000)
        mul r6.y, r6.x, r6.x
        mul r6.z, r6.x, r6.y
        mul r6.w, r6.y, cb5[66].y
        mad r6.w, cb5[66].x, r6.z, r6.w
        mad r6.w, cb5[66].z, r6.x, r6.w
        add_sat r6.w, r6.w, cb5[66].w
        mul r6.y, r6.y, cb5[67].y
        mad r6.y, cb5[67].x, r6.z, r6.y
        mad r6.y, cb5[67].z, r6.x, r6.y
        add_sat r6.y, r6.y, cb5[67].w
        add r6.y, -r6.w, r6.y
        mad r6.y, r3.w, r6.y, r6.w
        add r2.y, r2.y, -r6.x
        mul_sat r2.y, r2.y, l(3.33333325)
        add r6.x, -r6.y, l(1.000000)
        mad r6.x, r2.y, r6.x, r6.y
        add_sat r6.x, -r6.x, l(1.000000)
        add r6.x, -r2.w, r6.x
        mad r2.y, r2.y, r6.x, r2.w
        min r2.y, r2.y, r2.w
        add r2.z, -r2.y, r2.z
        mad r2.y, cb5[68].z, r2.z, r2.y
      else
        add r2.z, -r0.y, cb5[57].y
        mul r2.z, r2.z, cb5[57].z
        max r2.z, r2.z, l(0.000000)
        log r2.z, r2.z
        mul r2.z, r2.z, cb5[57].w
        exp r2.z, r2.z
        min r2.y, r2.z, l(1.000000)
        mov r3.w, l(0)
      endif
      rsq r0.x, r0.x
      mul r6.xyz, r0.xxxx, r1.xyzx
      add r0.x, r0.y, -cb5[69].w
      div_sat r0.x, r0.x, cb5[62].w
      mul r0.y, r0.x, r0.x
      mul r0.y, r0.y, r0.x
      add r8.xyz, -cb5[62].xyzx, cb5[69].xyzx
      mad r8.xyz, r0.xxxx, r8.xyzx, cb5[62].xyzx
      add r9.xyz, -cb5[59].xyzx, cb5[60].yzwy
      mad r9.xyz, r0.yyyy, r9.xyzx, cb5[59].xyzx
      add r8.xyz, r8.xyzx, -r9.xyzx
      mad r8.xyz, r3.wwww, r8.xyzx, r9.xyzx
      dp3_sat r0.x, r6.xyzx, cb5[64].xyzx
      add r6.xyz, -r8.xyzx, cb5[61].yzwy
      mul r6.xyz, r6.xyzx, cb5[63].xxxx
      add_sat r0.x, r0.x, -cb5[61].x
      lt r0.y, l(0.000000), r0.x
      add r1.x, l(1.000000), -cb5[61].x
      div r1.x, l(1.000000, 1.000000, 1.000000, 1.000000), r1.x
      mul r0.x, r0.x, r1.x
      mul r1.x, r0.x, r0.x
      mul r0.x, r0.x, r1.x
      mad r6.xyz, r0.xxxx, r6.xyzx, r8.xyzx
      movc r6.xyz, r0.yyyy, r6.xyzx, r8.xyzx
      add r8.xyz, -r6.xyzx, r7.xyzx
      mad r2.yzw, r2.yyyy, r8.xxyz, r6.xxyz
      ne r0.x, l(0.000000, 0.000000, 0.000000, 0.000000), cb1[6].w
      if_nz r0.x
        mad r6.xy, v0.xyxx, cb1[0].xyxx, cb1[0].zwzz
        div_sat r0.x, r1.z, cb5[56].y
        rsq r0.x, r0.x
        div r0.x, l(1.000000, 1.000000, 1.000000, 1.000000), r0.x
        add_sat r6.z, r0.x, l(-0.00390625000)
        sample_indexable(texture3d)(float,float,float,float) r6.xyzw, r6.xyzx, t16.xyzw, s13
        add r0.x, -r6.w, l(1.000000)
        min r0.y, l(1.000000), cb5[129].x
        add r1.xy, -r0.yyyy, l(1.000000, 1.000001, 0.000000, 0.000000)
        mul r6.xyz, r1.xxxx, r6.xyzx
        log r0.x, |r0.x|
        mul r0.x, r0.x, r1.y
        exp r0.x, r0.x
        mad r2.yzw, r2.yyzw, r0.xxxx, r6.xxyz
      endif
      add r1.xyz, -r7.xyzx, r2.yzwy
      mad r7.xyz, r3.xxxx, r1.xyzx, r7.xyzx
    endif
  endif
else
  mov r7.xyz, l(1.000000,1.000000,1.000000,0)
endif
ftou r0.xy, cb1[5].xzxx
imul null, r0.xy, r0.xyxx, l(14, 14, 0, 0)
div_sat r1.x, r2.x, cb1[15].y
ne r1.y, l(0.000000, 0.000000, 0.000000, 0.000000), cb5[r0.x + 1].x
add r1.z, -r0.w, cb5[r0.x + 1].y
mul r1.z, r1.z, cb5[r0.x + 1].z
max r1.z, r1.z, l(0.000000)
log r1.z, r1.z
mul r1.z, r1.z, cb5[r0.x + 1].w
exp r1.z, r1.z
min r1.z, r1.z, l(1.000000)
if_z r1.y
  dp3 r2.x, cb5[130].xyzx, v5.xyzx
  lt r2.y, l(0.000000), r2.x
  max r2.z, l(0.000000), cb5[r0.x + 8].w
  min r2.z, r2.x, r2.z
  mad r6.xyz, -cb5[130].xyzx, r2.zzzz, v5.xyzx
  max r2.x, r2.x, -cb5[r0.x + 8].w
  min r2.x, r2.x, l(0.000000)
  mad r2.xzw, -cb5[130].xxyz, r2.xxxx, v5.xxyz
  movc r2.xyz, r2.yyyy, r6.xyzx, r2.xzwx
  dp3 r2.x, r2.xyzx, r2.xyzx
  sqrt r2.x, r2.x
  add r2.y, r2.x, -cb5[r0.x + 0].w
  add r2.y, r2.y, -cb5[r0.x + 0].x
  max r2.y, r2.y, l(0.000000)
  mul r2.z, r2.y, cb5[r0.x + 4].x
  mul r2.z, r2.z, l(1.442695)
  exp r2.z, r2.z
  dp3 r2.w, cb5[r0.x + 2].xyzx, v5.xyzx
  add r2.w, r2.w, cb5[r0.x + 2].w
  mul_sat r2.w, r2.w, cb5[r0.x + 3].w
  add r2.w, -r2.w, l(1.000000)
  mul r3.w, r2.w, r2.w
  mul r6.x, r2.w, r3.w
  mul r3.w, r3.w, cb5[r0.x + 9].y
  mad r3.w, cb5[r0.x + 9].x, r6.x, r3.w
  mad r2.w, cb5[r0.x + 9].z, r2.w, r3.w
  add_sat r2.w, r2.w, cb5[r0.x + 9].w
  add r2.w, -r2.w, l(1.000000)
  div r3.w, r2.x, cb5[r0.x + 0].y
  mul r2.y, r2.y, cb5[r0.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)
  add r2.y, -r2.y, l(1.000000)
  add r2.z, -r3.w, 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[r0.x + 12].y
  add r3.w, -cb5[r0.x + 12].y, cb5[r0.x + 12].x
  div_sat r2.z, r2.z, r3.w
  div_sat r2.x, r2.x, cb5[r0.x + 12].x
  mul r3.w, r2.z, r2.z
  mul r6.x, r2.z, r3.w
  mul r6.y, r3.w, cb5[r0.x + 10].y
  mad r6.y, cb5[r0.x + 10].x, r6.x, r6.y
  mad r6.y, cb5[r0.x + 10].z, r2.z, r6.y
  add_sat r6.y, r6.y, cb5[r0.x + 10].w
  add r6.y, -r6.y, l(1.000000)
  mul r3.w, r3.w, cb5[r0.x + 11].y
  mad r3.w, cb5[r0.x + 11].x, r6.x, r3.w
  mad r2.z, cb5[r0.x + 11].z, r2.z, r3.w
  add_sat r2.z, r2.z, cb5[r0.x + 11].w
  add r2.z, -r2.z, l(1.000000)
  add r2.z, -r6.y, r2.z
  mad r2.z, r2.w, r2.z, r6.y
  add r2.z, -r2.z, l(1.000000)
  add r2.z, -r2.z, l(1.000000)
  div_sat r3.w, cb5[r0.x + 0].y, cb5[r0.x + 12].x
  add r3.w, r3.w, l(-0.300000)
  mul r6.x, r3.w, r3.w
  mul r6.y, r3.w, r6.x
  mul r6.z, r6.x, cb5[r0.x + 10].y
  mad r6.z, cb5[r0.x + 10].x, r6.y, r6.z
  mad r6.z, cb5[r0.x + 10].z, r3.w, r6.z
  add_sat r6.z, r6.z, cb5[r0.x + 10].w
  mul r6.x, r6.x, cb5[r0.x + 11].y
  mad r6.x, cb5[r0.x + 11].x, r6.y, r6.x
  mad r6.x, cb5[r0.x + 11].z, r3.w, r6.x
  add_sat r6.x, r6.x, cb5[r0.x + 11].w
  add r6.x, -r6.z, r6.x
  mad r2.w, r2.w, r6.x, r6.z
  add r2.x, r2.x, -r3.w
  mul_sat r2.x, r2.x, l(3.33333325)
  add r3.w, -r2.w, l(1.000000)
  mad r2.w, r2.x, r3.w, r2.w
  add_sat r2.w, -r2.w, l(1.000000)
  add r2.w, -r2.z, r2.w
  mad r2.x, r2.x, r2.w, r2.z
  min r2.x, r2.x, r2.z
  add r2.y, -r2.x, r2.y
  mad r2.x, cb5[r0.x + 12].z, r2.y, r2.x
else
  mov r2.x, r1.z
endif
mul_sat r2.x, r2.x, l(10.000000)
add r2.x, -r2.x, l(1.000000)
add r2.y, -r1.x, l(1.000000)
mad r1.x, r2.x, r2.y, r1.x
deriv_rtx_coarse r1.w, r1.w
lt r1.w, cb5[r0.x + 0].y, |r1.w|
movc r1.x, r1.w, l(1.000000), r1.x
mad r1.w, -r3.y, l(0.100000), l(1.000000)
mul r1.w, r3.x, r1.w
add r2.xyz, r4.yzwy, -r7.xyzx
mul r2.xyz, r1.wwww, r2.xyzx
mad r5.yzw, r3.xxxx, r2.xxyz, r7.xxyz
mul r1.w, r3.x, r1.w
min r4.x, r5.x, r1.w
movc r2.xyzw, r3.zzzz, r5.xyzw, r4.xyzw
if_z r1.y
  dp3 r1.y, cb5[130].xyzx, v5.xyzx
  lt r1.w, l(0.000000), r1.y
  max r3.x, l(0.000000), cb5[r0.x + 8].w
  min r3.x, r1.y, r3.x
  mad r3.xyz, -cb5[130].xyzx, r3.xxxx, v5.xyzx
  max r1.y, r1.y, -cb5[r0.x + 8].w
  min r1.y, r1.y, l(0.000000)
  mad r4.xyz, -cb5[130].xyzx, r1.yyyy, v5.xyzx
  movc r3.xyz, r1.wwww, r3.xyzx, r4.xyzx
  dp3 r1.y, r3.xyzx, r3.xyzx
  sqrt r1.y, r1.y
  add r1.w, r1.y, -cb5[r0.x + 0].x
  max r1.w, r1.w, l(0.000000)
  mul r3.x, r1.w, cb5[r0.x + 4].x
  mul r3.x, r3.x, l(1.442695)
  exp r3.x, r3.x
  rcp r3.x, r3.x
  dp3 r3.y, cb5[r0.x + 2].xyzx, v5.xyzx
  add r3.y, r3.y, cb5[r0.x + 2].w
  mul_sat r3.y, r3.y, cb5[r0.x + 3].w
  add r3.y, -r3.y, l(1.000000)
  mul r3.z, r3.y, r3.y
  mul r3.w, r3.y, r3.z
  mul r3.z, r3.z, cb5[r0.x + 9].y
  mad r3.z, cb5[r0.x + 9].x, r3.w, r3.z
  mad r3.y, cb5[r0.x + 9].z, r3.y, r3.z
  add_sat r3.y, r3.y, cb5[r0.x + 9].w
  add r3.y, -r3.y, l(1.000000)
  div r3.z, r1.y, cb5[r0.x + 0].y
  mul r1.w, r1.w, cb5[r0.x + 0].z
  mul r1.w, r1.w, l(1.442695)
  exp r1.w, r1.w
  rcp r1.w, r1.w
  add r3.x, -r1.w, r3.x
  mad r1.w, r3.y, r3.x, r1.w
  add r1.w, -r1.w, l(1.000000)
  add r1.w, -r1.w, l(1.000000)
  add r3.x, -r3.z, l(1.000000)
  mul_sat r3.x, r3.x, l(1.42857146)
  min r1.w, r1.w, r3.x
  add r3.x, r1.y, -cb5[r0.x + 12].y
  add r3.z, -cb5[r0.x + 12].y, cb5[r0.x + 12].x
  div_sat r3.x, r3.x, r3.z
  div_sat r1.y, r1.y, cb5[r0.x + 12].x
  mul r3.z, r3.x, r3.x
  mul r3.w, r3.x, r3.z
  mul r4.x, r3.z, cb5[r0.x + 10].y
  mad r4.x, cb5[r0.x + 10].x, r3.w, r4.x
  mad r4.x, cb5[r0.x + 10].z, r3.x, r4.x
  add_sat r4.x, r4.x, cb5[r0.x + 10].w
  add r4.x, -r4.x, l(1.000000)
  mul r3.z, r3.z, cb5[r0.x + 11].y
  mad r3.z, cb5[r0.x + 11].x, r3.w, r3.z
  mad r3.x, cb5[r0.x + 11].z, r3.x, r3.z
  add_sat r3.x, r3.x, cb5[r0.x + 11].w
  add r3.x, -r3.x, l(1.000000)
  add r3.x, -r4.x, r3.x
  mad r3.x, r3.y, r3.x, r4.x
  add r3.x, -r3.x, l(1.000000)
  div_sat r3.z, cb5[r0.x + 0].y, cb5[r0.x + 12].x
  add r3.z, r3.z, l(-0.300000)
  mul r3.w, r3.z, r3.z
  mul r4.x, r3.z, r3.w
  mul r4.y, r3.w, cb5[r0.x + 10].y
  mad r4.y, cb5[r0.x + 10].x, r4.x, r4.y
  mad r4.y, cb5[r0.x + 10].z, r3.z, r4.y
  add_sat r4.y, r4.y, cb5[r0.x + 10].w
  mul r3.w, r3.w, cb5[r0.x + 11].y
  mad r3.w, cb5[r0.x + 11].x, r4.x, r3.w
  mad r3.w, cb5[r0.x + 11].z, r3.z, r3.w
  add_sat r3.w, r3.w, cb5[r0.x + 11].w
  add r3.w, -r4.y, r3.w
  mad r3.w, r3.y, r3.w, r4.y
  add r1.y, r1.y, -r3.z
  mul_sat r1.y, r1.y, l(3.33333325)
  add r3.xz, -r3.xxwx, l(1.000000, 0.000000, 1.000000, 0.000000)
  mad r3.z, r1.y, r3.z, r3.w
  add_sat r3.z, -r3.z, l(1.000000)
  add r3.z, -r3.x, r3.z
  mad r1.y, r1.y, r3.z, r3.x
  min r1.y, r1.y, r3.x
  add r1.w, -r1.y, r1.w
  mad r1.z, cb5[r0.x + 12].z, r1.w, r1.y
else
  mov r3.y, l(0)
endif
rsq r0.z, r0.z
mul r3.xzw, r0.zzzz, v5.xxyz
add r0.z, r0.w, -cb5[r0.x + 13].w
div_sat r0.z, r0.z, cb5[r0.x + 6].w
mul r0.w, r0.z, r0.z
mul r0.w, r0.w, r0.z
add r4.xyz, -cb5[r0.y + 6].xyzx, cb5[r0.y + 13].xyzx
mad r4.xyz, r0.zzzz, r4.xyzx, cb5[r0.y + 6].xyzx
add r5.xyz, -cb5[r0.y + 3].xyzx, cb5[r0.y + 4].yzwy
mad r5.xyz, r0.wwww, r5.xyzx, cb5[r0.y + 3].xyzx
add r4.xyz, r4.xyzx, -r5.xyzx
mad r4.xyz, r3.yyyy, r4.xyzx, r5.xyzx
dp3_sat r0.z, r3.xzwx, cb5[r0.x + 8].xyzx
add r3.xyz, -r4.xyzx, cb5[r0.y + 5].yzwy
mul r3.xyz, r3.xyzx, cb5[r0.x + 7].xxxx
add_sat r0.y, r0.z, -cb5[r0.x + 5].x
lt r0.z, l(0.000000), r0.y
add r0.w, l(1.000000), -cb5[r0.x + 5].x
div r0.w, l(1.000000, 1.000000, 1.000000, 1.000000), r0.w
mul r0.y, r0.y, r0.w
mul r0.w, r0.y, r0.y
mul r0.y, r0.y, r0.w
mad r3.xyz, r0.yyyy, r3.xyzx, r4.xyzx
movc r0.yzw, r0.zzzz, r3.xxyz, r4.xxyz
add r2.yzw, -r0.yyzw, r2.yyzw
mad r0.yzw, r1.zzzz, r2.yyzw, r0.yyzw
ne r1.y, l(0.000000, 0.000000, 0.000000, 0.000000), cb1[6].w
if_nz r1.y
  mad r3.xy, v0.xyxx, cb6[1].xyxx, cb6[1].zwzz
  div_sat r0.x, v5.z, cb5[r0.x + 0].y
  rsq r0.x, r0.x
  div r0.x, l(1.000000, 1.000000, 1.000000, 1.000000), r0.x
  add_sat r3.z, r0.x, l(-0.00390625000)
  sample_indexable(texture3d)(float,float,float,float) r3.xyzw, r3.xyzx, t16.xyzw, s13
  add r0.x, -r3.w, l(1.000000)
  min r1.y, l(1.000000), cb5[129].x
  add r1.yz, -r1.yyyy, l(0.000000, 1.000000, 1.000001, 0.000000)
  mul r2.yzw, r1.yyyy, r3.xxyz
  log r0.x, |r0.x|
  mul r0.x, r0.x, r1.z
  exp r0.x, r0.x
  mad o0.xyz, r0.yzwy, r0.xxxx, r2.yzwy
else
  mov o0.xyz, r0.yzwy
endif
min o0.w, r1.x, r2.x
ret
// Approximately 0 instruction slots used

///////////////////////////////// HLSL Code /////////////////////////////////
// // ---- Created with 3Dmigoto v1.3.16.58 on Fri Feb 03 15:00:00 2023
// Texture3D<float4> t16 : register(t16);
//
// Texture2D<float4> t5 : register(t5);
//
// 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 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 cb1 : register(b1)
// {
//   float4 cb1[17];
// }
//
// 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,
//   float3 v1 : NORMAL0,
//   linear centroid float4 v2 : TEXCOORD0,
//   float2 v3 : TEXCOORD1,
//   float2 w3 : TEXCOORD2,
//   float4 v4 : TEXCOORD3,
//   float4 v5 : TEXCOORD4,
//   out float4 o0 : SV_TARGET0)
// {
//   const float4 icb[] = { { 0, 0, -1.000000, -1.000000},
//                               { 0.418000, 0.355000, -1.000000, 1.000000},
//                               { 0.865000, 0.148000, 1.000000, -1.000000},
//                               { 0.651000, 0.752000, 1.000000, 1.000000} };
//   float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9;
//   uint4 bitmask, uiDest;
//   float4 fDest;
//
//   r0.xy = v2.xy / v2.ww;
//   r0.xy = r0.xy * cb1[0].xy + cb1[0].zw;
//   r0.z = dot(v5.xyz, v5.xyz);
//   r0.w = sqrt(r0.z);
//   r1.xyz = v5.xyz / r0.www;
//   r1.w = t5.Sample(s5_s, r0.xy).x;
//   r2.x = -v5.z + r1.w;
//   r2.yz = t4.Sample(s4_s, w3.xy).xy;
//   r2.yz = r2.yz * float2(2,2) + float2(-1,-1);
//   r2.w = 100 * cb1[14].x;
//   r2.yz = r2.yz * r2.ww;
//   r3.xyz = ddx_coarse(v5.xyz);
//   r4.xyz = ddy_coarse(v5.zxy);
//   r2.w = dot(v1.xyz, v1.xyz);
//   r2.w = rsqrt(r2.w);
//   r5.xyz = v1.xyz * r2.www;
//   r6.xyz = r5.yzx * r4.xyz;
//   r4.xyz = r4.zxy * r5.zxy + -r6.xyz;
//   r6.xyz = r5.zxy * r3.yzx;
//   r6.xyz = r5.yzx * r3.zxy + -r6.xyz;
//   r2.w = dot(r3.xyz, r4.xyz);
//   r3.xy = ddx_coarse(v3.zw);
//   r3.zw = ddy_coarse(v3.zw);
//   r3.x = dot(r2.yz, r3.xy);
//   r2.y = dot(r2.yz, r3.zw);
//   r2.z = cmp(0 < r2.w);
//   r3.y = cmp(r2.w < 0);
//   r2.z = (int)-r2.z + (int)r3.y;
//   r2.z = (int)r2.z;
//   r3.yzw = r2.yyy * r6.xyz;
//   r3.xyz = r3.xxx * r4.xyz + r3.yzw;
//   r3.xyz = r3.xyz * r2.zzz;
//   r2.yzw = abs(r2.www) * r5.xyz + -r3.xyz;
//   r3.x = dot(r2.yzw, r2.yzw);
//   r3.x = rsqrt(r3.x);
//   r2.yzw = r3.xxx * r2.yzw;
//   r3.xy = v4.xy / cb1[12].xx;
//   r3.zw = float2(0,0);
//   while (true) {
//     r4.x = cmp((int)r3.w >= 4);
//     if (r4.x != 0) break;
//     r4.xy = icb[r3.w+0].xy + r3.xy;
//     r4.xy = cb1[12].zz * icb[r3.w+0].zw + r4.xy;
//     r4.y = -cb1[13].z + r4.y;
//     r4.x = t2.Sample(s2_s, r4.xy).x;
//     r3.z = r4.x + r3.z;
//     r3.w = (int)r3.w + 1;
//   }
//   r3.x = 0.25 * r3.z;
//   r3.y = 2.20000005 * cb1[11].x;
//   r3.x = log2(abs(r3.x));
//   r3.x = r3.y * r3.x;
//   r3.x = exp2(r3.x);
//   r3.x = saturate(cb1[11].y * r3.x);
//   r4.xyzw = t1.Sample(s1_s, w3.xy).xyzw;
//   r3.x = dot(r4.ww, r3.xx);
//   r3.yzw = t0.Sample(s0_s, v3.xy).xzw;
//   r5.xy = float2(1,1) + -r3.zw;
//   r6.x = v3.x;
//   r6.y = cb1[14].z + v3.y;
//   r3.z = t0.Sample(s1_s, r6.xy).y;
//   r3.y = dot(r3.yy, r3.zz);
//   r3.x = r3.x + -r3.y;
//   r3.x = cb1[11].z + r3.x;
//   r3.y = cb1[11].w * 2 + 1;
//   r3.x = saturate(r3.x * r3.y + -cb1[11].w);
//   r3.y = saturate(dot(cb1[1].xyz, r2.yzw));
//   r3.yzw = cb1[3].xyz * r3.yyy + cb1[2].xyz;
//   r3.yzw = cb1[16].xyz * r3.yzw;
//   r4.xyz = -cb1[16].xyz + r4.xyz;
//   r4.xyz = r3.xxx * r4.xyz + cb1[16].xyz;
//   r3.yzw = r4.xyz * r3.yzw + -r4.xyz;
//   r4.yzw = cb1[14].www * r3.yzw + r4.xyz;
//   r3.y = saturate(cb1[12].w * r5.y);
//   r3.x = r3.x + r3.y;
//   r3.x = min(1, r3.x);
//   r2.w = saturate(dot(-r1.xyz, r2.yzw));
//   r2.w = 1 + -r2.w;
//   r3.y = r2.w * r2.w;
//   r3.z = cmp(0 != cb1[13].y);
//   if (r3.z != 0) {
//     r3.w = r2.x / v5.z;
//     r2.yz = float2(0.0250000004,0.0250000004) * r2.yz;
//     r3.w = 100 * r3.w;
//     r2.w = -r2.w * r2.w + 1.20000005;
//     r2.w = saturate(r3.w * r2.w);
//     r6.xy = r2.yz * r2.ww;
//     r2.yz = r2.yz * r2.ww + r0.xy;
//     r2.y = t5.Sample(s5_s, r2.yz).x;
//     r2.z = cmp(0 != cb1[15].x);
//     r2.w = cmp(10000 < r2.y);
//     r2.z = r2.w ? r2.z : 0;
//     if (r2.z != 0) {
//       r2.z = (uint)cb1[5].z;
//       r2.z = (int)r2.z * 14;
//       r7.xyz = cb5[r2.z+4].yzw;
//     } else {
//       r2.y = cmp(v5.z < r2.y);
//       r2.y = r2.y ? 1.000000 : 0;
//       r2.yz = r2.yy * r6.xy;
//       r2.w = 1.53846157 * r3.x;
//       r2.w = min(1, r2.w);
//       r0.xy = r2.ww * r2.yz + r0.xy;
//       r7.xyz = t3.Sample(s3_s, r0.xy).xyz;
//     }
//     r0.x = cmp(0 != cb1[13].x);
//     if (r0.x != 0) {
//       r0.x = dot(v1.xyz, r1.xyz);
//       r0.x = cmp(0 < r0.x);
//       if (r0.x != 0) {
//         r1.z = cb1[14].y * v5.z;
//         r1.xy = v5.xy;
//         r0.x = dot(r1.xyz, r1.xyz);
//         r0.y = sqrt(r0.x);
//         r2.y = cmp(0 != cb5[57].x);
//         if (r2.y == 0) {
//           r2.y = dot(cb5[130].xyz, r1.xyz);
//           r2.z = cmp(0 < r2.y);
//           r2.w = max(cb5[64].w, 0);
//           r2.w = min(r2.w, r2.y);
//           r6.xyz = -cb5[130].xyz * r2.www + r1.xyz;
//           r2.y = max(-cb5[64].w, r2.y);
//           r2.y = min(0, r2.y);
//           r8.xyz = -cb5[130].xyz * r2.yyy + r1.xyz;
//           r2.yzw = r2.zzz ? r6.xyz : r8.xyz;
//           r2.y = dot(r2.yzw, r2.yzw);
//           r2.y = sqrt(r2.y);
//           r2.z = -cb5[56].x + r2.y;
//           r2.z = max(0, r2.z);
//           r2.w = cb5[60].x * r2.z;
//           r2.w = 1.44269502 * r2.w;
//           r2.w = exp2(r2.w);
//           r3.w = dot(cb5[58].xyz, r1.xyz);
//           r3.w = cb5[58].w + r3.w;
//           r3.w = saturate(cb5[59].w * r3.w);
//           r3.w = 1 + -r3.w;
//           r6.x = r3.w * r3.w;
//           r6.y = r6.x * r3.w;
//           r6.x = cb5[65].y * r6.x;
//           r6.x = cb5[65].x * r6.y + r6.x;
//           r3.w = cb5[65].z * r3.w + r6.x;
//           r3.w = saturate(cb5[65].w + r3.w);
//           r3.w = 1 + -r3.w;
//           r6.x = r2.y / cb5[56].y;
//           r2.z = cb5[56].z * r2.z;
//           r2.z = 1.44269502 * r2.z;
//           r2.z = exp2(r2.z);
//           r2.zw = rcp(r2.zw);
//           r2.w = r2.w + -r2.z;
//           r2.z = r3.w * r2.w + r2.z;
//           r2.z = 1 + -r2.z;
//           r2.z = 1 + -r2.z;
//           r2.w = 1 + -r6.x;
//           r2.w = saturate(1.42857146 * r2.w);
//           r2.z = min(r2.z, r2.w);
//           r2.w = -cb5[68].y + r2.y;
//           r6.x = cb5[68].x + -cb5[68].y;
//           r2.w = saturate(r2.w / r6.x);
//           r2.y = saturate(r2.y / cb5[68].x);
//           r6.x = r2.w * r2.w;
//           r6.y = r6.x * r2.w;
//           r6.z = cb5[66].y * r6.x;
//           r6.z = cb5[66].x * r6.y + r6.z;
//           r6.z = cb5[66].z * r2.w + r6.z;
//           r6.z = saturate(cb5[66].w + r6.z);
//           r6.z = 1 + -r6.z;
//           r6.x = cb5[67].y * r6.x;
//           r6.x = cb5[67].x * r6.y + r6.x;
//           r2.w = cb5[67].z * r2.w + r6.x;
//           r2.w = saturate(cb5[67].w + r2.w);
//           r2.w = 1 + -r2.w;
//           r2.w = r2.w + -r6.z;
//           r2.w = r3.w * r2.w + r6.z;
//           r2.w = 1 + -r2.w;
//           r2.w = 1 + -r2.w;
//           r6.x = saturate(cb5[56].y / cb5[68].x);
//           r6.x = -0.300000012 + r6.x;
//           r6.y = r6.x * r6.x;
//           r6.z = r6.y * r6.x;
//           r6.w = cb5[66].y * r6.y;
//           r6.w = cb5[66].x * r6.z + r6.w;
//           r6.w = cb5[66].z * r6.x + r6.w;
//           r6.w = saturate(cb5[66].w + r6.w);
//           r6.y = cb5[67].y * r6.y;
//           r6.y = cb5[67].x * r6.z + r6.y;
//           r6.y = cb5[67].z * r6.x + r6.y;
//           r6.y = saturate(cb5[67].w + r6.y);
//           r6.y = r6.y + -r6.w;
//           r6.y = r3.w * r6.y + r6.w;
//           r2.y = -r6.x + r2.y;
//           r2.y = saturate(3.33333325 * r2.y);
//           r6.x = 1 + -r6.y;
//           r6.x = r2.y * r6.x + r6.y;
//           r6.x = saturate(1 + -r6.x);
//           r6.x = r6.x + -r2.w;
//           r2.y = r2.y * r6.x + r2.w;
//           r2.y = min(r2.w, r2.y);
//           r2.z = r2.z + -r2.y;
//           r2.y = cb5[68].z * r2.z + r2.y;
//         } else {
//           r2.z = cb5[57].y + -r0.y;
//           r2.z = cb5[57].z * r2.z;
//           r2.z = max(0, r2.z);
//           r2.z = log2(r2.z);
//           r2.z = cb5[57].w * r2.z;
//           r2.z = exp2(r2.z);
//           r2.y = min(1, r2.z);
//           r3.w = 0;
//         }
//         r0.x = rsqrt(r0.x);
//         r6.xyz = r1.xyz * r0.xxx;
//         r0.x = -cb5[69].w + r0.y;
//         r0.x = saturate(r0.x / cb5[62].w);
//         r0.y = r0.x * r0.x;
//         r0.y = r0.x * r0.y;
//         r8.xyz = cb5[69].xyz + -cb5[62].xyz;
//         r8.xyz = r0.xxx * r8.xyz + cb5[62].xyz;
//         r9.xyz = cb5[60].yzw + -cb5[59].xyz;
//         r9.xyz = r0.yyy * r9.xyz + cb5[59].xyz;
//         r8.xyz = -r9.xyz + r8.xyz;
//         r8.xyz = r3.www * r8.xyz + r9.xyz;
//         r0.x = saturate(dot(r6.xyz, cb5[64].xyz));
//         r6.xyz = cb5[61].yzw + -r8.xyz;
//         r6.xyz = cb5[63].xxx * r6.xyz;
//         r0.x = saturate(-cb5[61].x + r0.x);
//         r0.y = cmp(0 < r0.x);
//         r1.x = -cb5[61].x + 1;
//         r1.x = 1 / r1.x;
//         r0.x = r1.x * r0.x;
//         r1.x = r0.x * r0.x;
//         r0.x = r1.x * r0.x;
//         r6.xyz = r0.xxx * r6.xyz + r8.xyz;
//         r6.xyz = r0.yyy ? r6.xyz : r8.xyz;
//         r8.xyz = r7.xyz + -r6.xyz;
//         r2.yzw = r2.yyy * r8.xyz + r6.xyz;
//         r0.x = cmp(0 != cb1[6].w);
//         if (r0.x != 0) {
//           r6.xy = v0.xy * cb1[0].xy + cb1[0].zw;
//           r0.x = saturate(r1.z / cb5[56].y);
//           r0.x = rsqrt(r0.x);
//           r0.x = 1 / r0.x;
//           r6.z = saturate(-0.00390625 + r0.x);
//           r6.xyzw = t16.Sample(s13_s, r6.xyz).xyzw;
//           r0.x = 1 + -r6.w;
//           r0.y = min(cb5[129].x, 1);
//           r1.xy = float2(1,1.00000095) + -r0.yy;
//           r6.xyz = r6.xyz * r1.xxx;
//           r0.x = log2(abs(r0.x));
//           r0.x = r1.y * r0.x;
//           r0.x = exp2(r0.x);
//           r2.yzw = r2.yzw * r0.xxx + r6.xyz;
//         }
//         r1.xyz = r2.yzw + -r7.xyz;
//         r7.xyz = r3.xxx * r1.xyz + r7.xyz;
//       }
//     }
//   } else {
//     r7.xyz = float3(1,1,1);
//   }
//   r0.xy = (uint2)cb1[5].xz;
//   r0.xy = (int2)r0.xy * int2(14,14);
//   r1.x = saturate(r2.x / cb1[15].y);
//   r1.y = cmp(0 != cb5[r0.x+1].x);
//   r1.z = cb5[r0.x+1].y + -r0.w;
//   r1.z = cb5[r0.x+1].z * r1.z;
//   r1.z = max(0, r1.z);
//   r1.z = log2(r1.z);
//   r1.z = cb5[r0.x+1].w * r1.z;
//   r1.z = exp2(r1.z);
//   r1.z = min(1, r1.z);
//   if (r1.y == 0) {
//     r2.x = dot(cb5[130].xyz, v5.xyz);
//     r2.y = cmp(0 < r2.x);
//     r2.z = max(cb5[r0.x+8].w, 0);
//     r2.z = min(r2.z, r2.x);
//     r6.xyz = -cb5[130].xyz * r2.zzz + v5.xyz;
//     r2.x = max(-cb5[r0.x+8].w, r2.x);
//     r2.x = min(0, r2.x);
//     r2.xzw = -cb5[130].xyz * r2.xxx + v5.xyz;
//     r2.xyz = r2.yyy ? r6.xyz : r2.xzw;
//     r2.x = dot(r2.xyz, r2.xyz);
//     r2.x = sqrt(r2.x);
//     r2.y = -cb5[r0.x+0].w + r2.x;
//     r2.y = -cb5[r0.x+0].x + r2.y;
//     r2.y = max(0, r2.y);
//     r2.z = cb5[r0.x+4].x * r2.y;
//     r2.z = 1.44269502 * r2.z;
//     r2.z = exp2(r2.z);
//     r2.w = dot(cb5[r0.x+2].xyz, v5.xyz);
//     r2.w = cb5[r0.x+2].w + r2.w;
//     r2.w = saturate(cb5[r0.x+3].w * r2.w);
//     r2.w = 1 + -r2.w;
//     r3.w = r2.w * r2.w;
//     r6.x = r3.w * r2.w;
//     r3.w = cb5[r0.x+9].y * r3.w;
//     r3.w = cb5[r0.x+9].x * r6.x + r3.w;
//     r2.w = cb5[r0.x+9].z * r2.w + r3.w;
//     r2.w = saturate(cb5[r0.x+9].w + r2.w);
//     r2.w = 1 + -r2.w;
//     r3.w = r2.x / cb5[r0.x+0].y;
//     r2.y = cb5[r0.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 = 1 + -r2.y;
//     r2.z = 1 + -r3.w;
//     r2.z = saturate(1.42857146 * r2.z);
//     r2.y = min(r2.y, r2.z);
//     r2.z = -cb5[r0.x+12].y + r2.x;
//     r3.w = cb5[r0.x+12].x + -cb5[r0.x+12].y;
//     r2.z = saturate(r2.z / r3.w);
//     r2.x = saturate(r2.x / cb5[r0.x+12].x);
//     r3.w = r2.z * r2.z;
//     r6.x = r3.w * r2.z;
//     r6.y = cb5[r0.x+10].y * r3.w;
//     r6.y = cb5[r0.x+10].x * r6.x + r6.y;
//     r6.y = cb5[r0.x+10].z * r2.z + r6.y;
//     r6.y = saturate(cb5[r0.x+10].w + r6.y);
//     r6.y = 1 + -r6.y;
//     r3.w = cb5[r0.x+11].y * r3.w;
//     r3.w = cb5[r0.x+11].x * r6.x + r3.w;
//     r2.z = cb5[r0.x+11].z * r2.z + r3.w;
//     r2.z = saturate(cb5[r0.x+11].w + r2.z);
//     r2.z = 1 + -r2.z;
//     r2.z = r2.z + -r6.y;
//     r2.z = r2.w * r2.z + r6.y;
//     r2.z = 1 + -r2.z;
//     r2.z = 1 + -r2.z;
//     r3.w = saturate(cb5[r0.x+0].y / cb5[r0.x+12].x);
//     r3.w = -0.300000012 + r3.w;
//     r6.x = r3.w * r3.w;
//     r6.y = r6.x * r3.w;
//     r6.z = cb5[r0.x+10].y * r6.x;
//     r6.z = cb5[r0.x+10].x * r6.y + r6.z;
//     r6.z = cb5[r0.x+10].z * r3.w + r6.z;
//     r6.z = saturate(cb5[r0.x+10].w + r6.z);
//     r6.x = cb5[r0.x+11].y * r6.x;
//     r6.x = cb5[r0.x+11].x * r6.y + r6.x;
//     r6.x = cb5[r0.x+11].z * r3.w + r6.x;
//     r6.x = saturate(cb5[r0.x+11].w + r6.x);
//     r6.x = r6.x + -r6.z;
//     r2.w = r2.w * r6.x + r6.z;
//     r2.x = -r3.w + r2.x;
//     r2.x = saturate(3.33333325 * r2.x);
//     r3.w = 1 + -r2.w;
//     r2.w = r2.x * r3.w + r2.w;
//     r2.w = saturate(1 + -r2.w);
//     r2.w = r2.w + -r2.z;
//     r2.x = r2.x * r2.w + r2.z;
//     r2.x = min(r2.z, r2.x);
//     r2.y = r2.y + -r2.x;
//     r2.x = cb5[r0.x+12].z * r2.y + r2.x;
//   } else {
//     r2.x = r1.z;
//   }
//   r2.x = saturate(10 * r2.x);
//   r2.x = 1 + -r2.x;
//   r2.y = 1 + -r1.x;
//   r1.x = r2.x * r2.y + r1.x;
//   r1.w = ddx_coarse(r1.w);
//   r1.w = cmp(cb5[r0.x+0].y < abs(r1.w));
//   r1.x = r1.w ? 1 : r1.x;
//   r1.w = -r3.y * 0.100000001 + 1;
//   r1.w = r1.w * r3.x;
//   r2.xyz = -r7.xyz + r4.yzw;
//   r2.xyz = r2.xyz * r1.www;
//   r5.yzw = r3.xxx * r2.xyz + r7.xyz;
//   r1.w = r1.w * r3.x;
//   r4.x = min(r1.w, r5.x);
//   r2.xyzw = r3.zzzz ? r5.xyzw : r4.xyzw;
//   if (r1.y == 0) {
//     r1.y = dot(cb5[130].xyz, v5.xyz);
//     r1.w = cmp(0 < r1.y);
//     r3.x = max(cb5[r0.x+8].w, 0);
//     r3.x = min(r3.x, r1.y);
//     r3.xyz = -cb5[130].xyz * r3.xxx + v5.xyz;
//     r1.y = max(-cb5[r0.x+8].w, r1.y);
//     r1.y = min(0, r1.y);
//     r4.xyz = -cb5[130].xyz * r1.yyy + v5.xyz;
//     r3.xyz = r1.www ? r3.xyz : r4.xyz;
//     r1.y = dot(r3.xyz, r3.xyz);
//     r1.y = sqrt(r1.y);
//     r1.w = -cb5[r0.x+0].x + r1.y;
//     r1.w = max(0, r1.w);
//     r3.x = cb5[r0.x+4].x * r1.w;
//     r3.x = 1.44269502 * r3.x;
//     r3.x = exp2(r3.x);
//     r3.x = rcp(r3.x);
//     r3.y = dot(cb5[r0.x+2].xyz, v5.xyz);
//     r3.y = cb5[r0.x+2].w + r3.y;
//     r3.y = saturate(cb5[r0.x+3].w * r3.y);
//     r3.y = 1 + -r3.y;
//     r3.z = r3.y * r3.y;
//     r3.w = r3.z * r3.y;
//     r3.z = cb5[r0.x+9].y * r3.z;
//     r3.z = cb5[r0.x+9].x * r3.w + r3.z;
//     r3.y = cb5[r0.x+9].z * r3.y + r3.z;
//     r3.y = saturate(cb5[r0.x+9].w + r3.y);
//     r3.y = 1 + -r3.y;
//     r3.z = r1.y / cb5[r0.x+0].y;
//     r1.w = cb5[r0.x+0].z * r1.w;
//     r1.w = 1.44269502 * r1.w;
//     r1.w = exp2(r1.w);
//     r1.w = rcp(r1.w);
//     r3.x = r3.x + -r1.w;
//     r1.w = r3.y * r3.x + r1.w;
//     r1.w = 1 + -r1.w;
//     r1.w = 1 + -r1.w;
//     r3.x = 1 + -r3.z;
//     r3.x = saturate(1.42857146 * r3.x);
//     r1.w = min(r3.x, r1.w);
//     r3.x = -cb5[r0.x+12].y + r1.y;
//     r3.z = cb5[r0.x+12].x + -cb5[r0.x+12].y;
//     r3.x = saturate(r3.x / r3.z);
//     r1.y = saturate(r1.y / cb5[r0.x+12].x);
//     r3.z = r3.x * r3.x;
//     r3.w = r3.z * r3.x;
//     r4.x = cb5[r0.x+10].y * r3.z;
//     r4.x = cb5[r0.x+10].x * r3.w + r4.x;
//     r4.x = cb5[r0.x+10].z * r3.x + r4.x;
//     r4.x = saturate(cb5[r0.x+10].w + r4.x);
//     r4.x = 1 + -r4.x;
//     r3.z = cb5[r0.x+11].y * r3.z;
//     r3.z = cb5[r0.x+11].x * r3.w + r3.z;
//     r3.x = cb5[r0.x+11].z * r3.x + r3.z;
//     r3.x = saturate(cb5[r0.x+11].w + r3.x);
//     r3.x = 1 + -r3.x;
//     r3.x = r3.x + -r4.x;
//     r3.x = r3.y * r3.x + r4.x;
//     r3.x = 1 + -r3.x;
//     r3.z = saturate(cb5[r0.x+0].y / cb5[r0.x+12].x);
//     r3.z = -0.300000012 + r3.z;
//     r3.w = r3.z * r3.z;
//     r4.x = r3.w * r3.z;
//     r4.y = cb5[r0.x+10].y * r3.w;
//     r4.y = cb5[r0.x+10].x * r4.x + r4.y;
//     r4.y = cb5[r0.x+10].z * r3.z + r4.y;
//     r4.y = saturate(cb5[r0.x+10].w + r4.y);
//     r3.w = cb5[r0.x+11].y * r3.w;
//     r3.w = cb5[r0.x+11].x * r4.x + r3.w;
//     r3.w = cb5[r0.x+11].z * r3.z + r3.w;
//     r3.w = saturate(cb5[r0.x+11].w + r3.w);
//     r3.w = r3.w + -r4.y;
//     r3.w = r3.y * r3.w + r4.y;
//     r1.y = -r3.z + r1.y;
//     r1.y = saturate(3.33333325 * r1.y);
//     r3.xz = float2(1,1) + -r3.xw;
//     r3.z = r1.y * r3.z + r3.w;
//     r3.z = saturate(1 + -r3.z);
//     r3.z = r3.z + -r3.x;
//     r1.y = r1.y * r3.z + r3.x;
//     r1.y = min(r3.x, r1.y);
//     r1.w = r1.w + -r1.y;
//     r1.z = cb5[r0.x+12].z * r1.w + r1.y;
//   } else {
//     r3.y = 0;
//   }
//   r0.z = rsqrt(r0.z);
//   r3.xzw = v5.xyz * r0.zzz;
//   r0.z = -cb5[r0.x+13].w + r0.w;
//   r0.z = saturate(r0.z / cb5[r0.x+6].w);
//   r0.w = r0.z * r0.z;
//   r0.w = r0.z * r0.w;
//   r4.xyz = cb5[r0.y+13].xyz + -cb5[r0.y+6].xyz;
//   r4.xyz = r0.zzz * r4.xyz + cb5[r0.y+6].xyz;
//   r5.xyz = cb5[r0.y+4].yzw + -cb5[r0.y+3].xyz;
//   r5.xyz = r0.www * r5.xyz + cb5[r0.y+3].xyz;
//   r4.xyz = -r5.xyz + r4.xyz;
//   r4.xyz = r3.yyy * r4.xyz + r5.xyz;
//   r0.z = saturate(dot(r3.xzw, cb5[r0.x+8].xyz));
//   r3.xyz = cb5[r0.y+5].yzw + -r4.xyz;
//   r3.xyz = cb5[r0.x+7].xxx * r3.xyz;
//   r0.y = saturate(-cb5[r0.x+5].x + r0.z);
//   r0.z = cmp(0 < r0.y);
//   r0.w = -cb5[r0.x+5].x + 1;
//   r0.w = 1 / r0.w;
//   r0.y = r0.w * r0.y;
//   r0.w = r0.y * r0.y;
//   r0.y = r0.w * r0.y;
//   r3.xyz = r0.yyy * r3.xyz + r4.xyz;
//   r0.yzw = r0.zzz ? r3.xyz : r4.xyz;
//   r2.yzw = r2.yzw + -r0.yzw;
//   r0.yzw = r1.zzz * r2.yzw + r0.yzw;
//   r1.y = cmp(0 != cb1[6].w);
//   if (r1.y != 0) {
//     r3.xy = v0.xy * cb6[1].xy + cb6[1].zw;
//     r0.x = saturate(v5.z / cb5[r0.x+0].y);
//     r0.x = rsqrt(r0.x);
//     r0.x = 1 / r0.x;
//     r3.z = saturate(-0.00390625 + r0.x);
//     r3.xyzw = t16.Sample(s13_s, r3.xyz).xyzw;
//     r0.x = 1 + -r3.w;
//     r1.y = min(cb5[129].x, 1);
//     r1.yz = float2(1,1.00000095) + -r1.yy;
//     r2.yzw = r3.xyz * r1.yyy;
//     r0.x = log2(abs(r0.x));
//     r0.x = r1.z * r0.x;
//     r0.x = exp2(r0.x);
//     o0.xyz = r0.yzw * r0.xxx + r2.yzw;
//   } else {
//     o0.xyz = r0.yzw;
//   }
//   o0.w = min(r2.x, r1.x);
//   return;
// }
//////////////////////////////// HLSL Errors ////////////////////////////////
// C:\Games\World of Warcraft\_retail_\ShaderFixes\3eb7b6c615dc710c-ps_replace.txt(93,22-26): error X3018: invalid subscript 'zw'
// C:\Games\World of Warcraft\_retail_\ShaderFixes\3eb7b6c615dc710c-ps_replace.txt(93,11-27): error X3013: 'ddx_coarse': no matching 1 parameter intrinsic function
// C:\Games\World of Warcraft\_retail_\ShaderFixes\3eb7b6c615dc710c-ps_replace.txt(93,11-27): error X3013: Possible intrinsic functions are:
// C:\Games\World of Warcraft\_retail_\ShaderFixes\3eb7b6c615dc710c-ps_replace.txt(93,11-27): error X3013:     ddx_coarse(float|half|min10float|min16float)
/////////////////////////////////////////////////////////////////////////////
