// ssa water reflections needs correction Neph
// ---- Created with 3Dmigoto v1.3.16.45 on Thu Dec 10 22:20:18 2020
Texture3D<float4> t16 : register(t16);

Texture2D<float4> t15 : register(t15);

Texture2D<float4> t14 : register(t14);

Texture2D<float4> t7 : register(t7);

Texture2D<float4> t6 : register(t6);

Texture2D<float4> t5 : register(t5);

Texture2D<float4> t4 : register(t4);

Texture2D<float4> t3 : register(t3);

Texture2D<float4> t1 : register(t1);

Texture2D<float4> t0 : register(t0);

SamplerState s15_s : register(s15);

SamplerState s14_s : register(s14);

SamplerState s13_s : register(s13);

SamplerState s7_s : register(s7);

SamplerState s6_s : register(s6);

SamplerState s5_s : register(s5);

SamplerState s4_s : register(s4);

SamplerState s3_s : register(s3);

SamplerState s1_s : register(s1);

SamplerState s0_s : register(s0);

cbuffer cb1 : register(b1)
{
  float4 cb1[36];
}

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 : TEXCOORD0,
  float4 v2 : TEXCOORD1,
  float4 v3 : TEXCOORD2,
  float4 v4 : TEXCOORD3,
  linear centroid float4 v5 : TEXCOORD4,
  float4 v6 : TEXCOORD5,
  float4 v7 : TEXCOORD6,
  float2 v8 : TEXCOORD7,
  float3 v9 : COLOR0,
  out float4 o0 : SV_TARGET0)
{
  float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11;
  uint4 bitmask, uiDest;
  float4 fDest;
  
float4 stereo = StereoParams.Load(0);
float4 iniParams = IniParams.Load(0);  
  
  

  r0.x = t14.Sample(s14_s, v5.zw).x;
  r0.y = t15.Sample(s15_s, v5.zw).x;
  r0.z = dot(v6.xyz, v6.xyz);
  r0.z = sqrt(r0.z);
  r1.xyz = v6.xyz / r0.zzz;
  
r1.y+=stereo.x * stereo.y * 0.00390625;
r1.z-=stereo.x * stereo.y * 0.00390625;
  
  r2.xy = v7.xy / v7.ww;
  r2.xy = r2.xy * cb1[31].xy + cb1[31].zw;
  r0.w = t6.Sample(s6_s, r2.xy).x;
  r0.w = -v1.z + r0.w;
  r1.w = r0.w / v1.z;
  r2.zw = t5.Sample(s5_s, v2.xy).xy;
  r3.xy = t5.Sample(s5_s, v2.zw).xy;
  r2.zw = r3.xy + r2.zw;
  r2.zw = float2(-1,-1) + r2.zw;
  r3.xy = t5.Sample(s5_s, v3.xy).xy;
  r3.zw = t5.Sample(s5_s, v3.zw).xy;
  r3.xy = r3.xy + r3.zw;
  r3.xy = float2(-1,-1) + r3.xy;
  r3.xy = float2(1.39999998,1.39999998) * r3.xy;
  r3.z = 0.00666666683 * r0.z;
  r0.z = r0.z * 0.00100000005 + 0.200000003;
  r0.z = min(1, r0.z);
  r2.zw = r2.zw * float2(2,2) + -r3.xy;
  r2.zw = r0.zz * r2.zw + r3.xy;
  r4.xy = cb1[28].ww * r2.zw;
  r4.z = 1;
  r0.z = dot(r4.xyz, r4.xyz);
  r0.z = rsqrt(r0.z);
  r2.zw = r4.xy * r0.zz;
  r3.xy = r2.zw * float2(0.0199999996,0.0199999996) + float2(9.99999997e-007,9.99999997e-007);
  r3.xy = v8.xy + -r3.xy;
  r4.xy = t4.Sample(s4_s, r3.xy).xy;
  r5.xw = cb1[33].xy;
  r5.yz = float2(0,0);
  r5.xyzw = r5.xyzw + r3.xyxy;
  r4.zw = t4.Sample(s4_s, r5.xy).xy;
  r5.xy = t4.Sample(s4_s, r5.zw).xy;
  r0.z = r4.x + -r4.y;
  r0.z = cb1[35].x * r0.z + r4.y;
  r3.w = r4.z + -r4.w;
  r3.w = cb1[35].x * r3.w + r4.w;
  r4.x = r5.x + -r5.y;
  r4.x = cb1[35].x * r4.x + r5.y;
  r5.x = r3.w + -r0.z;
  r5.yz = float2(1,1);
  r3.w = dot(r5.xy, r5.xy);
  r3.w = rsqrt(r3.w);
  r4.yz = r5.xy * r3.ww;
  r5.w = r4.x + -r0.z;
  r0.z = dot(r5.zw, r5.zw);
  r0.z = rsqrt(r0.z);
  r4.xw = r5.zw * r0.zz;
  r3.xy = r3.xy * float2(2,2) + float2(-1,-1);
  r0.z = max(abs(r3.x), abs(r3.y));
  r3.xy = float2(1,1) + -cb1[33].xy;
  r3.xy = cmp(r0.zz < r3.xy);
  r3.xy = r3.xy ? cb1[28].zz : 0;
  r4.xy = r4.yz * r4.xw;
  r2.zw = r4.xy * r3.xy + r2.zw;
  r4.xy = cb1[28].yy * r2.zw;
  r4.z = 1;
  r0.z = dot(r4.xyz, r4.xyz);
  r0.z = rsqrt(r0.z);
  r3.xyw = r4.xyz * r0.zzz;
  r2.z = saturate(dot(-r1.xyz, r3.xyw));
  r2.z = 1 + -r2.z;
  r4.w = r2.z * r2.z;
  r5.x = saturate(cb1[0].z);
  r5.xyz = cb1[2].xyz * r5.xxx + cb1[1].xyz;
  r5.xyz = v9.xyz * r5.xyz;
  r5.w = r0.x * r0.x;
  r6.x = cb1[8].y * r0.x + cb1[8].x;
  r0.x = r5.w * r0.x;
  r5.w = r5.w * cb1[8].z + r6.x;
  r0.x = saturate(r0.x * cb1[8].w + r5.w);
  r2.w = 0.100000001 * r2.w;
  r0.x = r0.x * cb1[21].w + abs(r2.w);
  r6.xyzw = cb1[18].xyzw + -cb1[17].xyzw;
  r6.xyzw = r0.xxxx * r6.xyzw + cb1[17].xyzw;
  r7.xyz = r6.xyz * r5.xyz;
  r8.xy = float2(0.100000001,0.100000001) * r3.xy;
  r0.x = 100 * r1.w;
  r1.w = -r2.z * r2.z + 1.20000005;
  r0.x = saturate(r1.w * r0.x);
  r2.zw = r8.xy * r0.xx;
  r8.xy = r8.xy * r0.xx + r2.xy;
  r8.zw = r4.ww * float2(0.5,0.5) + float2(0.100000001,0.200000003);
  r0.x = dot(r1.xyz, r3.xyw);
  r9.xy = float2(-1,-1) * r3.xy;
  r9.z = 0;
  r1.w = 1 + r0.x;
  r1.w = saturate(r1.w * 0.450000018 + 0.100000001);
  r9.xyz = r9.xyz + -r1.xyz;
  r9.xyz = r1.www * r9.xyz + r1.xyz;
  r0.x = r0.x + r0.x;
  r10.xyz = r3.xyw * -r0.xxx + r1.xyz;
  r10.xyw = r10.xyz * float3(128,128,128) + v6.xyz;
  r11.xyz = cb1[14].xyw * r10.yyy;
  r11.xyz = r10.xxx * cb1[13].xyw + r11.xyz;
  r10.xyw = r10.www * cb1[15].xyw + r11.xyz;
  r10.xyw = cb1[16].xyw + r10.xyw;
  r10.xy = r10.xy / r10.ww;
  r11.xy = r10.xy * cb1[31].xy + cb1[31].zw;
  r11.xyz = t3.Sample(s3_s, r11.xy).xyz;
  r0.x = -r10.z * r10.z + 0.75;
  r0.x = max(0, r0.x);
  r0.x = 1.33333337 * r0.x;
  r10.xy = r10.xy * r10.xy;
  r10.xy = -r10.yx * r10.yx + float2(1,1);
  r1.w = max(0, r10.y);
  r10.x = saturate(r10.x);
  r1.w = r10.x * r1.w;
  r0.x = r1.w * r0.x;
  r9.xyz = r9.xyz * float3(20,20,20) + v6.xyz;
  r10.xyz = cb1[14].xyw * r9.yyy;
  r9.xyw = r9.xxx * cb1[13].xyw + r10.xyz;
  r9.xyz = r9.zzz * cb1[15].xyw + r9.xyw;
  r9.xyz = cb1[16].xyw + r9.xyz;
  
 r9.x+=stereo.x * r9.w; 
  
  r9.w = -r9.y;
  r9.xy = r9.xw / r9.zz;
  r9.xy = float2(1,1) + r9.xy;
  r9.xy = float2(0.5,0.5) * r9.xy;
  r9.xyz = t1.Sample(s1_s, r9.xy).xyz;
  r10.xyz = r11.xyz + -r9.xyz;
  r9.xyz = r0.xxx * r10.xyz + r9.xyz;
  r10.xyz = r6.xyz * r5.xyz + -r9.xyz;
  r9.xyz = r10.xyz * float3(0.600000024,0.600000024,0.600000024) + r9.xyz;
  r10.xyz = cb1[5].xyz * r7.xyz;
  r10.xyz = cb1[4].www * r10.xyz;
  r0.x = saturate(dot(r3.xyw, -cb1[4].xyz));
  r9.xyz = r10.xyz * r0.xxx + r9.xyz;
  r0.x = t6.Sample(s0_s, r8.xy).x;
  r0.x = cmp(v1.z < r0.x);
  r0.x = r0.x ? 1.000000 : 0;
  r2.xy = r0.xx * r2.zw + r2.xy;
  r2.xyz = t0.Sample(s0_s, r2.xy).xyz;
  r0.x = -r4.w * 0.100000001 + 1;
  r0.x = r0.x * r6.w;
  r5.xyz = r6.xyz * r5.xyz + -r2.xyz;
  r2.xyz = r0.xxx * r5.xyz + r2.xyz;
  r5.xyz = r9.xyz + -r2.xyz;
  r2.xyz = r8.zzz * r5.xyz + r2.xyz;
  r1.xyw = cb1[0].xyz + -r1.xyz;
  r0.x = dot(r1.xyw, r1.xyw);
  r0.x = rsqrt(r0.x);
  r1.xyw = r1.xyw * r0.xxx;
  r0.x = saturate(dot(r1.xyw, r3.xyw));
  r0.x = log2(r0.x);
  r0.x = cb1[3].w * r0.x;
  r0.x = exp2(r0.x);
  r1.x = r4.z * r0.z + -0.800000012;
  r1.x = max(0, r1.x);
  r0.x = r1.x + r0.x;
  r1.xyw = cb1[3].xyz * r0.xxx;
  r1.xyw = r1.xyw * r4.www;
  r4.zw = float2(1.20000005,2.5) * r8.ww;
  r4.zw = float2(1,1) / r4.zw;
  r0.x = saturate(r4.z * r0.w);
  r2.w = r0.x * -2 + 3;
  r0.x = r0.x * r0.x;
  r4.z = r2.w * r0.x;
  r1.z = 1 + -r1.z;
  r1.z = r1.z * r0.w;
  r1.z = saturate(r1.z * r4.w);
  r4.w = r1.z * -2 + 3;
  r1.z = r1.z * r1.z;
  r1.z = -r4.w * r1.z + 1;
  r1.z = cb1[21].y * r1.z;
  r4.xy = -r4.xy * r0.zz + v4.xy;
  r4.xyw = t7.Sample(s7_s, r4.xy).xyz;
  r5.xy = r3.yx * float2(0.200000003,0.200000003) + v4.zw;
  r5.xyz = t7.Sample(s7_s, r5.xy).xyz;
  r4.xyw = r5.xyz + r4.xyw;
  r0.z = min(1, r3.z);
  r0.z = 1.10000002 + -r0.z;
  r0.z = r1.z * r0.z;
  r0.z = r0.z * r3.w;
  r2.xyz = r0.zzz * r4.xyw + r2.xyz;
  r0.w = saturate(-r0.w);
  r0.x = -r2.w * r0.x + 1;
  r0.x = r0.w * r0.x + r4.z;
  o0.w = r0.x * r0.y;
  r0.x = saturate(dot(cb1[0].xyz, r3.xyw));
  r0.x = cb1[32].z * r0.x;
  r0.xyz = cb1[2].xyz * r0.xxx;
  r0.xyz = r0.xyz * r7.xyz + r2.xyz;
  r0.xyz = cb1[32].www * r1.xyw + r0.xyz;
  r0.w = (uint)cb1[6].x;
  r0.w = (int)r0.w * 11;
  r1.x = dot(v1.xyz, v1.xyz);
  r1.z = dot(cb5[103].xyz, v1.xyz);
  r1.w = cmp(0 < r1.z);
  r2.x = max(cb5[r0.w+7].w, 0);
  r2.x = min(r2.x, r1.z);
  r2.xyz = -cb5[103].xyz * r2.xxx + v1.xyz;
  r1.z = max(-cb5[r0.w+7].w, r1.z);
  r1.z = min(0, r1.z);
  r3.xyz = -cb5[103].xyz * r1.zzz + v1.xyz;
  r2.xyz = r1.www ? r2.xyz : r3.xyz;
  r1.z = dot(r2.xyz, r2.xyz);
  r1.yz = sqrt(r1.xz);
  r1.w = -cb5[r0.w+0].w + r1.z;
  r1.w = -cb5[r0.w+0].x + r1.w;
  r1.w = max(0, r1.w);
  r2.x = cb5[r0.w+3].x * r1.w;
  r2.x = 1.44269502 * r2.x;
  r2.x = exp2(r2.x);
  r2.x = rcp(r2.x);
  r2.y = dot(cb5[r0.w+1].xyz, v1.xyz);
  r2.y = cb5[r0.w+1].w + r2.y;
  r2.y = saturate(cb5[r0.w+2].w * r2.y);
  r2.y = 1 + -r2.y;
  r2.z = r2.y * r2.y;
  r2.w = r2.z * r2.y;
  r2.z = cb5[r0.w+8].y * r2.z;
  r2.z = cb5[r0.w+8].x * r2.w + r2.z;
  r2.y = cb5[r0.w+8].z * r2.y + r2.z;
  r2.y = saturate(cb5[r0.w+8].w + r2.y);
  r2.y = 1 + -r2.y;
  r1.z = r1.z / cb5[r0.w+0].y;
  r1.w = cb5[r0.w+0].z * r1.w;
  r1.w = 1.44269502 * r1.w;
  r1.w = exp2(r1.w);
  r1.w = rcp(r1.w);
  r2.z = r2.x + -r1.w;
  r1.w = r2.y * r2.z + r1.w;
  r2.z = 1 + -r1.z;
  r2.z = saturate(1.42857146 * r2.z);
  r1.w = min(r2.z, r1.w);
  r2.z = r1.z * r1.z;
  r2.w = r2.z * r1.z;
  r2.z = cb5[r0.w+9].y * r2.z;
  r2.z = cb5[r0.w+9].x * r2.w + r2.z;
  r2.z = cb5[r0.w+9].z * r1.z + r2.z;
  r2.z = saturate(cb5[r0.w+9].w + r2.z);
  r2.z = 1 + -r2.z;
  r2.x = r2.x + -r2.z;
  r2.x = r2.y * r2.x + r2.z;
  r2.z = max(cb5[r0.w+10].y, 0.00100000005);
  r2.w = cb5[r0.w+10].x + -r2.z;
  r3.x = r2.w * r2.w;
  r3.y = r3.x * r2.w;
  r3.x = cb5[r0.w+9].y * r3.x;
  r3.x = cb5[r0.w+9].x * r3.y + r3.x;
  r3.x = cb5[r0.w+9].z * r2.w + r3.x;
  r3.x = saturate(cb5[r0.w+9].w + r3.x);
  r1.z = -r2.w + r1.z;
  r2.w = 1 + -r3.x;
  r2.w = r2.w * r1.z;
  r2.w = r2.w / r2.z;
  r2.w = r2.w + r3.x;
  r2.w = saturate(1 + -r2.w);
  r1.z = saturate(r1.z / r2.z);
  r2.z = r2.w + -r2.x;
  r1.z = r1.z * r2.z + r2.x;
  r1.z = min(r2.x, r1.z);
  r1.w = r1.w + -r1.z;
  r1.z = cb5[r0.w+10].z * r1.w + r1.z;
  r1.x = rsqrt(r1.x);
  r2.xzw = v1.xyz * r1.xxx;
  r1.x = r1.y / cb5[r0.w+5].w;
  r1.y = r1.x * r1.x;
  r1.y = saturate(r1.x * r1.y);
  r1.x = saturate(r1.x);
  r3.xyz = -cb5[r0.w+5].xyz + cb5[r0.w+3].yzw;
  r3.xyz = r1.xxx * r3.xyz + cb5[r0.w+5].xyz;
  r4.xyz = cb5[r0.w+3].yzw + -cb5[r0.w+2].xyz;
  r1.xyw = r1.yyy * r4.xyz + cb5[r0.w+2].xyz;
  r3.xyz = r3.xyz + -r1.xyw;
  r1.xyw = r2.yyy * r3.xyz + r1.xyw;
  r2.x = saturate(dot(r2.xzw, cb5[r0.w+7].xyz));
  r2.yzw = cb5[r0.w+4].yzw + -r1.xyw;
  r2.yzw = cb5[r0.w+6].xxx * r2.yzw;
  r2.x = saturate(-cb5[r0.w+4].x + r2.x);
  r3.x = cmp(0 < r2.x);
  r3.y = -cb5[r0.w+4].x + 1;
  r3.y = 1 / r3.y;
  r2.x = r3.y * r2.x;
  r3.y = r2.x * r2.x;
  r2.x = r3.y * r2.x;
  r2.xyz = r2.xxx * r2.yzw + r1.xyw;
  r1.xyw = r3.xxx ? r2.xyz : r1.xyw;
  r0.xyz = -r1.xyw + r0.xyz;
  r0.xyz = r1.zzz * r0.xyz + r1.xyw;
  r1.x = cmp(0 != cb1[7].w);
  if (r1.x != 0) {
    r1.xy = v0.xy * cb6[1].xy + cb6[1].zw;
    r0.w = saturate(v1.z / cb5[r0.w+0].y);
    r0.w = rsqrt(r0.w);
    r0.w = 1 / r0.w;
    r1.z = saturate(-0.00390625 + r0.w);
    r1.xyzw = t16.Sample(s13_s, r1.xyz).xyzw;
    r0.w = 1 + -r1.w;
    r1.w = min(cb5[102].x, 0);
    r2.xy = float2(1,1.00000095) + -r1.ww;
    r1.xyz = r2.xxx * r1.xyz;
    r0.w = log2(abs(r0.w));
    r0.w = r2.y * r0.w;
    r0.w = exp2(r0.w);
    o0.xyz = r0.xyz * r0.www + r1.xyz;
  } else {
    o0.xyz = r0.xyz;
  }
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16.45 on Thu Dec 10 22:20:18 2020
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float   xy
// TEXCOORD                 0   xyz         1     NONE   float   xyz
// TEXCOORD                 1   xyzw        2     NONE   float   xyzw
// TEXCOORD                 2   xyzw        3     NONE   float   xyzw
// TEXCOORD                 3   xyzw        4     NONE   float   xyzw
// TEXCOORD                 4   xyzw        5     NONE   float     zw
// TEXCOORD                 5   xyz         6     NONE   float   xyz
// TEXCOORD                 6   xyzw        7     NONE   float   xy w
// TEXCOORD                 7   xy          8     NONE   float   xy
// COLOR                    0   xyz         9     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 cb1[36], immediateIndexed
dcl_sampler s0, mode_default
dcl_sampler s1, mode_default
dcl_sampler s3, mode_default
dcl_sampler s4, mode_default
dcl_sampler s5, mode_default
dcl_sampler s6, mode_default
dcl_sampler s7, mode_default
dcl_sampler s13, mode_default
dcl_sampler s14, mode_default
dcl_sampler s15, 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) t3
dcl_resource_texture2d (float,float,float,float) t4
dcl_resource_texture2d (float,float,float,float) t5
dcl_resource_texture2d (float,float,float,float) t6
dcl_resource_texture2d (float,float,float,float) t7
dcl_resource_texture2d (float,float,float,float) t14
dcl_resource_texture2d (float,float,float,float) t15
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 v2.xyzw
dcl_input_ps linear v3.xyzw
dcl_input_ps linear v4.xyzw
dcl_input_ps linear centroid v5.zw
dcl_input_ps linear v6.xyz
dcl_input_ps linear v7.xyw
dcl_input_ps linear v8.xy
dcl_input_ps linear v9.xyz
dcl_output o0.xyzw
dcl_temps 12
sample_indexable(texture2d)(float,float,float,float) r0.x, v5.zwzz, t14.xyzw, s14
sample_indexable(texture2d)(float,float,float,float) r0.y, v5.zwzz, t15.yxzw, s15
dp3 r0.z, v6.xyzx, v6.xyzx
sqrt r0.z, r0.z
div r1.xyz, v6.xyzx, r0.zzzz
div r2.xy, v7.xyxx, v7.wwww
mad r2.xy, r2.xyxx, cb1[31].xyxx, cb1[31].zwzz
sample_indexable(texture2d)(float,float,float,float) r0.w, r2.xyxx, t6.yzwx, s6
add r0.w, r0.w, -v1.z
div r1.w, r0.w, v1.z
sample_indexable(texture2d)(float,float,float,float) r2.zw, v2.xyxx, t5.zwxy, s5
sample_indexable(texture2d)(float,float,float,float) r3.xy, v2.zwzz, t5.xyzw, s5
add r2.zw, r2.zzzw, r3.xxxy
add r2.zw, r2.zzzw, l(0.000000, 0.000000, -1.000000, -1.000000)
sample_indexable(texture2d)(float,float,float,float) r3.xy, v3.xyxx, t5.xyzw, s5
sample_indexable(texture2d)(float,float,float,float) r3.zw, v3.zwzz, t5.zwxy, s5
add r3.xy, r3.zwzz, r3.xyxx
add r3.xy, r3.xyxx, l(-1.000000, -1.000000, 0.000000, 0.000000)
mul r3.xy, r3.xyxx, l(1.400000, 1.400000, 0.000000, 0.000000)
mul r3.z, r0.z, l(0.00666666683)
mad r0.z, r0.z, l(0.001000), l(0.200000)
min r0.z, r0.z, l(1.000000)
mad r2.zw, r2.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), -r3.xxxy
mad r2.zw, r0.zzzz, r2.zzzw, r3.xxxy
mul r4.xy, r2.zwzz, cb1[28].wwww
mov r4.z, l(1.000000)
dp3 r0.z, r4.xyzx, r4.xyzx
rsq r0.z, r0.z
mul r2.zw, r0.zzzz, r4.xxxy
mad r3.xy, r2.zwzz, l(0.020000, 0.020000, 0.000000, 0.000000), l(0.000001, 0.000001, 0.000000, 0.000000)
add r3.xy, -r3.xyxx, v8.xyxx
sample_indexable(texture2d)(float,float,float,float) r4.xy, r3.xyxx, t4.xyzw, s4
mov r5.xw, cb1[33].xxxy
mov r5.yz, l(0,0,0,0)
add r5.xyzw, r3.xyxy, r5.xyzw
sample_indexable(texture2d)(float,float,float,float) r4.zw, r5.xyxx, t4.zwxy, s4
sample_indexable(texture2d)(float,float,float,float) r5.xy, r5.zwzz, t4.xyzw, s4
add r0.z, -r4.y, r4.x
mad r0.z, cb1[35].x, r0.z, r4.y
add r3.w, -r4.w, r4.z
mad r3.w, cb1[35].x, r3.w, r4.w
add r4.x, -r5.y, r5.x
mad r4.x, cb1[35].x, r4.x, r5.y
add r5.x, -r0.z, r3.w
mov r5.yz, l(0,1.000000,1.000000,0)
dp2 r3.w, r5.xyxx, r5.xyxx
rsq r3.w, r3.w
mul r4.yz, r3.wwww, r5.xxyx
add r5.w, -r0.z, r4.x
dp2 r0.z, r5.zwzz, r5.zwzz
rsq r0.z, r0.z
mul r4.xw, r0.zzzz, r5.zzzw
mad r3.xy, r3.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
max r0.z, |r3.y|, |r3.x|
add r3.xy, -cb1[33].xyxx, l(1.000000, 1.000000, 0.000000, 0.000000)
lt r3.xy, r0.zzzz, r3.xyxx
and r3.xy, r3.xyxx, cb1[28].zzzz
mul r4.xy, r4.xwxx, r4.yzyy
mad r2.zw, r4.xxxy, r3.xxxy, r2.zzzw
mul r4.xy, r2.zwzz, cb1[28].yyyy
mov r4.z, l(1.000000)
dp3 r0.z, r4.xyzx, r4.xyzx
rsq r0.z, r0.z
mul r3.xyw, r0.zzzz, r4.xyxz
dp3_sat r2.z, -r1.xyzx, r3.xywx
add r2.z, -r2.z, l(1.000000)
mul r4.w, r2.z, r2.z
mov_sat r5.x, cb1[0].z
mad r5.xyz, cb1[2].xyzx, r5.xxxx, cb1[1].xyzx
mul r5.xyz, r5.xyzx, v9.xyzx
mul r5.w, r0.x, r0.x
mad r6.x, cb1[8].y, r0.x, cb1[8].x
mul r0.x, r0.x, r5.w
mad r5.w, r5.w, cb1[8].z, r6.x
mad_sat r0.x, r0.x, cb1[8].w, r5.w
mul r2.w, r2.w, l(0.100000)
mad r0.x, r0.x, cb1[21].w, |r2.w|
add r6.xyzw, -cb1[17].xyzw, cb1[18].xyzw
mad r6.xyzw, r0.xxxx, r6.xyzw, cb1[17].xyzw
mul r7.xyz, r5.xyzx, r6.xyzx
mul r8.xy, r3.xyxx, l(0.100000, 0.100000, 0.000000, 0.000000)
mul r0.x, r1.w, l(100.000000)
mad r1.w, -r2.z, r2.z, l(1.200000)
mul_sat r0.x, r0.x, r1.w
mul r2.zw, r0.xxxx, r8.xxxy
mad r8.xy, r8.xyxx, r0.xxxx, r2.xyxx
mad r8.zw, r4.wwww, l(0.000000, 0.000000, 0.500000, 0.500000), l(0.000000, 0.000000, 0.100000, 0.200000)
dp3 r0.x, r1.xyzx, r3.xywx
mul r9.xy, r3.xyxx, l(-1.000000, -1.000000, 0.000000, 0.000000)
mov r9.z, l(0)
add r1.w, r0.x, l(1.000000)
mad_sat r1.w, r1.w, l(0.450000018), l(0.100000)
add r9.xyz, -r1.xyzx, r9.xyzx
mad r9.xyz, r1.wwww, r9.xyzx, r1.xyzx
add r0.x, r0.x, r0.x
mad r10.xyz, r3.xywx, -r0.xxxx, r1.xyzx
mad r10.xyw, r10.xyxz, l(128.000000, 128.000000, 0.000000, 128.000000), v6.xyxz
mul r11.xyz, r10.yyyy, cb1[14].xywx
mad r11.xyz, r10.xxxx, cb1[13].xywx, r11.xyzx
mad r10.xyw, r10.wwww, cb1[15].xyxw, r11.xyxz
add r10.xyw, r10.xyxw, cb1[16].xyxw
div r10.xy, r10.xyxx, r10.wwww
mad r11.xy, r10.xyxx, cb1[31].xyxx, cb1[31].zwzz
sample_indexable(texture2d)(float,float,float,float) r11.xyz, r11.xyxx, t3.xyzw, s3
mad r0.x, -r10.z, r10.z, l(0.750000)
max r0.x, r0.x, l(0.000000)
mul r0.x, r0.x, l(1.33333337)
mul r10.xy, r10.xyxx, r10.xyxx
mad r10.xy, -r10.yxyy, r10.yxyy, l(1.000000, 1.000000, 0.000000, 0.000000)
max r1.w, r10.y, l(0.000000)
mov_sat r10.x, r10.x
mul r1.w, r1.w, r10.x
mul r0.x, r0.x, r1.w
mad r9.xyz, r9.xyzx, l(20.000000, 20.000000, 20.000000, 0.000000), v6.xyzx
mul r10.xyz, r9.yyyy, cb1[14].xywx
mad r9.xyw, r9.xxxx, cb1[13].xyxw, r10.xyxz
mad r9.xyz, r9.zzzz, cb1[15].xywx, r9.xywx
add r9.xyz, r9.xyzx, cb1[16].xywx
mov r9.w, -r9.y
div r9.xy, r9.xwxx, r9.zzzz
add r9.xy, r9.xyxx, l(1.000000, 1.000000, 0.000000, 0.000000)
mul r9.xy, r9.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000)
sample_indexable(texture2d)(float,float,float,float) r9.xyz, r9.xyxx, t1.xyzw, s1
add r10.xyz, -r9.xyzx, r11.xyzx
mad r9.xyz, r0.xxxx, r10.xyzx, r9.xyzx
mad r10.xyz, r6.xyzx, r5.xyzx, -r9.xyzx
mad r9.xyz, r10.xyzx, l(0.600000, 0.600000, 0.600000, 0.000000), r9.xyzx
mul r10.xyz, r7.xyzx, cb1[5].xyzx
mul r10.xyz, r10.xyzx, cb1[4].wwww
dp3_sat r0.x, r3.xywx, -cb1[4].xyzx
mad r9.xyz, r10.xyzx, r0.xxxx, r9.xyzx
sample_indexable(texture2d)(float,float,float,float) r0.x, r8.xyxx, t6.xyzw, s0
lt r0.x, v1.z, r0.x
and r0.x, r0.x, l(0x3f800000)
mad r2.xy, r0.xxxx, r2.zwzz, r2.xyxx
sample_indexable(texture2d)(float,float,float,float) r2.xyz, r2.xyxx, t0.xyzw, s0
mad r0.x, -r4.w, l(0.100000), l(1.000000)
mul r0.x, r6.w, r0.x
mad r5.xyz, r6.xyzx, r5.xyzx, -r2.xyzx
mad r2.xyz, r0.xxxx, r5.xyzx, r2.xyzx
add r5.xyz, -r2.xyzx, r9.xyzx
mad r2.xyz, r8.zzzz, r5.xyzx, r2.xyzx
add r1.xyw, -r1.xyxz, cb1[0].xyxz
dp3 r0.x, r1.xywx, r1.xywx
rsq r0.x, r0.x
mul r1.xyw, r0.xxxx, r1.xyxw
dp3_sat r0.x, r1.xywx, r3.xywx
log r0.x, r0.x
mul r0.x, r0.x, cb1[3].w
exp r0.x, r0.x
mad r1.x, r4.z, r0.z, l(-0.800000)
max r1.x, r1.x, l(0.000000)
add r0.x, r0.x, r1.x
mul r1.xyw, r0.xxxx, cb1[3].xyxz
mul r1.xyw, r4.wwww, r1.xyxw
mul r4.zw, r8.wwww, l(0.000000, 0.000000, 1.200000, 2.500000)
div r4.zw, l(1.000000, 1.000000, 1.000000, 1.000000), r4.zzzw
mul_sat r0.x, r0.w, r4.z
mad r2.w, r0.x, l(-2.000000), l(3.000000)
mul r0.x, r0.x, r0.x
mul r4.z, r0.x, r2.w
add r1.z, -r1.z, l(1.000000)
mul r1.z, r0.w, r1.z
mul_sat r1.z, r4.w, r1.z
mad r4.w, r1.z, l(-2.000000), l(3.000000)
mul r1.z, r1.z, r1.z
mad r1.z, -r4.w, r1.z, l(1.000000)
mul r1.z, r1.z, cb1[21].y
mad r4.xy, -r4.xyxx, r0.zzzz, v4.xyxx
sample_indexable(texture2d)(float,float,float,float) r4.xyw, r4.xyxx, t7.xywz, s7
mad r5.xy, r3.yxyy, l(0.200000, 0.200000, 0.000000, 0.000000), v4.zwzz
sample_indexable(texture2d)(float,float,float,float) r5.xyz, r5.xyxx, t7.xyzw, s7
add r4.xyw, r4.xyxw, r5.xyxz
min r0.z, r3.z, l(1.000000)
add r0.z, -r0.z, l(1.100000)
mul r0.z, r0.z, r1.z
mul r0.z, r3.w, r0.z
mad r2.xyz, r0.zzzz, r4.xywx, r2.xyzx
mov_sat r0.w, -r0.w
mad r0.x, -r2.w, r0.x, l(1.000000)
mad r0.x, r0.w, r0.x, r4.z
mul o0.w, r0.y, r0.x
dp3_sat r0.x, cb1[0].xyzx, r3.xywx
mul r0.x, r0.x, cb1[32].z
mul r0.xyz, r0.xxxx, cb1[2].xyzx
mad r0.xyz, r0.xyzx, r7.xyzx, r2.xyzx
mad r0.xyz, cb1[32].wwww, r1.xywx, r0.xyzx
ftou r0.w, cb1[6].x
imul null, r0.w, r0.w, l(11)
dp3 r1.x, v1.xyzx, v1.xyzx
dp3 r1.z, cb5[103].xyzx, v1.xyzx
lt r1.w, l(0.000000), r1.z
max r2.x, l(0.000000), cb5[r0.w + 7].w
min r2.x, r1.z, r2.x
mad r2.xyz, -cb5[103].xyzx, r2.xxxx, v1.xyzx
max r1.z, r1.z, -cb5[r0.w + 7].w
min r1.z, r1.z, l(0.000000)
mad r3.xyz, -cb5[103].xyzx, r1.zzzz, v1.xyzx
movc r2.xyz, r1.wwww, r2.xyzx, r3.xyzx
dp3 r1.z, r2.xyzx, r2.xyzx
sqrt r1.yz, r1.xxzx
add r1.w, r1.z, -cb5[r0.w + 0].w
add r1.w, r1.w, -cb5[r0.w + 0].x
max r1.w, r1.w, l(0.000000)
mul r2.x, r1.w, cb5[r0.w + 3].x
mul r2.x, r2.x, l(1.442695)
exp r2.x, r2.x
rcp r2.x, r2.x
dp3 r2.y, cb5[r0.w + 1].xyzx, v1.xyzx
add r2.y, r2.y, cb5[r0.w + 1].w
mul_sat r2.y, r2.y, cb5[r0.w + 2].w
add r2.y, -r2.y, l(1.000000)
mul r2.z, r2.y, r2.y
mul r2.w, r2.y, r2.z
mul r2.z, r2.z, cb5[r0.w + 8].y
mad r2.z, cb5[r0.w + 8].x, r2.w, r2.z
mad r2.y, cb5[r0.w + 8].z, r2.y, r2.z
add_sat r2.y, r2.y, cb5[r0.w + 8].w
add r2.y, -r2.y, l(1.000000)
div r1.z, r1.z, cb5[r0.w + 0].y
mul r1.w, r1.w, cb5[r0.w + 0].z
mul r1.w, r1.w, l(1.442695)
exp r1.w, r1.w
rcp r1.w, r1.w
add r2.z, -r1.w, r2.x
mad r1.w, r2.y, r2.z, r1.w
add r2.z, -r1.z, l(1.000000)
mul_sat r2.z, r2.z, l(1.42857146)
min r1.w, r1.w, r2.z
mul r2.z, r1.z, r1.z
mul r2.w, r1.z, r2.z
mul r2.z, r2.z, cb5[r0.w + 9].y
mad r2.z, cb5[r0.w + 9].x, r2.w, r2.z
mad r2.z, cb5[r0.w + 9].z, r1.z, r2.z
add_sat r2.z, r2.z, cb5[r0.w + 9].w
add r2.z, -r2.z, l(1.000000)
add r2.x, -r2.z, r2.x
mad r2.x, r2.y, r2.x, r2.z
max r2.z, l(0.001000), cb5[r0.w + 10].y
add r2.w, -r2.z, cb5[r0.w + 10].x
mul r3.x, r2.w, r2.w
mul r3.y, r2.w, r3.x
mul r3.x, r3.x, cb5[r0.w + 9].y
mad r3.x, cb5[r0.w + 9].x, r3.y, r3.x
mad r3.x, cb5[r0.w + 9].z, r2.w, r3.x
add_sat r3.x, r3.x, cb5[r0.w + 9].w
add r1.z, r1.z, -r2.w
add r2.w, -r3.x, l(1.000000)
mul r2.w, r1.z, r2.w
div r2.w, r2.w, r2.z
add r2.w, r3.x, r2.w
add_sat r2.w, -r2.w, l(1.000000)
div_sat r1.z, r1.z, r2.z
add r2.z, -r2.x, r2.w
mad r1.z, r1.z, r2.z, r2.x
min r1.z, r1.z, r2.x
add r1.w, -r1.z, r1.w
mad r1.z, cb5[r0.w + 10].z, r1.w, r1.z
rsq r1.x, r1.x
mul r2.xzw, r1.xxxx, v1.xxyz
div r1.x, r1.y, cb5[r0.w + 5].w
mul r1.y, r1.x, r1.x
mul_sat r1.y, r1.y, r1.x
mov_sat r1.x, r1.x
add r3.xyz, cb5[r0.w + 3].yzwy, -cb5[r0.w + 5].xyzx
mad r3.xyz, r1.xxxx, r3.xyzx, cb5[r0.w + 5].xyzx
add r4.xyz, -cb5[r0.w + 2].xyzx, cb5[r0.w + 3].yzwy
mad r1.xyw, r1.yyyy, r4.xyxz, cb5[r0.w + 2].xyxz
add r3.xyz, -r1.xywx, r3.xyzx
mad r1.xyw, r2.yyyy, r3.xyxz, r1.xyxw
dp3_sat r2.x, r2.xzwx, cb5[r0.w + 7].xyzx
add r2.yzw, -r1.xxyw, cb5[r0.w + 4].yyzw
mul r2.yzw, r2.yyzw, cb5[r0.w + 6].xxxx
add_sat r2.x, r2.x, -cb5[r0.w + 4].x
lt r3.x, l(0.000000), r2.x
add r3.y, l(1.000000), -cb5[r0.w + 4].x
div r3.y, l(1.000000, 1.000000, 1.000000, 1.000000), r3.y
mul r2.x, r2.x, r3.y
mul r3.y, r2.x, r2.x
mul r2.x, r2.x, r3.y
mad r2.xyz, r2.xxxx, r2.yzwy, r1.xywx
movc r1.xyw, r3.xxxx, r2.xyxz, r1.xyxw
add r0.xyz, r0.xyzx, -r1.xywx
mad r0.xyz, r1.zzzz, r0.xyzx, r1.xywx
ne r1.x, l(0.000000, 0.000000, 0.000000, 0.000000), cb1[7].w
if_nz r1.x
  mad r1.xy, v0.xyxx, cb6[1].xyxx, cb6[1].zwzz
  div_sat r0.w, v1.z, cb5[r0.w + 0].y
  rsq r0.w, r0.w
  div r0.w, l(1.000000, 1.000000, 1.000000, 1.000000), r0.w
  add_sat r1.z, r0.w, l(-0.00390625000)
  sample_indexable(texture3d)(float,float,float,float) r1.xyzw, r1.xyzx, t16.xyzw, s13
  add r0.w, -r1.w, l(1.000000)
  min r1.w, l(0.000000), 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.w, |r0.w|
  mul r0.w, r0.w, r2.y
  exp r0.w, r0.w
  mad o0.xyz, r0.xyzx, r0.wwww, r1.xyzx
else
  mov o0.xyz, r0.xyzx
endif
ret
// Approximately 0 instruction slots used

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