// ---- Created with 3Dmigoto v1.3.16 on Sat Sep 14 02:44:48 2024
Texture2DArray<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> t2 : register(t2);

struct t1_t {
  float val[20];
};
StructuredBuffer<t1_t> t1 : register(t1);

Texture2DArray<float4> t0 : register(t0);

SamplerComparisonState s1_s : register(s1);

SamplerState s0_s : register(s0);

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

cbuffer cb3 : register(b3)
{
  float4 cb3[39];
}

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

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

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




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


void main(
  float4 v0 : TEXCOORD0,
  float4 v1 : TEXCOORD1,
  float4 v2 : TEXCOORD2,
  float4 v3 : TEXCOORD3,
  float4 v4 : TEXCOORD4,
  float4 v5 : TEXCOORD5,
  float4 v6 : TXCOORDD6,
  float4 v7 : TEXCOORD7,
  float4 v8 : TEXCOORD8,
  float3 v9 : TEXCOORD9,
  float4 v10 : SV_POSITION0,
  uint v11 : SV_IsFrontFace0,
  out float4 o0 : SV_Target0,
  out float4 o1 : SV_Target1,
  out float4 o2 : SV_Target2,
  out float4 o3 : SV_Target3)
{
  float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11,r12,r13,r14,r15,r16;
  uint4 bitmask, uiDest;
  float4 fDest;

  r0.x = v11.x ? 1 : -1;
  r0.y = cmp(0.5 < cb1[28].y);
  r0.zw = v5.xy / v5.ww;
  r1.xy = v6.xy / v6.ww;
  r1.xy = -r1.xy + r0.zw;
  r0.zw = float2(0.5,-0.5) * r1.xy;
  r0.zw = sqrt(abs(r0.zw));
  r1.z = -r1.y;
  r1.yw = cmp(float2(0,0) < r1.xz);
  r1.xz = cmp(r1.xz < float2(0,0));
  r1.xy = (int2)-r1.yw + (int2)r1.xz;
  r1.xy = (int2)r1.xy;
  r0.zw = r1.xy * r0.zw;
  r0.zw = r0.zw * float2(0.5,0.5) + float2(0.498039216,0.498039216);
  o2.xy = r0.yy ? r0.zw : float2(0.497999996,0.497999996);
  r0.y = cmp(0.5 < cb4[90].x);
  o2.z = r0.y ? 1.000000 : 0;
  r0.yz = cmp(float2(0.5,0.5) < cb4[89].zw);
  r0.w = cmp((int)v11.x == 0);
  r0.y = r0.w ? r0.y : 0;
  r0.w = cmp(1 < v0.z);
  r0.z = r0.w ? r0.z : 0;
  r0.z = (int)r0.z | (int)r0.y;
  r0.zw = r0.zz ? v0.zw : v0.xy;
  r1.xyz = t3.SampleBias(s0_s, r0.zw, cb0[163].y).xyz;
  r2.xyz = cb4[29].xyz * r1.xyz;
  r0.yz = r0.yy ? v0.zw : v0.xy;
  r3.xyz = t4.SampleBias(s0_s, r0.yz, cb0[163].y).xyz;
  r3.xyz = r3.xyz * float3(2,2,2) + float3(-1.00399995,-1.00399995,-1);
  r3.xy = cb4[80].zz * r3.xy;
  r0.w = dot(r3.xy, r3.xy);
  r0.w = min(1, r0.w);
  r0.w = 1 + -r0.w;
  r0.w = sqrt(r0.w);
  r0.x = r0.w * r0.x;
  r4.xyz = v4.xyz * r3.yyy;
  r3.xyw = r3.xxx * v3.xyz + r4.xyz;
  r3.xyw = r0.xxx * v2.xyz + r3.xyw;
  r0.x = dot(r3.xyw, r3.xyw);
  r0.x = rsqrt(r0.x);
  r3.xyw = r3.xyw * r0.xxx;
  r4.xyz = t5.SampleBias(s0_s, r0.yz, cb0[163].y).zxy;
  r0.x = cb4[80].w * r4.z;
  r0.yz = t6.SampleBias(s0_s, r0.yz, cb0[163].y).zy;
  r0.w = cmp(0.5 < cb4[78].z);
  if (r0.w != 0) {
    r5.xy = cmp(float2(0.5,0.5) < cb4[87].xy);
    r0.w = r5.y ? r5.x : 0;
    r1.w = -0.200000003 + r0.y;
    r1.w = saturate(1.25 * r1.w);
    r0.w = r0.w ? r1.w : r0.y;
    r0.y = r5.x ? r0.w : 0;
  }
  r0.w = cmp(0.5 < cb4[80].x);
  r5.xy = cb4[80].yy * v0.xy;
  r5.xyz = t2.SampleBias(s0_s, r5.xy, cb0[163].y).xyz;
  r1.xyz = r1.xyz * cb4[29].xyz + r5.xyz;
  r1.xyz = float3(-0.5,-0.5,-0.5) + r1.xyz;
  r1.xyz = max(float3(0,0,0), r1.xyz);
  r1.xyz = r0.www ? r1.xyz : r2.xyz;
  r2.x = v2.w;
  r2.y = v3.w;
  r2.z = v4.w;
  r5.xyz = cb0[40].yzw + -r2.xyz;
  r0.w = dot(r5.xyz, r5.xyz);
  r1.w = max(1.17549435e-38, r0.w);
  r1.w = rsqrt(r1.w);
  r6.xyz = r5.xyz * r1.www;
  r2.w = cmp(0 < asint(cb0[160].x));
  if (r2.w != 0) {
    r4.w = (int)cb3[2].z;
    r5.w = asint(cb0[160].x) + -1;
    r4.w = min((int)r5.w, (int)r4.w);
    r4.w = max(0, (int)r4.w);
    r7.x = t1[r4.w].val[0/4+3];
    r7.y = t1[r4.w].val[0/4];
    r7.z = t1[r4.w].val[0/4+1];
    r7.w = t1[r4.w].val[0/4+2];
    r8.x = t1[r4.w].val[16/4];
    r8.y = t1[r4.w].val[16/4+1];
    r8.z = t1[r4.w].val[16/4+2];
    r8.w = t1[r4.w].val[16/4+3];
    r4.w = t1[r4.w].val[32/4];
    r9.xyz = r7.yzw;
    r7.y = r8.w;
  } else {
    r9.xyz = float3(0,0,0);
    r7.xy = float2(0,0);
    r4.w = 0;
    r8.xyz = float3(0,0,0);
  }
  r8.xyz = r8.xyz + -r2.xyz;
  r5.w = dot(r8.xyz, r8.xyz);
  r5.w = max(1.17549435e-38, r5.w);
  r6.w = rsqrt(r5.w);
  r8.xyz = r8.xyz * r6.www;
  r6.w = r7.x * r7.x;
  r5.w = r5.w / r6.w;
  r5.w = 1 + -r5.w;
  r5.w = max(0, r5.w);
  r7.xzw = -cb0[161].xyz + r9.xyz;
  r7.xzw = r5.www * r7.xzw + cb0[161].xyz;
  r6.w = -1 + r5.w;
  r5.w = r5.w * r6.w + 1;
  r6.w = cmp(0.5 < cb0[13].x);
  if (r6.w != 0) {
    r9.xyzw = cmp(r4.yyyy < float4(0.200000003,0.400000006,0.600000024,0.800000012));
    r6.w = r9.w ? cb4[91].z : cb4[91].y;
    r6.w = r9.z ? cb4[91].w : r6.w;
    r6.w = r9.y ? cb4[92].x : r6.w;
    r6.w = r9.x ? cb4[92].y : r6.w;
    r9.xyz = r3.xyw * cb4[78].xxx + r2.xyz;
    r10.xyz = cb3[34].xyz * r9.yyy;
    r9.xyw = cb3[33].xyz * r9.xxx + r10.xyz;
    r9.xyz = cb3[35].xyz * r9.zzz + r9.xyw;
    r9.xyz = cb3[36].xyz + r9.xyz;
    r10.xy = r9.xy * cb3[38].xy + cb3[38].zw;
    r11.xy = -cb0[171].xy + r10.xy;
    r11.z = cb3[37].y;
    r8.w = t7.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r11.xyzw = cb0[171].xyxy * float4(1,-1,-1,1) + r10.xyxy;
    r12.xy = r11.zw;
    r12.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r12.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r11.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r11.xy = cb0[171].xy + r10.xy;
    r11.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r11.xyzw = cb0[171].xyxy * float4(1.41421294,0,-1.41421294,0) + r10.xyxy;
    r12.xy = r11.zw;
    r12.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r12.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r11.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r11.xyzw = cb0[171].xyxy * float4(0,1.41421294,0,-1.41421294) + r10.xyxy;
    r12.xy = r11.zw;
    r12.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r12.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r11.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r10.z = cb3[37].y;
    r9.x = t7.SampleCmpLevelZero(s1_s, r10.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r8.w = r8.w * 0.111100003 + -1;
    r6.w = r8.w * r6.w;
    r6.w = cb3[37].x * r6.w;
    r8.w = round(v7.w);
    r8.w = v7.w + -r8.w;
    r8.w = cmp(9.99999975e-05 < abs(r8.w));
    if (r8.w != 0) {
      r9.xyz = -cb2[20].xyz + r2.xyz;
      r10.xyz = -cb2[21].xyz + r2.xyz;
      r11.xyz = -cb2[22].xyz + r2.xyz;
      r12.xyz = -cb2[23].xyz + r2.xyz;
      r9.x = dot(r9.xyz, r9.xyz);
      r9.y = dot(r10.xyz, r10.xyz);
      r9.z = dot(r11.xyz, r11.xyz);
      r9.w = dot(r12.xyz, r12.xyz);
      r9.xyzw = cmp(r9.xyzw < cb2[24].xyzw);
      r10.xyzw = r9.xyzw ? float4(1,1,1,1) : 0;
      r9.xyz = r9.xyz ? float3(-1,-1,-1) : float3(-0,-0,-0);
      r9.xyz = r10.yzw + r9.xyz;
      r10.yzw = max(float3(0,0,0), r9.xyz);
      r8.w = dot(r10.xyzw, float4(4,3,2,1));
      r9.w = 4 + -r8.w;
      r8.w = (uint)r9.w;
      r8.w = (uint)r8.w << 2;
      r10.xyz = cb2[r8.w+1].xyz * v3.www;
      r10.xyz = cb2[r8.w+0].xyz * v2.www + r10.xyz;
      r10.xyz = cb2[r8.w+2].xyz * v4.www + r10.xyz;
      r9.xyz = cb2[r8.w+3].xyz + r10.xyz;
    } else {
      r9.xyzw = v7.xyzw;
    }
    r10.xy = float2(1024,1024) * r9.xy;
    r10.xy = frac(r10.xy);
    r8.w = dot(r10.xy, float2(12.9898005,78.2330017));
    r8.w = sin(r8.w);
    r8.w = 43758.5469 * r8.w;
    r8.w = frac(r8.w);
    sincos(r8.w, r10.x, r11.x);
    r12.xyzw = float4(1.29999995,1.29999995,1.29999995,1.29999995) * cb2[26].xxyy;
    r10.xz = r10.xx;
    r10.yw = r11.xx;
    r10.xyzw = r10.xyzw * r12.xyzw;
    r11.xyzw = float4(-0.172399998,-0.978299975,-0.978299975,0.172399998) * r10.xyzw;
    r11.xy = r11.xz + r11.yw;
    r11.xy = r11.xy + r9.xy;
    r11.z = r9.w;
    r8.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r12.xyzw = float4(0.87470001,0.484600008,0.484600008,-0.87470001) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(-0.968299985,-0.0373999998,-0.0373999998,0.968299985) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(0.278299987,0.41960001,0.41960001,-0.278299987) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(-0.150700003,0.839100003,0.839100003,-0.150700003) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(-0.641700029,0.479299992,0.479299992,-0.641700029) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(0.577899992,-0.816100001,-0.816100001,0.577899992) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(-0.540899992,-0.458799988,-0.458799988,0.540899992) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(0.704400003,-0.1919,-0.1919,0.704400003) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r12.xyzw = float4(0.105300002,-0.446399987,-0.446399987,0.105300002) * r10.xyzw;
    r12.xy = r12.xz + r12.yw;
    r11.xy = r12.xy + r9.xy;
    r9.w = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.w + r8.w;
    r10.xyzw = float4(-0.206599995,0.0661000013,0.0661000013,-0.206599995) * r10.xyzw;
    r10.xy = r10.xz + r10.yw;
    r11.xy = r10.xy + r9.xy;
    r9.x = t0.SampleCmpLevelZero(s1_s, r11.xyz, r9.z).x;
    r8.w = r9.x + r8.w;
    r8.w = cb2[25].x * r8.w;
    r9.x = 1 + -cb2[25].x;
    r8.w = r8.w * 0.0908999965 + r9.x;
    r9.x = cmp(0 >= r9.z);
    r9.y = cmp(r9.z >= 1);
    r9.x = (int)r9.y | (int)r9.x;
    r8.w = r9.x ? 1 : r8.w;
    r7.y = r8.w * r7.y;
    r4.w = saturate(r4.w * 2 + -1);
    r8.w = cb0[161].w * r4.w;
    r9.x = cmp(0.5 < cb3[37].x);
    r4.w = r4.w * r6.w + 1;
    r4.w = min(1, r4.w);
    r4.w = r9.x ? r4.w : 1;
    r6.w = r4.w * r7.y;
    r9.x = 1 + -cb4[77].z;
    r6.w = r6.w * cb4[77].z + r9.x;
    r9.x = cb4[77].z * r8.w;
    r8.w = -r8.w * cb4[77].z + 1;
    r7.y = r7.y * r9.x + r8.w;
    r4.w = r7.y * r4.w;
  } else {
    r6.w = 1;
    r4.w = 1;
  }
  r7.y = asint(cb4[76].w);
  r7.y = cmp(0.5 < r7.y);
  r8.w = cmp(v8.z < 0.5);
  r9.xyz = r8.www ? cb4[67].xyz : cb4[68].xyz;
  r8.xyz = r7.yyy ? r9.xyz : r8.xyz;
  r7.y = cmp(cb3[3].w != 0.000000);
  r2.x = dot(cb3[3].xyz, r2.xyz);
  r2.x = saturate(-cb3[3].w + r2.x);
  r9.xyz = cb0[8].xyz * r7.xzw;
  r10.xyz = cb0[8].xyz + r7.xzw;
  r10.xyz = -r7.xzw * cb0[8].xyz + r10.xyz;
  r9.xyz = cb0[8].www * r10.xyz + r9.xyz;
  r9.xyz = r9.xyz + -r7.xzw;
  r2.xyz = r2.xxx * r9.xyz + r7.xzw;
  r2.xyz = r7.yyy ? r2.xyz : r7.xzw;
  r7.x = max(9.99999975e-06, cb4[77].w);
  r7.y = rcp(r7.x);
  r7.z = dot(r3.xyw, r8.xyz);
  r7.w = 1 + r7.z;
  r8.w = 3 * r8.y;
  r8.w = min(1, r8.w);
  r8.w = -r8.w * 0.5 + r3.y;
  r8.w = saturate(1.5 + r8.w);
  r7.w = r7.w * r8.w + -1;
  r7.w = r7.w + -r7.z;
  r7.w = v8.y * r7.w + r7.z;
  r9.x = r3.z * 2 + r7.w;
  r9.yz = -r7.xx * float2(0.5,1.5) + r9.xx;
  r9.yzw = float3(1,0.333299994,-0.333299994) + r9.xyz;
  r3.z = -r7.x * 3 + 2;
  r3.z = 3 / r3.z;
  r10.xyw = r9.yzw * r3.zzz;
  r9.yzw = -r9.yzw * r3.zzz + float3(1,1,1);
  r11.xyz = float3(0.333299994,-0.333299994,-0.333299994) + r9.xxx;
  r7.xyw = r11.xyz * r7.yyy + float3(0.5,0.5,-0.5);
  r11.xyz = float3(1,1,1) + -r7.xyw;
  r12.xy = min(r11.yx, r10.yx);
  r10.xz = min(r9.zw, r7.xw);
  r12.z = r9.y;
  r12.w = r10.x;
  r9.yzw = saturate(r12.zyw);
  r12.y = saturate(min(r11.z, r7.y));
  r12.x = saturate(r12.x);
  r10.zw = saturate(r10.zw);
  r11.xyzw = r4.wwww * float4(-2,2,2,-2) + float4(1,0,-1,2);
  r11.y = saturate(min(r11.y, r11.w));
  r11.xz = saturate(r11.xz);
  if (r2.w != 0) {
    r3.z = (int)cb3[2].z;
    r7.x = asint(cb0[160].x) + -1;
    r3.z = min((int)r7.x, (int)r3.z);
    r3.z = max(0, (int)r3.z);
    r3.z = t1[r3.z].val[32/4];
  } else {
    r3.z = 0;
  }
  r7.xy = r11.xy * r3.zz;
  r7.w = 1 + -r9.y;
  r7.w = r7.w + -r9.z;
  r7.w = r7.w + -r9.w;
  r7.x = r7.x * r7.w + r9.w;
  r3.z = r11.y * r3.z + r11.z;
  r10.xy = r12.xy * r3.zz;
  r3.z = r10.z + r10.w;
  r3.z = r3.z * r7.y + r10.y;
  r7.y = r11.z * r10.z;
  r7.w = v8.x * r9.y;
  r8.w = -r9.y * v8.x + r9.y;
  r8.w = r9.z + r8.w;
  r12.xyzw = cmp(r4.yyyy < float4(0.200000003,0.400000006,0.600000024,0.800000012));
  r9.yzw = r12.www ? cb4[32].xyz : cb4[31].xyz;
  r9.yzw = r12.zzz ? cb4[33].xyz : r9.yzw*1.1;
  r9.yzw = r12.yyy ? cb4[34].xyz : r9.yzw;
  r9.yzw = r12.xxx ? cb4[35].xyz : r9.yzw;
  r11.xyw = r12.www ? cb4[37].xyz : cb4[36].xyz;
  r11.xyw = r12.zzz ? cb4[38].xyz : r11.xyw*1.35;
  r11.xyw = r12.yyy ? cb4[39].xyz : r11.xyw;
  r11.xyw = r12.xxx ? cb4[40].xyz : r11.xyw;
  r13.y = saturate(0.437249988 * v10.w);
  r13.x = -r13.y;
  r10.yz = float2(1,-1) + r13.xy;
  r10.yz = cb4[77].yy * r10.yz + float2(0,1);
  r9.yzw = float3(6.10351562e-05,6.10351562e-05,6.10351562e-05) + r9.yzw;
  r13.x = r9.y + r9.z;
  r13.x = r13.x + r9.w;
  r13.x = 0.333330005 * r13.x;
  r13.xyz = saturate(r9.yzw / r13.xxx);
  r9.yzw = r9.yzw * r10.zzz;
  r9.yzw = r13.xyz * r10.yyy + r9.yzw;
  r11.xyw = float3(6.10351562e-05,6.10351562e-05,6.10351562e-05) + r11.xyw;
  r13.x = r11.x + r11.y;
  r13.x = r13.x + r11.w;
  r13.x = 0.333330005 * r13.x;
  r13.xyz = saturate(r11.xyw / r13.xxx);
  r11.xyw = r11.xyw * r10.zzz;
  r11.xyw = r13.xyz * r10.yyy + r11.xyw;
  r13.xyz = cb0[2].xyz * r9.yzw;
  r9.yzw = cb0[3].xyz * r9.yzw;
  r14.xyz = cb0[4].xyz * r11.xyw;
  r11.xyw = cb0[7].xyz * r11.xyw;
  r15.xyz = float3(1.17549435e-38,1.17549435e-38,1.17549435e-38) + r2.xyz;
  r10.y = max(r15.x, r15.y);
  r10.y = max(r10.y, r15.z);
  r10.y = rcp(r10.y);
  if (r2.w != 0) {
    r10.z = (int)cb3[2].z;
    r13.w = asint(cb0[160].x) + -1;
    r10.z = min((int)r13.w, (int)r10.z);
    r10.z = max(0, (int)r10.z);
    r10.z = t1[r10.z].val[32/4];
  } else {
    r10.z = 0;
  }
  r13.w = 1 + -r5.w;
  r5.w = r10.z * r13.w + r5.w;
  r2.xyz = r5.www * r2.xyz;
  r5.w = min(1, r10.y);
  r15.xyz = r5.www * r2.xyz;
  r16.xyz = cb0[5].xyz * r7.yyy;
  r16.xyz = cb0[6].xyz * r3.zzz + r16.xyz;
  r10.yzw = r10.www * r11.zzz + r16.xyz;
  r14.xyz = r14.xyz * r8.www;
  r11.xyz = r11.xyw * r7.www + r14.xyz;
  r7.xyw = r9.yzw * r7.xxx + r11.xyz;
  r7.xyw = r13.xyz * r10.xxx + r7.xyw;
  r7.xyw = r7.xyw * r15.xyz;
  r2.xyz = r2.xyz * r10.yzw + r7.xyw;
  r3.z = cmp(0.5 < v8.z);
  r7.xyw = r3.zzz ? r3.xyw : v2.xyz;
  r5.w = dot(r1.xyz, float3(0.289999992,0.600000024,0.109999999));
  r5.w = r5.w * 0.287499994 + 1.4375;
  r7.x = dot(r8.xyz, r7.xyw);
  r7.y = r7.x + -r7.z;
  r7.y = saturate(-r7.y * 3 + 1);
  r7.w = r7.y + r7.y;
  r7.y = sqrt(r7.y);
  r7.y = r7.w * r7.y;
  r7.y = min(1, r7.y);
  r7.w = r7.z * 0.5 + 0.5;
  r8.w = saturate(r7.z);
  r7.y = r7.w * r7.y + -r8.w;
  r7.y = r7.y * 0.5 + r8.w;
  r7.x = saturate(r7.x);
  r8.w = max(r1.y, r1.z);
  r8.w = max(r8.w, r1.x);
  r9.y = cmp(1 < r8.w);
  r10.xyz = r1.xyz / r8.www;
  r9.yzw = r9.yyy ? r10.xyz : r1.xyz;
  r8.w = 1 + -r5.w;
  r5.w = r7.y * r8.w + r5.w;
  r9.yzw = log2(r9.yzw);
  r9.yzw = r9.yzw * r5.www;
  r9.yzw = exp2(r9.yzw);
  r10.xyz = r9.yzw + -r1.xyz;
  r1.xyz = r10.xyz * float3(0.5,0.5,0.5) + r1.xyz;
  r9.yzw = r9.yzw + -r1.xyz;
  r1.xyz = r7.xxx * r9.yzw + r1.xyz;
  r5.w = -r0.x * 0.959999979 + 0.959999979;
  r9.yzw = r5.www * r1.xyz;
  r10.xyz = float3(-0.0399999991,-0.0399999991,-0.0399999991) + r1.xyz;
  r10.xyz = r0.xxx * r10.xyz + float3(0.0399999991,0.0399999991,0.0399999991);
  r7.x = -r0.z * cb4[81].x + 1;
  r7.x = r7.x * r7.x;
  r7.y = r7.x * 4 + 2;
  r8.w = r7.x * r7.x;
  r10.w = r7.x * r7.x + -1;
  r11.xyz = cb0[1].xyz + r2.xyz;
  r11.xyz = v9.xyz + r11.xyz;
  r11.x = dot(r11.xyz, float3(0.212672904,0.715152204,0.0721750036));
  r11.y = cb0[12].y + -cb0[12].x;
  r11.z = 1 / r11.y;
  r11.w = -cb0[12].x * r11.z + 1;
  r11.z = r11.x * r11.z + r11.w;
  r11.z = rcp(r11.z);
  r11.y = -r11.y * r11.z + cb0[12].y;
  r11.z = cmp(r11.x < cb0[12].x);
  r11.y = r11.z ? r11.x : r11.y;
  r11.x = 9.99999975e-05 + r11.x;
  r11.x = r11.y / r11.x;
  r11.yzw = r11.xxx * r2.xyz;
  r13.x = r12.w ? cb4[84].z : cb4[84].y;
  r13.x = r12.z ? cb4[84].w : r13.x;
  r13.x = r12.y ? cb4[85].x : r13.x;
  r13.x = r12.x ? cb4[85].y : r13.x;
  r13.yzw = r12.www ? cb4[47].xyz : cb4[46].xyz;
  r13.yzw = r12.zzz ? cb4[48].xyz : r13.yzw;
  r13.yzw = r12.yyy ? cb4[49].xyz : r13.yzw;
  r13.yzw = r12.xxx ? cb4[50].xyz : r13.yzw;
  r14.x = cmp(0.5 < r13.x);
  if (r14.x != 0) {
    r9.x = saturate(r9.x * 1.5 + -0.5);
    r14.x = r12.w ? cb4[85].w : cb4[85].z;
    r14.x = r12.z ? cb4[86].x : r14.x;
    r14.x = r12.y ? cb4[86].y : r14.x;
    r14.x = r12.x ? cb4[86].z : r14.x;
    r14.yzw = r5.xyz * r1.www + r8.xyz;
    r15.x = dot(r14.yzw, r14.yzw);
    r15.x = rsqrt(r15.x);
    r14.yzw = r15.xxx * r14.yzw;
    r14.y = saturate(dot(r3.xyw, r14.yzw));
    r9.x = r9.x * r9.x;
    r9.x = -r9.x * r14.y + 1;
    r9.x = -r9.x + r4.x;
    r14.x = max(9.99999975e-06, r14.x);
    r4.x = saturate(r9.x / r14.x);
  }
  r4.x = cb4[86].w * r4.x;
  r13.yzw = r4.xxx * r13.yzw;
  r13.yzw = r13.yzw * r10.xyz;
  r4.x = cmp(r13.x < 0.5);
  r5.xyz = r5.xyz * r1.www + r8.xyz;
  r1.w = dot(r5.xyz, r5.xyz);
  r1.w = rsqrt(r1.w);
  r5.xyz = r5.xyz * r1.www;
  r1.w = r12.w ? cb4[83].y : cb4[83].x;
  r1.w = r12.z ? cb4[83].z : r1.w;
  r1.w = r12.y ? cb4[83].w : r1.w;
  r1.w = r12.x ? cb4[84].x : r1.w;
  r7.z = r1.w * r7.z;
  r7.z = saturate(r7.z * 0.75 + 0.25);
  r9.x = dot(r3.xyw, r5.xyz);
  r9.x = r9.x * r1.w;
  r9.x = saturate(r9.x * 0.75 + 0.25);
  r5.x = dot(r8.xyz, r5.xyz);
  r1.w = r5.x * r1.w;
  r1.w = saturate(r1.w * 0.75 + 0.25);
  r5.x = r9.x * r9.x;
  r5.x = r5.x * r10.w + 1.00001001;
  r1.w = r1.w * r1.w;
  r5.x = r5.x * r5.x;
  r1.w = max(0.100000001, r1.w);
  r5.x = r5.x * r1.w;
  r5.x = r5.x * r7.y;
  r5.x = r8.w / r5.x;
  r0.z = saturate(-r0.z * cb4[81].x + r5.x);
  r0.z = r0.z * r7.z;
  r5.x = max(9.99999975e-06, r7.x);
  r0.z = r0.z / r5.x;
  r5.x = r12.w ? cb4[82].x : cb4[81].w;
  r5.x = r12.z ? cb4[82].y : r5.x;
  r5.x = r12.y ? cb4[82].z : r5.x;
  r5.x = r12.x ? cb4[82].w : r5.x;
  r5.y = r12.w ? cb4[93].w : cb4[93].z;
  r5.y = r12.z ? cb4[94].x : r5.y;
  r5.y = r12.y ? cb4[94].y : r5.y;
  r5.y = r12.x ? cb4[94].z : r5.y;
  r5.x = r5.x * r5.y;
  r0.z = r5.x * r0.z;
  r0.z = saturate(10 * r0.z);
  r0.z = 100 * r0.z;
  r1.w = 0.166663334 / r1.w;
  r1.w = min(1, r1.w);
  r1.w = r1.w * r7.z;
  r1.w = 100 * r1.w;
  r0.z = r4.x ? r0.z : r1.w;
  r5.xyz = r0.zzz * r13.yzw;
  r7.xyz = r5.xyz * r11.yzw;
  r5.xyz = r5.xyz * r11.yzw + float3(-1,-1,-1);
  r5.xyz = max(float3(0,0,0), r5.xyz);
  r7.xyz = r9.yzw * r11.yzw + r7.xyz;
  r0.z = cmp(cb4[87].x >= 0.5);
  r13.xyz = r12.www ? cb4[52].xyz : cb4[51].xyz;
  r13.xyz = r12.zzz ? cb4[53].xyz : r13.xyz;
  r12.yzw = r12.yyy ? cb4[54].xyz : r13.xyz;
  r12.xyz = r12.xxx ? cb4[55].xyz : r12.yzw;
  r12.xyz = r12.xyz * r0.yyy;
  r12.xyz = r12.xyz * r1.xyz;
  r12.xyz = r0.zzz ? r12.xyz : 0;
  r0.y = r12.x + r12.y;
  r0.y = r0.y + r12.z;
  r0.z = 4.5 * r4.y;
  r0.z = floor(r0.z);
  r0.z = 4 + -r0.z;
  r0.z = (int)r0.z;
  r0.z = cmp((int)r0.z == asint(cb4[77].x));
  r13.xyz = v9.xyz * r11.xxx;
  r7.xyz = r13.xyz * r9.yzw + r7.xyz;
  r1.xyw = cb0[1].xyz * r1.xyz;
  r1.xyw = r1.xyw * r11.xxx + r7.xyz;
  r1.xyw = r1.xyw + r5.xyz;
  r4.x = cmp(0.5 >= cb0[160].y);
  if (r4.x != 0) {
    r4.x = dot(r6.xyz, r8.xyz);
    r4.x = -r4.x * 0.5 + 0.5;
    r5.x = r4.x * 0.800000012 + 0.200000003;
    r5.y = r3.y * 0.5 + 0.5;
    r5.z = r5.y * r5.y;
    r5.y = r0.z ? r5.y : r5.z;
    r5.y = -0.200000003 + r5.y;
    r5.y = saturate(1.25 * r5.y);
    r5.z = r5.y * -2 + 3;
    r5.y = r5.y * r5.y;
    r5.y = r5.z * r5.y;
    r5.z = r5.y * r5.y;
    r5.z = r5.z * r5.z;
    r5.z = r5.y * r5.z;
    r7.xyz = r0.zzz ? float3(1,0.300000012,-1) : float3(0.5,1,-0.5);
    r7.y = r7.y + r7.z;
    r5.z = r5.z * r7.y + r7.x;
    r5.y = r5.y * r5.z;
    r4.w = r7.w * r4.w;
    r4.w = r4.w * 1.39999998 + 0.100000001;
    if (r2.w != 0) {
      r2.w = (int)cb3[2].z;
      r5.z = asint(cb0[160].x) + -1;
      r2.w = min((int)r5.z, (int)r2.w);
      r2.w = max(0, (int)r2.w);
      r2.w = t1[r2.w].val[32/4];
    } else {
      r2.w = 0;
    }
    r2.w = r2.w * 0.399999976 + r6.w;
    r2.w = saturate(0.600000024 + r2.w);
    r5.x = r5.x * r5.y;
    r4.w = r5.x * r4.w;
    r2.w = r4.w * r2.w;
    r4.w = cmp(0 != v8.z);
    r5.x = saturate(-r6.y);
    r4.z = r4.z * cb4[80].w + 2.5;
    r4.z = r4.w ? 4.5 : r4.z;
    r4.z = r5.x * r4.z + 0.5;
    r2.w = r4.z * r2.w;
    r0.w = sqrt(r0.w);
    r4.z = 0.0833333358 * r0.w;
    r4.z = min(1, r4.z);
    r4.zw = r4.zz * float2(-0.300000012,-0.300000012) + float2(0.5,0.600000024);
    r5.x = dot(r6.xyz, r3.xyw);
    r5.x = 1 + -r5.x;
    r4.zw = r5.xx + -r4.zw;
    r4.zw = saturate(float2(3.33333325,5.00000048) * r4.zw);
    r5.xy = r4.zw * float2(-2,-2) + float2(3,3);
    r4.zw = r4.zw * r4.zw;
    r4.zw = r5.xy * r4.zw;
    r4.z = r0.z ? r4.z : r4.w;
    r4.w = dot(cb0[161].xyz, float3(0.330000013,0.330000013,0.330000013));
    r5.xyz = cb0[161].xyz * cb0[161].xyz;
    r5.xyz = r5.xyz * r5.xyz;
    r5.xyz = r5.xyz * r5.xyz;
    r6.x = dot(r5.xyz, float3(0.699999988,0.699999988,0.699999988));
    r6.x = 6.10351562e-05 + r6.x;
    r6.x = rcp(r6.x);
    r4.w = r6.x * r4.w;
    r5.xyz = r4.www * r5.xyz + -r11.yzw;
    r5.xyz = r6.www * r5.xyz + r11.yzw;
    r4.x = r4.x * r4.x;
    r4.x = log2(r4.x);
    r4.x = 20 * r4.x;
    r4.x = exp2(r4.x);
    r2.xyz = r2.xyz * r11.xxx + -r5.xyz;
    r2.xyz = r4.xxx * r2.xyz + r5.xyz;
    r4.x = r9.y + r9.z;
    r1.z = r1.z * r5.w + r4.x;
    r1.z = 0.330000013 * r1.z;
    r1.z = r1.z * r1.z;
    r1.z = r1.z * -0.199999988 + 1;
    r4.x = 48 * cb0[170].x;
    r1.z = 0.100000001 * r1.z;
    r5.xyz = log2(r9.yzw);
    r5.xyz = float3(0.200000003,0.200000003,0.200000003) * r5.xyz;
    r5.xyz = exp2(r5.xyz);
    r4.w = dot(r5.xyz, r5.xyz);
    r4.w = max(1.17549435e-38, r4.w);
    r4.w = rsqrt(r4.w);
    r5.xyz = r5.xyz * r4.www;
    r6.xyz = r5.xyz * r1.zzz;
    r5.xyz = -r1.zzz * r5.xyz + r10.xyz;
    r5.xyz = r0.xxx * r5.xyz + r6.xyz;
    r5.xyz = r5.xyz * r4.xxx;
    r0.x = r4.z * r2.w;
    r2.xyz = r0.xxx * r2.xyz;
    r2.xyz = r2.xyz * r5.xyz;
    r4.xyzw = cmp(r4.yyyy < float4(0.200000003,0.400000006,0.600000024,0.800000012));
    r5.xyz = r4.www ? cb4[58].xyz : cb4[57].xyz;
    r5.xyz = r4.zzz ? cb4[59].xyz : r5.xyz;
    r4.yzw = r4.yyy ? cb4[60].xyz : r5.xyz;
    r4.xyz = r4.xxx ? cb4[61].xyz : r4.yzw;
    r2.xyz = r4.xyz * r2.xyz;
    r0.x = saturate(r0.w * 0.200000003 + -1);
    r0.x = r0.x * -0.699999988 + 1;
    r2.xyw = r2.xyz * r0.xxx;
    r0.w = r2.x + r2.y;
    r0.x = r2.z * r0.x + r0.w;
    r0.x = 0.330000013 * r0.x;
    r0.x = r0.x * r0.x;
    r0.x = r0.x * 0.5 + 1;
    r2.xyz = r2.xyw * r0.xxx;
    r0.x = r3.z ? 0.5 : 1;
    r2.xyz = r2.xyz * r0.xxx;
  } else {
    r2.xyz = float3(0,0,0);
  }
  r4.xyz = r13.xyz * float3(2,2,2) + float3(1,1,1);
  r2.xyz = r4.xyz * r2.xyz;
  o0.xyz = r1.xyw + r12.xyz;
  r1.xyz = max(float3(0,0,0), r2.xyz);
  r1.xyz = sqrt(r1.xyz);
  r1.xyz = float3(0.200000003,0.200000003,0.200000003) * r1.xyz;
  o1.xyz = min(float3(1,1,1), r1.xyz);
  o1.w = 0.333299994 * r0.y;
  o2.w = r0.z ? 0.340000 : 0;
  o3.xyz = r3.xyw * float3(0.5,0.5,0.5) + float3(0.5,0.5,0.5);
  o0.w = 1;
  o3.w = 1;
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.3.16 on Sat Sep 14 02:44:48 2024
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// TEXCOORD                 0   xyzw        0     NONE   float   xyzw
// TEXCOORD                 1   xyzw        1     NONE   float
// TEXCOORD                 2   xyzw        2     NONE   float   xyzw
// TEXCOORD                 3   xyzw        3     NONE   float   xyzw
// TEXCOORD                 4   xyzw        4     NONE   float   xyzw
// TEXCOORD                 5   xyzw        5     NONE   float   xy w
// TXCOORDD                 6   xyzw        6     NONE   float   xy w
// TEXCOORD                 7   xyzw        7     NONE   float   xyzw
// TEXCOORD                 8   xyzw        8     NONE   float   xyz
// TEXCOORD                 9   xyz         9     NONE   float   xyz
// SV_POSITION              0   xyzw       10      POS   float      w
// SV_IsFrontFace           0   x          11    FFACE    uint   x
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_Target                0   xyzw        0   TARGET   float   xyzw
// SV_Target                1   xyzw        1   TARGET   float   xyzw
// SV_Target                2   xyzw        2   TARGET   float   xyzw
// SV_Target                3   xyzw        3   TARGET   float   xyzw
//
ps_5_0
dcl_globalFlags refactoringAllowed
dcl_constantbuffer CB0[172], immediateIndexed
dcl_constantbuffer CB1[29], immediateIndexed
dcl_constantbuffer CB2[27], dynamicIndexed
dcl_constantbuffer CB3[39], immediateIndexed
dcl_constantbuffer CB4[95], immediateIndexed
dcl_sampler s0, mode_default
dcl_sampler s1, mode_comparison
dcl_resource_texture2darray (float,float,float,float) t0
dcl_resource_structured t1, 80
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_texture2d (float,float,float,float) t6
dcl_resource_texture2darray (float,float,float,float) t7
dcl_input_ps linear v0.xyzw
dcl_input_ps linear v2.xyzw
dcl_input_ps linear v3.xyzw
dcl_input_ps linear v4.xyzw
dcl_input_ps linear v5.xyw
dcl_input_ps linear v6.xyw
dcl_input_ps linear v7.xyzw
dcl_input_ps linear v8.xyz
dcl_input_ps linear v9.xyz
dcl_input_ps_siv linear noperspective v10.w, position
dcl_input_ps_sgv constant v11.x, is_front_face
dcl_output o0.xyzw
dcl_output o1.xyzw
dcl_output o2.xyzw
dcl_output o3.xyzw
dcl_temps 17
movc r0.x, v11.x, l(1.000000), l(-1.000000)
lt r0.y, l(0.500000), cb1[28].y
div r0.zw, v5.xxxy, v5.wwww
div r1.xy, v6.xyxx, v6.wwww
add r1.xy, r0.zwzz, -r1.xyxx
mul r0.zw, r1.xxxy, l(0.000000, 0.000000, 0.500000, -0.500000)
sqrt r0.zw, |r0.zzzw|
mov r1.z, -r1.y
lt r1.yw, l(0.000000, 0.000000, 0.000000, 0.000000), r1.xxxz
lt r1.xz, r1.xxzx, l(0.000000, 0.000000, 0.000000, 0.000000)
iadd r1.xy, -r1.ywyy, r1.xzxx
itof r1.xy, r1.xyxx
mul r0.zw, r0.zzzw, r1.xxxy
mad r0.zw, r0.zzzw, l(0.000000, 0.000000, 0.500000, 0.500000), l(0.000000, 0.000000, 0.498039216, 0.498039216)
movc o2.xy, r0.yyyy, r0.zwzz, l(0.498000,0.498000,0,0)
lt r0.y, l(0.500000), cb4[90].x
and o2.z, r0.y, l(0x3f800000)
lt r0.yz, l(0.000000, 0.500000, 0.500000, 0.000000), cb4[89].zzwz
ieq r0.w, v11.x, l(0)
and r0.y, r0.w, r0.y
lt r0.w, l(1.000000), v0.z
and r0.z, r0.w, r0.z
or r0.z, r0.z, r0.y
movc r0.zw, r0.zzzz, v0.zzzw, v0.xxxy
sample_b_indexable(texture2d)(float,float,float,float) r1.xyz, r0.zwzz, t3.xyzw, s0, cb0[163].y
mul r2.xyz, r1.xyzx, cb4[29].xyzx
movc r0.yz, r0.yyyy, v0.zzwz, v0.xxyx
sample_b_indexable(texture2d)(float,float,float,float) r3.xyz, r0.yzyy, t4.xyzw, s0, cb0[163].y
mad r3.xyz, r3.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(-1.004000, -1.004000, -1.000000, 0.000000)
mul r3.xy, r3.xyxx, cb4[80].zzzz
dp2 r0.w, r3.xyxx, r3.xyxx
min r0.w, r0.w, l(1.000000)
add r0.w, -r0.w, l(1.000000)
sqrt r0.w, r0.w
mul r0.x, r0.x, r0.w
mul r4.xyz, r3.yyyy, v4.xyzx
mad r3.xyw, r3.xxxx, v3.xyxz, r4.xyxz
mad r3.xyw, r0.xxxx, v2.xyxz, r3.xyxw
dp3 r0.x, r3.xywx, r3.xywx
rsq r0.x, r0.x
mul r3.xyw, r0.xxxx, r3.xyxw
sample_b_indexable(texture2d)(float,float,float,float) r4.xyz, r0.yzyy, t5.zxyw, s0, cb0[163].y
mul r0.x, r4.z, cb4[80].w
sample_b_indexable(texture2d)(float,float,float,float) r0.yz, r0.yzyy, t6.xzyw, s0, cb0[163].y
lt r0.w, l(0.500000), cb4[78].z
if_nz r0.w
  lt r5.xy, l(0.500000, 0.500000, 0.000000, 0.000000), cb4[87].xyxx
  and r0.w, r5.y, r5.x
  add r1.w, r0.y, l(-0.200000)
  mul_sat r1.w, r1.w, l(1.250000)
  movc r0.w, r0.w, r1.w, r0.y
  and r0.y, r0.w, r5.x
endif
lt r0.w, l(0.500000), cb4[80].x
mul r5.xy, v0.xyxx, cb4[80].yyyy
sample_b_indexable(texture2d)(float,float,float,float) r5.xyz, r5.xyxx, t2.xyzw, s0, cb0[163].y
mad r1.xyz, r1.xyzx, cb4[29].xyzx, r5.xyzx
add r1.xyz, r1.xyzx, l(-0.500000, -0.500000, -0.500000, 0.000000)
max r1.xyz, r1.xyzx, l(0.000000, 0.000000, 0.000000, 0.000000)
movc r1.xyz, r0.wwww, r1.xyzx, r2.xyzx
mov r2.x, v2.w
mov r2.y, v3.w
mov r2.z, v4.w
add r5.xyz, -r2.xyzx, cb0[40].yzwy
dp3 r0.w, r5.xyzx, r5.xyzx
max r1.w, r0.w, l(1.175494351E-38)
rsq r1.w, r1.w
mul r6.xyz, r1.wwww, r5.xyzx
ilt r2.w, l(0), cb0[160].x
if_nz r2.w
  ftoi r4.w, cb3[2].z
  iadd r5.w, cb0[160].x, l(-1)
  imin r4.w, r4.w, r5.w
  imax r4.w, r4.w, l(0)
  ld_structured_indexable(structured_buffer, stride=80)(mixed,mixed,mixed,mixed) r7.xyzw, r4.w, l(0), t1.wxyz
  ld_structured_indexable(structured_buffer, stride=80)(mixed,mixed,mixed,mixed) r8.xyzw, r4.w, l(16), t1.xyzw
  ld_structured_indexable(structured_buffer, stride=80)(mixed,mixed,mixed,mixed) r4.w, r4.w, l(32), t1.xxxx
  mov r9.xyz, r7.yzwy
  mov r7.y, r8.w
else
  mov r9.xyz, l(0,0,0,0)
  mov r7.xy, l(0,0,0,0)
  mov r4.w, l(0)
  mov r8.xyz, l(0,0,0,0)
endif
add r8.xyz, -r2.xyzx, r8.xyzx
dp3 r5.w, r8.xyzx, r8.xyzx
max r5.w, r5.w, l(1.175494351E-38)
rsq r6.w, r5.w
mul r8.xyz, r6.wwww, r8.xyzx
mul r6.w, r7.x, r7.x
div r5.w, r5.w, r6.w
add r5.w, -r5.w, l(1.000000)
max r5.w, r5.w, l(0.000000)
add r7.xzw, r9.xxyz, -cb0[161].xxyz
mad r7.xzw, r5.wwww, r7.xxzw, cb0[161].xxyz
add r6.w, r5.w, l(-1.000000)
mad r5.w, r5.w, r6.w, l(1.000000)
lt r6.w, l(0.500000), cb0[13].x
if_nz r6.w
  lt r9.xyzw, r4.yyyy, l(0.200000, 0.400000, 0.600000, 0.800000)
  movc r6.w, r9.w, cb4[91].z, cb4[91].y
  movc r6.w, r9.z, cb4[91].w, r6.w
  movc r6.w, r9.y, cb4[92].x, r6.w
  movc r6.w, r9.x, cb4[92].y, r6.w
  mad r9.xyz, r3.xywx, cb4[78].xxxx, r2.xyzx
  mul r10.xyz, r9.yyyy, cb3[34].xyzx
  mad r9.xyw, cb3[33].xyxz, r9.xxxx, r10.xyxz
  mad r9.xyz, cb3[35].xyzx, r9.zzzz, r9.xywx
  add r9.xyz, r9.xyzx, cb3[36].xyzx
  mad r10.xy, r9.xyxx, cb3[38].xyxx, cb3[38].zwzz
  add r11.xy, r10.xyxx, -cb0[171].xyxx
  mov r11.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r8.w, r11.xyzx, t7.xxxx, s1, r9.z
  mad r11.xyzw, cb0[171].xyxy, l(1.000000, -1.000000, -1.000000, 1.000000), r10.xyxy
  mov r12.xy, r11.zwzz
  mov r12.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r12.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mov r11.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r11.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  add r11.xy, r10.xyxx, cb0[171].xyxx
  mov r11.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r11.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mad r11.xyzw, cb0[171].xyxy, l(1.414213, 0.000000, -1.414213, 0.000000), r10.xyxy
  mov r12.xy, r11.zwzz
  mov r12.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r12.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mov r11.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r11.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mad r11.xyzw, cb0[171].xyxy, l(0.000000, 1.414213, 0.000000, -1.414213), r10.xyxy
  mov r12.xy, r11.zwzz
  mov r12.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r12.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mov r11.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r11.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mov r10.z, cb3[37].y
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r10.xyzx, t7.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mad r8.w, r8.w, l(0.111100), l(-1.000000)
  mul r6.w, r6.w, r8.w
  mul r6.w, r6.w, cb3[37].x
  round_ne r8.w, v7.w
  add r8.w, -r8.w, v7.w
  lt r8.w, l(0.000100), |r8.w|
  if_nz r8.w
    add r9.xyz, r2.xyzx, -cb2[20].xyzx
    add r10.xyz, r2.xyzx, -cb2[21].xyzx
    add r11.xyz, r2.xyzx, -cb2[22].xyzx
    add r12.xyz, r2.xyzx, -cb2[23].xyzx
    dp3 r9.x, r9.xyzx, r9.xyzx
    dp3 r9.y, r10.xyzx, r10.xyzx
    dp3 r9.z, r11.xyzx, r11.xyzx
    dp3 r9.w, r12.xyzx, r12.xyzx
    lt r9.xyzw, r9.xyzw, cb2[24].xyzw
    and r10.xyzw, r9.xyzw, l(0x3f800000, 0x3f800000, 0x3f800000, 0x3f800000)
    movc r9.xyz, r9.xyzx, l(-1.000000,-1.000000,-1.000000,0), l(-0.000000,-0.000000,-0.000000,0)
    add r9.xyz, r9.xyzx, r10.yzwy
    max r10.yzw, r9.xxyz, l(0.000000, 0.000000, 0.000000, 0.000000)
    dp4 r8.w, r10.xyzw, l(4.000000, 3.000000, 2.000000, 1.000000)
    add r9.w, -r8.w, l(4.000000)
    ftou r8.w, r9.w
    ishl r8.w, r8.w, l(2)
    mul r10.xyz, v3.wwww, cb2[r8.w + 1].xyzx
    mad r10.xyz, cb2[r8.w + 0].xyzx, v2.wwww, r10.xyzx
    mad r10.xyz, cb2[r8.w + 2].xyzx, v4.wwww, r10.xyzx
    add r9.xyz, r10.xyzx, cb2[r8.w + 3].xyzx
  else
    mov r9.xyzw, v7.xyzw
  endif
  mul r10.xy, r9.xyxx, l(1024.000000, 1024.000000, 0.000000, 0.000000)
  frc r10.xy, r10.xyxx
  dp2 r8.w, r10.xyxx, l(12.989800, 78.233002, 0.000000, 0.000000)
  sincos r8.w, null, r8.w
  mul r8.w, r8.w, l(43758.546875)
  frc r8.w, r8.w
  sincos r10.x, r11.x, r8.w
  mul r12.xyzw, cb2[26].xxyy, l(1.300000, 1.300000, 1.300000, 1.300000)
  mov r10.xz, r10.xxxx
  mov r10.yw, r11.xxxx
  mul r10.xyzw, r12.xyzw, r10.xyzw
  mul r11.xyzw, r10.xyzw, l(-0.172400, -0.978300, -0.978300, 0.172400)
  add r11.xy, r11.ywyy, r11.xzxx
  add r11.xy, r9.xyxx, r11.xyxx
  mov r11.z, r9.w
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r8.w, r11.xyzx, t0.xxxx, s1, r9.z
  mul r12.xyzw, r10.xyzw, l(0.874700, 0.484600, 0.484600, -0.874700)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(-0.968300, -0.037400, -0.037400, 0.968300)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(0.278300, 0.419600, 0.419600, -0.278300)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(-0.150700, 0.839100, 0.839100, -0.150700)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(-0.641700, 0.479300, 0.479300, -0.641700)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(0.577900, -0.816100, -0.816100, 0.577900)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(-0.540900, -0.458800, -0.458800, 0.540900)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(0.704400, -0.191900, -0.191900, 0.704400)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r12.xyzw, r10.xyzw, l(0.105300, -0.446400, -0.446400, 0.105300)
  add r12.xy, r12.ywyy, r12.xzxx
  add r11.xy, r9.xyxx, r12.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.w, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.w
  mul r10.xyzw, r10.xyzw, l(-0.206600, 0.066100, 0.066100, -0.206600)
  add r10.xy, r10.ywyy, r10.xzxx
  add r11.xy, r9.xyxx, r10.xyxx
  sample_c_lz_indexable(texture2darray)(float,float,float,float) r9.x, r11.xyzx, t0.xxxx, s1, r9.z
  add r8.w, r8.w, r9.x
  mul r8.w, r8.w, cb2[25].x
  add r9.x, -cb2[25].x, l(1.000000)
  mad r8.w, r8.w, l(0.090900), r9.x
  ge r9.x, l(0.000000), r9.z
  ge r9.y, r9.z, l(1.000000)
  or r9.x, r9.y, r9.x
  movc r8.w, r9.x, l(1.000000), r8.w
  mul r7.y, r7.y, r8.w
  mad_sat r4.w, r4.w, l(2.000000), l(-1.000000)
  mul r8.w, r4.w, cb0[161].w
  lt r9.x, l(0.500000), cb3[37].x
  mad r4.w, r4.w, r6.w, l(1.000000)
  min r4.w, r4.w, l(1.000000)
  movc r4.w, r9.x, r4.w, l(1.000000)
  mul r6.w, r7.y, r4.w
  add r9.x, -cb4[77].z, l(1.000000)
  mad r6.w, r6.w, cb4[77].z, r9.x
  mul r9.x, r8.w, cb4[77].z
  mad r8.w, -r8.w, cb4[77].z, l(1.000000)
  mad r7.y, r7.y, r9.x, r8.w
  mul r4.w, r4.w, r7.y
else
  mov r6.w, l(1.000000)
  mov r4.w, l(1.000000)
endif
itof r7.y, cb4[76].w
lt r7.y, l(0.500000), r7.y
lt r8.w, v8.z, l(0.500000)
movc r9.xyz, r8.wwww, cb4[67].xyzx, cb4[68].xyzx
movc r8.xyz, r7.yyyy, r9.xyzx, r8.xyzx
ne r7.y, cb3[3].w, l(0.000000)
dp3 r2.x, cb3[3].xyzx, r2.xyzx
add_sat r2.x, r2.x, -cb3[3].w
mul r9.xyz, r7.xzwx, cb0[8].xyzx
add r10.xyz, r7.xzwx, cb0[8].xyzx
mad r10.xyz, -r7.xzwx, cb0[8].xyzx, r10.xyzx
mad r9.xyz, cb0[8].wwww, r10.xyzx, r9.xyzx
add r9.xyz, -r7.xzwx, r9.xyzx
mad r2.xyz, r2.xxxx, r9.xyzx, r7.xzwx
movc r2.xyz, r7.yyyy, r2.xyzx, r7.xzwx
max r7.x, cb4[77].w, l(0.000010)
rcp r7.y, r7.x
dp3 r7.z, r3.xywx, r8.xyzx
add r7.w, r7.z, l(1.000000)
mul r8.w, r8.y, l(3.000000)
min r8.w, r8.w, l(1.000000)
mad r8.w, -r8.w, l(0.500000), r3.y
add_sat r8.w, r8.w, l(1.500000)
mad r7.w, r7.w, r8.w, l(-1.000000)
add r7.w, -r7.z, r7.w
mad r7.w, v8.y, r7.w, r7.z
mad r9.x, r3.z, l(2.000000), r7.w
mad r9.yz, -r7.xxxx, l(0.000000, 0.500000, 1.500000, 0.000000), r9.xxxx
add r9.yzw, r9.xxyz, l(0.000000, 1.000000, 0.333300, -0.333300)
mad r3.z, -r7.x, l(3.000000), l(2.000000)
div r3.z, l(3.000000), r3.z
mul r10.xyw, r3.zzzz, r9.yzyw
mad r9.yzw, -r9.yyzw, r3.zzzz, l(0.000000, 1.000000, 1.000000, 1.000000)
add r11.xyz, r9.xxxx, l(0.333300, -0.333300, -0.333300, 0.000000)
mad r7.xyw, r11.xyxz, r7.yyyy, l(0.500000, 0.500000, 0.000000, -0.500000)
add r11.xyz, -r7.xywx, l(1.000000, 1.000000, 1.000000, 0.000000)
min r12.xy, r10.yxyy, r11.yxyy
min r10.xz, r7.xxwx, r9.zzwz
mov r12.z, r9.y
mov r12.w, r10.x
mov_sat r9.yzw, r12.zzyw
min_sat r12.y, r7.y, r11.z
mov_sat r12.x, r12.x
mov_sat r10.zw, r10.zzzw
mad r11.xyzw, r4.wwww, l(-2.000000, 2.000000, 2.000000, -2.000000), l(1.000000, 0.000000, -1.000000, 2.000000)
min_sat r11.y, r11.w, r11.y
mov_sat r11.xz, r11.xxzx
if_nz r2.w
  ftoi r3.z, cb3[2].z
  iadd r7.x, cb0[160].x, l(-1)
  imin r3.z, r3.z, r7.x
  imax r3.z, r3.z, l(0)
  ld_structured_indexable(structured_buffer, stride=80)(mixed,mixed,mixed,mixed) r3.z, r3.z, l(32), t1.xxxx
else
  mov r3.z, l(0)
endif
mul r7.xy, r3.zzzz, r11.xyxx
add r7.w, -r9.y, l(1.000000)
add r7.w, -r9.z, r7.w
add r7.w, -r9.w, r7.w
mad r7.x, r7.x, r7.w, r9.w
mad r3.z, r11.y, r3.z, r11.z
mul r10.xy, r3.zzzz, r12.xyxx
add r3.z, r10.w, r10.z
mad r3.z, r3.z, r7.y, r10.y
mul r7.y, r10.z, r11.z
mul r7.w, r9.y, v8.x
mad r8.w, -r9.y, v8.x, r9.y
add r8.w, r8.w, r9.z
lt r12.xyzw, r4.yyyy, l(0.200000, 0.400000, 0.600000, 0.800000)
movc r9.yzw, r12.wwww, cb4[32].xxyz, cb4[31].xxyz
movc r9.yzw, r12.zzzz, cb4[33].xxyz, r9.yyzw
movc r9.yzw, r12.yyyy, cb4[34].xxyz, r9.yyzw
movc r9.yzw, r12.xxxx, cb4[35].xxyz, r9.yyzw
movc r11.xyw, r12.wwww, cb4[37].xyxz, cb4[36].xyxz
movc r11.xyw, r12.zzzz, cb4[38].xyxz, r11.xyxw
movc r11.xyw, r12.yyyy, cb4[39].xyxz, r11.xyxw
movc r11.xyw, r12.xxxx, cb4[40].xyxz, r11.xyxw
mul_sat r13.y, v10.w, l(0.437250)
mov r13.x, -r13.y
add r10.yz, r13.xxyx, l(0.000000, 1.000000, -1.000000, 0.000000)
mad r10.yz, cb4[77].yyyy, r10.yyzy, l(0.000000, 0.000000, 1.000000, 0.000000)
add r9.yzw, r9.yyzw, l(0.000000, 0.0000610351562, 0.0000610351562, 0.0000610351562)
add r13.x, r9.z, r9.y
add r13.x, r9.w, r13.x
mul r13.x, r13.x, l(0.333330)
div_sat r13.xyz, r9.yzwy, r13.xxxx
mul r9.yzw, r10.zzzz, r9.yyzw
mad r9.yzw, r13.xxyz, r10.yyyy, r9.yyzw
add r11.xyw, r11.xyxw, l(0.0000610351562, 0.0000610351562, 0.000000, 0.0000610351562)
add r13.x, r11.y, r11.x
add r13.x, r11.w, r13.x
mul r13.x, r13.x, l(0.333330)
div_sat r13.xyz, r11.xywx, r13.xxxx
mul r11.xyw, r10.zzzz, r11.xyxw
mad r11.xyw, r13.xyxz, r10.yyyy, r11.xyxw
mul r13.xyz, r9.yzwy, cb0[2].xyzx
mul r9.yzw, r9.yyzw, cb0[3].xxyz
mul r14.xyz, r11.xywx, cb0[4].xyzx
mul r11.xyw, r11.xyxw, cb0[7].xyxz
add r15.xyz, r2.xyzx, l(1.175494351E-38, 1.175494351E-38, 1.175494351E-38, 0.000000)
max r10.y, r15.y, r15.x
max r10.y, r15.z, r10.y
rcp r10.y, r10.y
if_nz r2.w
  ftoi r10.z, cb3[2].z
  iadd r13.w, cb0[160].x, l(-1)
  imin r10.z, r10.z, r13.w
  imax r10.z, r10.z, l(0)
  ld_structured_indexable(structured_buffer, stride=80)(mixed,mixed,mixed,mixed) r10.z, r10.z, l(32), t1.xxxx
else
  mov r10.z, l(0)
endif
add r13.w, -r5.w, l(1.000000)
mad r5.w, r10.z, r13.w, r5.w
mul r2.xyz, r2.xyzx, r5.wwww
min r5.w, r10.y, l(1.000000)
mul r15.xyz, r2.xyzx, r5.wwww
mul r16.xyz, r7.yyyy, cb0[5].xyzx
mad r16.xyz, cb0[6].xyzx, r3.zzzz, r16.xyzx
mad r10.yzw, r10.wwww, r11.zzzz, r16.xxyz
mul r14.xyz, r8.wwww, r14.xyzx
mad r11.xyz, r11.xywx, r7.wwww, r14.xyzx
mad r7.xyw, r9.yzyw, r7.xxxx, r11.xyxz
mad r7.xyw, r13.xyxz, r10.xxxx, r7.xyxw
mul r7.xyw, r15.xyxz, r7.xyxw
mad r2.xyz, r2.xyzx, r10.yzwy, r7.xywx
lt r3.z, l(0.500000), v8.z
movc r7.xyw, r3.zzzz, r3.xyxw, v2.xyxz
dp3 r5.w, r1.xyzx, l(0.290000, 0.600000, 0.110000, 0.000000)
mad r5.w, r5.w, l(0.287500), l(1.437500)
dp3 r7.x, r8.xyzx, r7.xywx
add r7.y, -r7.z, r7.x
mad_sat r7.y, -r7.y, l(3.000000), l(1.000000)
add r7.w, r7.y, r7.y
sqrt r7.y, r7.y
mul r7.y, r7.y, r7.w
min r7.y, r7.y, l(1.000000)
mad r7.w, r7.z, l(0.500000), l(0.500000)
mov_sat r8.w, r7.z
mad r7.y, r7.w, r7.y, -r8.w
mad r7.y, r7.y, l(0.500000), r8.w
mov_sat r7.x, r7.x
max r8.w, r1.z, r1.y
max r8.w, r1.x, r8.w
lt r9.y, l(1.000000), r8.w
div r10.xyz, r1.xyzx, r8.wwww
movc r9.yzw, r9.yyyy, r10.xxyz, r1.xxyz
add r8.w, -r5.w, l(1.000000)
mad r5.w, r7.y, r8.w, r5.w
log r9.yzw, r9.yyzw
mul r9.yzw, r5.wwww, r9.yyzw
exp r9.yzw, r9.yyzw
add r10.xyz, -r1.xyzx, r9.yzwy
mad r1.xyz, r10.xyzx, l(0.500000, 0.500000, 0.500000, 0.000000), r1.xyzx
add r9.yzw, -r1.xxyz, r9.yyzw
mad r1.xyz, r7.xxxx, r9.yzwy, r1.xyzx
mad r5.w, -r0.x, l(0.960000), l(0.960000)
mul r9.yzw, r1.xxyz, r5.wwww
add r10.xyz, r1.xyzx, l(-0.040000, -0.040000, -0.040000, 0.000000)
mad r10.xyz, r0.xxxx, r10.xyzx, l(0.040000, 0.040000, 0.040000, 0.000000)
mad r7.x, -r0.z, cb4[81].x, l(1.000000)
mul r7.x, r7.x, r7.x
mad r7.y, r7.x, l(4.000000), l(2.000000)
mul r8.w, r7.x, r7.x
mad r10.w, r7.x, r7.x, l(-1.000000)
add r11.xyz, r2.xyzx, cb0[1].xyzx
add r11.xyz, r11.xyzx, v9.xyzx
dp3 r11.x, r11.xyzx, l(0.212672904, 0.715152204, 0.072175, 0.000000)
add r11.y, -cb0[12].x, cb0[12].y
div r11.z, l(1.000000, 1.000000, 1.000000, 1.000000), r11.y
mad r11.w, -cb0[12].x, r11.z, l(1.000000)
mad r11.z, r11.x, r11.z, r11.w
rcp r11.z, r11.z
mad r11.y, -r11.y, r11.z, cb0[12].y
lt r11.z, r11.x, cb0[12].x
movc r11.y, r11.z, r11.x, r11.y
add r11.x, r11.x, l(0.000100)
div r11.x, r11.y, r11.x
mul r11.yzw, r2.xxyz, r11.xxxx
movc r13.x, r12.w, cb4[84].z, cb4[84].y
movc r13.x, r12.z, cb4[84].w, r13.x
movc r13.x, r12.y, cb4[85].x, r13.x
movc r13.x, r12.x, cb4[85].y, r13.x
movc r13.yzw, r12.wwww, cb4[47].xxyz, cb4[46].xxyz
movc r13.yzw, r12.zzzz, cb4[48].xxyz, r13.yyzw
movc r13.yzw, r12.yyyy, cb4[49].xxyz, r13.yyzw
movc r13.yzw, r12.xxxx, cb4[50].xxyz, r13.yyzw
lt r14.x, l(0.500000), r13.x
if_nz r14.x
  mad_sat r9.x, r9.x, l(1.500000), l(-0.500000)
  movc r14.x, r12.w, cb4[85].w, cb4[85].z
  movc r14.x, r12.z, cb4[86].x, r14.x
  movc r14.x, r12.y, cb4[86].y, r14.x
  movc r14.x, r12.x, cb4[86].z, r14.x
  mad r14.yzw, r5.xxyz, r1.wwww, r8.xxyz
  dp3 r15.x, r14.yzwy, r14.yzwy
  rsq r15.x, r15.x
  mul r14.yzw, r14.yyzw, r15.xxxx
  dp3_sat r14.y, r3.xywx, r14.yzwy
  mul r9.x, r9.x, r9.x
  mad r9.x, -r9.x, r14.y, l(1.000000)
  add r9.x, r4.x, -r9.x
  max r14.x, r14.x, l(0.000010)
  div_sat r4.x, r9.x, r14.x
endif
mul r4.x, r4.x, cb4[86].w
mul r13.yzw, r13.yyzw, r4.xxxx
mul r13.yzw, r10.xxyz, r13.yyzw
lt r4.x, r13.x, l(0.500000)
mad r5.xyz, r5.xyzx, r1.wwww, r8.xyzx
dp3 r1.w, r5.xyzx, r5.xyzx
rsq r1.w, r1.w
mul r5.xyz, r1.wwww, r5.xyzx
movc r1.w, r12.w, cb4[83].y, cb4[83].x
movc r1.w, r12.z, cb4[83].z, r1.w
movc r1.w, r12.y, cb4[83].w, r1.w
movc r1.w, r12.x, cb4[84].x, r1.w
mul r7.z, r7.z, r1.w
mad_sat r7.z, r7.z, l(0.750000), l(0.250000)
dp3 r9.x, r3.xywx, r5.xyzx
mul r9.x, r1.w, r9.x
mad_sat r9.x, r9.x, l(0.750000), l(0.250000)
dp3 r5.x, r8.xyzx, r5.xyzx
mul r1.w, r1.w, r5.x
mad_sat r1.w, r1.w, l(0.750000), l(0.250000)
mul r5.x, r9.x, r9.x
mad r5.x, r5.x, r10.w, l(1.000010)
mul r1.w, r1.w, r1.w
mul r5.x, r5.x, r5.x
max r1.w, r1.w, l(0.100000)
mul r5.x, r1.w, r5.x
mul r5.x, r7.y, r5.x
div r5.x, r8.w, r5.x
mad_sat r0.z, -r0.z, cb4[81].x, r5.x
mul r0.z, r7.z, r0.z
max r5.x, r7.x, l(0.000010)
div r0.z, r0.z, r5.x
movc r5.x, r12.w, cb4[82].x, cb4[81].w
movc r5.x, r12.z, cb4[82].y, r5.x
movc r5.x, r12.y, cb4[82].z, r5.x
movc r5.x, r12.x, cb4[82].w, r5.x
movc r5.y, r12.w, cb4[93].w, cb4[93].z
movc r5.y, r12.z, cb4[94].x, r5.y
movc r5.y, r12.y, cb4[94].y, r5.y
movc r5.y, r12.x, cb4[94].z, r5.y
mul r5.x, r5.y, r5.x
mul r0.z, r0.z, r5.x
mul_sat r0.z, r0.z, l(10.000000)
mul r0.z, r0.z, l(100.000000)
div r1.w, l(0.166663334), r1.w
min r1.w, r1.w, l(1.000000)
mul r1.w, r7.z, r1.w
mul r1.w, r1.w, l(100.000000)
movc r0.z, r4.x, r0.z, r1.w
mul r5.xyz, r13.yzwy, r0.zzzz
mul r7.xyz, r11.yzwy, r5.xyzx
mad r5.xyz, r5.xyzx, r11.yzwy, l(-1.000000, -1.000000, -1.000000, 0.000000)
max r5.xyz, r5.xyzx, l(0.000000, 0.000000, 0.000000, 0.000000)
mad r7.xyz, r9.yzwy, r11.yzwy, r7.xyzx
ge r0.z, cb4[87].x, l(0.500000)
movc r13.xyz, r12.wwww, cb4[52].xyzx, cb4[51].xyzx
movc r13.xyz, r12.zzzz, cb4[53].xyzx, r13.xyzx
movc r12.yzw, r12.yyyy, cb4[54].xxyz, r13.xxyz
movc r12.xyz, r12.xxxx, cb4[55].xyzx, r12.yzwy
mul r12.xyz, r0.yyyy, r12.xyzx
mul r12.xyz, r1.xyzx, r12.xyzx
and r12.xyz, r0.zzzz, r12.xyzx
add r0.y, r12.y, r12.x
add r0.y, r12.z, r0.y
mul r0.z, r4.y, l(4.500000)
round_ni r0.z, r0.z
add r0.z, -r0.z, l(4.000000)
ftoi r0.z, r0.z
ieq r0.z, r0.z, cb4[77].x
mul r13.xyz, r11.xxxx, v9.xyzx
mad r7.xyz, r13.xyzx, r9.yzwy, r7.xyzx
mul r1.xyw, r1.xyxz, cb0[1].xyxz
mad r1.xyw, r1.xyxw, r11.xxxx, r7.xyxz
add r1.xyw, r5.xyxz, r1.xyxw
ge r4.x, l(0.500000), cb0[160].y
if_nz r4.x
  dp3 r4.x, r6.xyzx, r8.xyzx
  mad r4.x, -r4.x, l(0.500000), l(0.500000)
  mad r5.x, r4.x, l(0.800000), l(0.200000)
  mad r5.y, r3.y, l(0.500000), l(0.500000)
  mul r5.z, r5.y, r5.y
  movc r5.y, r0.z, r5.y, r5.z
  add r5.y, r5.y, l(-0.200000)
  mul_sat r5.y, r5.y, l(1.250000)
  mad r5.z, r5.y, l(-2.000000), l(3.000000)
  mul r5.y, r5.y, r5.y
  mul r5.y, r5.y, r5.z
  mul r5.z, r5.y, r5.y
  mul r5.z, r5.z, r5.z
  mul r5.z, r5.z, r5.y
  movc r7.xyz, r0.zzzz, l(1.000000,0.300000,-1.000000,0), l(0.500000,1.000000,-0.500000,0)
  add r7.y, r7.z, r7.y
  mad r5.z, r5.z, r7.y, r7.x
  mul r5.y, r5.z, r5.y
  mul r4.w, r4.w, r7.w
  mad r4.w, r4.w, l(1.400000), l(0.100000)
  if_nz r2.w
    ftoi r2.w, cb3[2].z
    iadd r5.z, cb0[160].x, l(-1)
    imin r2.w, r2.w, r5.z
    imax r2.w, r2.w, l(0)
    ld_structured_indexable(structured_buffer, stride=80)(mixed,mixed,mixed,mixed) r2.w, r2.w, l(32), t1.xxxx
  else
    mov r2.w, l(0)
  endif
  mad r2.w, r2.w, l(0.399999976), r6.w
  add_sat r2.w, r2.w, l(0.600000)
  mul r5.x, r5.y, r5.x
  mul r4.w, r4.w, r5.x
  mul r2.w, r2.w, r4.w
  ne r4.w, l(0.000000, 0.000000, 0.000000, 0.000000), v8.z
  mov_sat r5.x, -r6.y
  mad r4.z, r4.z, cb4[80].w, l(2.500000)
  movc r4.z, r4.w, l(4.500000), r4.z
  mad r4.z, r5.x, r4.z, l(0.500000)
  mul r2.w, r2.w, r4.z
  sqrt r0.w, r0.w
  mul r4.z, r0.w, l(0.0833333358)
  min r4.z, r4.z, l(1.000000)
  mad r4.zw, r4.zzzz, l(0.000000, 0.000000, -0.300000, -0.300000), l(0.000000, 0.000000, 0.500000, 0.600000)
  dp3 r5.x, r6.xyzx, r3.xywx
  add r5.x, -r5.x, l(1.000000)
  add r4.zw, -r4.zzzw, r5.xxxx
  mul_sat r4.zw, r4.zzzw, l(0.000000, 0.000000, 3.33333325, 5.00000048)
  mad r5.xy, r4.zwzz, l(-2.000000, -2.000000, 0.000000, 0.000000), l(3.000000, 3.000000, 0.000000, 0.000000)
  mul r4.zw, r4.zzzw, r4.zzzw
  mul r4.zw, r4.zzzw, r5.xxxy
  movc r4.z, r0.z, r4.z, r4.w
  dp3 r4.w, cb0[161].xyzx, l(0.330000, 0.330000, 0.330000, 0.000000)
  mul r5.xyz, cb0[161].xyzx, cb0[161].xyzx
  mul r5.xyz, r5.xyzx, r5.xyzx
  mul r5.xyz, r5.xyzx, r5.xyzx
  dp3 r6.x, r5.xyzx, l(0.700000, 0.700000, 0.700000, 0.000000)
  add r6.x, r6.x, l(0.0000610351562)
  rcp r6.x, r6.x
  mul r4.w, r4.w, r6.x
  mad r5.xyz, r4.wwww, r5.xyzx, -r11.yzwy
  mad r5.xyz, r6.wwww, r5.xyzx, r11.yzwy
  mul r4.x, r4.x, r4.x
  log r4.x, r4.x
  mul r4.x, r4.x, l(20.000000)
  exp r4.x, r4.x
  mad r2.xyz, r2.xyzx, r11.xxxx, -r5.xyzx
  mad r2.xyz, r4.xxxx, r2.xyzx, r5.xyzx
  add r4.x, r9.z, r9.y
  mad r1.z, r1.z, r5.w, r4.x
  mul r1.z, r1.z, l(0.330000)
  mul r1.z, r1.z, r1.z
  mad r1.z, r1.z, l(-0.199999988), l(1.000000)
  mul r4.x, cb0[170].x, l(48.000000)
  mul r1.z, r1.z, l(0.100000)
  log r5.xyz, r9.yzwy
  mul r5.xyz, r5.xyzx, l(0.200000, 0.200000, 0.200000, 0.000000)
  exp r5.xyz, r5.xyzx
  dp3 r4.w, r5.xyzx, r5.xyzx
  max r4.w, r4.w, l(1.175494351E-38)
  rsq r4.w, r4.w
  mul r5.xyz, r4.wwww, r5.xyzx
  mul r6.xyz, r1.zzzz, r5.xyzx
  mad r5.xyz, -r1.zzzz, r5.xyzx, r10.xyzx
  mad r5.xyz, r0.xxxx, r5.xyzx, r6.xyzx
  mul r5.xyz, r4.xxxx, r5.xyzx
  mul r0.x, r2.w, r4.z
  mul r2.xyz, r2.xyzx, r0.xxxx
  mul r2.xyz, r5.xyzx, r2.xyzx
  lt r4.xyzw, r4.yyyy, l(0.200000, 0.400000, 0.600000, 0.800000)
  movc r5.xyz, r4.wwww, cb4[58].xyzx, cb4[57].xyzx
  movc r5.xyz, r4.zzzz, cb4[59].xyzx, r5.xyzx
  movc r4.yzw, r4.yyyy, cb4[60].xxyz, r5.xxyz
  movc r4.xyz, r4.xxxx, cb4[61].xyzx, r4.yzwy
  mul r2.xyz, r2.xyzx, r4.xyzx
  mad_sat r0.x, r0.w, l(0.200000), l(-1.000000)
  mad r0.x, r0.x, l(-0.700000), l(1.000000)
  mul r2.xyw, r0.xxxx, r2.xyxz
  add r0.w, r2.y, r2.x
  mad r0.x, r2.z, r0.x, r0.w
  mul r0.x, r0.x, l(0.330000)
  mul r0.x, r0.x, r0.x
  mad r0.x, r0.x, l(0.500000), l(1.000000)
  mul r2.xyz, r0.xxxx, r2.xywx
  movc r0.x, r3.z, l(0.500000), l(1.000000)
  mul r2.xyz, r0.xxxx, r2.xyzx
else
  mov r2.xyz, l(0,0,0,0)
endif
mad r4.xyz, r13.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(1.000000, 1.000000, 1.000000, 0.000000)
mul r2.xyz, r2.xyzx, r4.xyzx
add o0.xyz, r12.xyzx, r1.xywx
max r1.xyz, r2.xyzx, l(0.000000, 0.000000, 0.000000, 0.000000)
sqrt r1.xyz, r1.xyzx
mul r1.xyz, r1.xyzx, l(0.200000, 0.200000, 0.200000, 0.000000)
min o1.xyz, r1.xyzx, l(1.000000, 1.000000, 1.000000, 0.000000)
mul o1.w, r0.y, l(0.333300)
and o2.w, r0.z, l(0x3eae147b)
mad o3.xyz, r3.xywx, l(0.500000, 0.500000, 0.500000, 0.000000), l(0.500000, 0.500000, 0.500000, 0.000000)
mov o0.w, l(1.000000)
mov o3.w, l(1.000000)
ret
// Approximately 0 instruction slots used

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