//this shader was fixed because it blacked out char in load screen.
// ---- Created with 3Dmigoto v1.3.16.45 on Wed Dec 23 02:15:38 2020
 Texture3D<float4> t16 : register(t16);

 Texture2D<float4> t11 : register(t11);

 Texture2D<float4> t1 : register(t1);

 Texture2D<float4> t0 : register(t0);

 SamplerState s13_s : register(s13);

 SamplerState s11_s : register(s11);

 SamplerState s1_s : register(s1);

 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 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,
   out float4 o0 : SV_TARGET0)
 {
   float4 r0,r1,r2,r3,r4,r5;
   uint4 bitmask, uiDest;
   float4 fDest;
   
float4 newv4;
newv4.xy=v4.xy;
newv4.zw=w4.xy;   
   

   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;
   r2.xy = r0.zw * float2(0.5,0.5) + float2(0.5,0.5);
   r0.zw = cmp(cb0[4].yy == float2(1,2));
   r2.zw = v4.xy;
   r3.xyzw = r0.wwww ? r2.zwxy : r2.xyxy;
   r2.zw = w4.xy;
   r2.xyzw = r0.zzzz ? r2.xyzw : r3.xyzw;
   
r2.xyzw = r0.xxxx ? r2.xyzw : newv4.xyzw;   
   
//r2.xyzw = r0.xxxx ? r2.xyzw : v4.xyzw;
   r3.xyzw = t0.Sample(s0_s, r2.xy).xyzw;
   r0.xzw = t1.Sample(s1_s, r2.zw).xyz;
   r0.xzw = r3.xyz * r0.xzw;
   r2.xyz = r0.xzw + r0.xzw;
   r0.xzw = -r0.xzw * float3(2,2,2) + r3.xyz;
   r0.xzw = r3.www * r0.xzw + r2.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.x = dot(r2.xyz, cb8[5].xyz);
   r2.yz = v0.xy * cb5[99].xy + cb5[99].zw;
   r2.yzw = t11.Sample(s11_s, r2.yz).xyz;
   r3.xyz = v1.xyz * r0.xzw;
   r3.xyz = r3.xyz + r3.xyz;
   r3.w = cmp(r2.x >= 0);
   r4.xyz = -cb8[1].xyz + cb8[0].xyz;
   r4.xyz = r2.xxx * r4.xyz + cb8[1].xyz;
   r5.xyz = cb8[2].xyz + -cb8[1].xyz;
   r5.xyz = -r2.xxx * r5.xyz + cb8[1].xyz;
   r4.xyz = r3.www ? r4.xyz : r5.xyz;
   r1.w = r1.w * 0.5 + 0.5;
   r5.xyz = r4.xyz * r1.www;
   r5.xyz = float3(0.400000036,0.400000036,0.400000036) * r5.xyz;
   r4.xyz = r4.xyz * float3(0.699999988,0.699999988,0.699999988) + r5.xyz;
   r1.w = saturate(dot(v3.xyz, -cb8[3].xyz));
   r4.xyz = cb8[4].xyz * r1.www + r4.xyz;
   r4.xyz = r4.xyz * r3.xyz;
   r3.xyz = r3.xyz * r3.xyz;
   r2.xyz = r3.xyz * r2.yzw;
   r1.w = 1 + -v2.w;
   r1.w = r1.w * r1.w;
   r3.xyz = cb7[1].xyz * r0.xzw;
   r3.xyz = cb7[0].www * r3.xyz;
   r2.w = dot(v3.xyz, cb7[0].xyz);
   r3.w = saturate(r2.w);
   r3.xyz = r3.xyz * r3.www;
   r4.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.xzw = r2.www * r0.xzw;
   r0.xzw = cb7[1].xyz * r0.xzw;
   r5.xyz = -cb7[0].www * r0.xzw;
   r3.w = v1.w;
   r3.xyzw = r4.wwww ? r5.xyzw : r3.xyzw;
   r5.xyz = r3.xyz * r1.www;
   r0.x = r1.w * r3.w + -v1.w;
   r0.x = r1.w * r0.x + v1.w;
   r2.xyz = r4.xyz * r4.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.xzw = cb0[15].xyz * r2.xyz;
     r1.w = saturate(dot(r4.xyz, float3(0.300000012,0.589999974,0.109999999)));
     r1.w = 1 + -r1.w;
     r1.w = sqrt(r1.w);
     r0.xzw = r1.www * r0.xzw;
     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.xzw = r0.xzw * float3(3,3,3) + -r2.xyz;
     r2.xyz = r1.www * r0.xzw + 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.xzw = r0.xxx + -r2.xyz;
     r2.xyz = cb0[16].www * r0.xzw + r2.xyz;
   }
   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);
   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.yw = sqrt(r0.yw);
   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.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.xzw = -cb5[r0.z+5].xyz + cb5[r0.z+3].yzw;
   r3.xzw = r0.yyy * r3.xzw + 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.xzw = -r4.xyz + r3.xzw;
   r3.xyz = r3.yyy * r3.xzw + 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;
   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.xyz = cb0[1].www * r0.xyz;
     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;
   return;
 }


/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16.45 on Wed Dec 23 02:15:38 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     zw
//
//
// 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[6], immediateIndexed
dcl_constantbuffer cb0[17], immediateIndexed
dcl_sampler s0, mode_default
dcl_sampler s1, mode_default
dcl_sampler s11, 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) t11
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 v4.zw
dcl_output o0.xyzw
dcl_temps 6
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 r2.xy, r0.zwzz, l(0.500000, 0.500000, 0.000000, 0.000000), l(0.500000, 0.500000, 0.000000, 0.000000)
eq r0.zw, cb0[4].yyyy, l(0.000000, 0.000000, 1.000000, 2.000000)
mov r2.zw, v4.xxxy
movc r3.xyzw, r0.wwww, r2.zwxy, r2.xyxy
mov r2.zw, v4.zzzw
movc r2.xyzw, r0.zzzz, r2.xyzw, r3.xyzw
movc r2.xyzw, r0.xxxx, r2.xyzw, v4.xyzw
sample_indexable(texture2d)(float,float,float,float) r3.xyzw, r2.xyxx, t0.xyzw, s0
sample_indexable(texture2d)(float,float,float,float) r0.xzw, r2.zwzz, t1.xwyz, s1
mul r0.xzw, r0.xxzw, r3.xxyz
add r2.xyz, r0.xzwx, r0.xzwx
mad r0.xzw, -r0.xxzw, l(2.000000, 0.000000, 2.000000, 2.000000), r3.xxyz
mad r0.xzw, r3.wwww, r0.xxzw, r2.xxyz
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.x, r2.xyzx, cb8[5].xyzx
mad r2.yz, v0.xxyx, cb5[99].xxyx, cb5[99].zzwz
sample_indexable(texture2d)(float,float,float,float) r2.yzw, r2.yzyy, t11.wxyz, s11
mul r3.xyz, r0.xzwx, v1.xyzx
add r3.xyz, r3.xyzx, r3.xyzx
ge r3.w, r2.x, l(0.000000)
add r4.xyz, cb8[0].xyzx, -cb8[1].xyzx
mad r4.xyz, r2.xxxx, r4.xyzx, cb8[1].xyzx
add r5.xyz, -cb8[1].xyzx, cb8[2].xyzx
mad r5.xyz, -r2.xxxx, r5.xyzx, cb8[1].xyzx
movc r4.xyz, r3.wwww, r4.xyzx, r5.xyzx
mad r1.w, r1.w, l(0.500000), l(0.500000)
mul r5.xyz, r1.wwww, r4.xyzx
mul r5.xyz, r5.xyzx, l(0.400000036, 0.400000036, 0.400000036, 0.000000)
mad r4.xyz, r4.xyzx, l(0.700000, 0.700000, 0.700000, 0.000000), r5.xyzx
dp3_sat r1.w, v3.xyzx, -cb8[3].xyzx
mad r4.xyz, cb8[4].xyzx, r1.wwww, r4.xyzx
mul r4.xyz, r3.xyzx, r4.xyzx
mul r3.xyz, r3.xyzx, r3.xyzx
mul r2.xyz, r2.yzwy, r3.xyzx
add r1.w, -v2.w, l(1.000000)
mul r1.w, r1.w, r1.w
mul r3.xyz, r0.xzwx, cb7[1].xyzx
mul r3.xyz, r3.xyzx, cb7[0].wwww
dp3 r2.w, v3.xyzx, cb7[0].xyzx
mov_sat r3.w, r2.w
mul r3.xyz, r3.wwww, r3.xyzx
lt r4.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.xzw, r0.xxzw, r2.wwww
mul r0.xzw, r0.xxzw, cb7[1].xxyz
mul r5.xyz, r0.xzwx, -cb7[0].wwww
mov r3.w, v1.w
movc r3.xyzw, r4.wwww, r5.xyzw, r3.xyzw
mul r5.xyz, r1.wwww, r3.xyzx
mad r0.x, r1.w, r3.w, -v1.w
mad r0.x, r1.w, r0.x, v1.w
mad r2.xyz, r4.xyzx, r4.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.xzw, r2.xxyz, cb0[15].xxyz
  dp3_sat r1.w, r4.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 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.xzw, r0.xxzw, l(3.000000, 0.000000, 3.000000, 3.000000), -r2.xxyz
  mad r2.xyz, r1.wwww, r0.xzwx, 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.xzw, -r2.xxyz, r0.xxxx
  mad r2.xyz, cb0[16].wwww, r0.xzwx, r2.xyzx
endif
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 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.yw, r0.yyyw
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.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.xzw, cb5[r0.z + 3].yyzw, -cb5[r0.z + 5].xxyz
mad r3.xzw, r0.yyyy, r3.xxzw, 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.xzw, r3.xxzw, -r4.xxyz
mad r3.xyz, r3.yyyy, r3.xzwx, 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 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
  mul r0.xyz, r0.xyzx, cb0[1].wwww
  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
  else
mov o0.xyzw, r2.xyzw
ret  
endif
// Approximately 0 instruction slots used

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