// ---- Created with 3Dmigoto v1.3.16.45 on Thu Dec 10 21:40:32 2020
Texture3D<float4> t16 : register(t16);

Texture2D<float4> t2 : register(t2);

Texture2D<float4> t1 : register(t1);

Texture2D<float4> t0 : register(t0);

SamplerState s13_s : register(s13);

SamplerState s2_s : register(s2);

SamplerState s1_s : register(s1);

SamplerState s0_s : register(s0);

cbuffer cb2 : register(b2)
{
  float4 cb2[7];
}

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

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

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

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,
  float2 v4 : TEXCOORD2,
  float2 w4 : TEXCOORD3,
  float3 v5 : TEXCOORD4,
  out float4 o0 : SV_TARGET0)
{
  float4 r0,r1,r2,r3,r4,r5,r6,r7;
  uint4 bitmask, uiDest;
  float4 fDest;

  float4 x0[3];
  r0.x = cmp(0 < cb0[4].y);
  r0.y = dot(v2.xyz, v2.xyz);
  r0.z = rsqrt(r0.y);
  r1.xyz = v2.xyz * r0.zzz;
  r0.z = dot(-r1.xyz, v3.xyz);
  r0.z = r0.z + r0.z;
  r2.xyz = -r0.zzz * v3.xyz + -r1.xyz;
  r2.w = 1 + r2.z;
  r0.z = dot(r2.xyw, r2.xyw);
  r0.z = rsqrt(r0.z);
  r0.zw = r2.xy * r0.zz;
  r0.zw = r0.zw * float2(0.5,0.5) + float2(0.5,0.5);
  r2.xy = cmp(cb0[4].yy == float2(1,2));
  r2.yz = r2.yy ? v4.xy : r0.zw;
  r0.zw = r2.xx ? r0.zw : r2.yz;
  r0.xz = r0.xx ? r0.zw : v4.xy;
  r2.xyz = t0.Sample(s0_s, r0.xz).xyz;
  r3.xy = t1.Sample(s1_s, r0.xz).xy;
  r0.xzw = t2.Sample(s2_s, r0.xz).xyz;
  r1.w = saturate(4 * r3.y);
  r2.w = saturate(r3.y * 2 + -1);
  r2.w = r2.w * r2.w;
  r3.yz = float2(-0.25,1) + r3.yx;
  r3.y = saturate(r3.y);
  r3.y = r3.y * 0.0600000024 + 0.0199999996;
  r4.xyz = -r3.yyy + r2.xyz;
  r4.xyz = r2.www * r4.xyz + r3.yyy;
  r2.w = dot(v3.xyz, v3.xyz);
  r2.w = rsqrt(r2.w);
  r5.xyz = v3.xyz * r2.www;
  r2.w = dot(-v2.xyz, -v2.xyz);
  r2.w = rsqrt(r2.w);
  r6.xyz = -v2.xyz * r2.www;
  r7.xyz = -v2.xyz * r2.www + -cb8[3].xyz;
  r2.w = dot(r7.xyz, r7.xyz);
  r2.w = rsqrt(r2.w);
  r7.xyz = r7.xyz * r2.www;
  r2.w = dot(r5.xyz, -cb8[3].xyz);
  r3.y = dot(r5.xyz, r7.xyz);
  r3.w = dot(r5.xyz, r6.xyz);
  r4.w = dot(r6.xyz, r7.xyz);
  r5.xyz = v1.xyz * r2.xyz;
  r5.xyz = r5.xyz + r5.xyz;
  r5.w = cmp(0 < r2.w);
  r7.xyz = float3(1,1,1) + -r4.xyz;
  r4.w = 1 + -r4.w;
  r6.w = r4.w * r4.w;
  r6.w = r6.w * r6.w;
  r4.w = r6.w * r4.w;
  r4.xyz = r7.xyz * r4.www + r4.xyz;
  r3.xy = r3.xy * r3.xy;
  r3.x = max(0.00100000005, r3.x);
  r4.w = r3.x * r3.x;
  r3.x = r3.x * r3.x + -1;
  r3.x = r3.y * r3.x + 1;
  r3.xy = r3.xz * r3.xz;
  r3.x = r4.w / r3.x;
  r3.z = 0.125 * r3.y;
  r3.y = -r3.y * 0.125 + 1;
  r4.w = r3.w * r3.y + r3.z;
  r4.w = r3.w / r4.w;
  r3.y = r2.w * r3.y + r3.z;
  r3.y = r2.w / r3.y;
  r3.y = r3.y * r4.w;
  r3.z = r3.w * r2.w;
  r3.z = 4 * r3.z;
  r3.y = r3.y / r3.z;
  r3.x = r3.x * r3.y;
  r3.xyz = r3.xxx * r4.xyz;
  r3.xyz = r3.xyz * r2.www;
  r3.xyz = max(float3(0,0,0), r3.xyz);
  r3.xyz = cb8[4].xyz * r3.xyz;
  r3.xyz = r5.www ? r3.xyz : 0;
  r2.w = 1 + -v2.w;
  r2.w = r2.w * r2.w;
  r4.xyz = cb7[1].xyz * r2.xyz;
  r4.xyz = cb7[0].www * r4.xyz;
  r3.w = dot(v3.xyz, cb7[0].xyz);
  r4.w = saturate(r3.w);
  r4.xyz = r4.xyz * r4.www;
  r5.w = cmp(cb7[0].w < 0);
  r3.w = saturate(-r3.w);
  r6.w = cb7[1].w * -0.75 + 0.800000012;
  r6.w = saturate(-cb7[0].w * r6.w);
  r7.x = saturate(v1.w);
  r7.x = cb7[1].w * r7.x;
  r7.x = -r7.x * r7.x + 1;
  r3.w = r7.x * r3.w;
  r7.x = saturate(5 * r3.w);
  r6.w = -r6.w * r7.x + 1;
  r7.w = v1.w * r6.w;
  r2.xyz = r3.www * r2.xyz;
  r2.xyz = cb7[1].xyz * r2.xyz;
  r7.xyz = -cb7[0].www * r2.xyz;
  r4.w = v1.w;
  r4.xyzw = r5.wwww ? r7.xyzw : r4.xyzw;
  r7.xyz = r4.xyz * r2.www;
  r2.x = r2.w * r4.w + -v1.w;
  r2.x = r2.w * r2.x + v1.w;
  r2.yzw = r3.xyz * r1.www + abs(r5.xyz);
  r3.xyz = r2.yzw + r0.xzw;
  r3.w = cb0[4].x * r2.x;
  r0.x = cmp(0 < cb0[15].w);
  if (r0.x != 0) {
    r0.xzw = cb0[15].xyz * r3.xyz;
    r1.w = saturate(dot(r5.xyz, float3(0.300000012,0.589999974,0.109999999)));
    r1.w = 1 + -r1.w;
    r1.w = sqrt(r1.w);
    r0.xzw = r1.www * r0.xzw;
    r2.xyz = -cb0[14].xyz + v2.xyz;
    r1.w = 4 * cb0[14].w;
    r2.x = dot(r2.xyz, r2.xyz);
    r2.x = cb0[14].w * 4 + -r2.x;
    r2.x = max(0, r2.x);
    r1.w = r2.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.xzw = r0.xzw * float3(3,3,3) + -r3.xyz;
    r3.xyz = r1.www * r0.xzw + r3.xyz;
  }
  r7.w = 0;
  r2.xyzw = r7.xyzw + r3.xyzw;
  r0.x = cmp(cb0[16].w != 0.000000);
  if (r0.x != 0) {
    r0.x = dot(r2.xyz, cb0[16].xyz);
    r0.xzw = r0.xxx + -r2.xyz;
    r2.xyz = cb0[16].www * r0.xzw + r2.xyz;
  }
  r0.x = saturate(dot(r2.xyz, float3(0.212599993,0.715200007,0.0722000003)));
  x0[0].x = 0;
  x0[1].x = cb2[2].w;
  x0[2].x = 1;
  r0.z = cmp(cb2[2].w >= r0.x);
  r0.z = r0.z ? 0 : 1;
  r0.w = x0[r0.z+0].x;
  r1.w = r0.x + -r0.w;
  r2.x = x0[r0.z+1].x;
  r0.w = r2.x + -r0.w;
  r0.w = saturate(r1.w / r0.w);
  r2.xyz = cb2[r0.z+1].xyz + -cb2[r0.z+0].xyz;
  r2.xyz = r0.www * r2.xyz + cb2[r0.z+0].xyz;
  r0.z = cmp(0 < cb2[r0.z+0].w);
  r0.w = cmp(0 < v3.z);
  r0.z = r0.w ? r0.z : 0;
  r3.xyz = r0.zzz ? -v3.xyz : v3.xyz;
  r4.x = saturate(dot(-v2.xyz, r3.xyz));
  r3.xyz = float3(0.0500000007,0.0500000007,1) * r3.xyz;
  r4.y = saturate(dot(r6.xyz, r3.xyz));
  r0.zw = float2(1,1) + -r4.xy;
  r0.zw = r0.zw * r0.zw;
  r0.z = r0.z + r0.w;
  r0.z = log2(r0.z);
  r0.z = cb2[3].w * r0.z;
  r0.z = exp2(r0.z);
  r0.w = cmp(0 != cb2[6].x);
  r3.xyz = -cb2[4].xyz + v2.xyz;
  r1.w = dot(r3.xyz, cb2[5].xyz);
  r1.w = cb2[4].w * r1.w;
  r1.w = 1.66666663 * r1.w;
  r1.w = max(0, r1.w);
  r1.w = min(0.899999976, r1.w);
  r1.w = r1.w * r1.w;
  r1.w = r2.w * r1.w;
  r0.w = r0.w ? r2.w : r1.w;
  r3.xyz = cb2[3].xyz + -r2.xyz;
  r2.xyz = r0.zzz * r3.xyz + r2.xyz;
  r0.z = cmp(0 != cb2[5].w);
  r0.x = r0.w * r0.x;
  o0.w = r0.z ? r0.x : r0.w;
  r0.xz = (uint2)cb0[0].xz;
  r0.xz = (int2)r0.xz * int2(11,11);
  r0.w = dot(cb5[103].xyz, v2.xyz);
  r1.w = cmp(0 < r0.w);
  r2.w = max(cb5[r0.x+7].w, 0);
  r2.w = min(r2.w, r0.w);
  r3.xyz = -cb5[103].xyz * r2.www + 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.yw = sqrt(r0.yw);
  r1.w = -cb5[r0.x+0].x + r0.w;
  r1.w = max(0, r1.w);
  r2.w = cb5[r0.x+3].x * r1.w;
  r2.w = 1.44269502 * r2.w;
  r2.w = exp2(r2.w);
  r2.w = rcp(r2.w);
  r3.x = dot(cb5[r0.x+1].xyz, v2.xyz);
  r3.x = cb5[r0.x+1].w + r3.x;
  r3.x = saturate(cb5[r0.x+2].w * r3.x);
  r3.x = 1 + -r3.x;
  r3.y = r3.x * r3.x;
  r3.z = r3.y * r3.x;
  r3.y = cb5[r0.x+8].y * r3.y;
  r3.y = cb5[r0.x+8].x * r3.z + r3.y;
  r3.x = cb5[r0.x+8].z * r3.x + r3.y;
  r3.x = saturate(cb5[r0.x+8].w + r3.x);
  r3.x = 1 + -r3.x;
  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.y = r2.w + -r1.w;
  r1.w = r3.x * r3.y + r1.w;
  r3.y = 1 + -r0.w;
  r3.y = saturate(1.42857146 * r3.y);
  r1.w = min(r3.y, r1.w);
  r3.y = r0.w * r0.w;
  r3.z = r3.y * r0.w;
  r3.y = cb5[r0.x+9].y * r3.y;
  r3.y = cb5[r0.x+9].x * r3.z + r3.y;
  r3.y = cb5[r0.x+9].z * r0.w + r3.y;
  r3.y = saturate(cb5[r0.x+9].w + r3.y);
  r3.y = 1 + -r3.y;
  r2.w = -r3.y + r2.w;
  r2.w = r3.x * r2.w + r3.y;
  r3.y = max(cb5[r0.x+10].y, 0.00100000005);
  r3.z = cb5[r0.x+10].x + -r3.y;
  r3.w = r3.z * r3.z;
  r4.x = r3.w * r3.z;
  r3.w = cb5[r0.x+9].y * r3.w;
  r3.w = cb5[r0.x+9].x * r4.x + r3.w;
  r3.w = cb5[r0.x+9].z * r3.z + r3.w;
  r3.w = saturate(cb5[r0.x+9].w + r3.w);
  r0.w = -r3.z + r0.w;
  r3.z = 1 + -r3.w;
  r3.z = r3.z * r0.w;
  r3.z = r3.z / r3.y;
  r3.z = r3.z + r3.w;
  r3.z = saturate(1 + -r3.z);
  r0.w = saturate(r0.w / r3.y);
  r3.y = r3.z + -r2.w;
  r0.w = r0.w * r3.y + r2.w;
  r0.w = min(r2.w, r0.w);
  r1.w = r1.w + -r0.w;
  r0.w = cb5[r0.x+10].z * r1.w + r0.w;
  r0.y = r0.y / cb5[r0.x+5].w;
  r1.w = r0.y * r0.y;
  r1.w = saturate(r1.w * r0.y);
  r0.y = saturate(r0.y);
  r3.yzw = -cb5[r0.z+5].xyz + cb5[r0.z+3].yzw;
  r3.yzw = r0.yyy * r3.yzw + cb5[r0.z+5].xyz;
  r4.xyz = cb5[r0.z+3].yzw + -cb5[r0.z+2].xyz;
  r4.xyz = r1.www * r4.xyz + cb5[r0.z+2].xyz;
  r3.yzw = -r4.xyz + r3.yzw;
  r3.xyz = r3.xxx * r3.yzw + r4.xyz;
  r0.y = saturate(dot(r1.xyz, cb5[r0.x+7].xyz));
  r1.xyz = cb5[r0.z+4].yzw + -r3.xyz;
  r1.xyz = cb5[r0.x+6].xxx * r1.xyz;
  r0.y = saturate(-cb5[r0.x+4].x + r0.y);
  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;
  r2.xyz = r2.xyz + -r1.xyz;
  r0.yzw = r0.www * r2.xyz + r1.xyz;
  r1.x = cmp(0 != cb0[1].w);
  if (r1.x != 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);
    r1.xyzw = t16.Sample(s13_s, r1.xyz).xyzw;
    r0.x = 1 + -r1.w;
    r1.w = min(cb5[102].x, v2.w);
    r2.xy = float2(1,1.00000095) + -r1.ww;
    r1.xyz = r2.xxx * r1.xyz;
    r0.x = log2(abs(r0.x));
    r0.x = r2.y * r0.x;
    r0.x = exp2(r0.x);
    o0.xyz = r0.yzw * r0.xxx + r1.xyz;
  } else {
    o0.xyz = r0.yzw;
  }
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16.45 on Thu Dec 10 21:40:32 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     zw        4     NONE   float
// TEXCOORD                 4   xyz         5     NONE   float
//
//
// 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 cb7[2], immediateIndexed
dcl_constantbuffer cb8[5], immediateIndexed
dcl_constantbuffer cb0[17], immediateIndexed
dcl_constantbuffer cb2[7], dynamicIndexed
dcl_sampler s0, mode_default
dcl_sampler s1, mode_default
dcl_sampler s2, 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_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_output o0.xyzw
dcl_temps 8
dcl_indexableTemp x0[3], 4
lt r0.x, l(0.000000), cb0[4].y
dp3 r0.y, v2.xyzx, v2.xyzx
rsq r0.z, r0.y
mul r1.xyz, r0.zzzz, v2.xyzx
dp3 r0.z, -r1.xyzx, v3.xyzx
add r0.z, r0.z, r0.z
mad r2.xyz, -r0.zzzz, v3.xyzx, -r1.xyzx
add r2.w, r2.z, l(1.000000)
dp3 r0.z, r2.xywx, r2.xywx
rsq r0.z, r0.z
mul r0.zw, r0.zzzz, r2.xxxy
mad r0.zw, r0.zzzw, l(0.000000, 0.000000, 0.500000, 0.500000), l(0.000000, 0.000000, 0.500000, 0.500000)
eq r2.xy, cb0[4].yyyy, l(1.000000, 2.000000, 0.000000, 0.000000)
movc r2.yz, r2.yyyy, v4.xxyx, r0.zzwz
movc r0.zw, r2.xxxx, r0.zzzw, r2.yyyz
movc r0.xz, r0.xxxx, r0.zzwz, v4.xxyx
sample_indexable(texture2d)(float,float,float,float) r2.xyz, r0.xzxx, t0.xyzw, s0
sample_indexable(texture2d)(float,float,float,float) r3.xy, r0.xzxx, t1.xyzw, s1
sample_indexable(texture2d)(float,float,float,float) r0.xzw, r0.xzxx, t2.xwyz, s2
mul_sat r1.w, r3.y, l(4.000000)
mad_sat r2.w, r3.y, l(2.000000), l(-1.000000)
mul r2.w, r2.w, r2.w
add r3.yz, r3.yyxy, l(0.000000, -0.250000, 1.000000, 0.000000)
mov_sat r3.y, r3.y
mad r3.y, r3.y, l(0.0600000024), l(0.020000)
add r4.xyz, r2.xyzx, -r3.yyyy
mad r4.xyz, r2.wwww, r4.xyzx, r3.yyyy
dp3 r2.w, v3.xyzx, v3.xyzx
rsq r2.w, r2.w
mul r5.xyz, r2.wwww, v3.xyzx
dp3 r2.w, -v2.xyzx, -v2.xyzx
rsq r2.w, r2.w
mul r6.xyz, r2.wwww, -v2.xyzx
mad r7.xyz, -v2.xyzx, r2.wwww, -cb8[3].xyzx
dp3 r2.w, r7.xyzx, r7.xyzx
rsq r2.w, r2.w
mul r7.xyz, r2.wwww, r7.xyzx
dp3 r2.w, r5.xyzx, -cb8[3].xyzx
dp3 r3.y, r5.xyzx, r7.xyzx
dp3 r3.w, r5.xyzx, r6.xyzx
dp3 r4.w, r6.xyzx, r7.xyzx
mul r5.xyz, r2.xyzx, v1.xyzx
add r5.xyz, r5.xyzx, r5.xyzx
lt r5.w, l(0.000000), r2.w
add r7.xyz, -r4.xyzx, l(1.000000, 1.000000, 1.000000, 0.000000)
add r4.w, -r4.w, l(1.000000)
mul r6.w, r4.w, r4.w
mul r6.w, r6.w, r6.w
mul r4.w, r4.w, r6.w
mad r4.xyz, r7.xyzx, r4.wwww, r4.xyzx
mul r3.xy, r3.xyxx, r3.xyxx
max r3.x, r3.x, l(0.001000)
mul r4.w, r3.x, r3.x
mad r3.x, r3.x, r3.x, l(-1.000000)
mad r3.x, r3.y, r3.x, l(1.000000)
mul r3.xy, r3.xzxx, r3.xzxx
div r3.x, r4.w, r3.x
mul r3.z, r3.y, l(0.125000)
mad r3.y, -r3.y, l(0.125000), l(1.000000)
mad r4.w, r3.w, r3.y, r3.z
div r4.w, r3.w, r4.w
mad r3.y, r2.w, r3.y, r3.z
div r3.y, r2.w, r3.y
mul r3.y, r4.w, r3.y
mul r3.z, r2.w, r3.w
mul r3.z, r3.z, l(4.000000)
div r3.y, r3.y, r3.z
mul r3.x, r3.y, r3.x
mul r3.xyz, r4.xyzx, r3.xxxx
mul r3.xyz, r2.wwww, r3.xyzx
max r3.xyz, r3.xyzx, l(0.000000, 0.000000, 0.000000, 0.000000)
mul r3.xyz, r3.xyzx, cb8[4].xyzx
and r3.xyz, r3.xyzx, r5.wwww
add r2.w, -v2.w, l(1.000000)
mul r2.w, r2.w, r2.w
mul r4.xyz, r2.xyzx, cb7[1].xyzx
mul r4.xyz, r4.xyzx, cb7[0].wwww
dp3 r3.w, v3.xyzx, cb7[0].xyzx
mov_sat r4.w, r3.w
mul r4.xyz, r4.wwww, r4.xyzx
lt r5.w, cb7[0].w, l(0.000000)
mov_sat r3.w, -r3.w
mad r6.w, cb7[1].w, l(-0.750000), l(0.800000)
mul_sat r6.w, r6.w, -cb7[0].w
mov_sat r7.x, v1.w
mul r7.x, r7.x, cb7[1].w
mad r7.x, -r7.x, r7.x, l(1.000000)
mul r3.w, r3.w, r7.x
mul_sat r7.x, r3.w, l(5.000000)
mad r6.w, -r6.w, r7.x, l(1.000000)
mul r7.w, r6.w, v1.w
mul r2.xyz, r2.xyzx, r3.wwww
mul r2.xyz, r2.xyzx, cb7[1].xyzx
mul r7.xyz, r2.xyzx, -cb7[0].wwww
mov r4.w, v1.w
movc r4.xyzw, r5.wwww, r7.xyzw, r4.xyzw
mul r7.xyz, r2.wwww, r4.xyzx
mad r2.x, r2.w, r4.w, -v1.w
mad r2.x, r2.w, r2.x, v1.w
mad r2.yzw, r3.xxyz, r1.wwww, |r5.xxyz|
add r3.xyz, r0.xzwx, r2.yzwy
mul r3.w, r2.x, cb0[4].x
lt r0.x, l(0.000000), cb0[15].w
if_nz r0.x
  mul r0.xzw, r3.xxyz, cb0[15].xxyz
  dp3_sat r1.w, r5.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.xzw, r0.xxzw, r1.wwww
  add r2.xyz, v2.xyzx, -cb0[14].xyzx
  mul r1.w, cb0[14].w, l(4.000000)
  dp3 r2.x, r2.xyzx, r2.xyzx
  mad r2.x, cb0[14].w, l(4.000000), -r2.x
  max r2.x, r2.x, l(0.000000)
  div r1.w, r2.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.xzw, r0.xxzw, l(3.000000, 0.000000, 3.000000, 3.000000), -r3.xxyz
  mad r3.xyz, r1.wwww, r0.xzwx, r3.xyzx
endif
mov r7.w, l(0)
add r2.xyzw, r3.xyzw, r7.xyzw
ne r0.x, cb0[16].w, l(0.000000)
if_nz r0.x
  dp3 r0.x, r2.xyzx, cb0[16].xyzx
  add r0.xzw, -r2.xxyz, r0.xxxx
  mad r2.xyz, cb0[16].wwww, r0.xzwx, r2.xyzx
endif
dp3_sat r0.x, r2.xyzx, l(0.212600, 0.715200, 0.072200, 0.000000)
mov x0[0].x, l(0)
mov x0[1].x, cb2[2].w
mov x0[2].x, l(1.000000)
ge r0.z, cb2[2].w, r0.x
movc r0.z, r0.z, l(0), l(1)
mov r0.w, x0[r0.z + 0].x
add r1.w, -r0.w, r0.x
mov r2.x, x0[r0.z + 1].x
add r0.w, -r0.w, r2.x
div_sat r0.w, r1.w, r0.w
add r2.xyz, -cb2[r0.z + 0].xyzx, cb2[r0.z + 1].xyzx
mad r2.xyz, r0.wwww, r2.xyzx, cb2[r0.z + 0].xyzx
lt r0.z, l(0.000000), cb2[0].w
lt r0.w, l(0.000000), v3.z
and r0.z, r0.w, r0.z
movc r3.xyz, r0.zzzz, -v3.xyzx, v3.xyzx
dp3_sat r4.x, -v2.xyzx, r3.xyzx
mul r3.xyz, r3.xyzx, l(0.050000, 0.050000, 1.000000, 0.000000)
dp3_sat r4.y, r6.xyzx, r3.xyzx
add r0.zw, -r4.xxxy, l(0.000000, 0.000000, 1.000000, 1.000000)
mul r0.zw, r0.zzzw, r0.zzzw
add r0.z, r0.w, r0.z
log r0.z, r0.z
mul r0.z, r0.z, cb2[3].w
exp r0.z, r0.z
ne r0.w, l(0.000000, 0.000000, 0.000000, 0.000000), cb2[6].x
add r3.xyz, v2.xyzx, -cb2[4].xyzx
dp3 r1.w, r3.xyzx, cb2[5].xyzx
mul r1.w, r1.w, cb2[4].w
mul r1.w, r1.w, l(1.66666663)
max r1.w, r1.w, l(0.000000)
min r1.w, r1.w, l(0.900000)
mul r1.w, r1.w, r1.w
mul r1.w, r1.w, r2.w
movc r0.w, r0.w, r2.w, r1.w
add r3.xyz, -r2.xyzx, cb2[3].xyzx
mad r2.xyz, r0.zzzz, r3.xyzx, r2.xyzx
ne r0.z, l(0.000000, 0.000000, 0.000000, 0.000000), cb2[5].w
mul r0.x, r0.x, r0.w
movc o0.w, r0.z, r0.x, r0.w
ftou r0.xz, cb0[0].xxzx
imul null, r0.xz, r0.xxzx, l(11, 0, 11, 0)
dp3 r0.w, cb5[103].xyzx, v2.xyzx
lt r1.w, l(0.000000), r0.w
max r2.w, l(0.000000), cb5[r0.x + 7].w
min r2.w, r0.w, r2.w
mad r3.xyz, -cb5[103].xyzx, r2.wwww, 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.yw, r0.yyyw
add r1.w, r0.w, -cb5[r0.x + 0].x
max r1.w, r1.w, l(0.000000)
mul r2.w, r1.w, cb5[r0.x + 3].x
mul r2.w, r2.w, l(1.442695)
exp r2.w, r2.w
rcp r2.w, r2.w
dp3 r3.x, cb5[r0.x + 1].xyzx, v2.xyzx
add r3.x, r3.x, cb5[r0.x + 1].w
mul_sat r3.x, r3.x, cb5[r0.x + 2].w
add r3.x, -r3.x, l(1.000000)
mul r3.y, r3.x, r3.x
mul r3.z, r3.x, r3.y
mul r3.y, r3.y, cb5[r0.x + 8].y
mad r3.y, cb5[r0.x + 8].x, r3.z, r3.y
mad r3.x, cb5[r0.x + 8].z, r3.x, r3.y
add_sat r3.x, r3.x, cb5[r0.x + 8].w
add r3.x, -r3.x, 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.y, -r1.w, r2.w
mad r1.w, r3.x, r3.y, r1.w
add r3.y, -r0.w, l(1.000000)
mul_sat r3.y, r3.y, l(1.42857146)
min r1.w, r1.w, r3.y
mul r3.y, r0.w, r0.w
mul r3.z, r0.w, r3.y
mul r3.y, r3.y, cb5[r0.x + 9].y
mad r3.y, cb5[r0.x + 9].x, r3.z, r3.y
mad r3.y, cb5[r0.x + 9].z, r0.w, r3.y
add_sat r3.y, r3.y, cb5[r0.x + 9].w
add r3.y, -r3.y, l(1.000000)
add r2.w, r2.w, -r3.y
mad r2.w, r3.x, r2.w, r3.y
max r3.y, l(0.001000), cb5[r0.x + 10].y
add r3.z, -r3.y, cb5[r0.x + 10].x
mul r3.w, r3.z, r3.z
mul r4.x, r3.z, r3.w
mul r3.w, r3.w, cb5[r0.x + 9].y
mad r3.w, cb5[r0.x + 9].x, r4.x, r3.w
mad r3.w, cb5[r0.x + 9].z, r3.z, r3.w
add_sat r3.w, r3.w, cb5[r0.x + 9].w
add r0.w, r0.w, -r3.z
add r3.z, -r3.w, l(1.000000)
mul r3.z, r0.w, r3.z
div r3.z, r3.z, r3.y
add r3.z, r3.w, r3.z
add_sat r3.z, -r3.z, l(1.000000)
div_sat r0.w, r0.w, r3.y
add r3.y, -r2.w, r3.z
mad r0.w, r0.w, r3.y, r2.w
min r0.w, r0.w, r2.w
add r1.w, -r0.w, r1.w
mad r0.w, cb5[r0.x + 10].z, r1.w, r0.w
div r0.y, r0.y, cb5[r0.x + 5].w
mul r1.w, r0.y, r0.y
mul_sat r1.w, r0.y, r1.w
mov_sat r0.y, r0.y
add r3.yzw, cb5[r0.z + 3].yyzw, -cb5[r0.z + 5].xxyz
mad r3.yzw, r0.yyyy, r3.yyzw, cb5[r0.z + 5].xxyz
add r4.xyz, -cb5[r0.z + 2].xyzx, cb5[r0.z + 3].yzwy
mad r4.xyz, r1.wwww, r4.xyzx, cb5[r0.z + 2].xyzx
add r3.yzw, r3.yyzw, -r4.xxyz
mad r3.xyz, r3.xxxx, r3.yzwy, r4.xyzx
dp3_sat r0.y, r1.xyzx, cb5[r0.x + 7].xyzx
add r1.xyz, -r3.xyzx, cb5[r0.z + 4].yzwy
mul r1.xyz, r1.xyzx, cb5[r0.x + 6].xxxx
add_sat r0.y, r0.y, -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 r2.xyz, -r1.xyzx, r2.xyzx
mad r0.yzw, r0.wwww, r2.xxyz, r1.xxyz
ne r1.x, l(0.000000, 0.000000, 0.000000, 0.000000), cb0[1].w
if_nz r1.x
  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) r1.xyzw, r1.xyzx, t16.xyzw, s13
  add r0.x, -r1.w, l(1.000000)
  min r1.w, v2.w, cb5[102].x
  add r2.xy, -r1.wwww, l(1.000000, 1.000001, 0.000000, 0.000000)
  mul r1.xyz, r1.xyzx, r2.xxxx
  log r0.x, |r0.x|
  mul r0.x, r0.x, r2.y
  exp r0.x, r0.x
  mad o0.xyz, r0.yzwy, r0.xxxx, r1.xyzx
else
  mov o0.xyz, r0.yzwy
endif
ret
// Approximately 0 instruction slots used

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