// ---- Created with 3Dmigoto v1.3.16.45 on Mon Dec 14 14:20:23 2020
Texture3D<float4> t16 : register(t16);

Texture2D<float4> t9 : register(t9);

Texture2D<float4> t8 : register(t8);

Texture2D<float4> t7 : register(t7);

Texture2D<float4> t6 : register(t6);

Texture2D<float4> t0 : register(t0);

SamplerState s13_s : register(s13);

SamplerComparisonState s6_s : register(s6);

SamplerState s0_s : register(s0);

cbuffer cb0 : register(b0)
{
  float4 cb0[17];
}

cbuffer cb8 : register(b8)
{
  float4 cb8[6];
}

cbuffer cb7 : register(b7)
{
  float4 cb7[2];
}

cbuffer cb4 : register(b4)
{
  float4 cb4[65];
}

cbuffer cb9 : register(b9)
{
  float4 cb9[8];
}

cbuffer cb6 : register(b6)
{
  float4 cb6[2];
}

cbuffer cb5 : register(b5)
{
  float4 cb5[104];
}




// 3Dmigoto declarations
#define cmp -
Texture1D<float4> IniParams : register(t120);
Texture2D<float4> StereoParams : register(t125);


void main(
  float4 v0 : SV_POSITION0,
  float4 v1 : COLOR0,
  float4 v2 : TEXCOORD0,
  float4 v3 : TEXCOORD1,
  float4 v4 : TEXCOORD2,
  float3 v5 : TEXCOORD3,
  out float4 o0 : SV_TARGET0)
{
  float4 r0,r1,r2,r3,r4,r5,r6;
  uint4 bitmask, uiDest;
  float4 fDest;

  r0.x = cmp(0 < cb0[4].y);
  r0.y = cmp(cb0[4].y == 1.000000);
  r0.z = dot(v2.xyz, v2.xyz);
  r0.w = rsqrt(r0.z);
  r1.xyz = v2.xyz * r0.www;
  r0.w = dot(-r1.xyz, v3.xyz);
  r0.w = r0.w + r0.w;
  r2.xyz = -r0.www * v3.xyz + -r1.xyz;
  r2.w = 1 + r2.z;
  r0.w = dot(r2.xyw, r2.xyw);
  r0.w = rsqrt(r0.w);
  r2.xy = r2.xy * r0.ww;
  r2.xy = r2.xy * float2(0.5,0.5) + float2(0.5,0.5);
  r0.yw = r0.yy ? r2.xy : v4.xy;
  r0.xy = r0.xx ? r0.yw : v4.xy;
  r0.xyw = t0.Sample(s0_s, r0.xy).xyz;
  r1.w = dot(v3.xyz, v3.xyz);
  r1.w = rsqrt(r1.w);
  r2.xyz = v3.xyz * r1.www;
  r1.w = dot(r2.xyz, -cb8[3].xyz);
  r2.w = dot(r2.xyz, cb8[5].xyz);
  r3.x = max(abs(v5.x), abs(v5.y));
  r3.y = cb0[2].z * r3.x;
  r3.y = saturate(r3.y * -10 + 9.89999962);
  r3.x = cmp(r3.x < 1);
  r3.z = cmp(cb0[2].y < 2);
  r3.x = (int)r3.z | (int)r3.x;
  if (r3.x != 0) {
    r3.xz = v5.xy * float2(0.5,0.5) + float2(0.5,0.5);
    r4.xyzw = cb9[6].xyzw + r3.xzxz;
    r5.xyzw = cb9[7].xyzw + r3.xzxz;
    r3.x = t6.SampleCmpLevelZero(s6_s, r3.xz, v5.z).x;
    r3.z = t6.SampleCmpLevelZero(s6_s, r4.xy, v5.z).x;
    r3.x = r3.x + r3.z;
    r3.z = t6.SampleCmpLevelZero(s6_s, r4.zw, v5.z).x;
    r3.x = r3.x + r3.z;
    r3.z = t6.SampleCmpLevelZero(s6_s, r5.xy, v5.z).x;
    r3.x = r3.x + r3.z;
    r3.z = t6.SampleCmpLevelZero(s6_s, r5.zw, v5.z).x;
    r3.x = r3.x + r3.z;
    r3.x = 0.200000003 * r3.x;
  } else {
    r4.xyz = v5.xyz * cb9[0].xyz + cb9[1].xyz;
    r3.z = max(abs(r4.x), abs(r4.y));
    r3.z = cmp(r3.z < 1);
    r3.w = cmp(cb0[2].y < 3);
    r3.z = (int)r3.w | (int)r3.z;
    if (r3.z != 0) {
      r3.zw = r4.xy * float2(0.5,0.5) + float2(0.5,0.5);
      r5.xyzw = cb9[6].xyzw + r3.zwzw;
      r6.xyzw = cb9[7].xyzw + r3.zwzw;
      r3.z = t7.SampleCmpLevelZero(s6_s, r3.zw, r4.z).x;
      r3.w = t7.SampleCmpLevelZero(s6_s, r5.xy, r4.z).x;
      r3.z = r3.z + r3.w;
      r3.w = t7.SampleCmpLevelZero(s6_s, r5.zw, r4.z).x;
      r3.z = r3.z + r3.w;
      r3.w = t7.SampleCmpLevelZero(s6_s, r6.xy, r4.z).x;
      r3.z = r3.z + r3.w;
      r3.w = t7.SampleCmpLevelZero(s6_s, r6.zw, r4.z).x;
      r3.z = r3.z + r3.w;
      r3.x = 0.200000003 * r3.z;
    } else {
      r4.xyz = v5.xyz * cb9[2].xyz + cb9[3].xyz;
      r3.z = max(abs(r4.x), abs(r4.y));
      r3.z = cmp(r3.z < 1);
      r3.w = cmp(cb0[2].y < 4);
      r3.z = (int)r3.w | (int)r3.z;
      if (r3.z != 0) {
        r3.zw = r4.xy * float2(0.5,0.5) + float2(0.5,0.5);
        r5.xyzw = cb9[6].xyzw + r3.zwzw;
        r6.xyzw = cb9[7].xyzw + r3.zwzw;
        r3.z = t8.SampleCmpLevelZero(s6_s, r3.zw, r4.z).x;
        r3.w = t8.SampleCmpLevelZero(s6_s, r5.xy, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.w = t8.SampleCmpLevelZero(s6_s, r5.zw, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.w = t8.SampleCmpLevelZero(s6_s, r6.xy, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.w = t8.SampleCmpLevelZero(s6_s, r6.zw, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.x = 0.200000003 * r3.z;
      } else {
        r4.xyz = v5.xyz * cb9[4].xyz + cb9[5].xyz;
        r3.zw = r4.xy * float2(0.5,0.5) + float2(0.5,0.5);
        r5.xyzw = cb9[6].xyzw + r3.zwzw;
        r6.xyzw = cb9[7].xyzw + r3.zwzw;
        r3.z = t9.SampleCmpLevelZero(s6_s, r3.zw, r4.z).x;
        r3.w = t9.SampleCmpLevelZero(s6_s, r5.xy, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.w = t9.SampleCmpLevelZero(s6_s, r5.zw, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.w = t9.SampleCmpLevelZero(s6_s, r6.xy, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.w = t9.SampleCmpLevelZero(s6_s, r6.zw, r4.z).x;
        r3.z = r3.z + r3.w;
        r3.x = 0.200000003 * r3.z;
      }
    }
  }
  r3.x = -1 + r3.x;
  r3.x = r3.y * r3.x + 1;
  r3.y = min(asint(cb4[64].x), 8);
  r4.xyz = float3(0,0,0);
  r3.z = 0;
  while (true) {
    r3.w = cmp((int)r3.z >= (int)r3.y);
    if (r3.w != 0) break;
    r3.w = (uint)r3.z << 3;
    r5.xyz = cb4[r3.w+2].xyz + -v2.xyz;
    r4.w = dot(r5.xyz, r5.xyz);
    r5.w = rsqrt(r4.w);
    r5.x = dot(r5.xyz, r2.xyz);
    r5.x = r5.x * r5.w;
    r5.x = max(0, r5.x);
    r5.y = r4.w * r5.w + -cb4[r3.w+3].x;
    r5.y = saturate(cb4[r3.w+3].z * r5.y);
    r5.y = 1 + -r5.y;
    r5.z = cb4[r3.w+4].x + -cb4[r3.w+4].y;
    r4.w = r4.w * r5.w + -cb4[r3.w+4].y;
    r5.z = 1 / r5.z;
    r4.w = saturate(r5.z * r4.w);
    r5.z = r4.w * -2 + 3;
    r4.w = r4.w * r4.w;
    r4.w = r5.z * r4.w;
    r6.xyz = -cb4[r3.w+1].xyz + cb4[r3.w+0].xyz;
    r6.xyz = r4.www * r6.xyz + cb4[r3.w+1].xyz;
    r5.yzw = r6.xyz * r5.yyy;
    r5.yzw = r5.yzw * r5.yzw;
    r4.xyz = r5.yzw * r5.xxx + r4.xyz;
    r3.z = (int)r3.z + 1;
  }
  r2.xyz = v1.xyz * r0.xyw;
  r2.xyz = r2.xyz + r2.xyz;
  r3.y = cmp(r2.w >= 0);
  r5.xyz = -cb8[1].xyz + cb8[0].xyz;
  r5.xyz = r2.www * r5.xyz + cb8[1].xyz;
  r6.xyz = cb8[2].xyz + -cb8[1].xyz;
  r6.xyz = -r2.www * r6.xyz + cb8[1].xyz;
  r3.yzw = r3.yyy ? r5.xyz : r6.xyz;
  r1.w = r1.w * 0.5 + 0.5;
  r5.xyz = r3.yzw * r1.www;
  r5.xyz = float3(0.400000036,0.400000036,0.400000036) * r5.xyz;
  r3.yzw = r3.yzw * float3(0.699999988,0.699999988,0.699999988) + r5.xyz;
  r1.w = saturate(dot(v3.xyz, -cb8[3].xyz));
  r5.xyz = cb8[4].xyz * r1.www;
  r3.xyz = r5.xyz * r3.xxx + r3.yzw;
  r3.xyz = r3.xyz * r2.xyz;
  r2.xyz = r2.xyz * r2.xyz;
  r2.xyz = r2.xyz * r4.xyz;
  r1.w = 1 + -v2.w;
  r1.w = r1.w * r1.w;
  r4.xyz = cb7[1].xyz * r0.xyw;
  r4.xyz = cb7[0].www * r4.xyz;
  r2.w = dot(v3.xyz, cb7[0].xyz);
  r3.w = saturate(r2.w);
  r4.xyz = r4.xyz * r3.www;
  r3.w = cmp(cb7[0].w < 0);
  r2.w = saturate(-r2.w);
  r5.x = cb7[1].w * -0.75 + 0.800000012;
  r5.x = saturate(-cb7[0].w * r5.x);
  r5.y = saturate(v1.w);
  r5.y = cb7[1].w * r5.y;
  r5.y = -r5.y * r5.y + 1;
  r2.w = r5.y * r2.w;
  r5.y = saturate(5 * r2.w);
  r5.x = -r5.x * r5.y + 1;
  r5.w = v1.w * r5.x;
  r0.xyw = r2.www * r0.xyw;
  r0.xyw = cb7[1].xyz * r0.xyw;
  r5.xyz = -cb7[0].www * r0.xyw;
  r4.w = v1.w;
  r4.xyzw = r3.wwww ? r5.xyzw : r4.xyzw;
  r5.xyz = r4.xyz * r1.www;
  r0.x = r1.w * r4.w + -v1.w;
  r0.x = r1.w * r0.x + v1.w;
  r2.xyz = r3.xyz * r3.xyz + r2.xyz;
  r2.xyz = sqrt(r2.xyz);
  r2.w = cb0[4].x * r0.x;
  r0.x = cmp(0 < cb0[15].w);
  if (r0.x != 0) {
    r0.xyw = cb0[15].xyz * r2.xyz;
    r1.w = saturate(dot(r3.xyz, float3(0.300000012,0.589999974,0.109999999)));
    r1.w = 1 + -r1.w;
    r1.w = sqrt(r1.w);
    r0.xyw = r1.www * r0.xyw;
    r3.xyz = -cb0[14].xyz + v2.xyz;
    r1.w = 4 * cb0[14].w;
    r3.x = dot(r3.xyz, r3.xyz);
    r3.x = cb0[14].w * 4 + -r3.x;
    r3.x = max(0, r3.x);
    r1.w = r3.x / r1.w;
    r1.w = log2(abs(r1.w));
    r1.w = 20 * r1.w;
    r1.w = exp2(r1.w);
    r1.w = cb0[15].w * r1.w;
    r0.xyw = r0.xyw * float3(3,3,3) + -r2.xyz;
    r2.xyz = r1.www * r0.xyw + r2.xyz;
  }
  r5.w = 0;
  r2.xyzw = r5.xyzw + r2.xyzw;
  r0.x = cmp(cb0[16].w != 0.000000);
  if (r0.x != 0) {
    r0.x = dot(r2.xyz, cb0[16].xyz);
    r0.xyw = r0.xxx + -r2.xyz;
    r2.xyz = cb0[16].www * r0.xyw + r2.xyz;
  }
  r0.xy = (uint2)cb0[0].xz;
  r0.xy = (int2)r0.xy * int2(11,11);
  r0.w = dot(cb5[103].xyz, v2.xyz);
  r1.w = cmp(0 < r0.w);
  r3.x = max(cb5[r0.x+7].w, 0);
  r3.x = min(r3.x, r0.w);
  r3.xyz = -cb5[103].xyz * r3.xxx + v2.xyz;
  r0.w = max(-cb5[r0.x+7].w, r0.w);
  r0.w = min(0, r0.w);
  r4.xyz = -cb5[103].xyz * r0.www + v2.xyz;
  r3.xyz = r1.www ? r3.xyz : r4.xyz;
  r0.w = dot(r3.xyz, r3.xyz);
  r0.zw = sqrt(r0.zw);
  r1.w = -cb5[r0.x+0].x + r0.w;
  r1.w = max(0, r1.w);
  r3.x = cb5[r0.x+3].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+1].xyz, v2.xyz);
  r3.y = cb5[r0.x+1].w + r3.y;
  r3.y = saturate(cb5[r0.x+2].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+8].y * r3.z;
  r3.z = cb5[r0.x+8].x * r3.w + r3.z;
  r3.y = cb5[r0.x+8].z * r3.y + r3.z;
  r3.y = saturate(cb5[r0.x+8].w + r3.y);
  r3.y = 1 + -r3.y;
  r0.w = r0.w / 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.z = r3.x + -r1.w;
  r1.w = r3.y * r3.z + r1.w;
  r3.z = 1 + -r0.w;
  r3.z = saturate(1.42857146 * r3.z);
  r1.w = min(r3.z, r1.w);
  r3.z = r0.w * r0.w;
  r3.w = r3.z * r0.w;
  r3.z = cb5[r0.x+9].y * r3.z;
  r3.z = cb5[r0.x+9].x * r3.w + r3.z;
  r3.z = cb5[r0.x+9].z * r0.w + r3.z;
  r3.z = saturate(cb5[r0.x+9].w + r3.z);
  r3.z = 1 + -r3.z;
  r3.x = r3.x + -r3.z;
  r3.x = r3.y * r3.x + r3.z;
  r3.z = max(cb5[r0.x+10].y, 0.00100000005);
  r3.w = cb5[r0.x+10].x + -r3.z;
  r4.x = r3.w * r3.w;
  r4.y = r4.x * r3.w;
  r4.x = cb5[r0.x+9].y * r4.x;
  r4.x = cb5[r0.x+9].x * r4.y + r4.x;
  r4.x = cb5[r0.x+9].z * r3.w + r4.x;
  r4.x = saturate(cb5[r0.x+9].w + r4.x);
  r0.w = -r3.w + r0.w;
  r3.w = 1 + -r4.x;
  r3.w = r3.w * r0.w;
  r3.w = r3.w / r3.z;
  r3.w = r3.w + r4.x;
  r3.w = saturate(1 + -r3.w);
  r0.w = saturate(r0.w / r3.z);
  r3.z = r3.w + -r3.x;
  r0.w = r0.w * r3.z + r3.x;
  r0.w = min(r3.x, r0.w);
  r1.w = r1.w + -r0.w;
  r0.w = cb5[r0.x+10].z * r1.w + r0.w;
  r0.z = r0.z / cb5[r0.x+5].w;
  r1.w = r0.z * r0.z;
  r1.w = saturate(r1.w * r0.z);
  r0.z = saturate(r0.z);
  r3.xzw = -cb5[r0.y+5].xyz + cb5[r0.y+3].yzw;
  r3.xzw = r0.zzz * r3.xzw + cb5[r0.y+5].xyz;
  r4.xyz = cb5[r0.y+3].yzw + -cb5[r0.y+2].xyz;
  r4.xyz = r1.www * r4.xyz + cb5[r0.y+2].xyz;
  r3.xzw = -r4.xyz + r3.xzw;
  r3.xyz = r3.yyy * r3.xzw + r4.xyz;
  r0.z = saturate(dot(r1.xyz, cb5[r0.x+7].xyz));
  r1.xyz = cb5[r0.y+4].yzw + -r3.xyz;
  r1.xyz = cb5[r0.x+6].xxx * r1.xyz;
  r0.y = saturate(-cb5[r0.x+4].x + r0.z);
  r0.z = cmp(0 < r0.y);
  r1.w = -cb5[r0.x+4].x + 1;
  r1.w = 1 / r1.w;
  r0.y = r1.w * r0.y;
  r1.w = r0.y * r0.y;
  r0.y = r1.w * r0.y;
  r1.xyz = r0.yyy * r1.xyz + r3.xyz;
  r1.xyz = r0.zzz ? r1.xyz : r3.xyz;
  r3.xyz = r2.xyz + -r1.xyz;
  r2.xyz = r0.www * r3.xyz + r1.xyz;
  r0.y = cmp(0 != cb0[1].w);
  if (r0.y != 0) {
    r1.xy = v0.xy * cb6[1].xy + cb6[1].zw;
    r0.x = saturate(v2.z / cb5[r0.x+0].y);
    r0.x = rsqrt(r0.x);
    r0.x = 1 / r0.x;
    r1.z = saturate(-0.00390625 + r0.x);
    r0.xyzw = t16.Sample(s13_s, r1.xyz).xyzw;
    r0.w = 1 + -r0.w;
    r1.x = min(cb5[102].x, v2.w);
    r1.xy = float2(1,1.00000095) + -r1.xx;
    r0.xyz = r1.xxx * r0.xyz;
    r0.w = log2(abs(r0.w));
    r0.w = r1.y * r0.w;
    r0.w = exp2(r0.w);
    r2.xyz = r2.xyz * r0.www + r0.xyz;
  }
  o0.xyzw = r2.xyzw;
  
//o0=0;  
  
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16.45 on Mon Dec 14 14:20:23 2020
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float   xy
// COLOR                    0   xyzw        1     NONE   float   xyzw
// TEXCOORD                 0   xyzw        2     NONE   float   xyzw
// TEXCOORD                 1   xyz         3     NONE   float   xyz
// TEXCOORD                 2   xy          4     NONE   float   xy
// TEXCOORD                 3   xyz         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_constantbuffer cb5[104], dynamicIndexed
dcl_constantbuffer cb6[2], immediateIndexed
dcl_constantbuffer cb9[8], immediateIndexed
dcl_constantbuffer cb4[65], dynamicIndexed
dcl_constantbuffer cb7[2], immediateIndexed
dcl_constantbuffer cb8[6], immediateIndexed
dcl_constantbuffer cb0[17], immediateIndexed
dcl_sampler s0, mode_default
dcl_sampler s6, mode_comparison
dcl_sampler s13, mode_default
dcl_resource_texture2d (float,float,float,float) t0
dcl_resource_texture2d (float,float,float,float) t6
dcl_resource_texture2d (float,float,float,float) t7
dcl_resource_texture2d (float,float,float,float) t8
dcl_resource_texture2d (float,float,float,float) t9
dcl_resource_texture3d (float,float,float,float) t16
dcl_input_ps_siv linear noperspective v0.xy, position
dcl_input_ps linear v1.xyzw
dcl_input_ps linear v2.xyzw
dcl_input_ps linear v3.xyz
dcl_input_ps linear v4.xy
dcl_input_ps linear v5.xyz
dcl_output o0.xyzw
dcl_temps 7
lt r0.x, l(0.000000), cb0[4].y
eq r0.y, cb0[4].y, l(1.000000)
dp3 r0.z, v2.xyzx, v2.xyzx
rsq r0.w, r0.z
mul r1.xyz, r0.wwww, v2.xyzx
dp3 r0.w, -r1.xyzx, v3.xyzx
add r0.w, r0.w, r0.w
mad r2.xyz, -r0.wwww, v3.xyzx, -r1.xyzx
add r2.w, r2.z, l(1.000000)
dp3 r0.w, r2.xywx, r2.xywx
rsq r0.w, r0.w
mul r2.xy, r0.wwww, r2.xyxx
mad r2.xy, r2.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000), l(0.500000, 0.500000, 0.000000, 0.000000)
movc r0.yw, r0.yyyy, r2.xxxy, v4.xxxy
movc r0.xy, r0.xxxx, r0.ywyy, v4.xyxx
sample_indexable(texture2d)(float,float,float,float) r0.xyw, r0.xyxx, t0.xywz, s0
dp3 r1.w, v3.xyzx, v3.xyzx
rsq r1.w, r1.w
mul r2.xyz, r1.wwww, v3.xyzx
dp3 r1.w, r2.xyzx, -cb8[3].xyzx
dp3 r2.w, r2.xyzx, cb8[5].xyzx
max r3.x, |v5.y|, |v5.x|
mul r3.y, r3.x, cb0[2].z
mad_sat r3.y, r3.y, l(-10.000000), l(9.900000)
lt r3.x, r3.x, l(1.000000)
lt r3.z, cb0[2].y, l(2.000000)
or r3.x, r3.z, r3.x
if_nz r3.x
  mad r3.xz, v5.xxyx, l(0.500000, 0.000000, 0.500000, 0.000000), l(0.500000, 0.000000, 0.500000, 0.000000)
  add r4.xyzw, r3.xzxz, cb9[6].xyzw
  add r5.xyzw, r3.xzxz, cb9[7].xyzw
  sample_c_lz_indexable(texture2d)(float,float,float,float) r3.x, r3.xzxx, t6.xxxx, s6, v5.z
  sample_c_lz_indexable(texture2d)(float,float,float,float) r3.z, r4.xyxx, t6.xxxx, s6, v5.z
  add r3.x, r3.z, r3.x
  sample_c_lz_indexable(texture2d)(float,float,float,float) r3.z, r4.zwzz, t6.xxxx, s6, v5.z
  add r3.x, r3.z, r3.x
  sample_c_lz_indexable(texture2d)(float,float,float,float) r3.z, r5.xyxx, t6.xxxx, s6, v5.z
  add r3.x, r3.z, r3.x
  sample_c_lz_indexable(texture2d)(float,float,float,float) r3.z, r5.zwzz, t6.xxxx, s6, v5.z
  add r3.x, r3.z, r3.x
  mul r3.x, r3.x, l(0.200000)
else
  mad r4.xyz, v5.xyzx, cb9[0].xyzx, cb9[1].xyzx
  max r3.z, |r4.y|, |r4.x|
  lt r3.z, r3.z, l(1.000000)
  lt r3.w, cb0[2].y, l(3.000000)
  or r3.z, r3.w, r3.z
  if_nz r3.z
    mad r3.zw, r4.xxxy, l(0.000000, 0.000000, 0.500000, 0.500000), l(0.000000, 0.000000, 0.500000, 0.500000)
    add r5.xyzw, r3.zwzw, cb9[6].xyzw
    add r6.xyzw, r3.zwzw, cb9[7].xyzw
    sample_c_lz_indexable(texture2d)(float,float,float,float) r3.z, r3.zwzz, t7.xxxx, s6, r4.z
    sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r5.xyxx, t7.xxxx, s6, r4.z
    add r3.z, r3.w, r3.z
    sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r5.zwzz, t7.xxxx, s6, r4.z
    add r3.z, r3.w, r3.z
    sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r6.xyxx, t7.xxxx, s6, r4.z
    add r3.z, r3.w, r3.z
    sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r6.zwzz, t7.xxxx, s6, r4.z
    add r3.z, r3.w, r3.z
    mul r3.x, r3.z, l(0.200000)
  else
    mad r4.xyz, v5.xyzx, cb9[2].xyzx, cb9[3].xyzx
    max r3.z, |r4.y|, |r4.x|
    lt r3.z, r3.z, l(1.000000)
    lt r3.w, cb0[2].y, l(4.000000)
    or r3.z, r3.w, r3.z
    if_nz r3.z
      mad r3.zw, r4.xxxy, l(0.000000, 0.000000, 0.500000, 0.500000), l(0.000000, 0.000000, 0.500000, 0.500000)
      add r5.xyzw, r3.zwzw, cb9[6].xyzw
      add r6.xyzw, r3.zwzw, cb9[7].xyzw
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.z, r3.zwzz, t8.xxxx, s6, r4.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r5.xyxx, t8.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r5.zwzz, t8.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r6.xyxx, t8.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r6.zwzz, t8.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      mul r3.x, r3.z, l(0.200000)
    else
      mad r4.xyz, v5.xyzx, cb9[4].xyzx, cb9[5].xyzx
      mad r3.zw, r4.xxxy, l(0.000000, 0.000000, 0.500000, 0.500000), l(0.000000, 0.000000, 0.500000, 0.500000)
      add r5.xyzw, r3.zwzw, cb9[6].xyzw
      add r6.xyzw, r3.zwzw, cb9[7].xyzw
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.z, r3.zwzz, t9.xxxx, s6, r4.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r5.xyxx, t9.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r5.zwzz, t9.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r6.xyxx, t9.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      sample_c_lz_indexable(texture2d)(float,float,float,float) r3.w, r6.zwzz, t9.xxxx, s6, r4.z
      add r3.z, r3.w, r3.z
      mul r3.x, r3.z, l(0.200000)
    endif
  endif
endif
add r3.x, r3.x, l(-1.000000)
mad r3.x, r3.y, r3.x, l(1.000000)
imin r3.y, l(8), cb4[64].x
mov r4.xyz, l(0,0,0,0)
mov r3.z, l(0)
loop
  ige r3.w, r3.z, r3.y
  breakc_nz r3.w
  ishl r3.w, r3.z, l(3)
  add r5.xyz, -v2.xyzx, cb4[r3.w + 2].xyzx
  dp3 r4.w, r5.xyzx, r5.xyzx
  rsq r5.w, r4.w
  dp3 r5.x, r5.xyzx, r2.xyzx
  mul r5.x, r5.w, r5.x
  max r5.x, r5.x, l(0.000000)
  mad r5.y, r4.w, r5.w, -cb4[r3.w + 3].x
  mul_sat r5.y, r5.y, cb4[r3.w + 3].z
  add r5.y, -r5.y, l(1.000000)
  add r5.z, -cb4[r3.w + 4].y, cb4[r3.w + 4].x
  mad r4.w, r4.w, r5.w, -cb4[r3.w + 4].y
  div r5.z, l(1.000000, 1.000000, 1.000000, 1.000000), r5.z
  mul_sat r4.w, r4.w, r5.z
  mad r5.z, r4.w, l(-2.000000), l(3.000000)
  mul r4.w, r4.w, r4.w
  mul r4.w, r4.w, r5.z
  add r6.xyz, cb4[r3.w + 0].xyzx, -cb4[r3.w + 1].xyzx
  mad r6.xyz, r4.wwww, r6.xyzx, cb4[r3.w + 1].xyzx
  mul r5.yzw, r5.yyyy, r6.xxyz
  mul r5.yzw, r5.yyzw, r5.yyzw
  mad r4.xyz, r5.yzwy, r5.xxxx, r4.xyzx
  iadd r3.z, r3.z, l(1)
endloop
mul r2.xyz, r0.xywx, v1.xyzx
add r2.xyz, r2.xyzx, r2.xyzx
ge r3.y, r2.w, l(0.000000)
add r5.xyz, cb8[0].xyzx, -cb8[1].xyzx
mad r5.xyz, r2.wwww, r5.xyzx, cb8[1].xyzx
add r6.xyz, -cb8[1].xyzx, cb8[2].xyzx
mad r6.xyz, -r2.wwww, r6.xyzx, cb8[1].xyzx
movc r3.yzw, r3.yyyy, r5.xxyz, r6.xxyz
mad r1.w, r1.w, l(0.500000), l(0.500000)
mul r5.xyz, r1.wwww, r3.yzwy
mul r5.xyz, r5.xyzx, l(0.400000036, 0.400000036, 0.400000036, 0.000000)
mad r3.yzw, r3.yyzw, l(0.000000, 0.700000, 0.700000, 0.700000), r5.xxyz
dp3_sat r1.w, v3.xyzx, -cb8[3].xyzx
mul r5.xyz, r1.wwww, cb8[4].xyzx
mad r3.xyz, r5.xyzx, r3.xxxx, r3.yzwy
mul r3.xyz, r2.xyzx, r3.xyzx
mul r2.xyz, r2.xyzx, r2.xyzx
mul r2.xyz, r4.xyzx, r2.xyzx
add r1.w, -v2.w, l(1.000000)
mul r1.w, r1.w, r1.w
mul r4.xyz, r0.xywx, cb7[1].xyzx
mul r4.xyz, r4.xyzx, cb7[0].wwww
dp3 r2.w, v3.xyzx, cb7[0].xyzx
mov_sat r3.w, r2.w
mul r4.xyz, r3.wwww, r4.xyzx
lt r3.w, cb7[0].w, l(0.000000)
mov_sat r2.w, -r2.w
mad r5.x, cb7[1].w, l(-0.750000), l(0.800000)
mul_sat r5.x, r5.x, -cb7[0].w
mov_sat r5.y, v1.w
mul r5.y, r5.y, cb7[1].w
mad r5.y, -r5.y, r5.y, l(1.000000)
mul r2.w, r2.w, r5.y
mul_sat r5.y, r2.w, l(5.000000)
mad r5.x, -r5.x, r5.y, l(1.000000)
mul r5.w, r5.x, v1.w
mul r0.xyw, r0.xyxw, r2.wwww
mul r0.xyw, r0.xyxw, cb7[1].xyxz
mul r5.xyz, r0.xywx, -cb7[0].wwww
mov r4.w, v1.w
movc r4.xyzw, r3.wwww, r5.xyzw, r4.xyzw
mul r5.xyz, r1.wwww, r4.xyzx
mad r0.x, r1.w, r4.w, -v1.w
mad r0.x, r1.w, r0.x, v1.w
mad r2.xyz, r3.xyzx, r3.xyzx, r2.xyzx
sqrt r2.xyz, r2.xyzx
mul r2.w, r0.x, cb0[4].x
lt r0.x, l(0.000000), cb0[15].w
if_nz r0.x
  mul r0.xyw, r2.xyxz, cb0[15].xyxz
  dp3_sat r1.w, r3.xyzx, l(0.300000, 0.590000, 0.110000, 0.000000)
  add r1.w, -r1.w, l(1.000000)
  sqrt r1.w, r1.w
  mul r0.xyw, r0.xyxw, r1.wwww
  add r3.xyz, v2.xyzx, -cb0[14].xyzx
  mul r1.w, cb0[14].w, l(4.000000)
  dp3 r3.x, r3.xyzx, r3.xyzx
  mad r3.x, cb0[14].w, l(4.000000), -r3.x
  max r3.x, r3.x, l(0.000000)
  div r1.w, r3.x, r1.w
  log r1.w, |r1.w|
  mul r1.w, r1.w, l(20.000000)
  exp r1.w, r1.w
  mul r1.w, r1.w, cb0[15].w
  mad r0.xyw, r0.xyxw, l(3.000000, 3.000000, 0.000000, 3.000000), -r2.xyxz
  mad r2.xyz, r1.wwww, r0.xywx, r2.xyzx
endif
mov r5.w, l(0)
add r2.xyzw, r2.xyzw, r5.xyzw
ne r0.x, cb0[16].w, l(0.000000)
if_nz r0.x
  dp3 r0.x, r2.xyzx, cb0[16].xyzx
  add r0.xyw, -r2.xyxz, r0.xxxx
  mad r2.xyz, cb0[16].wwww, r0.xywx, r2.xyzx
endif
ftou r0.xy, cb0[0].xzxx
imul null, r0.xy, r0.xyxx, l(11, 11, 0, 0)
dp3 r0.w, cb5[103].xyzx, v2.xyzx
lt r1.w, l(0.000000), r0.w
max r3.x, l(0.000000), cb5[r0.x + 7].w
min r3.x, r0.w, r3.x
mad r3.xyz, -cb5[103].xyzx, r3.xxxx, v2.xyzx
max r0.w, r0.w, -cb5[r0.x + 7].w
min r0.w, r0.w, l(0.000000)
mad r4.xyz, -cb5[103].xyzx, r0.wwww, v2.xyzx
movc r3.xyz, r1.wwww, r3.xyzx, r4.xyzx
dp3 r0.w, r3.xyzx, r3.xyzx
sqrt r0.zw, r0.zzzw
add r1.w, r0.w, -cb5[r0.x + 0].x
max r1.w, r1.w, l(0.000000)
mul r3.x, r1.w, cb5[r0.x + 3].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 + 1].xyzx, v2.xyzx
add r3.y, r3.y, cb5[r0.x + 1].w
mul_sat r3.y, r3.y, cb5[r0.x + 2].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 + 8].y
mad r3.z, cb5[r0.x + 8].x, r3.w, r3.z
mad r3.y, cb5[r0.x + 8].z, r3.y, r3.z
add_sat r3.y, r3.y, cb5[r0.x + 8].w
add r3.y, -r3.y, l(1.000000)
div r0.w, r0.w, 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.z, -r1.w, r3.x
mad r1.w, r3.y, r3.z, r1.w
add r3.z, -r0.w, l(1.000000)
mul_sat r3.z, r3.z, l(1.42857146)
min r1.w, r1.w, r3.z
mul r3.z, r0.w, r0.w
mul r3.w, r0.w, 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.z, cb5[r0.x + 9].z, r0.w, r3.z
add_sat r3.z, r3.z, cb5[r0.x + 9].w
add r3.z, -r3.z, l(1.000000)
add r3.x, -r3.z, r3.x
mad r3.x, r3.y, r3.x, r3.z
max r3.z, l(0.001000), cb5[r0.x + 10].y
add r3.w, -r3.z, cb5[r0.x + 10].x
mul r4.x, r3.w, r3.w
mul r4.y, r3.w, r4.x
mul r4.x, r4.x, cb5[r0.x + 9].y
mad r4.x, cb5[r0.x + 9].x, r4.y, r4.x
mad r4.x, cb5[r0.x + 9].z, r3.w, r4.x
add_sat r4.x, r4.x, cb5[r0.x + 9].w
add r0.w, r0.w, -r3.w
add r3.w, -r4.x, l(1.000000)
mul r3.w, r0.w, r3.w
div r3.w, r3.w, r3.z
add r3.w, r4.x, r3.w
add_sat r3.w, -r3.w, l(1.000000)
div_sat r0.w, r0.w, r3.z
add r3.z, -r3.x, r3.w
mad r0.w, r0.w, r3.z, r3.x
min r0.w, r0.w, r3.x
add r1.w, -r0.w, r1.w
mad r0.w, cb5[r0.x + 10].z, r1.w, r0.w
div r0.z, r0.z, cb5[r0.x + 5].w
mul r1.w, r0.z, r0.z
mul_sat r1.w, r0.z, r1.w
mov_sat r0.z, r0.z
add r3.xzw, cb5[r0.y + 3].yyzw, -cb5[r0.y + 5].xxyz
mad r3.xzw, r0.zzzz, r3.xxzw, cb5[r0.y + 5].xxyz
add r4.xyz, -cb5[r0.y + 2].xyzx, cb5[r0.y + 3].yzwy
mad r4.xyz, r1.wwww, r4.xyzx, cb5[r0.y + 2].xyzx
add r3.xzw, r3.xxzw, -r4.xxyz
mad r3.xyz, r3.yyyy, r3.xzwx, r4.xyzx
dp3_sat r0.z, r1.xyzx, cb5[r0.x + 7].xyzx
add r1.xyz, -r3.xyzx, cb5[r0.y + 4].yzwy
mul r1.xyz, r1.xyzx, cb5[r0.x + 6].xxxx
add_sat r0.y, r0.z, -cb5[r0.x + 4].x
lt r0.z, l(0.000000), r0.y
add r1.w, l(1.000000), -cb5[r0.x + 4].x
div r1.w, l(1.000000, 1.000000, 1.000000, 1.000000), r1.w
mul r0.y, r0.y, r1.w
mul r1.w, r0.y, r0.y
mul r0.y, r0.y, r1.w
mad r1.xyz, r0.yyyy, r1.xyzx, r3.xyzx
movc r1.xyz, r0.zzzz, r1.xyzx, r3.xyzx
add r3.xyz, -r1.xyzx, r2.xyzx
mad r2.xyz, r0.wwww, r3.xyzx, r1.xyzx
ne r0.y, l(0.000000, 0.000000, 0.000000, 0.000000), cb0[1].w
if_nz r0.y
  mad r1.xy, v0.xyxx, cb6[1].xyxx, cb6[1].zwzz
  div_sat r0.x, v2.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 r1.z, r0.x, l(-0.00390625000)
  sample_indexable(texture3d)(float,float,float,float) r0.xyzw, r1.xyzx, t16.xyzw, s13
  add r0.w, -r0.w, l(1.000000)
  min r1.x, v2.w, cb5[102].x
  add r1.xy, -r1.xxxx, l(1.000000, 1.000001, 0.000000, 0.000000)
  mul r0.xyz, r0.xyzx, r1.xxxx
  log r0.w, |r0.w|
  mul r0.w, r0.w, r1.y
  exp r0.w, r0.w
  mad r2.xyz, r2.xyzx, r0.wwww, r0.xyzx
endif
mov o0.xyzw, r2.xyzw
ret
// Approximately 0 instruction slots used

//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
