//water edges
// ---- Created with 3Dmigoto v1.2.67 on Wed Nov 29 11:28:34 2017
Texture2D<float4> t13 : register(t13);

Texture2D<float4> t12 : register(t12);

Texture2D<float4> t11 : register(t11);

Texture2D<float4> t10 : register(t10);

Texture2D<float4> t8 : register(t8);

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> t2 : register(t2);

Texture2D<float4> t1 : register(t1);

SamplerState s13_s : register(s13);

SamplerState s12_s : register(s12);

SamplerState s11_s : register(s11);

SamplerState s10_s : register(s10);

SamplerState s8_s : register(s8);

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 s2_s : register(s2);

SamplerState s1_s : register(s1);

cbuffer cb11 : register(b11)
{
  float4 cb11[192];
}

cbuffer cb10 : register(b10)
{
  float4 cb10[4];
}

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

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

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

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

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




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


void main(
  float4 v0 : SV_POSITION0,
  linear centroid float4 v1 : TEXCOORD0,
  linear centroid float4 v2 : TEXCOORD1,
  linear centroid float4 v3 : TEXCOORD2,
  linear centroid float4 v4 : TEXCOORD3,
  linear centroid float4 v5 : TEXCOORD4,
  linear centroid float4 v6 : TEXCOORD5,
  linear centroid float4 v7 : TEXCOORD6,
  linear centroid float4 v8 : TEXCOORD8,
  out float4 o0 : SV_Target0)
{
  float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11,r12,r13,r14;
  uint4 bitmask, uiDest;
  float4 fDest;

float4 r15 = v2;
float4 stereo = StereoParams.Load(0);
r15.x += stereo.x*(r15.z - stereo.y) * (cb9[6].x - 0.05);

  r0.xy = v3.xz + v3.xz;
  r0.x = r0.x + r0.y;
  r0.x = sin(r0.x);
  r0.y = dot(v3.xz, float2(2.17000008,2.17000008));
  r0.y = cos(r0.y);
  r0.x = r0.x + r0.y;
  r1.xyzw = float4(0.100000001,0.100000001,0.135000005,0.135000005) * v3.xzxz;
  r0.y = t6.Sample(s6_s, r1.xy).x;
  r0.y = -0.5 + r0.y;
  r0.x = r0.x * 0.00400000019 + v7.z;
  r0.x = r0.y * 0.100000001 + r0.x;
  r0.y = 0.200000003 + r0.x;
  r0.z = dot(v4.xyz, v4.xyz);
  r0.z = rsqrt(r0.z);
  r0.z = v4.y * r0.z + -0.850000024;
  r0.yz = saturate(float2(20,10) * r0.yz);
  r1.xyzw = sin(r1.xyzw);
  r1.xy = max(r1.xz, r1.yw);
  r0.z = cb9[39].y * r0.z;
  r1.zw = cb9[38].xy + abs(r1.xy);
  r1.zw = r1.zw * r0.zz + -r0.xx;
  r2.xyzw = saturate(float4(100,10,100,10) * r1.zzww);
  r0.zw = abs(r1.xy) * r0.zz + -r0.xx;
  r0.zw = float2(0.0500000007,0.0500000007) + r0.zw;
  r3.xy = saturate(float2(10,10) * r0.zw);
  r4.xy = r2.xz * r2.xz;
  r4.z = r3.x;
  r4.w = r2.y;
  r2.xyz = r4.xzw * r0.yyy;
  r3.z = r4.y;
  r3.w = r2.w;
  r0.yzw = r3.zyw * r0.yyy;
  r0.zw = max(r2.yz, r0.zw);
  r1.x = cmp(r0.z < 0.00100000005);
  r2.yz = float2(0.5,0.5) * v3.xz;
  r2.yz = t7.Sample(s7_s, r2.yz).yw;
  r3.xy = r2.yz * float2(2,2) + float2(-1,-1);
  r3.z = 3;
  r1.y = dot(r3.xyz, r3.xyz);
  r1.y = rsqrt(r1.y);
  r2.y = 1 + -r0.w;
  r4.xyz = cb6[6].xyz + -v1.xyz;
  r2.z = dot(r4.xyz, r4.xyz);
  r2.z = sqrt(r2.z);
  r2.z = 9.99999975e-005 + r2.z;
  r4.xyz = r4.xyz / r2.zzz;
  r2.zw = t1.Sample(s1_s, v5.xy).yw;
  r5.xy = t1.Sample(s1_s, v5.zw).yw;
  r2.zw = r2.zw * float2(2,2) + float2(-1,-1);
  r5.xy = r5.xy * float2(2,2) + float2(-1,-1);
  r6.xyzw = float4(0.25,0.25,0.5,0.5) + v5.zwzw;
  r5.zw = t1.Sample(s1_s, r6.xy).yw;
  r6.xy = t1.Sample(s1_s, r6.zw).yw;
  r6.zw = float2(0.75,0.75) + v5.zw;
  r6.zw = t1.Sample(s1_s, r6.zw).yw;
  r7.xy = t3.Sample(s3_s, v6.xy).yw;
  r8.xyzw = float4(0.25,0.25,0.5,0.5) + v6.xyxy;
  r7.zw = t3.Sample(s3_s, r8.xy).yw;
  r8.xy = t3.Sample(s3_s, r8.zw).yw;
  r8.zw = float2(0.75,0.75) + v6.xy;
  r8.zw = t3.Sample(s3_s, r8.zw).yw;
  r5.zw = r5.zw * float2(2,2) + float2(-1,-1);
  r6.xy = r6.xy * float2(2,2) + float2(-1,-1);
  r6.zw = r6.zw * float2(2,2) + float2(-1,-1);
  r7.xy = r7.xy * float2(2,2) + float2(-1,-1);
  r7.zw = r7.zw * float2(2,2) + float2(-1,-1);
  r8.xy = r8.xy * float2(2,2) + float2(-1,-1);
  r8.zw = r8.zw * float2(2,2) + float2(-1,-1);
  r3.w = cb9[5].x * 0.800000012 + 0.400000006;
  r9.xyzw = cb9[1].xyzw * r3.wwww;
  r9.xyzw = v6.zzzz * r9.xyzw;
  r10.xyzw = cb9[2].xyzw * r3.wwww;
  r10.xyzw = v6.wwww * r10.xyzw;
  r5.zw = r9.yy * r5.zw;
  r5.zw = r5.xy * r9.xx + r5.zw;
  r5.zw = r6.xy * r9.zz + r5.zw;
  r5.zw = r6.zw * r9.ww + r5.zw;
  r6.xy = r10.yy * r7.zw;
  r6.xy = r7.xy * r10.xx + r6.xy;
  r6.xy = r8.xy * r10.zz + r6.xy;
  r6.xy = r8.zw * r10.ww + r6.xy;
  r2.zw = r5.xy + r2.zw;
  r5.xy = r2.zw * float2(1.79999995,1.79999995) + r5.zw;
  r5.xy = r5.xy + r6.xy;
  r5.z = cb9[4].y;
  r3.w = dot(r5.xyz, r5.xyz);
  r3.w = rsqrt(r3.w);
  r5.xyz = r5.xyz * r3.www;
  r3.xyz = r3.xyz * r1.yyy + -r5.xyz;
  r3.xyz = r2.yyy * r3.xyz + r5.xyz;
  r1.y = dot(r3.xyz, r3.xyz);
  r1.y = rsqrt(r1.y);
  r3.xyz = r3.xyz * r1.yyy;
  r5.xyz = float3(1,0,0) * v4.zxy;
  r5.xyz = v4.xyz * float3(0,1,0) + -r5.xyz;
  r1.y = dot(r5.xy, r5.xy);
  r1.y = rsqrt(r1.y);
  r5.xyz = r5.xyz * r1.yyy;
  r6.xyz = v4.zxy * r5.xyz;
  r6.xyz = v4.yzx * r5.yzx + -r6.xyz;
  r7.xyz = v4.xyz * r3.zzz;
  r6.xyz = r6.yzx * r3.yyy + r7.yzx;
  r6.xy = r5.xy * -r3.xx + r6.xy;
  r1.y = dot(-r4.yzx, r6.xyz);
  r1.y = r1.y + r1.y;
  r3.xyz = r6.zxy * -r1.yyy + -r4.xyz;
  r1.y = dot(r3.xz, r3.xz);
  r3.zw = r3.xz * r1.yy;
  r3.zw = r3.zw * float2(0.449999988,0.449999988) + float2(0.5,0.5);
  r5.xyz = t4.Sample(s4_s, r3.zw).xyz;
  r7.xyz = t5.Sample(s5_s, r3.zw).xyz;
  r3.zw = v0.xy * cb9[3].xy + cb9[3].zw;
  r1.y = cb9[35].x * r0.w;
  r8.xy = r6.zy * r1.yy + r3.zw;
  r4.w = t11.SampleLevel(s11_s, r8.xy, 0).x;
  r4.w = -v2.z + r4.w;
  r4.w = 0.0500000007 + r4.w;
  r4.w = saturate(100000 * r4.w);
  r1.y = r4.w * r1.y;
  r3.zw = r6.zy * r1.yy + r3.zw;
  r8.xyz = t10.Sample(s10_s, r3.zw).xyz;
  r9.xyzw = float4(50.0999985,50.0999985,10.1999998,10.1999998) * v5.xyzw;
  r3.zw = float2(0.109999999,0.109999999) * v6.xy;
  r1.y = t2.Sample(s2_s, r9.xy).x;
  r4.w = t2.Sample(s2_s, r9.zw).x;
  r3.z = t2.Sample(s2_s, r3.zw).x;
  r9.xy = cb9[36].yy * r6.zy;
  r9.xy = v3.xz * cb9[36].zz + r9.xy;
  r9.xy = cb9[37].xy + r9.xy;
  r3.w = t2.Sample(s2_s, r9.xy).x;
  if (r1.x != 0) {
    o0.xyzw = float4(0,0,0,0);
    return;
  }
  r1.xz = saturate(float2(15,15) * r1.zw);
  r1.xz = float2(1,1) + -r1.xz;
  r0.x = saturate(20 * r0.x);
  r1.xz = r1.xz * r0.xx;
  r9.xy = max(cb9[38].zw, float2(0,0));
  r0.x = dot(r1.xx, r9.xx);
  r1.xw = cb9[38].zw * float2(0.300000012,0.300000012);
  r1.xw = min(float2(0,0), r1.xw);
  r0.x = r1.x + r0.x;
  r0.x = r0.x + r3.w;
  r1.x = dot(r1.zz, r9.yy);
  r1.x = r1.w + r1.x;
  r1.x = r1.x + r3.w;
  r1.z = cb9[39].z + -1;
  r1.z = r2.y * r1.z + 1;
  r9.xy = r2.zw + r2.zw;
  r9.z = 1;
  r1.w = dot(r9.xyz, r9.xyz);
  r1.w = rsqrt(r1.w);
  r2.z = dot(r6.zxy, r4.xyz);
  r2.z = max(0, r2.z);
  r2.z = 1 + -r2.z;
  r2.w = r2.z * r2.z;
  r2.w = r2.w * r2.w;
  r2.z = r2.z * r2.w;
  r2.z = r2.z * 0.980000019 + 0.0199999996;
  r5.xyz = -r7.xyz + r5.xyz;
  r5.xyz = v7.www * r5.xyz + r7.xyz;
  r3.xy = r3.xy * float2(0.5,-0.5) + float2(0.5,0.5);
  r2.w = saturate(cb5[6].w * 0.00100000005);
  r2.w = 1 + -r2.w;
  r2.w = log2(r2.w);
  r2.w = 10 * r2.w;
  r2.w = exp2(r2.w);
  r2.w = 8 * r2.w;
  r7.xyzw = t8.SampleLevel(s8_s, r3.xy, r2.w).xyzw;
  r2.w = 1 + -r7.w;
  r2.w = 4 * r2.w;
  r2.w = exp2(r2.w);
  r3.xyw = r7.xyz * r2.www + -r5.xyz;
  r3.xyw = r2.yyy * r3.xyw + r5.xyz;
  r5.xyz = cb1[2].xyz * r3.xyw;
  r7.xyz = -v4.xyz + r6.zxy;
  r7.xyz = cb9[33].www * r7.xyz + v4.xyz;
  r2.y = dot(r7.xyz, r7.xyz);
  r2.y = rsqrt(r2.y);
  r7.xyz = r7.xyz * r2.yyy;
  r2.y = dot(-r4.xyz, r7.xyz);
  r2.y = r2.y + r2.y;
  r2.y = r7.y * -r2.y + -r4.y;
  r2.y = saturate(-100 * r2.y);
  r2.y = 1 + r2.y;
  r2.w = cb9[33].x * r0.w;
  r2.y = r2.w * r2.y;
  r2.y = cmp(0.00100000005 < r2.y);
  if (r2.y != 0) {
    r2.y = cb9[33].y + -v2.z;
    r2.w = cmp(0 < r2.y);
    if (r2.w != 0) {
      r9.x = dot(r7.xyz, cb9[40].xyz);
      r9.y = dot(r7.xyz, cb9[41].xyz);
      r9.z = dot(r7.xyz, cb9[42].xyz);
      r2.w = dot(v2.xyz, v2.xyz);
      r2.w = rsqrt(r2.w);

      r7.xyz = r15.xyz * r2.www;

      r2.w = dot(r7.xyz, r9.xyz);
      r2.w = r2.w + r2.w;
      r7.xyz = r9.xyz * -r2.www + r7.xyz;
      r2.w = -0.200000003 + r7.z;
      r2.w = saturate(5 * r2.w);
      r5.w = cmp(r2.w >= 0.00999999978);
      if (r5.w != 0) {
        r2.y = r2.y / r7.z;
        r7.xyz = r7.xyz * r2.yyy + v2.xyz;
        r9.xyz = cb9[30].xyw * v2.yyy;

        r9.xyz = cb9[29].xyw * r15.xxx + r9.xyz;

        r9.xyz = cb9[31].xyw * v2.zzz + r9.xyz;
        r9.xyz = cb9[32].xyw + r9.xyz;
        r10.xyz = cb9[30].xyw * r7.yyy;
        r7.xyw = cb9[29].xyw * r7.xxx + r10.xyz;
        r7.xyz = cb9[31].xyw * r7.zzz + r7.xyw;
        r7.xyz = cb9[32].xyw + r7.xyz;
        r2.y = 1 / r9.z;
        r5.w = 1 / r7.z;
        r9.xy = r9.xy * r2.yy;
        r7.xy = r7.xy * r5.ww;
        r9.z = -r9.y;
        r9.xy = float2(1,1) + r9.xz;
        r9.zw = float2(0.5,0.5) * r9.xy;
        r7.z = -r7.y;
        r7.xy = float2(1,1) + r7.xz;
        r7.xy = r7.xy * float2(0.5,0.5) + -r9.zw;
        r7.zw = cmp(float2(0,0) < r7.xy);
        r9.xy = -r9.xy * float2(0.5,0.5) + float2(1,1);
        r9.xy = saturate(r9.xy / r7.xy);
        r10.xy = float2(9.99999975e-005,9.99999975e-005) + -r7.xy;
        r10.xy = saturate(r9.zw / r10.xy);
        r7.zw = r7.zw ? r9.xy : r10.xy;
        r7.z = min(r7.z, r7.w);
        r7.xy = r7.xy * r7.zz;
        r5.w = r5.w + -r2.y;
        r5.w = r5.w * r7.z;
        r7.z = 0.125 * r5.w;
        r7.w = cb9[33].y * 0.75;
        r7.w = min(100, r7.w);
        r8.w = cb9[33].y + -r7.w;
        r8.w = 1 / r8.w;
        r10.xyzw = r7.xyxy * float4(0.0125000002,0.0125000002,0.0437499993,0.0437499993) + r9.zwzw;
        r11.xyz = r5.www * float3(0.0125000002,0.0437499993,0.075000003) + r2.yyy;
        r9.x = t13.SampleLevel(s13_s, r10.xy, 0).x;
        r9.y = saturate(9.99999975e-005 + -r9.x);
        r9.y = r9.x + r9.y;
        r9.y = 1 / r9.y;
        r9.y = r11.x + -r9.y;
        r9.y = cmp(abs(r9.y) < abs(r7.z));
        if (r9.y != 0) {
          r11.xw = float2(-0.5,-0.5) + r10.xy;
          r11.x = max(abs(r11.x), abs(r11.w));
          r11.x = r11.x + r11.x;
          r11.x = log2(r11.x);
          r11.x = cb9[34].x * r11.x;
          r11.x = saturate(exp2(r11.x));
          r11.x = 1 + -r11.x;
          r9.x = r9.x + -r7.w;
          r9.x = saturate(r9.x * r8.w);
          r9.x = 1 + -r9.x;
          r9.x = log2(r9.x);
          r9.x = cb9[34].y * r9.x;
          r9.x = exp2(r9.x);
          r12.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
          r9.x = r11.x * r9.x;
          r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyz;
          r12.xyz = r9.xxx * r12.xyz + r5.xyz;
        } else {
          r12.xyz = r5.xyz;
        }
        r9.x = r9.y ? 0.0125000002 : 0.137500003;
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r11.x = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r11.x = -r12.w + r11.x;
            r11.x = cmp(abs(r11.x) < abs(r7.z));
            if (r11.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r10.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r10.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r10.xxx * r13.xyz + r5.xyz;
            }
            r10.x = r9.y ? 0.137500003 : 0.262499988;
            r9.x = r11.x ? r9.x : r10.x;
          } else {
            r11.x = -1;
          }
          r9.y = (int)r9.y | (int)r11.x;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r11.x = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r11.x = -r12.w + r11.x;
            r11.x = cmp(abs(r11.x) < abs(r7.z));
            if (r11.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r10.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r10.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r10.xxx * r13.xyz + r5.xyz;
            }
            r10.x = 0.125 + r9.x;
            r9.x = r11.x ? r9.x : r10.x;
          } else {
            r11.x = -1;
          }
          r9.y = (int)r9.y | (int)r11.x;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r11.x = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r11.x = -r12.w + r11.x;
            r11.x = cmp(abs(r11.x) < abs(r7.z));
            if (r11.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r10.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r10.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r10.xxx * r13.xyz + r5.xyz;
            }
            r10.x = 0.125 + r9.x;
            r9.x = r11.x ? r9.x : r10.x;
          } else {
            r11.x = -1;
          }
          r9.y = (int)r9.y | (int)r11.x;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r11.x = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r11.x = -r12.w + r11.x;
            r11.x = cmp(abs(r11.x) < abs(r7.z));
            if (r11.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r10.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r10.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r10.xxx * r13.xyz + r5.xyz;
            }
            r10.x = 0.125 + r9.x;
            r9.x = r11.x ? r9.x : r10.x;
          } else {
            r11.x = -1;
          }
          r9.y = (int)r9.y | (int)r11.x;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r11.x = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r11.x = -r12.w + r11.x;
            r11.x = cmp(abs(r11.x) < abs(r7.z));
            if (r11.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r10.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r10.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r10.xxx * r13.xyz + r5.xyz;
            }
            r10.x = 0.125 + r9.x;
            r9.x = r11.x ? r9.x : r10.x;
          } else {
            r11.x = -1;
          }
          r9.y = (int)r9.y | (int)r11.x;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r11.x = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r11.x = -r12.w + r11.x;
            r11.x = cmp(abs(r11.x) < abs(r7.z));
            if (r11.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r10.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r10.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r10.xxx * r13.xyz + r5.xyz;
            }
            r10.x = 0.125 + r9.x;
            r9.x = r11.x ? r9.x : r10.x;
          } else {
            r11.x = -1;
          }
          r9.y = (int)r9.y | (int)r11.x;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r11.x = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r11.x = -r12.w + r11.x;
            r11.x = cmp(abs(r11.x) < abs(r7.z));
            if (r11.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r10.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r10.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r10.xxx * r13.xyz + r5.xyz;
            }
            r10.x = 0.125 + r9.x;
            r9.x = r11.x ? r9.x : r10.x;
          } else {
            r11.x = -1;
          }
          r9.y = (int)r9.y | (int)r11.x;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r10.xy = r9.xx * r7.xy + r9.zw;
            r9.x = r9.x * r5.w + r2.y;
            r9.y = t13.SampleLevel(s13_s, r10.xy, 0).x;
            r11.x = saturate(9.99999975e-005 + -r9.y);
            r11.x = r11.x + r9.y;
            r11.x = 1 / r11.x;
            r9.x = -r11.x + r9.x;
            r9.x = cmp(abs(r9.x) < abs(r7.z));
            if (r9.x != 0) {
              r11.xw = float2(-0.5,-0.5) + r10.xy;
              r9.x = max(abs(r11.x), abs(r11.w));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = saturate(exp2(r9.x));
              r9.y = r9.y + -r7.w;
              r9.y = saturate(r9.y * r8.w);
              r9.xy = float2(1,1) + -r9.xy;
              r9.y = log2(r9.y);
              r9.y = cb9[34].y * r9.y;
              r9.y = exp2(r9.y);
              r13.xyz = t12.SampleLevel(s12_s, r10.xy, 0).xyz;
              r9.x = r9.x * r9.y;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r12.xyz = r9.xxx * r13.xyz + r5.xyz;
            }
          }
        }
        r9.x = t13.SampleLevel(s13_s, r10.zw, 0).x;
        r9.y = saturate(9.99999975e-005 + -r9.x);
        r9.y = r9.x + r9.y;
        r9.y = 1 / r9.y;
        r9.y = r11.y + -r9.y;
        r9.y = cmp(abs(r9.y) < abs(r7.z));
        if (r9.y != 0) {
          r10.xy = float2(-0.5,-0.5) + r10.zw;
          r10.x = max(abs(r10.x), abs(r10.y));
          r10.x = r10.x + r10.x;
          r10.x = log2(r10.x);
          r10.x = cb9[34].x * r10.x;
          r10.x = saturate(exp2(r10.x));
          r10.x = 1 + -r10.x;
          r9.x = r9.x + -r7.w;
          r9.x = saturate(r9.x * r8.w);
          r9.x = 1 + -r9.x;
          r9.x = log2(r9.x);
          r9.x = cb9[34].y * r9.x;
          r9.x = exp2(r9.x);
          r10.yzw = t12.SampleLevel(s12_s, r10.zw, 0).xyz;
          r9.x = r10.x * r9.x;
          r10.xyz = -r3.xyw * cb1[2].xyz + r10.yzw;
          r10.xyz = r9.xxx * r10.xyz + r5.xyz;
        } else {
          r10.xyz = r5.xyz;
        }
        r9.x = r9.y ? 0.0437499993 : 0.168750003;
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r10.w = -r12.w + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r11.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r10.xyz = r11.xxx * r13.xyz + r5.xyz;
            }
            r11.x = r9.y ? 0.168750003 : 0.293749988;
            r9.x = r10.w ? r9.x : r11.x;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r10.w = -r12.w + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r11.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r10.xyz = r11.xxx * r13.xyz + r5.xyz;
            }
            r11.x = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.x;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r10.w = -r12.w + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r11.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r10.xyz = r11.xxx * r13.xyz + r5.xyz;
            }
            r11.x = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.x;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r10.w = -r12.w + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r11.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r10.xyz = r11.xxx * r13.xyz + r5.xyz;
            }
            r11.x = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.x;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r10.w = -r12.w + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r11.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r10.xyz = r11.xxx * r13.xyz + r5.xyz;
            }
            r11.x = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.x;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r10.w = -r12.w + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r11.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r10.xyz = r11.xxx * r13.xyz + r5.xyz;
            }
            r11.x = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.x;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r12.w = saturate(9.99999975e-005 + -r11.w);
            r12.w = r12.w + r11.w;
            r12.w = 1 / r12.w;
            r10.w = -r12.w + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r12.w = max(abs(r13.x), abs(r13.y));
              r12.w = r12.w + r12.w;
              r12.w = log2(r12.w);
              r12.w = cb9[34].x * r12.w;
              r12.w = saturate(exp2(r12.w));
              r12.w = 1 + -r12.w;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.xyz = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r11.x = r12.w * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r10.xyz = r11.xxx * r13.xyz + r5.xyz;
            }
            r11.x = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.x;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r11.xy = r9.xx * r7.xy + r9.zw;
            r9.x = r9.x * r5.w + r2.y;
            r9.y = t13.SampleLevel(s13_s, r11.xy, 0).x;
            r10.w = saturate(9.99999975e-005 + -r9.y);
            r10.w = r10.w + r9.y;
            r10.w = 1 / r10.w;
            r9.x = -r10.w + r9.x;
            r9.x = cmp(abs(r9.x) < abs(r7.z));
            if (r9.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r11.xy;
              r9.x = max(abs(r13.x), abs(r13.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = saturate(exp2(r9.x));
              r9.y = r9.y + -r7.w;
              r9.y = saturate(r9.y * r8.w);
              r9.xy = float2(1,1) + -r9.xy;
              r9.y = log2(r9.y);
              r9.y = cb9[34].y * r9.y;
              r9.y = exp2(r9.y);
              r11.xyw = t12.SampleLevel(s12_s, r11.xy, 0).xyz;
              r9.x = r9.x * r9.y;
              r11.xyw = -r3.xyw * cb1[2].xyz + r11.xyw;
              r10.xyz = r9.xxx * r11.xyw + r5.xyz;
            }
          }
        }
        r10.xyz = r12.xyz + r10.xyz;
        r12.xyzw = r7.xyxy * float4(0.075000003,0.075000003,0.106250003,0.106250003) + r9.zwzw;
        r9.x = t13.SampleLevel(s13_s, r12.xy, 0).x;
        r9.y = saturate(9.99999975e-005 + -r9.x);
        r9.y = r9.x + r9.y;
        r9.y = 1 / r9.y;
        r9.y = r11.z + -r9.y;
        r9.y = cmp(abs(r9.y) < abs(r7.z));
        if (r9.y != 0) {
          r11.xy = float2(-0.5,-0.5) + r12.xy;
          r10.w = max(abs(r11.x), abs(r11.y));
          r10.w = r10.w + r10.w;
          r10.w = log2(r10.w);
          r10.w = cb9[34].x * r10.w;
          r10.w = saturate(exp2(r10.w));
          r10.w = 1 + -r10.w;
          r9.x = r9.x + -r7.w;
          r9.x = saturate(r9.x * r8.w);
          r9.x = 1 + -r9.x;
          r9.x = log2(r9.x);
          r9.x = cb9[34].y * r9.x;
          r9.x = exp2(r9.x);
          r11.xyz = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
          r9.x = r10.w * r9.x;
          r11.xyz = -r3.xyw * cb1[2].xyz + r11.xyz;
          r11.xyz = r9.xxx * r11.xyz + r5.xyz;
        } else {
          r11.xyz = r5.xyz;
        }
        r9.x = r9.y ? 0.075000003 : 0.200000003;
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r13.x = saturate(9.99999975e-005 + -r11.w);
            r13.x = r13.x + r11.w;
            r13.x = 1 / r13.x;
            r10.w = -r13.x + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r13.x = max(abs(r13.x), abs(r13.y));
              r13.x = r13.x + r13.x;
              r13.x = log2(r13.x);
              r13.x = cb9[34].x * r13.x;
              r13.x = saturate(exp2(r13.x));
              r13.x = 1 + -r13.x;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.yzw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r13.x * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.yzw;
              r11.xyz = r11.www * r13.xyz + r5.xyz;
            }
            r11.w = r9.y ? 0.200000003 : 0.324999988;
            r9.x = r10.w ? r9.x : r11.w;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r13.x = saturate(9.99999975e-005 + -r11.w);
            r13.x = r13.x + r11.w;
            r13.x = 1 / r13.x;
            r10.w = -r13.x + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r13.x = max(abs(r13.x), abs(r13.y));
              r13.x = r13.x + r13.x;
              r13.x = log2(r13.x);
              r13.x = cb9[34].x * r13.x;
              r13.x = saturate(exp2(r13.x));
              r13.x = 1 + -r13.x;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.yzw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r13.x * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.yzw;
              r11.xyz = r11.www * r13.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.w;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r13.x = saturate(9.99999975e-005 + -r11.w);
            r13.x = r13.x + r11.w;
            r13.x = 1 / r13.x;
            r10.w = -r13.x + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r13.x = max(abs(r13.x), abs(r13.y));
              r13.x = r13.x + r13.x;
              r13.x = log2(r13.x);
              r13.x = cb9[34].x * r13.x;
              r13.x = saturate(exp2(r13.x));
              r13.x = 1 + -r13.x;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.yzw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r13.x * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.yzw;
              r11.xyz = r11.www * r13.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.w;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r13.x = saturate(9.99999975e-005 + -r11.w);
            r13.x = r13.x + r11.w;
            r13.x = 1 / r13.x;
            r10.w = -r13.x + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r13.x = max(abs(r13.x), abs(r13.y));
              r13.x = r13.x + r13.x;
              r13.x = log2(r13.x);
              r13.x = cb9[34].x * r13.x;
              r13.x = saturate(exp2(r13.x));
              r13.x = 1 + -r13.x;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.yzw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r13.x * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.yzw;
              r11.xyz = r11.www * r13.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.w;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r13.x = saturate(9.99999975e-005 + -r11.w);
            r13.x = r13.x + r11.w;
            r13.x = 1 / r13.x;
            r10.w = -r13.x + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r13.x = max(abs(r13.x), abs(r13.y));
              r13.x = r13.x + r13.x;
              r13.x = log2(r13.x);
              r13.x = cb9[34].x * r13.x;
              r13.x = saturate(exp2(r13.x));
              r13.x = 1 + -r13.x;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.yzw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r13.x * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.yzw;
              r11.xyz = r11.www * r13.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.w;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r13.x = saturate(9.99999975e-005 + -r11.w);
            r13.x = r13.x + r11.w;
            r13.x = 1 / r13.x;
            r10.w = -r13.x + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r13.x = max(abs(r13.x), abs(r13.y));
              r13.x = r13.x + r13.x;
              r13.x = log2(r13.x);
              r13.x = cb9[34].x * r13.x;
              r13.x = saturate(exp2(r13.x));
              r13.x = 1 + -r13.x;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.yzw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r13.x * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.yzw;
              r11.xyz = r11.www * r13.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.w;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r10.w = r9.x * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r13.x = saturate(9.99999975e-005 + -r11.w);
            r13.x = r13.x + r11.w;
            r13.x = 1 / r13.x;
            r10.w = -r13.x + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r13.x = max(abs(r13.x), abs(r13.y));
              r13.x = r13.x + r13.x;
              r13.x = log2(r13.x);
              r13.x = cb9[34].x * r13.x;
              r13.x = saturate(exp2(r13.x));
              r13.x = 1 + -r13.x;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r13.yzw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r13.x * r11.w;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.yzw;
              r11.xyz = r11.www * r13.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.x;
            r9.x = r10.w ? r9.x : r11.w;
          } else {
            r10.w = -1;
          }
          r9.y = (int)r9.y | (int)r10.w;
        } else {
          r9.y = -1;
        }
        if (r9.y == 0) {
          if (r9.y == 0) {
            r12.xy = r9.xx * r7.xy + r9.zw;
            r9.x = r9.x * r5.w + r2.y;
            r9.y = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r10.w = saturate(9.99999975e-005 + -r9.y);
            r10.w = r10.w + r9.y;
            r10.w = 1 / r10.w;
            r9.x = -r10.w + r9.x;
            r9.x = cmp(abs(r9.x) < abs(r7.z));
            if (r9.x != 0) {
              r13.xy = float2(-0.5,-0.5) + r12.xy;
              r9.x = max(abs(r13.x), abs(r13.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = saturate(exp2(r9.x));
              r9.y = r9.y + -r7.w;
              r9.y = saturate(r9.y * r8.w);
              r9.xy = float2(1,1) + -r9.xy;
              r9.y = log2(r9.y);
              r9.y = cb9[34].y * r9.y;
              r9.y = exp2(r9.y);
              r13.xyz = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r9.x = r9.x * r9.y;
              r13.xyz = -r3.xyw * cb1[2].xyz + r13.xyz;
              r11.xyz = r9.xxx * r13.xyz + r5.xyz;
            }
          }
        }
        r10.xyz = r11.xyz + r10.xyz;
        r9.x = r5.w * 0.106250003 + r2.y;
        r9.y = t13.SampleLevel(s13_s, r12.zw, 0).x;
        r10.w = saturate(9.99999975e-005 + -r9.y);
        r10.w = r10.w + r9.y;
        r10.w = 1 / r10.w;
        r9.x = -r10.w + r9.x;
        r9.x = cmp(abs(r9.x) < abs(r7.z));
        if (r9.x != 0) {
          r11.xy = float2(-0.5,-0.5) + r12.zw;
          r10.w = max(abs(r11.x), abs(r11.y));
          r10.w = r10.w + r10.w;
          r10.w = log2(r10.w);
          r10.w = cb9[34].x * r10.w;
          r10.w = saturate(exp2(r10.w));
          r10.w = 1 + -r10.w;
          r9.y = r9.y + -r7.w;
          r9.y = saturate(r9.y * r8.w);
          r9.y = 1 + -r9.y;
          r9.y = log2(r9.y);
          r9.y = cb9[34].y * r9.y;
          r9.y = exp2(r9.y);
          r11.xyz = t12.SampleLevel(s12_s, r12.zw, 0).xyz;
          r9.y = r10.w * r9.y;
          r11.xyz = -r3.xyw * cb1[2].xyz + r11.xyz;
          r11.xyz = r9.yyy * r11.xyz + r5.xyz;
        } else {
          r11.xyz = r5.xyz;
        }
        r9.y = r9.x ? 0.106250003 : 0.231250003;
        if (r9.x == 0) {
          if (r9.x == 0) {
            r12.xy = r9.yy * r7.xy + r9.zw;
            r10.w = r9.y * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r12.z = saturate(9.99999975e-005 + -r11.w);
            r12.z = r12.z + r11.w;
            r12.z = 1 / r12.z;
            r10.w = -r12.z + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r12.zw = float2(-0.5,-0.5) + r12.xy;
              r12.z = max(abs(r12.z), abs(r12.w));
              r12.z = r12.z + r12.z;
              r12.z = log2(r12.z);
              r12.z = cb9[34].x * r12.z;
              r12.z = saturate(exp2(r12.z));
              r12.z = 1 + -r12.z;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r12.xyw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r12.z * r11.w;
              r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyw;
              r11.xyz = r11.www * r12.xyz + r5.xyz;
            }
            r11.w = r9.x ? 0.231250003 : 0.356249988;
            r9.y = r10.w ? r9.y : r11.w;
          } else {
            r10.w = -1;
          }
          r9.x = (int)r9.x | (int)r10.w;
        } else {
          r9.x = -1;
        }
        if (r9.x == 0) {
          if (r9.x == 0) {
            r12.xy = r9.yy * r7.xy + r9.zw;
            r10.w = r9.y * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r12.z = saturate(9.99999975e-005 + -r11.w);
            r12.z = r12.z + r11.w;
            r12.z = 1 / r12.z;
            r10.w = -r12.z + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r12.zw = float2(-0.5,-0.5) + r12.xy;
              r12.z = max(abs(r12.z), abs(r12.w));
              r12.z = r12.z + r12.z;
              r12.z = log2(r12.z);
              r12.z = cb9[34].x * r12.z;
              r12.z = saturate(exp2(r12.z));
              r12.z = 1 + -r12.z;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r12.xyw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r12.z * r11.w;
              r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyw;
              r11.xyz = r11.www * r12.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.y;
            r9.y = r10.w ? r9.y : r11.w;
          } else {
            r10.w = -1;
          }
          r9.x = (int)r9.x | (int)r10.w;
        } else {
          r9.x = -1;
        }
        if (r9.x == 0) {
          if (r9.x == 0) {
            r12.xy = r9.yy * r7.xy + r9.zw;
            r10.w = r9.y * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r12.z = saturate(9.99999975e-005 + -r11.w);
            r12.z = r12.z + r11.w;
            r12.z = 1 / r12.z;
            r10.w = -r12.z + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r12.zw = float2(-0.5,-0.5) + r12.xy;
              r12.z = max(abs(r12.z), abs(r12.w));
              r12.z = r12.z + r12.z;
              r12.z = log2(r12.z);
              r12.z = cb9[34].x * r12.z;
              r12.z = saturate(exp2(r12.z));
              r12.z = 1 + -r12.z;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r12.xyw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r12.z * r11.w;
              r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyw;
              r11.xyz = r11.www * r12.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.y;
            r9.y = r10.w ? r9.y : r11.w;
          } else {
            r10.w = -1;
          }
          r9.x = (int)r9.x | (int)r10.w;
        } else {
          r9.x = -1;
        }
        if (r9.x == 0) {
          if (r9.x == 0) {
            r12.xy = r9.yy * r7.xy + r9.zw;
            r10.w = r9.y * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r12.z = saturate(9.99999975e-005 + -r11.w);
            r12.z = r12.z + r11.w;
            r12.z = 1 / r12.z;
            r10.w = -r12.z + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r12.zw = float2(-0.5,-0.5) + r12.xy;
              r12.z = max(abs(r12.z), abs(r12.w));
              r12.z = r12.z + r12.z;
              r12.z = log2(r12.z);
              r12.z = cb9[34].x * r12.z;
              r12.z = saturate(exp2(r12.z));
              r12.z = 1 + -r12.z;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r12.xyw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r12.z * r11.w;
              r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyw;
              r11.xyz = r11.www * r12.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.y;
            r9.y = r10.w ? r9.y : r11.w;
          } else {
            r10.w = -1;
          }
          r9.x = (int)r9.x | (int)r10.w;
        } else {
          r9.x = -1;
        }
        if (r9.x == 0) {
          if (r9.x == 0) {
            r12.xy = r9.yy * r7.xy + r9.zw;
            r10.w = r9.y * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r12.z = saturate(9.99999975e-005 + -r11.w);
            r12.z = r12.z + r11.w;
            r12.z = 1 / r12.z;
            r10.w = -r12.z + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r12.zw = float2(-0.5,-0.5) + r12.xy;
              r12.z = max(abs(r12.z), abs(r12.w));
              r12.z = r12.z + r12.z;
              r12.z = log2(r12.z);
              r12.z = cb9[34].x * r12.z;
              r12.z = saturate(exp2(r12.z));
              r12.z = 1 + -r12.z;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r12.xyw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r12.z * r11.w;
              r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyw;
              r11.xyz = r11.www * r12.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.y;
            r9.y = r10.w ? r9.y : r11.w;
          } else {
            r10.w = -1;
          }
          r9.x = (int)r9.x | (int)r10.w;
        } else {
          r9.x = -1;
        }
        if (r9.x == 0) {
          if (r9.x == 0) {
            r12.xy = r9.yy * r7.xy + r9.zw;
            r10.w = r9.y * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r12.z = saturate(9.99999975e-005 + -r11.w);
            r12.z = r12.z + r11.w;
            r12.z = 1 / r12.z;
            r10.w = -r12.z + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r12.zw = float2(-0.5,-0.5) + r12.xy;
              r12.z = max(abs(r12.z), abs(r12.w));
              r12.z = r12.z + r12.z;
              r12.z = log2(r12.z);
              r12.z = cb9[34].x * r12.z;
              r12.z = saturate(exp2(r12.z));
              r12.z = 1 + -r12.z;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r12.xyw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r12.z * r11.w;
              r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyw;
              r11.xyz = r11.www * r12.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.y;
            r9.y = r10.w ? r9.y : r11.w;
          } else {
            r10.w = -1;
          }
          r9.x = (int)r9.x | (int)r10.w;
        } else {
          r9.x = -1;
        }
        if (r9.x == 0) {
          if (r9.x == 0) {
            r12.xy = r9.yy * r7.xy + r9.zw;
            r10.w = r9.y * r5.w + r2.y;
            r11.w = t13.SampleLevel(s13_s, r12.xy, 0).x;
            r12.z = saturate(9.99999975e-005 + -r11.w);
            r12.z = r12.z + r11.w;
            r12.z = 1 / r12.z;
            r10.w = -r12.z + r10.w;
            r10.w = cmp(abs(r10.w) < abs(r7.z));
            if (r10.w != 0) {
              r12.zw = float2(-0.5,-0.5) + r12.xy;
              r12.z = max(abs(r12.z), abs(r12.w));
              r12.z = r12.z + r12.z;
              r12.z = log2(r12.z);
              r12.z = cb9[34].x * r12.z;
              r12.z = saturate(exp2(r12.z));
              r12.z = 1 + -r12.z;
              r11.w = r11.w + -r7.w;
              r11.w = saturate(r11.w * r8.w);
              r11.w = 1 + -r11.w;
              r11.w = log2(r11.w);
              r11.w = cb9[34].y * r11.w;
              r11.w = exp2(r11.w);
              r12.xyw = t12.SampleLevel(s12_s, r12.xy, 0).xyz;
              r11.w = r12.z * r11.w;
              r12.xyz = -r3.xyw * cb1[2].xyz + r12.xyw;
              r11.xyz = r11.www * r12.xyz + r5.xyz;
            }
            r11.w = 0.125 + r9.y;
            r9.y = r10.w ? r9.y : r11.w;
          } else {
            r10.w = -1;
          }
          r9.x = (int)r9.x | (int)r10.w;
        } else {
          r9.x = -1;
        }
        if (r9.x == 0) {
          if (r9.x == 0) {
            r7.xy = r9.yy * r7.xy + r9.zw;
            r2.y = r9.y * r5.w + r2.y;
            r5.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r5.w);
            r9.x = r9.x + r5.w;
            r9.x = 1 / r9.x;
            r2.y = -r9.x + r2.y;
            r2.y = cmp(abs(r2.y) < abs(r7.z));
            if (r2.y != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r2.y = max(abs(r9.x), abs(r9.y));
              r2.y = r2.y + r2.y;
              r2.y = log2(r2.y);
              r2.y = cb9[34].x * r2.y;
              r2.y = saturate(exp2(r2.y));
              r2.y = 1 + -r2.y;
              r5.w = r5.w + -r7.w;
              r5.w = saturate(r5.w * r8.w);
              r5.w = 1 + -r5.w;
              r5.w = log2(r5.w);
              r5.w = cb9[34].y * r5.w;
              r5.w = exp2(r5.w);
              r7.xyz = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r2.y = r5.w * r2.y;
              r7.xyz = -r3.xyw * cb1[2].xyz + r7.xyz;
              r11.xyz = r2.yyy * r7.xyz + r5.xyz;
            }
          }
        }
        r7.xyz = r11.xyz + r10.xyz;
        r2.y = cb9[33].x * r2.w;
        r7.xyz = r7.xyz * float3(0.25,0.25,0.25) + -r5.xyz;
        r7.xyz = r2.yyy * r7.xyz + r5.xyz;
      } else {
        r7.xyz = r5.xyz;
      }
    } else {
      r7.xyz = r5.xyz;
    }
    r3.xyw = -r3.xyw * cb1[2].xyz + r7.xyz;
    r5.xyz = r0.www * r3.xyw + r5.xyz;
  }
  r3.xyw = cb0[7].xyz + -r8.xyz;
  r3.xyw = cb9[37].www * r3.xyw + r8.xyz;
  r0.w = -0.699999988 + r1.w;
  r0.w = saturate(5 * r0.w);
  r2.yw = float2(1,1.5) + -r0.ww;
  r0.w = r2.y * r2.w;
  r1.y = r4.w + r1.y;
  r1.y = r1.y + r3.z;
  r1.y = saturate(-2.4000001 + r1.y);
  r1.w = saturate(-cb9[5].x + 0.5);
  r0.w = r1.w * r0.w;
  r0.w = r0.w * r1.y;
  r0.w = 1.10000002 * r0.w;
  r1.y = r2.z * r1.z;
  r5.xyz = r5.xyz + -r3.xyw;
  r1.yzw = r1.yyy * r5.xyz + r3.xyw;
  r6.w = 0.600000024;
  r2.y = dot(r6.yzw, r6.yzw);
  r2.y = rsqrt(r2.y);
  r3.xyz = r6.zwy * r2.yyy + -r6.zxy;
  r3.xyz = cb9[37].zzz * r3.xyz + r6.zxy;
  r2.y = dot(r3.xyz, r3.xyz);
  r2.y = rsqrt(r2.y);
  r3.xyz = r3.xyz * r2.yyy;
  r5.xy = -cb5[5].yz;
  r5.z = cb5[5].x;
  r2.y = dot(r5.xyz, r3.xyz);
  r2.y = r2.y + r2.y;
  r3.xyz = r3.xyz * -r2.yyy + r5.xyz;
  r2.y = saturate(dot(r3.xyz, r4.xyz));
  r2.y = log2(r2.y);
  r2.y = cb9[4].w * r2.y;
  r2.y = exp2(r2.y);
  r2.y = r2.y * r2.z;
  r2.yzw = cb5[6].xyz * r2.yyy;
  r2.yzw = saturate(cb9[4].zzz * r2.yzw);
  r3.x = 1;
  r5.xyz = float3(0,0,0);
  r7.xyz = float3(0,0,0);
  r8.xyz = float3(0,0,0);
  r3.w = 0;
  while (true) {
    r4.w = cmp((int)r3.w >= asint(cb10[0].x));
    if (r4.w != 0) break;
    r4.w = (int)r3.w * 6;
    r9.xyz = cb11[r4.w+0].xyz + -v1.xyz;
    r4.w = dot(r9.xyz, r9.xyz);
    r4.w = sqrt(r4.w);
    r5.w = 9.99999975e-005 + r4.w;
    r9.xyz = r9.xyz / r5.www;
    r10.xyzw = mad((int4)r3.wwww, int4(6,6,6,6), int4(4,5,2,3));
    r5.w = r4.w * cb10[2].x + -cb11[r10.x+0].x;
    r3.y = max(0, r5.w);
    r3.z = r3.y * r3.y;
    r3.y = dot(cb11[r10.x+0].yzw, r3.xyz);
    r3.y = 9.99999975e-005 + r3.y;
    r3.y = 1 / r3.y;
    r3.y = saturate(r3.y);
    r3.z = r4.w * cb10[2].x + -cb11[r10.y+0].x;
    r3.z = saturate(cb11[r10.y+0].y * r3.z);
    r3.z = 1 + -r3.z;
    r3.y = r3.y * r3.z;
    r11.xyz = r9.xyz + r4.xyz;
    r3.z = dot(r11.xyz, r11.xyz);
    r3.z = rsqrt(r3.z);
    r11.xyz = r11.xyz * r3.zzz;
    r3.z = dot(r6.zxy, r9.xyz);
    r4.w = dot(r6.zxy, r11.xyz);
    r5.w = cmp(r3.z >= 0);
    r3.z = max(0, r3.z);
    r6.w = cmp(r4.w >= 0);
    r5.w = r5.w ? r6.w : 0;
    r4.w = log2(r4.w);
    r4.w = cb9[4].w * r4.w;
    r4.w = exp2(r4.w);
    r4.w = r5.w ? r4.w : 0;
    r4.w = min(1, r4.w);
    r9.xyz = cb11[r10.z+0].xyz * cb10[3].xyz;
    r9.xyz = r9.xyz * r3.zzz;
    r9.xyz = r9.xyz * r3.yyy;
    r5.xyz = r9.xyz * float3(0.5,0.5,0.5) + r5.xyz;
    r7.xyz = cb11[r10.w+0].xyz * r3.yyy + r7.xyz;
    r9.xyz = cb11[r10.z+0].xyz * cb5[7].xyz;
    r9.xyz = r9.xyz * r4.www;
    r8.xyz = r9.xyz * r3.yyy + r8.xyz;
    r3.w = (int)r3.w + 1;
  }
  r3.x = asint(cb10[0].x) + asint(cb10[1].x);
  r9.x = 1;
  r10.xyz = r5.xyz;
  r11.xyz = r7.xyz;
  r12.xyz = r8.xyz;
  r3.y = r3.w;
  while (true) {
    r3.z = cmp((int)r3.y >= (int)r3.x);
    if (r3.z != 0) break;
    r3.z = (int)r3.y * 6;
    r13.xyz = cb11[r3.z+0].xyz + -v1.xyz;
    r3.z = dot(r13.xyz, r13.xyz);
    r3.z = sqrt(r3.z);
    r4.w = 9.99999975e-005 + r3.z;
    r13.xyz = r13.xyz / r4.www;
    r4.w = mad((int)r3.y, 6, 1);
    r5.w = dot(-cb11[r4.w+0].xyz, r13.xyz);
    r4.w = -cb11[r4.w+0].w + r5.w;
    r14.xyzw = mad((int4)r3.yyyy, int4(6,6,6,6), int4(2,3,4,5));
    r4.w = saturate(cb11[r14.x+0].w * r4.w);
    r4.w = log2(r4.w);
    r4.w = cb11[r14.y+0].w * r4.w;
    r4.w = exp2(r4.w);
    r5.w = r3.z * cb10[2].x + -cb11[r14.z+0].x;
    r9.y = max(0, r5.w);
    r9.z = r9.y * r9.y;
    r5.w = dot(cb11[r14.z+0].yzw, r9.xyz);
    r5.w = 9.99999975e-005 + r5.w;
    r5.w = 1 / r5.w;
    r5.w = saturate(r5.w);
    r3.z = r3.z * cb10[2].x + -cb11[r14.w+0].x;
    r3.z = saturate(cb11[r14.w+0].y * r3.z);
    r3.z = 1 + -r3.z;
    r3.z = r5.w * r3.z;
    r3.z = r3.z * r4.w;
    r9.yzw = r13.xyz + r4.xyz;
    r4.w = dot(r9.yzw, r9.yzw);
    r4.w = rsqrt(r4.w);
    r9.yzw = r9.yzw * r4.www;
    r4.w = dot(r6.zxy, r13.xyz);
    r5.w = dot(r6.zxy, r9.yzw);
    r6.w = cmp(r4.w >= 0);
    r4.w = max(0, r4.w);
    r7.w = cmp(r5.w >= 0);
    r6.w = r6.w ? r7.w : 0;
    r5.w = log2(r5.w);
    r5.w = cb9[4].w * r5.w;
    r5.w = exp2(r5.w);
    r5.w = r6.w ? r5.w : 0;
    r5.w = min(1, r5.w);
    r9.yzw = cb11[r14.x+0].xyz * cb10[3].xyz;
    r9.yzw = r9.yzw * r4.www;
    r9.yzw = r9.yzw * r3.zzz;
    r10.xyz = r9.yzw * float3(0.5,0.5,0.5) + r10.xyz;
    r11.xyz = cb11[r14.y+0].xyz * r3.zzz + r11.xyz;
    r9.yzw = cb11[r14.x+0].xyz * cb5[7].xyz;
    r9.yzw = r9.yzw * r5.www;
    r12.xyz = r9.yzw * r3.zzz + r12.xyz;
    r3.y = (int)r3.y + 1;
  }
  r0.x = saturate(-0.5 + r0.x);
  r0.x = r2.x * r0.x;
  r1.x = saturate(-0.5 + r1.x);
  r0.y = r1.x * r0.y;
  r0.x = max(r0.x, r0.y);
  r0.x = cb9[39].x * r0.x;
  r0.x = max(r0.x, r0.w);
  r3.xyz = cb9[0].xyz + -r1.yzw;
  r1.xyz = r0.xxx * r3.xyz + r1.yzw;
  r0.y = cb9[5].x * 0.600000024 + 0.200000003;
  r3.xyz = r1.xyz * r0.yyy + -r1.xyz;
  r3.xyz = r0.zzz * r3.xyz + r1.xyz;
  r0.x = 1 + -r0.x;
  r0.x = r0.z * r0.x;
  r2.xyz = r0.xxx * r2.yzw;
  r0.x = 1 + -r0.y;
  r0.xyw = r0.xxx * r1.xyz;
  r0.xyw = r0.zzz * r0.xyw;
  r1.xyz = r11.xyz * r0.zzz;
  r4.xyz = r12.xyz * r0.zzz;
  r1.xyz = r10.xyz * r0.zzz + r1.xyz;
  r1.w = cmp(0 < cb6[4].x);
  r2.w = -cb6[4].y + r0.z;
  r2.w = cmp(r2.w < 0);
  r1.w = r1.w ? r2.w : 0;
  if (r1.w != 0) discard;
  r0.z = max(cb5[0].w, r0.z);
  r1.w = cb5[12].z + -v8.w;
  r1.w = max(0, r1.w);
  r5.xyz = cb0[15].xyz * -r1.www;
  r5.xyz = float3(1.44269502,1.44269502,1.44269502) * r5.xyz;
  r5.xyz = exp2(r5.xyz);
  r6.xyz = cb0[16].xyz * -r1.www;
  r6.xyz = float3(1.44269502,1.44269502,1.44269502) * r6.xyz;
  r6.xyz = exp2(r6.xyz);
  r0.xyw = r0.xyw * r5.xyz + r4.xyz;
  r1.xyz = r3.xyz * r6.xyz + r1.xyz;
  r0.xyw = r2.xyz * r6.xyz + r0.xyw;
  r0.xyw = r1.xyz * r0.zzz + r0.xyw;
  switch (cb5[11].x) {
    case 1 :    case 3 :    r1.y = cb5[13].y + cb5[12].z;
    r2.xyz = cb6[9].xyz + -v8.xyz;
    r1.z = dot(r2.xyz, r2.xyz);
    r1.z = sqrt(r1.z);
    r1.w = cmp(cb6[9].y < r1.y);
    if (r1.w != 0) {
      r2.x = -cb6[9].y + v8.y;
      r2.x = max(0, r2.x);
      r2.x = 9.99999975e-006 + r2.x;
      r2.y = -cb6[9].y + r1.y;
      r2.x = saturate(r2.y / r2.x);
      r2.y = r2.x * r1.z;
      r2.z = -r1.z * r2.x + r1.z;
      r2.w = cmp(0 < r2.z);
      if (r2.w != 0) {
        r2.x = 1 + -r2.x;
        r2.x = r2.x * r1.z;
        r2.w = v8.y + -r1.y;
        r3.x = 9.99999975e-006 + r2.z;
        r3.y = abs(r2.w) / r3.x;
        r3.y = cb5[10].x * r3.y;
        r3.z = cmp(r3.y == 0.000000);
        r3.w = -r3.y * r2.x;
        r3.w = 1.44269502 * r3.w;
        r3.w = exp2(r3.w);
        r3.w = 1 + -r3.w;
        r3.y = r3.w / r3.y;
        r3.y = r3.z ? r2.x : r3.y;
        r3.z = min(v8.y, r1.y);
        r3.z = -cb5[10].x * r3.z;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = -cb5[10].y * r3.z;
        r3.y = r3.z * r3.y;
        r3.y = 1.44269502 * r3.y;
        r3.y = saturate(exp2(r3.y));
        r2.w = r2.w / r3.x;
        r2.w = cb0[14].z * r2.w;
        r3.x = cmp(r2.w == 0.000000);
        r3.z = -r2.w * r2.x;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = 1 + -r3.z;
        r2.w = r3.z / r2.w;
        r2.x = r3.x ? r2.x : r2.w;
        r2.w = -cb0[14].x + r1.y;
        r2.w = -cb0[14].z * r2.w;
        r2.w = 1.44269502 * r2.w;
        r2.w = exp2(r2.w);
        r2.w = -cb0[14].y * r2.w;
        r2.x = r2.w * r2.x;
        r2.x = 1.44269502 * r2.x;
        r2.x = saturate(exp2(r2.x));
        r2.x = r3.y * r2.x;
      } else {
        r2.x = 1;
      }
      r2.y = -cb5[12].w * r2.y;
      r2.y = 1.44269502 * r2.y;
      r2.y = saturate(exp2(r2.y));
    } else {
      r2.w = cb6[9].y + -v8.y;
      r2.w = max(0, r2.w);
      r2.w = 9.99999975e-006 + r2.w;
      r3.x = cb6[9].y + -r1.y;
      r2.w = saturate(r3.x / r2.w);
      r2.z = r2.w * r1.z;
      r3.x = -r1.z * r2.w + r1.z;
      r1.y = max(v8.y, r1.y);
      r3.y = -cb6[9].y + r1.y;
      r1.z = r1.z * r2.w + 9.99999975e-006;
      r2.w = abs(r3.y) / r1.z;
      r2.w = cb5[10].x * r2.w;
      r3.z = cmp(r2.w == 0.000000);
      r3.w = -r2.w * r2.z;
      r3.w = 1.44269502 * r3.w;
      r3.w = exp2(r3.w);
      r3.w = 1 + -r3.w;
      r2.w = r3.w / r2.w;
      r2.w = r3.z ? r2.z : r2.w;
      r1.y = min(cb6[9].y, r1.y);
      r1.y = -cb5[10].x * r1.y;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.y = -cb5[10].y * r1.y;
      r1.y = r1.y * r2.w;
      r1.y = 1.44269502 * r1.y;
      r1.y = saturate(exp2(r1.y));
      r1.z = r3.y / r1.z;
      r1.z = cb0[14].z * r1.z;
      r2.w = cmp(r1.z == 0.000000);
      r3.y = -r1.z * r2.z;
      r3.y = 1.44269502 * r3.y;
      r3.y = exp2(r3.y);
      r3.y = 1 + -r3.y;
      r1.z = r3.y / r1.z;
      r1.z = r2.w ? r2.z : r1.z;
      r2.w = cb6[9].y + -cb0[14].x;
      r2.w = -cb0[14].z * r2.w;
      r2.w = 1.44269502 * r2.w;
      r2.w = exp2(r2.w);
      r2.w = -cb0[14].y * r2.w;
      r1.z = r2.w * r1.z;
      r1.z = 1.44269502 * r1.z;
      r1.z = saturate(exp2(r1.z));
      r2.x = r1.y * r1.z;
      r1.y = -cb5[12].w * r3.x;
      r1.y = 1.44269502 * r1.y;
      r2.y = saturate(exp2(r1.y));
    }
    r1.y = cb5[12].x + -r2.z;
    r1.y = saturate(cb5[12].y * r1.y);
    r1.z = r2.x * r1.y;
    r3.xyz = -cb6[9].xyz + v8.xyz;
    r2.z = dot(r3.xyz, r3.xyz);
    r2.z = rsqrt(r2.z);
    r2.w = r3.y * r2.z;
    r3.x = cmp(r2.w < 0);
    r2.z = r3.y * r2.z + 1;
    r2.z = r2.z * r2.z;
    r3.yz = cb0[17].yz + -cb0[17].xy;
    r2.z = r2.z * r3.y + cb0[17].x;
    r2.w = r2.w * r3.z + cb0[17].y;
    r2.z = r3.x ? r2.z : r2.w;
    r3.xyz = cb0[7].xyz * r2.zzz;
    r3.xyz = r3.xyz * r0.zzz;
    r4.xyz = cb0[1].xyz * r0.zzz;
    r5.x = -r2.x * r1.y + 1;
    r6.x = r5.x * r2.y;
    r6.y = 1 + -r2.y;
    r6.z = r1.z * r2.y;
    r5.y = r6.y * r1.z;
    r5.z = r6.z;
    r1.yzw = r1.www ? r6.xyz : r5.xyz;
    r2.xyz = r3.xyz * r1.zzz;
    r2.xyz = r4.xyz * r1.yyy + r2.xyz;
    r0.xyw = r0.xyw * r1.www + r2.xyz;
    r1.x = 1;
    break;
    case 2 :    r1.y = cb5[13].y + cb5[12].z;
    r2.xyz = cb6[9].xyz + -v8.xyz;
    r1.z = dot(r2.xyz, r2.xyz);
    r1.z = sqrt(r1.z);
    r1.w = cmp(cb6[9].y < r1.y);
    if (r1.w != 0) {
      r1.w = -cb6[9].y + v8.y;
      r1.w = max(0, r1.w);
      r1.w = 9.99999975e-006 + r1.w;
      r2.x = -cb6[9].y + r1.y;
      r1.w = saturate(r2.x / r1.w);
      r2.x = r1.z * r1.w;
      r2.y = -r1.z * r1.w + r1.z;
      r2.z = cmp(0 < r2.y);
      if (r2.z != 0) {
        r1.w = 1 + -r1.w;
        r1.w = r1.z * r1.w;
        r2.z = v8.y + -r1.y;
        r2.w = 9.99999975e-006 + r2.y;
        r3.x = abs(r2.z) / r2.w;
        r3.x = cb5[10].x * r3.x;
        r3.y = cmp(r3.x == 0.000000);
        r3.z = -r3.x * r1.w;
        r3.z = 1.44269502 * r3.z;
        r3.z = exp2(r3.z);
        r3.z = 1 + -r3.z;
        r3.x = r3.z / r3.x;
        r3.x = r3.y ? r1.w : r3.x;
        r3.y = min(v8.y, r1.y);
        r3.y = -cb5[10].x * r3.y;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = -cb5[10].y * r3.y;
        r3.x = r3.y * r3.x;
        r3.x = 1.44269502 * r3.x;
        r3.x = saturate(exp2(r3.x));
        r2.z = r2.z / r2.w;
        r2.z = cb0[14].z * r2.z;
        r2.w = cmp(r2.z == 0.000000);
        r3.y = -r2.z * r1.w;
        r3.y = 1.44269502 * r3.y;
        r3.y = exp2(r3.y);
        r3.y = 1 + -r3.y;
        r2.z = r3.y / r2.z;
        r1.w = r2.w ? r1.w : r2.z;
        r2.z = -cb0[14].x + r1.y;
        r2.z = -cb0[14].z * r2.z;
        r2.z = 1.44269502 * r2.z;
        r2.z = exp2(r2.z);
        r2.z = -cb0[14].y * r2.z;
        r1.w = r2.z * r1.w;
        r1.w = 1.44269502 * r1.w;
        r1.w = saturate(exp2(r1.w));
        r3.x = r3.x * r1.w;
      } else {
        r3.x = 1;
      }
      r1.w = -cb5[12].w * r2.x;
      r1.w = 1.44269502 * r1.w;
      r3.y = saturate(exp2(r1.w));
    } else {
      r1.w = cb6[9].y + -v8.y;
      r1.w = max(0, r1.w);
      r1.w = 9.99999975e-006 + r1.w;
      r2.x = cb6[9].y + -r1.y;
      r1.w = saturate(r2.x / r1.w);
      r2.y = r1.z * r1.w;
      r2.x = -r1.z * r1.w + r1.z;
      r1.y = max(v8.y, r1.y);
      r2.z = -cb6[9].y + r1.y;
      r1.z = r1.z * r1.w + 9.99999975e-006;
      r1.w = abs(r2.z) / r1.z;
      r1.w = cb5[10].x * r1.w;
      r2.w = cmp(r1.w == 0.000000);
      r3.z = -r1.w * r2.y;
      r3.z = 1.44269502 * r3.z;
      r3.z = exp2(r3.z);
      r3.z = 1 + -r3.z;
      r1.w = r3.z / r1.w;
      r1.w = r2.w ? r2.y : r1.w;
      r1.y = min(cb6[9].y, r1.y);
      r1.y = -cb5[10].x * r1.y;
      r1.y = 1.44269502 * r1.y;
      r1.y = exp2(r1.y);
      r1.y = -cb5[10].y * r1.y;
      r1.y = r1.y * r1.w;
      r1.y = 1.44269502 * r1.y;
      r1.y = saturate(exp2(r1.y));
      r1.z = r2.z / r1.z;
      r1.z = cb0[14].z * r1.z;
      r1.w = cmp(r1.z == 0.000000);
      r2.z = -r1.z * r2.y;
      r2.z = 1.44269502 * r2.z;
      r2.z = exp2(r2.z);
      r2.z = 1 + -r2.z;
      r1.z = r2.z / r1.z;
      r1.z = r1.w ? r2.y : r1.z;
      r1.w = cb6[9].y + -cb0[14].x;
      r1.w = -cb0[14].z * r1.w;
      r1.w = 1.44269502 * r1.w;
      r1.w = exp2(r1.w);
      r1.w = -cb0[14].y * r1.w;
      r1.z = r1.w * r1.z;
      r1.z = 1.44269502 * r1.z;
      r1.z = saturate(exp2(r1.z));
      r3.x = r1.y * r1.z;
      r1.y = -cb5[12].w * r2.x;
      r1.y = 1.44269502 * r1.y;
      r3.y = saturate(exp2(r1.y));
    }
    r1.y = cb5[12].x + -r2.y;
    r1.y = saturate(cb5[12].y * r1.y);
    r1.y = r3.x * r1.y;
    r1.x = r1.y * r3.y;
    break;
    default :
    r1.x = 1;
    break;
  }
  o0.xyzw = r1.xxxx * r0.xywz;
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.2.67 on Wed Nov 29 11:28:34 2017
//
//
// 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   xyz         2     NONE   float   xyz 
// TEXCOORD                 2   xyz         3     NONE   float   x z 
// TEXCOORD                 3   xyz         4     NONE   float   xyz 
// TEXCOORD                 4   xyzw        5     NONE   float   xyzw
// TEXCOORD                 5   xyzw        6     NONE   float   xyzw
// TEXCOORD                 6   xyzw        7     NONE   float     zw
// TEXCOORD                 8   xyzw        8     NONE   float   xyzw
//
//
// 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 cb0[18], immediateIndexed
dcl_constantbuffer cb1[3], immediateIndexed
dcl_constantbuffer cb5[14], immediateIndexed
dcl_constantbuffer cb6[10], immediateIndexed
dcl_constantbuffer cb9[43], immediateIndexed
dcl_constantbuffer cb10[4], immediateIndexed
dcl_constantbuffer cb11[192], dynamicIndexed
dcl_sampler s1, mode_default
dcl_sampler s2, 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 s8, mode_default
dcl_sampler s10, mode_default
dcl_sampler s11, mode_default
dcl_sampler s12, mode_default
dcl_sampler s13, mode_default
dcl_resource_texture2d (float,float,float,float) t1
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_texture2d (float,float,float,float) t7
dcl_resource_texture2d (float,float,float,float) t8
dcl_resource_texture2d (float,float,float,float) t10
dcl_resource_texture2d (float,float,float,float) t11
dcl_resource_texture2d (float,float,float,float) t12
dcl_resource_texture2d (float,float,float,float) t13
dcl_input_ps_siv linear noperspective v0.xy, position
dcl_input_ps linear centroid v1.xyz
dcl_input_ps linear centroid v2.xyz
dcl_input_ps linear centroid v3.xz
dcl_input_ps linear centroid v4.xyz
dcl_input_ps linear centroid v5.xyzw
dcl_input_ps linear centroid v6.xyzw
dcl_input_ps linear centroid v7.zw
dcl_input_ps linear centroid v8.xyzw
dcl_output o0.xyzw
dcl_temps 15
add r0.xy, v3.xzxx, v3.xzxx
add r0.x, r0.y, r0.x
sincos r0.x, null, r0.x
dp2 r0.y, v3.xzxx, l(2.170000, 2.170000, 0.000000, 0.000000)
sincos null, r0.y, r0.y
add r0.x, r0.y, r0.x
mul r1.xyzw, v3.xzxz, l(0.100000, 0.100000, 0.135000, 0.135000)
sample_indexable(texture2d)(float,float,float,float) r0.y, r1.xyxx, t6.yxzw, s6
add r0.y, r0.y, l(-0.500000)
mad r0.x, r0.x, l(0.004000), v7.z
mad r0.x, r0.y, l(0.100000), r0.x
add r0.y, r0.x, l(0.200000)
dp3 r0.z, v4.xyzx, v4.xyzx
rsq r0.z, r0.z
mad r0.z, v4.y, r0.z, l(-0.850000)
mul_sat r0.yz, r0.yyzy, l(0.000000, 20.000000, 10.000000, 0.000000)
sincos r1.xyzw, null, r1.xyzw
max r1.xy, r1.ywyy, r1.xzxx
mul r0.z, r0.z, cb9[39].y
add r1.zw, |r1.xxxy|, cb9[38].xxxy
mad r1.zw, r1.zzzw, r0.zzzz, -r0.xxxx
mul_sat r2.xyzw, r1.zzww, l(100.000000, 10.000000, 100.000000, 10.000000)
mad r0.zw, |r1.xxxy|, r0.zzzz, -r0.xxxx
add r0.zw, r0.zzzw, l(0.000000, 0.000000, 0.050000, 0.050000)
mul_sat r3.xy, r0.zwzz, l(10.000000, 10.000000, 0.000000, 0.000000)
mul r4.xy, r2.xzxx, r2.xzxx
mov r4.z, r3.x
mov r4.w, r2.y
mul r2.xyz, r0.yyyy, r4.xzwx
mov r3.z, r4.y
mov r3.w, r2.w
mul r0.yzw, r0.yyyy, r3.zzyw
max r0.zw, r0.zzzw, r2.yyyz
lt r1.x, r0.z, l(0.001000)
mul r2.yz, v3.xxzx, l(0.000000, 0.500000, 0.500000, 0.000000)
sample_indexable(texture2d)(float,float,float,float) r2.yz, r2.yzyy, t7.xywz, s7
mad r3.xy, r2.yzyy, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mov r3.z, l(3.000000)
dp3 r1.y, r3.xyzx, r3.xyzx
rsq r1.y, r1.y
add r2.y, -r0.w, l(1.000000)
add r4.xyz, -v1.xyzx, cb6[6].xyzx
dp3 r2.z, r4.xyzx, r4.xyzx
sqrt r2.z, r2.z
add r2.z, r2.z, l(0.000100)
div r4.xyz, r4.xyzx, r2.zzzz
sample_indexable(texture2d)(float,float,float,float) r2.zw, v5.xyxx, t1.xzyw, s1
sample_indexable(texture2d)(float,float,float,float) r5.xy, v5.zwzz, t1.ywxz, s1
mad r2.zw, r2.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
mad r5.xy, r5.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
add r6.xyzw, v5.zwzw, l(0.250000, 0.250000, 0.500000, 0.500000)
sample_indexable(texture2d)(float,float,float,float) r5.zw, r6.xyxx, t1.xzyw, s1
sample_indexable(texture2d)(float,float,float,float) r6.xy, r6.zwzz, t1.ywxz, s1
add r6.zw, v5.zzzw, l(0.000000, 0.000000, 0.750000, 0.750000)
sample_indexable(texture2d)(float,float,float,float) r6.zw, r6.zwzz, t1.xzyw, s1
sample_indexable(texture2d)(float,float,float,float) r7.xy, v6.xyxx, t3.ywxz, s3
add r8.xyzw, v6.xyxy, l(0.250000, 0.250000, 0.500000, 0.500000)
sample_indexable(texture2d)(float,float,float,float) r7.zw, r8.xyxx, t3.xzyw, s3
sample_indexable(texture2d)(float,float,float,float) r8.xy, r8.zwzz, t3.ywxz, s3
add r8.zw, v6.xxxy, l(0.000000, 0.000000, 0.750000, 0.750000)
sample_indexable(texture2d)(float,float,float,float) r8.zw, r8.zwzz, t3.xzyw, s3
mad r5.zw, r5.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
mad r6.xy, r6.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mad r6.zw, r6.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
mad r7.xy, r7.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mad r7.zw, r7.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
mad r8.xy, r8.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mad r8.zw, r8.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
mad r3.w, cb9[5].x, l(0.800000), l(0.400000)
mul r9.xyzw, r3.wwww, cb9[1].xyzw
mul r9.xyzw, r9.xyzw, v6.zzzz
mul r10.xyzw, r3.wwww, cb9[2].xyzw
mul r10.xyzw, r10.xyzw, v6.wwww
mul r5.zw, r5.zzzw, r9.yyyy
mad r5.zw, r5.xxxy, r9.xxxx, r5.zzzw
mad r5.zw, r6.xxxy, r9.zzzz, r5.zzzw
mad r5.zw, r6.zzzw, r9.wwww, r5.zzzw
mul r6.xy, r7.zwzz, r10.yyyy
mad r6.xy, r7.xyxx, r10.xxxx, r6.xyxx
mad r6.xy, r8.xyxx, r10.zzzz, r6.xyxx
mad r6.xy, r8.zwzz, r10.wwww, r6.xyxx
add r2.zw, r2.zzzw, r5.xxxy
mad r5.xy, r2.zwzz, l(1.800000, 1.800000, 0.000000, 0.000000), r5.zwzz
add r5.xy, r6.xyxx, r5.xyxx
mov r5.z, cb9[4].y
dp3 r3.w, r5.xyzx, r5.xyzx
rsq r3.w, r3.w
mul r5.xyz, r3.wwww, r5.xyzx
mad r3.xyz, r3.xyzx, r1.yyyy, -r5.xyzx
mad r3.xyz, r2.yyyy, r3.xyzx, r5.xyzx
dp3 r1.y, r3.xyzx, r3.xyzx
rsq r1.y, r1.y
mul r3.xyz, r1.yyyy, r3.xyzx
mul r5.xyz, v4.zxyz, l(1.000000, 0.000000, 0.000000, 0.000000)
mad r5.xyz, v4.xyzx, l(0.000000, 1.000000, 0.000000, 0.000000), -r5.xyzx
dp2 r1.y, r5.xyxx, r5.xyxx
rsq r1.y, r1.y
mul r5.xyz, r1.yyyy, r5.xyzx
mul r6.xyz, r5.xyzx, v4.zxyz
mad r6.xyz, v4.yzxy, r5.yzxy, -r6.xyzx
mul r7.xyz, r3.zzzz, v4.xyzx
mad r6.xyz, r6.yzxy, r3.yyyy, r7.yzxy
mad r6.xy, r5.xyxx, -r3.xxxx, r6.xyxx
dp3 r1.y, -r4.yzxy, r6.xyzx
add r1.y, r1.y, r1.y
mad r3.xyz, r6.zxyz, -r1.yyyy, -r4.xyzx
dp2 r1.y, r3.xzxx, r3.xzxx
mul r3.zw, r1.yyyy, r3.xxxz
mad r3.zw, r3.zzzw, l(0.000000, 0.000000, 0.450000, 0.450000), l(0.000000, 0.000000, 0.500000, 0.500000)
sample_indexable(texture2d)(float,float,float,float) r5.xyz, r3.zwzz, t4.xyzw, s4
sample_indexable(texture2d)(float,float,float,float) r7.xyz, r3.zwzz, t5.xyzw, s5
mad r3.zw, v0.xxxy, cb9[3].xxxy, cb9[3].zzzw
mul r1.y, r0.w, cb9[35].x
mad r8.xy, r6.zyzz, r1.yyyy, r3.zwzz
sample_l_indexable(texture2d)(float,float,float,float) r4.w, r8.xyxx, t11.yzwx, s11, l(0.000000)
add r4.w, r4.w, -v2.z
add r4.w, r4.w, l(0.050000)
mul_sat r4.w, r4.w, l(100000.000000)
mul r1.y, r1.y, r4.w
mad r3.zw, r6.zzzy, r1.yyyy, r3.zzzw
sample_indexable(texture2d)(float,float,float,float) r8.xyz, r3.zwzz, t10.xyzw, s10
mul r9.xyzw, v5.xyzw, l(50.099998, 50.099998, 10.200000, 10.200000)
mul r3.zw, v6.xxxy, l(0.000000, 0.000000, 0.110000, 0.110000)
sample_indexable(texture2d)(float,float,float,float) r1.y, r9.xyxx, t2.yxzw, s2
sample_indexable(texture2d)(float,float,float,float) r4.w, r9.zwzz, t2.yzwx, s2
sample_indexable(texture2d)(float,float,float,float) r3.z, r3.zwzz, t2.yzxw, s2
mul r9.xy, r6.zyzz, cb9[36].yyyy
mad r9.xy, v3.xzxx, cb9[36].zzzz, r9.xyxx
add r9.xy, r9.xyxx, cb9[37].xyxx
sample_indexable(texture2d)(float,float,float,float) r3.w, r9.xyxx, t2.yzwx, s2
if_nz r1.x
  mov o0.xyzw, l(0,0,0,0)
  ret 
endif 
mul_sat r1.xz, r1.zzwz, l(15.000000, 0.000000, 15.000000, 0.000000)
add r1.xz, -r1.xxzx, l(1.000000, 0.000000, 1.000000, 0.000000)
mul_sat r0.x, r0.x, l(20.000000)
mul r1.xz, r0.xxxx, r1.xxzx
max r9.xy, l(0.000000, 0.000000, 0.000000, 0.000000), cb9[38].zwzz
dp2 r0.x, r1.xxxx, r9.xxxx
mul r1.xw, l(0.300000, 0.000000, 0.000000, 0.300000), cb9[38].zzzw
min r1.xw, r1.xxxw, l(0.000000, 0.000000, 0.000000, 0.000000)
add r0.x, r0.x, r1.x
add r0.x, r3.w, r0.x
dp2 r1.x, r1.zzzz, r9.yyyy
add r1.x, r1.x, r1.w
add r1.x, r3.w, r1.x
add r1.z, l(-1.000000), cb9[39].z
mad r1.z, r2.y, r1.z, l(1.000000)
add r9.xy, r2.zwzz, r2.zwzz
mov r9.z, l(1.000000)
dp3 r1.w, r9.xyzx, r9.xyzx
rsq r1.w, r1.w
dp3 r2.z, r6.zxyz, r4.xyzx
max r2.z, r2.z, l(0.000000)
add r2.z, -r2.z, l(1.000000)
mul r2.w, r2.z, r2.z
mul r2.w, r2.w, r2.w
mul r2.z, r2.w, r2.z
mad r2.z, r2.z, l(0.980000), l(0.020000)
add r5.xyz, r5.xyzx, -r7.xyzx
mad r5.xyz, v7.wwww, r5.xyzx, r7.xyzx
mad r3.xy, r3.xyxx, l(0.500000, -0.500000, 0.000000, 0.000000), l(0.500000, 0.500000, 0.000000, 0.000000)
mul_sat r2.w, l(0.001000), cb5[6].w
add r2.w, -r2.w, l(1.000000)
log r2.w, r2.w
mul r2.w, r2.w, l(10.000000)
exp r2.w, r2.w
mul r2.w, r2.w, l(8.000000)
sample_l_indexable(texture2d)(float,float,float,float) r7.xyzw, r3.xyxx, t8.xyzw, s8, r2.w
add r2.w, -r7.w, l(1.000000)
mul r2.w, r2.w, l(4.000000)
exp r2.w, r2.w
mad r3.xyw, r7.xyxz, r2.wwww, -r5.xyxz
mad r3.xyw, r2.yyyy, r3.xyxw, r5.xyxz
mul r5.xyz, r3.xywx, cb1[2].xyzx
add r7.xyz, r6.zxyz, -v4.xyzx
mad r7.xyz, cb9[33].wwww, r7.xyzx, v4.xyzx
dp3 r2.y, r7.xyzx, r7.xyzx
rsq r2.y, r2.y
mul r7.xyz, r2.yyyy, r7.xyzx
dp3 r2.y, -r4.xyzx, r7.xyzx
add r2.y, r2.y, r2.y
mad r2.y, r7.y, -r2.y, -r4.y
mul_sat r2.y, r2.y, l(-100.000000)
add r2.y, r2.y, l(1.000000)
mul r2.w, r0.w, cb9[33].x
mul r2.y, r2.y, r2.w
lt r2.y, l(0.001000), r2.y
if_nz r2.y
  add r2.y, -v2.z, cb9[33].y
  lt r2.w, l(0.000000), r2.y
  if_nz r2.w
    dp3 r9.x, r7.xyzx, cb9[40].xyzx
    dp3 r9.y, r7.xyzx, cb9[41].xyzx
    dp3 r9.z, r7.xyzx, cb9[42].xyzx
    dp3 r2.w, v2.xyzx, v2.xyzx
    rsq r2.w, r2.w
    mul r7.xyz, r2.wwww, v2.xyzx
    dp3 r2.w, r7.xyzx, r9.xyzx
    add r2.w, r2.w, r2.w
    mad r7.xyz, r9.xyzx, -r2.wwww, r7.xyzx
    add r2.w, r7.z, l(-0.200000)
    mul_sat r2.w, r2.w, l(5.000000)
    ge r5.w, r2.w, l(0.010000)
    if_nz r5.w
      div r2.y, r2.y, r7.z
      mad r7.xyz, r7.xyzx, r2.yyyy, v2.xyzx
      mul r9.xyz, v2.yyyy, cb9[30].xywx
      mad r9.xyz, cb9[29].xywx, v2.xxxx, r9.xyzx
      mad r9.xyz, cb9[31].xywx, v2.zzzz, r9.xyzx
      add r9.xyz, r9.xyzx, cb9[32].xywx
      mul r10.xyz, r7.yyyy, cb9[30].xywx
      mad r7.xyw, cb9[29].xyxw, r7.xxxx, r10.xyxz
      mad r7.xyz, cb9[31].xywx, r7.zzzz, r7.xywx
      add r7.xyz, r7.xyzx, cb9[32].xywx
      div r2.y, l(1.000000, 1.000000, 1.000000, 1.000000), r9.z
      div r5.w, l(1.000000, 1.000000, 1.000000, 1.000000), r7.z
      mul r9.xy, r2.yyyy, r9.xyxx
      mul r7.xy, r5.wwww, r7.xyxx
      mov r9.z, -r9.y
      add r9.xy, r9.xzxx, l(1.000000, 1.000000, 0.000000, 0.000000)
      mul r9.zw, r9.xxxy, l(0.000000, 0.000000, 0.500000, 0.500000)
      mov r7.z, -r7.y
      add r7.xy, r7.xzxx, l(1.000000, 1.000000, 0.000000, 0.000000)
      mad r7.xy, r7.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000), -r9.zwzz
      lt r7.zw, l(0.000000, 0.000000, 0.000000, 0.000000), r7.xxxy
      mad r9.xy, -r9.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000), l(1.000000, 1.000000, 0.000000, 0.000000)
      div_sat r9.xy, r9.xyxx, r7.xyxx
      add r10.xy, -r7.xyxx, l(0.000100, 0.000100, 0.000000, 0.000000)
      div_sat r10.xy, r9.zwzz, r10.xyxx
      movc r7.zw, r7.zzzw, r9.xxxy, r10.xxxy
      min r7.z, r7.w, r7.z
      mul r7.xy, r7.zzzz, r7.xyxx
      add r5.w, -r2.y, r5.w
      mul r5.w, r7.z, r5.w
      mul r7.z, r5.w, l(0.125000)
      mul r7.w, l(0.750000), cb9[33].y
      min r7.w, r7.w, l(100.000000)
      add r8.w, -r7.w, cb9[33].y
      div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
      mad r10.xyzw, r7.xyxy, l(0.012500, 0.012500, 0.043750, 0.043750), r9.zwzw
      mad r11.xyz, r5.wwww, l(0.012500, 0.043750, 0.075000, 0.000000), r2.yyyy
      sample_l_indexable(texture2d)(float,float,float,float) r9.x, r10.xyxx, t13.xyzw, s13, l(0.000000)
      add_sat r9.y, -r9.x, l(0.000100)
      add r9.y, r9.y, r9.x
      div r9.y, l(1.000000, 1.000000, 1.000000, 1.000000), r9.y
      add r9.y, -r9.y, r11.x
      lt r9.y, |r9.y|, |r7.z|
      if_nz r9.y
        add r11.xw, r10.xxxy, l(-0.500000, 0.000000, 0.000000, -0.500000)
        max r11.x, |r11.w|, |r11.x|
        add r11.x, r11.x, r11.x
        log r11.x, r11.x
        mul r11.x, r11.x, cb9[34].x
        exp_sat r11.x, r11.x
        add r11.x, -r11.x, l(1.000000)
        add r9.x, -r7.w, r9.x
        mul_sat r9.x, r8.w, r9.x
        add r9.x, -r9.x, l(1.000000)
        log r9.x, r9.x
        mul r9.x, r9.x, cb9[34].y
        exp r9.x, r9.x
        sample_l_indexable(texture2d)(float,float,float,float) r12.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
        mul r9.x, r9.x, r11.x
        mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xyzx
        mad r12.xyz, r9.xxxx, r12.xyzx, r5.xyzx
      else 
        mov r12.xyz, r5.xyzx
      endif 
      movc r9.x, r9.y, l(0.012500), l(0.137500)
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r11.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r10.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r11.x, r11.x, -r12.w
          lt r11.x, |r11.x|, |r7.z|
          if_nz r11.x
            add r13.xy, r10.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r10.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r10.xxxx, r13.xyzx, r5.xyzx
          endif 
          movc r10.x, r9.y, l(0.137500), l(0.262500)
          movc r9.x, r11.x, r9.x, r10.x
        else 
          mov r11.x, l(-1)
        endif 
        or r9.y, r9.y, r11.x
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r11.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r10.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r11.x, r11.x, -r12.w
          lt r11.x, |r11.x|, |r7.z|
          if_nz r11.x
            add r13.xy, r10.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r10.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r10.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r10.x, r9.x, l(0.125000)
          movc r9.x, r11.x, r9.x, r10.x
        else 
          mov r11.x, l(-1)
        endif 
        or r9.y, r9.y, r11.x
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r11.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r10.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r11.x, r11.x, -r12.w
          lt r11.x, |r11.x|, |r7.z|
          if_nz r11.x
            add r13.xy, r10.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r10.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r10.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r10.x, r9.x, l(0.125000)
          movc r9.x, r11.x, r9.x, r10.x
        else 
          mov r11.x, l(-1)
        endif 
        or r9.y, r9.y, r11.x
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r11.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r10.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r11.x, r11.x, -r12.w
          lt r11.x, |r11.x|, |r7.z|
          if_nz r11.x
            add r13.xy, r10.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r10.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r10.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r10.x, r9.x, l(0.125000)
          movc r9.x, r11.x, r9.x, r10.x
        else 
          mov r11.x, l(-1)
        endif 
        or r9.y, r9.y, r11.x
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r11.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r10.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r11.x, r11.x, -r12.w
          lt r11.x, |r11.x|, |r7.z|
          if_nz r11.x
            add r13.xy, r10.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r10.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r10.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r10.x, r9.x, l(0.125000)
          movc r9.x, r11.x, r9.x, r10.x
        else 
          mov r11.x, l(-1)
        endif 
        or r9.y, r9.y, r11.x
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r11.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r10.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r11.x, r11.x, -r12.w
          lt r11.x, |r11.x|, |r7.z|
          if_nz r11.x
            add r13.xy, r10.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r10.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r10.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r10.x, r9.x, l(0.125000)
          movc r9.x, r11.x, r9.x, r10.x
        else 
          mov r11.x, l(-1)
        endif 
        or r9.y, r9.y, r11.x
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r11.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r10.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r11.x, r11.x, -r12.w
          lt r11.x, |r11.x|, |r7.z|
          if_nz r11.x
            add r13.xy, r10.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r10.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r10.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r10.x, r9.x, l(0.125000)
          movc r9.x, r11.x, r9.x, r10.x
        else 
          mov r11.x, l(-1)
        endif 
        or r9.y, r9.y, r11.x
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r10.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r9.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r9.y, r10.xyxx, t13.yxzw, s13, l(0.000000)
          add_sat r11.x, -r9.y, l(0.000100)
          add r11.x, r9.y, r11.x
          div r11.x, l(1.000000, 1.000000, 1.000000, 1.000000), r11.x
          add r9.x, r9.x, -r11.x
          lt r9.x, |r9.x|, |r7.z|
          if_nz r9.x
            add r11.xw, r10.xxxy, l(-0.500000, 0.000000, 0.000000, -0.500000)
            max r9.x, |r11.w|, |r11.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp_sat r9.x, r9.x
            add r9.y, -r7.w, r9.y
            mul_sat r9.y, r8.w, r9.y
            add r9.xy, -r9.xyxx, l(1.000000, 1.000000, 0.000000, 0.000000)
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].y
            exp r9.y, r9.y
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r10.xyxx, t12.xyzw, s12, l(0.000000)
            mul r9.x, r9.y, r9.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r12.xyz, r9.xxxx, r13.xyzx, r5.xyzx
          endif 
        endif 
      endif 
      sample_l_indexable(texture2d)(float,float,float,float) r9.x, r10.zwzz, t13.xyzw, s13, l(0.000000)
      add_sat r9.y, -r9.x, l(0.000100)
      add r9.y, r9.y, r9.x
      div r9.y, l(1.000000, 1.000000, 1.000000, 1.000000), r9.y
      add r9.y, -r9.y, r11.y
      lt r9.y, |r9.y|, |r7.z|
      if_nz r9.y
        add r10.xy, r10.zwzz, l(-0.500000, -0.500000, 0.000000, 0.000000)
        max r10.x, |r10.y|, |r10.x|
        add r10.x, r10.x, r10.x
        log r10.x, r10.x
        mul r10.x, r10.x, cb9[34].x
        exp_sat r10.x, r10.x
        add r10.x, -r10.x, l(1.000000)
        add r9.x, -r7.w, r9.x
        mul_sat r9.x, r8.w, r9.x
        add r9.x, -r9.x, l(1.000000)
        log r9.x, r9.x
        mul r9.x, r9.x, cb9[34].y
        exp r9.x, r9.x
        sample_l_indexable(texture2d)(float,float,float,float) r10.yzw, r10.zwzz, t12.wxyz, s12, l(0.000000)
        mul r9.x, r9.x, r10.x
        mad r10.xyz, -r3.xywx, cb1[2].xyzx, r10.yzwy
        mad r10.xyz, r9.xxxx, r10.xyzx, r5.xyzx
      else 
        mov r10.xyz, r5.xyzx
      endif 
      movc r9.x, r9.y, l(0.043750), l(0.168750)
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r11.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r10.w, r10.w, -r12.w
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r11.xyxx, t12.xyzw, s12, l(0.000000)
            mul r11.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r10.xyz, r11.xxxx, r13.xyzx, r5.xyzx
          endif 
          movc r11.x, r9.y, l(0.168750), l(0.293750)
          movc r9.x, r10.w, r9.x, r11.x
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r11.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r10.w, r10.w, -r12.w
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r11.xyxx, t12.xyzw, s12, l(0.000000)
            mul r11.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r10.xyz, r11.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r11.x, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.x
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r11.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r10.w, r10.w, -r12.w
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r11.xyxx, t12.xyzw, s12, l(0.000000)
            mul r11.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r10.xyz, r11.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r11.x, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.x
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r11.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r10.w, r10.w, -r12.w
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r11.xyxx, t12.xyzw, s12, l(0.000000)
            mul r11.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r10.xyz, r11.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r11.x, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.x
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r11.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r10.w, r10.w, -r12.w
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r11.xyxx, t12.xyzw, s12, l(0.000000)
            mul r11.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r10.xyz, r11.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r11.x, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.x
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r11.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r10.w, r10.w, -r12.w
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r11.xyxx, t12.xyzw, s12, l(0.000000)
            mul r11.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r10.xyz, r11.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r11.x, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.x
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r11.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.w, -r11.w, l(0.000100)
          add r12.w, r11.w, r12.w
          div r12.w, l(1.000000, 1.000000, 1.000000, 1.000000), r12.w
          add r10.w, r10.w, -r12.w
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r12.w, |r13.y|, |r13.x|
            add r12.w, r12.w, r12.w
            log r12.w, r12.w
            mul r12.w, r12.w, cb9[34].x
            exp_sat r12.w, r12.w
            add r12.w, -r12.w, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r11.xyxx, t12.xyzw, s12, l(0.000000)
            mul r11.x, r11.w, r12.w
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r10.xyz, r11.xxxx, r13.xyzx, r5.xyzx
          endif 
          add r11.x, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.x
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r11.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r9.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r9.y, r11.xyxx, t13.yxzw, s13, l(0.000000)
          add_sat r10.w, -r9.y, l(0.000100)
          add r10.w, r9.y, r10.w
          div r10.w, l(1.000000, 1.000000, 1.000000, 1.000000), r10.w
          add r9.x, r9.x, -r10.w
          lt r9.x, |r9.x|, |r7.z|
          if_nz r9.x
            add r13.xy, r11.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r13.y|, |r13.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp_sat r9.x, r9.x
            add r9.y, -r7.w, r9.y
            mul_sat r9.y, r8.w, r9.y
            add r9.xy, -r9.xyxx, l(1.000000, 1.000000, 0.000000, 0.000000)
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].y
            exp r9.y, r9.y
            sample_l_indexable(texture2d)(float,float,float,float) r11.xyw, r11.xyxx, t12.xywz, s12, l(0.000000)
            mul r9.x, r9.y, r9.x
            mad r11.xyw, -r3.xyxw, cb1[2].xyxz, r11.xyxw
            mad r10.xyz, r9.xxxx, r11.xywx, r5.xyzx
          endif 
        endif 
      endif 
      add r10.xyz, r10.xyzx, r12.xyzx
      mad r12.xyzw, r7.xyxy, l(0.075000, 0.075000, 0.106250, 0.106250), r9.zwzw
      sample_l_indexable(texture2d)(float,float,float,float) r9.x, r12.xyxx, t13.xyzw, s13, l(0.000000)
      add_sat r9.y, -r9.x, l(0.000100)
      add r9.y, r9.y, r9.x
      div r9.y, l(1.000000, 1.000000, 1.000000, 1.000000), r9.y
      add r9.y, -r9.y, r11.z
      lt r9.y, |r9.y|, |r7.z|
      if_nz r9.y
        add r11.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
        max r10.w, |r11.y|, |r11.x|
        add r10.w, r10.w, r10.w
        log r10.w, r10.w
        mul r10.w, r10.w, cb9[34].x
        exp_sat r10.w, r10.w
        add r10.w, -r10.w, l(1.000000)
        add r9.x, -r7.w, r9.x
        mul_sat r9.x, r8.w, r9.x
        add r9.x, -r9.x, l(1.000000)
        log r9.x, r9.x
        mul r9.x, r9.x, cb9[34].y
        exp r9.x, r9.x
        sample_l_indexable(texture2d)(float,float,float,float) r11.xyz, r12.xyxx, t12.xyzw, s12, l(0.000000)
        mul r9.x, r9.x, r10.w
        mad r11.xyz, -r3.xywx, cb1[2].xyzx, r11.xyzx
        mad r11.xyz, r9.xxxx, r11.xyzx, r5.xyzx
      else 
        mov r11.xyz, r5.xyzx
      endif 
      movc r9.x, r9.y, l(0.075000), l(0.200000)
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r13.x, -r11.w, l(0.000100)
          add r13.x, r11.w, r13.x
          div r13.x, l(1.000000, 1.000000, 1.000000, 1.000000), r13.x
          add r10.w, r10.w, -r13.x
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r13.x, |r13.y|, |r13.x|
            add r13.x, r13.x, r13.x
            log r13.x, r13.x
            mul r13.x, r13.x, cb9[34].x
            exp_sat r13.x, r13.x
            add r13.x, -r13.x, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.yzw, r12.xyxx, t12.wxyz, s12, l(0.000000)
            mul r11.w, r11.w, r13.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.yzwy
            mad r11.xyz, r11.wwww, r13.xyzx, r5.xyzx
          endif 
          movc r11.w, r9.y, l(0.200000), l(0.325000)
          movc r9.x, r10.w, r9.x, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r13.x, -r11.w, l(0.000100)
          add r13.x, r11.w, r13.x
          div r13.x, l(1.000000, 1.000000, 1.000000, 1.000000), r13.x
          add r10.w, r10.w, -r13.x
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r13.x, |r13.y|, |r13.x|
            add r13.x, r13.x, r13.x
            log r13.x, r13.x
            mul r13.x, r13.x, cb9[34].x
            exp_sat r13.x, r13.x
            add r13.x, -r13.x, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.yzw, r12.xyxx, t12.wxyz, s12, l(0.000000)
            mul r11.w, r11.w, r13.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.yzwy
            mad r11.xyz, r11.wwww, r13.xyzx, r5.xyzx
          endif 
          add r11.w, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r13.x, -r11.w, l(0.000100)
          add r13.x, r11.w, r13.x
          div r13.x, l(1.000000, 1.000000, 1.000000, 1.000000), r13.x
          add r10.w, r10.w, -r13.x
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r13.x, |r13.y|, |r13.x|
            add r13.x, r13.x, r13.x
            log r13.x, r13.x
            mul r13.x, r13.x, cb9[34].x
            exp_sat r13.x, r13.x
            add r13.x, -r13.x, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.yzw, r12.xyxx, t12.wxyz, s12, l(0.000000)
            mul r11.w, r11.w, r13.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.yzwy
            mad r11.xyz, r11.wwww, r13.xyzx, r5.xyzx
          endif 
          add r11.w, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r13.x, -r11.w, l(0.000100)
          add r13.x, r11.w, r13.x
          div r13.x, l(1.000000, 1.000000, 1.000000, 1.000000), r13.x
          add r10.w, r10.w, -r13.x
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r13.x, |r13.y|, |r13.x|
            add r13.x, r13.x, r13.x
            log r13.x, r13.x
            mul r13.x, r13.x, cb9[34].x
            exp_sat r13.x, r13.x
            add r13.x, -r13.x, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.yzw, r12.xyxx, t12.wxyz, s12, l(0.000000)
            mul r11.w, r11.w, r13.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.yzwy
            mad r11.xyz, r11.wwww, r13.xyzx, r5.xyzx
          endif 
          add r11.w, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r13.x, -r11.w, l(0.000100)
          add r13.x, r11.w, r13.x
          div r13.x, l(1.000000, 1.000000, 1.000000, 1.000000), r13.x
          add r10.w, r10.w, -r13.x
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r13.x, |r13.y|, |r13.x|
            add r13.x, r13.x, r13.x
            log r13.x, r13.x
            mul r13.x, r13.x, cb9[34].x
            exp_sat r13.x, r13.x
            add r13.x, -r13.x, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.yzw, r12.xyxx, t12.wxyz, s12, l(0.000000)
            mul r11.w, r11.w, r13.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.yzwy
            mad r11.xyz, r11.wwww, r13.xyzx, r5.xyzx
          endif 
          add r11.w, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r13.x, -r11.w, l(0.000100)
          add r13.x, r11.w, r13.x
          div r13.x, l(1.000000, 1.000000, 1.000000, 1.000000), r13.x
          add r10.w, r10.w, -r13.x
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r13.x, |r13.y|, |r13.x|
            add r13.x, r13.x, r13.x
            log r13.x, r13.x
            mul r13.x, r13.x, cb9[34].x
            exp_sat r13.x, r13.x
            add r13.x, -r13.x, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.yzw, r12.xyxx, t12.wxyz, s12, l(0.000000)
            mul r11.w, r11.w, r13.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.yzwy
            mad r11.xyz, r11.wwww, r13.xyzx, r5.xyzx
          endif 
          add r11.w, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r10.w, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r13.x, -r11.w, l(0.000100)
          add r13.x, r11.w, r13.x
          div r13.x, l(1.000000, 1.000000, 1.000000, 1.000000), r13.x
          add r10.w, r10.w, -r13.x
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r13.x, |r13.y|, |r13.x|
            add r13.x, r13.x, r13.x
            log r13.x, r13.x
            mul r13.x, r13.x, cb9[34].x
            exp_sat r13.x, r13.x
            add r13.x, -r13.x, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r13.yzw, r12.xyxx, t12.wxyz, s12, l(0.000000)
            mul r11.w, r11.w, r13.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.yzwy
            mad r11.xyz, r11.wwww, r13.xyzx, r5.xyzx
          endif 
          add r11.w, r9.x, l(0.125000)
          movc r9.x, r10.w, r9.x, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.y, r9.y, r10.w
      else 
        mov r9.y, l(-1)
      endif 
      if_z r9.y
        if_z r9.y
          mad r12.xy, r9.xxxx, r7.xyxx, r9.zwzz
          mad r9.x, r9.x, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r9.y, r12.xyxx, t13.yxzw, s13, l(0.000000)
          add_sat r10.w, -r9.y, l(0.000100)
          add r10.w, r9.y, r10.w
          div r10.w, l(1.000000, 1.000000, 1.000000, 1.000000), r10.w
          add r9.x, r9.x, -r10.w
          lt r9.x, |r9.x|, |r7.z|
          if_nz r9.x
            add r13.xy, r12.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r13.y|, |r13.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp_sat r9.x, r9.x
            add r9.y, -r7.w, r9.y
            mul_sat r9.y, r8.w, r9.y
            add r9.xy, -r9.xyxx, l(1.000000, 1.000000, 0.000000, 0.000000)
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].y
            exp r9.y, r9.y
            sample_l_indexable(texture2d)(float,float,float,float) r13.xyz, r12.xyxx, t12.xyzw, s12, l(0.000000)
            mul r9.x, r9.y, r9.x
            mad r13.xyz, -r3.xywx, cb1[2].xyzx, r13.xyzx
            mad r11.xyz, r9.xxxx, r13.xyzx, r5.xyzx
          endif 
        endif 
      endif 
      add r10.xyz, r10.xyzx, r11.xyzx
      mad r9.x, r5.w, l(0.106250), r2.y
      sample_l_indexable(texture2d)(float,float,float,float) r9.y, r12.zwzz, t13.yxzw, s13, l(0.000000)
      add_sat r10.w, -r9.y, l(0.000100)
      add r10.w, r9.y, r10.w
      div r10.w, l(1.000000, 1.000000, 1.000000, 1.000000), r10.w
      add r9.x, r9.x, -r10.w
      lt r9.x, |r9.x|, |r7.z|
      if_nz r9.x
        add r11.xy, r12.zwzz, l(-0.500000, -0.500000, 0.000000, 0.000000)
        max r10.w, |r11.y|, |r11.x|
        add r10.w, r10.w, r10.w
        log r10.w, r10.w
        mul r10.w, r10.w, cb9[34].x
        exp_sat r10.w, r10.w
        add r10.w, -r10.w, l(1.000000)
        add r9.y, -r7.w, r9.y
        mul_sat r9.y, r8.w, r9.y
        add r9.y, -r9.y, l(1.000000)
        log r9.y, r9.y
        mul r9.y, r9.y, cb9[34].y
        exp r9.y, r9.y
        sample_l_indexable(texture2d)(float,float,float,float) r11.xyz, r12.zwzz, t12.xyzw, s12, l(0.000000)
        mul r9.y, r9.y, r10.w
        mad r11.xyz, -r3.xywx, cb1[2].xyzx, r11.xyzx
        mad r11.xyz, r9.yyyy, r11.xyzx, r5.xyzx
      else 
        mov r11.xyz, r5.xyzx
      endif 
      movc r9.y, r9.x, l(0.106250), l(0.231250)
      if_z r9.x
        if_z r9.x
          mad r12.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r10.w, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.z, -r11.w, l(0.000100)
          add r12.z, r11.w, r12.z
          div r12.z, l(1.000000, 1.000000, 1.000000, 1.000000), r12.z
          add r10.w, r10.w, -r12.z
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r12.zw, r12.xxxy, l(0.000000, 0.000000, -0.500000, -0.500000)
            max r12.z, |r12.w|, |r12.z|
            add r12.z, r12.z, r12.z
            log r12.z, r12.z
            mul r12.z, r12.z, cb9[34].x
            exp_sat r12.z, r12.z
            add r12.z, -r12.z, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r12.xyw, r12.xyxx, t12.xywz, s12, l(0.000000)
            mul r11.w, r11.w, r12.z
            mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xywx
            mad r11.xyz, r11.wwww, r12.xyzx, r5.xyzx
          endif 
          movc r11.w, r9.x, l(0.231250), l(0.356250)
          movc r9.y, r10.w, r9.y, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.x, r9.x, r10.w
      else 
        mov r9.x, l(-1)
      endif 
      if_z r9.x
        if_z r9.x
          mad r12.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r10.w, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.z, -r11.w, l(0.000100)
          add r12.z, r11.w, r12.z
          div r12.z, l(1.000000, 1.000000, 1.000000, 1.000000), r12.z
          add r10.w, r10.w, -r12.z
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r12.zw, r12.xxxy, l(0.000000, 0.000000, -0.500000, -0.500000)
            max r12.z, |r12.w|, |r12.z|
            add r12.z, r12.z, r12.z
            log r12.z, r12.z
            mul r12.z, r12.z, cb9[34].x
            exp_sat r12.z, r12.z
            add r12.z, -r12.z, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r12.xyw, r12.xyxx, t12.xywz, s12, l(0.000000)
            mul r11.w, r11.w, r12.z
            mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xywx
            mad r11.xyz, r11.wwww, r12.xyzx, r5.xyzx
          endif 
          add r11.w, r9.y, l(0.125000)
          movc r9.y, r10.w, r9.y, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.x, r9.x, r10.w
      else 
        mov r9.x, l(-1)
      endif 
      if_z r9.x
        if_z r9.x
          mad r12.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r10.w, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.z, -r11.w, l(0.000100)
          add r12.z, r11.w, r12.z
          div r12.z, l(1.000000, 1.000000, 1.000000, 1.000000), r12.z
          add r10.w, r10.w, -r12.z
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r12.zw, r12.xxxy, l(0.000000, 0.000000, -0.500000, -0.500000)
            max r12.z, |r12.w|, |r12.z|
            add r12.z, r12.z, r12.z
            log r12.z, r12.z
            mul r12.z, r12.z, cb9[34].x
            exp_sat r12.z, r12.z
            add r12.z, -r12.z, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r12.xyw, r12.xyxx, t12.xywz, s12, l(0.000000)
            mul r11.w, r11.w, r12.z
            mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xywx
            mad r11.xyz, r11.wwww, r12.xyzx, r5.xyzx
          endif 
          add r11.w, r9.y, l(0.125000)
          movc r9.y, r10.w, r9.y, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.x, r9.x, r10.w
      else 
        mov r9.x, l(-1)
      endif 
      if_z r9.x
        if_z r9.x
          mad r12.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r10.w, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.z, -r11.w, l(0.000100)
          add r12.z, r11.w, r12.z
          div r12.z, l(1.000000, 1.000000, 1.000000, 1.000000), r12.z
          add r10.w, r10.w, -r12.z
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r12.zw, r12.xxxy, l(0.000000, 0.000000, -0.500000, -0.500000)
            max r12.z, |r12.w|, |r12.z|
            add r12.z, r12.z, r12.z
            log r12.z, r12.z
            mul r12.z, r12.z, cb9[34].x
            exp_sat r12.z, r12.z
            add r12.z, -r12.z, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r12.xyw, r12.xyxx, t12.xywz, s12, l(0.000000)
            mul r11.w, r11.w, r12.z
            mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xywx
            mad r11.xyz, r11.wwww, r12.xyzx, r5.xyzx
          endif 
          add r11.w, r9.y, l(0.125000)
          movc r9.y, r10.w, r9.y, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.x, r9.x, r10.w
      else 
        mov r9.x, l(-1)
      endif 
      if_z r9.x
        if_z r9.x
          mad r12.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r10.w, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.z, -r11.w, l(0.000100)
          add r12.z, r11.w, r12.z
          div r12.z, l(1.000000, 1.000000, 1.000000, 1.000000), r12.z
          add r10.w, r10.w, -r12.z
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r12.zw, r12.xxxy, l(0.000000, 0.000000, -0.500000, -0.500000)
            max r12.z, |r12.w|, |r12.z|
            add r12.z, r12.z, r12.z
            log r12.z, r12.z
            mul r12.z, r12.z, cb9[34].x
            exp_sat r12.z, r12.z
            add r12.z, -r12.z, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r12.xyw, r12.xyxx, t12.xywz, s12, l(0.000000)
            mul r11.w, r11.w, r12.z
            mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xywx
            mad r11.xyz, r11.wwww, r12.xyzx, r5.xyzx
          endif 
          add r11.w, r9.y, l(0.125000)
          movc r9.y, r10.w, r9.y, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.x, r9.x, r10.w
      else 
        mov r9.x, l(-1)
      endif 
      if_z r9.x
        if_z r9.x
          mad r12.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r10.w, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.z, -r11.w, l(0.000100)
          add r12.z, r11.w, r12.z
          div r12.z, l(1.000000, 1.000000, 1.000000, 1.000000), r12.z
          add r10.w, r10.w, -r12.z
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r12.zw, r12.xxxy, l(0.000000, 0.000000, -0.500000, -0.500000)
            max r12.z, |r12.w|, |r12.z|
            add r12.z, r12.z, r12.z
            log r12.z, r12.z
            mul r12.z, r12.z, cb9[34].x
            exp_sat r12.z, r12.z
            add r12.z, -r12.z, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r12.xyw, r12.xyxx, t12.xywz, s12, l(0.000000)
            mul r11.w, r11.w, r12.z
            mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xywx
            mad r11.xyz, r11.wwww, r12.xyzx, r5.xyzx
          endif 
          add r11.w, r9.y, l(0.125000)
          movc r9.y, r10.w, r9.y, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.x, r9.x, r10.w
      else 
        mov r9.x, l(-1)
      endif 
      if_z r9.x
        if_z r9.x
          mad r12.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r10.w, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r11.w, r12.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r12.z, -r11.w, l(0.000100)
          add r12.z, r11.w, r12.z
          div r12.z, l(1.000000, 1.000000, 1.000000, 1.000000), r12.z
          add r10.w, r10.w, -r12.z
          lt r10.w, |r10.w|, |r7.z|
          if_nz r10.w
            add r12.zw, r12.xxxy, l(0.000000, 0.000000, -0.500000, -0.500000)
            max r12.z, |r12.w|, |r12.z|
            add r12.z, r12.z, r12.z
            log r12.z, r12.z
            mul r12.z, r12.z, cb9[34].x
            exp_sat r12.z, r12.z
            add r12.z, -r12.z, l(1.000000)
            add r11.w, -r7.w, r11.w
            mul_sat r11.w, r8.w, r11.w
            add r11.w, -r11.w, l(1.000000)
            log r11.w, r11.w
            mul r11.w, r11.w, cb9[34].y
            exp r11.w, r11.w
            sample_l_indexable(texture2d)(float,float,float,float) r12.xyw, r12.xyxx, t12.xywz, s12, l(0.000000)
            mul r11.w, r11.w, r12.z
            mad r12.xyz, -r3.xywx, cb1[2].xyzx, r12.xywx
            mad r11.xyz, r11.wwww, r12.xyzx, r5.xyzx
          endif 
          add r11.w, r9.y, l(0.125000)
          movc r9.y, r10.w, r9.y, r11.w
        else 
          mov r10.w, l(-1)
        endif 
        or r9.x, r9.x, r10.w
      else 
        mov r9.x, l(-1)
      endif 
      if_z r9.x
        if_z r9.x
          mad r7.xy, r9.yyyy, r7.xyxx, r9.zwzz
          mad r2.y, r9.y, r5.w, r2.y
          sample_l_indexable(texture2d)(float,float,float,float) r5.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r5.w, l(0.000100)
          add r9.x, r5.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r2.y, r2.y, -r9.x
          lt r2.y, |r2.y|, |r7.z|
          if_nz r2.y
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r2.y, |r9.y|, |r9.x|
            add r2.y, r2.y, r2.y
            log r2.y, r2.y
            mul r2.y, r2.y, cb9[34].x
            exp_sat r2.y, r2.y
            add r2.y, -r2.y, l(1.000000)
            add r5.w, -r7.w, r5.w
            mul_sat r5.w, r8.w, r5.w
            add r5.w, -r5.w, l(1.000000)
            log r5.w, r5.w
            mul r5.w, r5.w, cb9[34].y
            exp r5.w, r5.w
            sample_l_indexable(texture2d)(float,float,float,float) r7.xyz, r7.xyxx, t12.xyzw, s12, l(0.000000)
            mul r2.y, r2.y, r5.w
            mad r7.xyz, -r3.xywx, cb1[2].xyzx, r7.xyzx
            mad r11.xyz, r2.yyyy, r7.xyzx, r5.xyzx
          endif 
        endif 
      endif 
      add r7.xyz, r10.xyzx, r11.xyzx
      mul r2.y, r2.w, cb9[33].x
      mad r7.xyz, r7.xyzx, l(0.250000, 0.250000, 0.250000, 0.000000), -r5.xyzx
      mad r7.xyz, r2.yyyy, r7.xyzx, r5.xyzx
    else 
      mov r7.xyz, r5.xyzx
    endif 
  else 
    mov r7.xyz, r5.xyzx
  endif 
  mad r3.xyw, -r3.xyxw, cb1[2].xyxz, r7.xyxz
  mad r5.xyz, r0.wwww, r3.xywx, r5.xyzx
endif 
add r3.xyw, -r8.xyxz, cb0[7].xyxz
mad r3.xyw, cb9[37].wwww, r3.xyxw, r8.xyxz
add r0.w, r1.w, l(-0.700000)
mul_sat r0.w, r0.w, l(5.000000)
add r2.yw, -r0.wwww, l(0.000000, 1.000000, 0.000000, 1.500000)
mul r0.w, r2.w, r2.y
add r1.y, r1.y, r4.w
add r1.y, r3.z, r1.y
add_sat r1.y, r1.y, l(-2.400000)
add_sat r1.w, l(0.500000), -cb9[5].x
mul r0.w, r0.w, r1.w
mul r0.w, r1.y, r0.w
mul r0.w, r0.w, l(1.100000)
mul r1.y, r1.z, r2.z
add r5.xyz, -r3.xywx, r5.xyzx
mad r1.yzw, r1.yyyy, r5.xxyz, r3.xxyw
mov r6.w, l(0.600000)
dp3 r2.y, r6.yzwy, r6.yzwy
rsq r2.y, r2.y
mad r3.xyz, r6.zwyz, r2.yyyy, -r6.zxyz
mad r3.xyz, cb9[37].zzzz, r3.xyzx, r6.zxyz
dp3 r2.y, r3.xyzx, r3.xyzx
rsq r2.y, r2.y
mul r3.xyz, r2.yyyy, r3.xyzx
mov r5.xy, -cb5[5].yzyy
mov r5.z, cb5[5].x
dp3 r2.y, r5.xyzx, r3.xyzx
add r2.y, r2.y, r2.y
mad r3.xyz, r3.xyzx, -r2.yyyy, r5.xyzx
dp3_sat r2.y, r3.xyzx, r4.xyzx
log r2.y, r2.y
mul r2.y, r2.y, cb9[4].w
exp r2.y, r2.y
mul r2.y, r2.z, r2.y
mul r2.yzw, r2.yyyy, cb5[6].xxyz
mul_sat r2.yzw, r2.yyzw, cb9[4].zzzz
mov r3.x, l(1.000000)
mov r5.xyz, l(0,0,0,0)
mov r7.xyz, l(0,0,0,0)
mov r8.xyz, l(0,0,0,0)
mov r3.w, l(0)
loop 
  ige r4.w, r3.w, cb10[0].x
  breakc_nz r4.w
  imul null, r4.w, r3.w, l(6)
  add r9.xyz, -v1.xyzx, cb11[r4.w + 0].xyzx
  dp3 r4.w, r9.xyzx, r9.xyzx
  sqrt r4.w, r4.w
  add r5.w, r4.w, l(0.000100)
  div r9.xyz, r9.xyzx, r5.wwww
  imad r10.xyzw, r3.wwww, l(6, 6, 6, 6), l(4, 5, 2, 3)
  mad r5.w, r4.w, cb10[2].x, -cb11[r10.x + 0].x
  max r3.y, r5.w, l(0.000000)
  mul r3.z, r3.y, r3.y
  dp3 r3.y, cb11[r10.x + 0].yzwy, r3.xyzx
  add r3.y, r3.y, l(0.000100)
  div r3.y, l(1.000000, 1.000000, 1.000000, 1.000000), r3.y
  mov_sat r3.y, r3.y
  mad r3.z, r4.w, cb10[2].x, -cb11[r10.y + 0].x
  mul_sat r3.z, r3.z, cb11[r10.y + 0].y
  add r3.z, -r3.z, l(1.000000)
  mul r3.y, r3.z, r3.y
  add r11.xyz, r4.xyzx, r9.xyzx
  dp3 r3.z, r11.xyzx, r11.xyzx
  rsq r3.z, r3.z
  mul r11.xyz, r3.zzzz, r11.xyzx
  dp3 r3.z, r6.zxyz, r9.xyzx
  dp3 r4.w, r6.zxyz, r11.xyzx
  ge r5.w, r3.z, l(0.000000)
  max r3.z, r3.z, l(0.000000)
  ge r6.w, r4.w, l(0.000000)
  and r5.w, r5.w, r6.w
  log r4.w, r4.w
  mul r4.w, r4.w, cb9[4].w
  exp r4.w, r4.w
  and r4.w, r4.w, r5.w
  min r4.w, r4.w, l(1.000000)
  mul r9.xyz, cb10[3].xyzx, cb11[r10.z + 0].xyzx
  mul r9.xyz, r3.zzzz, r9.xyzx
  mul r9.xyz, r3.yyyy, r9.xyzx
  mad r5.xyz, r9.xyzx, l(0.500000, 0.500000, 0.500000, 0.000000), r5.xyzx
  mad r7.xyz, cb11[r10.w + 0].xyzx, r3.yyyy, r7.xyzx
  mul r9.xyz, cb5[7].xyzx, cb11[r10.z + 0].xyzx
  mul r9.xyz, r4.wwww, r9.xyzx
  mad r8.xyz, r9.xyzx, r3.yyyy, r8.xyzx
  iadd r3.w, r3.w, l(1)
endloop 
iadd r3.x, cb10[0].x, cb10[1].x
mov r9.x, l(1.000000)
mov r10.xyz, r5.xyzx
mov r11.xyz, r7.xyzx
mov r12.xyz, r8.xyzx
mov r3.y, r3.w
loop 
  ige r3.z, r3.y, r3.x
  breakc_nz r3.z
  imul null, r3.z, r3.y, l(6)
  add r13.xyz, -v1.xyzx, cb11[r3.z + 0].xyzx
  dp3 r3.z, r13.xyzx, r13.xyzx
  sqrt r3.z, r3.z
  add r4.w, r3.z, l(0.000100)
  div r13.xyz, r13.xyzx, r4.wwww
  imad r4.w, r3.y, l(6), l(1)
  dp3 r5.w, -cb11[r4.w + 0].xyzx, r13.xyzx
  add r4.w, r5.w, -cb11[r4.w + 0].w
  imad r14.xyzw, r3.yyyy, l(6, 6, 6, 6), l(2, 3, 4, 5)
  mul_sat r4.w, r4.w, cb11[r14.x + 0].w
  log r4.w, r4.w
  mul r4.w, r4.w, cb11[r14.y + 0].w
  exp r4.w, r4.w
  mad r5.w, r3.z, cb10[2].x, -cb11[r14.z + 0].x
  max r9.y, r5.w, l(0.000000)
  mul r9.z, r9.y, r9.y
  dp3 r5.w, cb11[r14.z + 0].yzwy, r9.xyzx
  add r5.w, r5.w, l(0.000100)
  div r5.w, l(1.000000, 1.000000, 1.000000, 1.000000), r5.w
  mov_sat r5.w, r5.w
  mad r3.z, r3.z, cb10[2].x, -cb11[r14.w + 0].x
  mul_sat r3.z, r3.z, cb11[r14.w + 0].y
  add r3.z, -r3.z, l(1.000000)
  mul r3.z, r3.z, r5.w
  mul r3.z, r4.w, r3.z
  add r9.yzw, r4.xxyz, r13.xxyz
  dp3 r4.w, r9.yzwy, r9.yzwy
  rsq r4.w, r4.w
  mul r9.yzw, r4.wwww, r9.yyzw
  dp3 r4.w, r6.zxyz, r13.xyzx
  dp3 r5.w, r6.zxyz, r9.yzwy
  ge r6.w, r4.w, l(0.000000)
  max r4.w, r4.w, l(0.000000)
  ge r7.w, r5.w, l(0.000000)
  and r6.w, r6.w, r7.w
  log r5.w, r5.w
  mul r5.w, r5.w, cb9[4].w
  exp r5.w, r5.w
  and r5.w, r5.w, r6.w
  min r5.w, r5.w, l(1.000000)
  mul r9.yzw, cb10[3].xxyz, cb11[r14.x + 0].xxyz
  mul r9.yzw, r4.wwww, r9.yyzw
  mul r9.yzw, r3.zzzz, r9.yyzw
  mad r10.xyz, r9.yzwy, l(0.500000, 0.500000, 0.500000, 0.000000), r10.xyzx
  mad r11.xyz, cb11[r14.y + 0].xyzx, r3.zzzz, r11.xyzx
  mul r9.yzw, cb5[7].xxyz, cb11[r14.x + 0].xxyz
  mul r9.yzw, r5.wwww, r9.yyzw
  mad r12.xyz, r9.yzwy, r3.zzzz, r12.xyzx
  iadd r3.y, r3.y, l(1)
endloop 
add_sat r0.x, r0.x, l(-0.500000)
mul r0.x, r0.x, r2.x
add_sat r1.x, r1.x, l(-0.500000)
mul r0.y, r0.y, r1.x
max r0.x, r0.y, r0.x
mul r0.x, r0.x, cb9[39].x
max r0.x, r0.w, r0.x
add r3.xyz, -r1.yzwy, cb9[0].xyzx
mad r1.xyz, r0.xxxx, r3.xyzx, r1.yzwy
mad r0.y, cb9[5].x, l(0.600000), l(0.200000)
mad r3.xyz, r1.xyzx, r0.yyyy, -r1.xyzx
mad r3.xyz, r0.zzzz, r3.xyzx, r1.xyzx
add r0.x, -r0.x, l(1.000000)
mul r0.x, r0.x, r0.z
mul r2.xyz, r2.yzwy, r0.xxxx
add r0.x, -r0.y, l(1.000000)
mul r0.xyw, r1.xyxz, r0.xxxx
mul r0.xyw, r0.xyxw, r0.zzzz
mul r1.xyz, r0.zzzz, r11.xyzx
mul r4.xyz, r0.zzzz, r12.xyzx
mad r1.xyz, r10.xyzx, r0.zzzz, r1.xyzx
lt r1.w, l(0.000000), cb6[4].x
add r2.w, r0.z, -cb6[4].y
lt r2.w, r2.w, l(0.000000)
and r1.w, r1.w, r2.w
discard_nz r1.w
max r0.z, r0.z, cb5[0].w
add r1.w, -v8.w, cb5[12].z
max r1.w, r1.w, l(0.000000)
mul r5.xyz, -r1.wwww, cb0[15].xyzx
mul r5.xyz, r5.xyzx, l(1.442695, 1.442695, 1.442695, 0.000000)
exp r5.xyz, r5.xyzx
mul r6.xyz, -r1.wwww, cb0[16].xyzx
mul r6.xyz, r6.xyzx, l(1.442695, 1.442695, 1.442695, 0.000000)
exp r6.xyz, r6.xyzx
mad r0.xyw, r0.xyxw, r5.xyxz, r4.xyxz
mad r1.xyz, r3.xyzx, r6.xyzx, r1.xyzx
mad r0.xyw, r2.xyxz, r6.xyxz, r0.xyxw
mad r0.xyw, r1.xyxz, r0.zzzz, r0.xyxw
switch cb5[11].x
  case l(1)
  case l(3)
  add r1.y, cb5[12].z, cb5[13].y
  add r2.xyz, -v8.xyzx, cb6[9].xyzx
  dp3 r1.z, r2.xyzx, r2.xyzx
  sqrt r1.z, r1.z
  lt r1.w, cb6[9].y, r1.y
  if_nz r1.w
    add r2.x, v8.y, -cb6[9].y
    max r2.x, r2.x, l(0.000000)
    add r2.x, r2.x, l(0.000010)
    add r2.y, r1.y, -cb6[9].y
    div_sat r2.x, r2.y, r2.x
    mul r2.y, r1.z, r2.x
    mad r2.z, -r1.z, r2.x, r1.z
    lt r2.w, l(0.000000), r2.z
    if_nz r2.w
      add r2.x, -r2.x, l(1.000000)
      mul r2.x, r1.z, r2.x
      add r2.w, -r1.y, v8.y
      add r3.x, r2.z, l(0.000010)
      div r3.y, |r2.w|, r3.x
      mul r3.y, r3.y, cb5[10].x
      eq r3.z, r3.y, l(0.000000)
      mul r3.w, r2.x, -r3.y
      mul r3.w, r3.w, l(1.442695)
      exp r3.w, r3.w
      add r3.w, -r3.w, l(1.000000)
      div r3.y, r3.w, r3.y
      movc r3.y, r3.z, r2.x, r3.y
      min r3.z, r1.y, v8.y
      mul r3.z, r3.z, -cb5[10].x
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      mul r3.z, r3.z, -cb5[10].y
      mul r3.y, r3.y, r3.z
      mul r3.y, r3.y, l(1.442695)
      exp_sat r3.y, r3.y
      div r2.w, r2.w, r3.x
      mul r2.w, r2.w, cb0[14].z
      eq r3.x, r2.w, l(0.000000)
      mul r3.z, r2.x, -r2.w
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      add r3.z, -r3.z, l(1.000000)
      div r2.w, r3.z, r2.w
      movc r2.x, r3.x, r2.x, r2.w
      add r2.w, r1.y, -cb0[14].x
      mul r2.w, r2.w, -cb0[14].z
      mul r2.w, r2.w, l(1.442695)
      exp r2.w, r2.w
      mul r2.w, r2.w, -cb0[14].y
      mul r2.x, r2.x, r2.w
      mul r2.x, r2.x, l(1.442695)
      exp_sat r2.x, r2.x
      mul r2.x, r2.x, r3.y
    else 
      mov r2.x, l(1.000000)
    endif 
    mul r2.y, r2.y, -cb5[12].w
    mul r2.y, r2.y, l(1.442695)
    exp_sat r2.y, r2.y
  else 
    add r2.w, -v8.y, cb6[9].y
    max r2.w, r2.w, l(0.000000)
    add r2.w, r2.w, l(0.000010)
    add r3.x, -r1.y, cb6[9].y
    div_sat r2.w, r3.x, r2.w
    mul r2.z, r1.z, r2.w
    mad r3.x, -r1.z, r2.w, r1.z
    max r1.y, r1.y, v8.y
    add r3.y, r1.y, -cb6[9].y
    mad r1.z, r1.z, r2.w, l(0.000010)
    div r2.w, |r3.y|, r1.z
    mul r2.w, r2.w, cb5[10].x
    eq r3.z, r2.w, l(0.000000)
    mul r3.w, r2.z, -r2.w
    mul r3.w, r3.w, l(1.442695)
    exp r3.w, r3.w
    add r3.w, -r3.w, l(1.000000)
    div r2.w, r3.w, r2.w
    movc r2.w, r3.z, r2.z, r2.w
    min r1.y, r1.y, cb6[9].y
    mul r1.y, r1.y, -cb5[10].x
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    mul r1.y, r1.y, -cb5[10].y
    mul r1.y, r2.w, r1.y
    mul r1.y, r1.y, l(1.442695)
    exp_sat r1.y, r1.y
    div r1.z, r3.y, r1.z
    mul r1.z, r1.z, cb0[14].z
    eq r2.w, r1.z, l(0.000000)
    mul r3.y, r2.z, -r1.z
    mul r3.y, r3.y, l(1.442695)
    exp r3.y, r3.y
    add r3.y, -r3.y, l(1.000000)
    div r1.z, r3.y, r1.z
    movc r1.z, r2.w, r2.z, r1.z
    add r2.w, -cb0[14].x, cb6[9].y
    mul r2.w, r2.w, -cb0[14].z
    mul r2.w, r2.w, l(1.442695)
    exp r2.w, r2.w
    mul r2.w, r2.w, -cb0[14].y
    mul r1.z, r1.z, r2.w
    mul r1.z, r1.z, l(1.442695)
    exp_sat r1.z, r1.z
    mul r2.x, r1.z, r1.y
    mul r1.y, r3.x, -cb5[12].w
    mul r1.y, r1.y, l(1.442695)
    exp_sat r2.y, r1.y
  endif 
  add r1.y, -r2.z, cb5[12].x
  mul_sat r1.y, r1.y, cb5[12].y
  mul r1.z, r1.y, r2.x
  add r3.xyz, v8.xyzx, -cb6[9].xyzx
  dp3 r2.z, r3.xyzx, r3.xyzx
  rsq r2.z, r2.z
  mul r2.w, r2.z, r3.y
  lt r3.x, r2.w, l(0.000000)
  mad r2.z, r3.y, r2.z, l(1.000000)
  mul r2.z, r2.z, r2.z
  add r3.yz, -cb0[17].xxyx, cb0[17].yyzy
  mad r2.z, r2.z, r3.y, cb0[17].x
  mad r2.w, r2.w, r3.z, cb0[17].y
  movc r2.z, r3.x, r2.z, r2.w
  mul r3.xyz, r2.zzzz, cb0[7].xyzx
  mul r3.xyz, r0.zzzz, r3.xyzx
  mul r4.xyz, r0.zzzz, cb0[1].xyzx
  mad r5.x, -r2.x, r1.y, l(1.000000)
  mul r6.x, r2.y, r5.x
  add r6.y, -r2.y, l(1.000000)
  mul r6.z, r2.y, r1.z
  mul r5.y, r1.z, r6.y
  mov r5.z, r6.z
  movc r1.yzw, r1.wwww, r6.xxyz, r5.xxyz
  mul r2.xyz, r1.zzzz, r3.xyzx
  mad r2.xyz, r4.xyzx, r1.yyyy, r2.xyzx
  mad r0.xyw, r0.xyxw, r1.wwww, r2.xyxz
  mov r1.x, l(1.000000)
  break 
  case l(2)
  add r1.y, cb5[12].z, cb5[13].y
  add r2.xyz, -v8.xyzx, cb6[9].xyzx
  dp3 r1.z, r2.xyzx, r2.xyzx
  sqrt r1.z, r1.z
  lt r1.w, cb6[9].y, r1.y
  if_nz r1.w
    add r1.w, v8.y, -cb6[9].y
    max r1.w, r1.w, l(0.000000)
    add r1.w, r1.w, l(0.000010)
    add r2.x, r1.y, -cb6[9].y
    div_sat r1.w, r2.x, r1.w
    mul r2.x, r1.w, r1.z
    mad r2.y, -r1.z, r1.w, r1.z
    lt r2.z, l(0.000000), r2.y
    if_nz r2.z
      add r1.w, -r1.w, l(1.000000)
      mul r1.w, r1.w, r1.z
      add r2.z, -r1.y, v8.y
      add r2.w, r2.y, l(0.000010)
      div r3.x, |r2.z|, r2.w
      mul r3.x, r3.x, cb5[10].x
      eq r3.y, r3.x, l(0.000000)
      mul r3.z, r1.w, -r3.x
      mul r3.z, r3.z, l(1.442695)
      exp r3.z, r3.z
      add r3.z, -r3.z, l(1.000000)
      div r3.x, r3.z, r3.x
      movc r3.x, r3.y, r1.w, r3.x
      min r3.y, r1.y, v8.y
      mul r3.y, r3.y, -cb5[10].x
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      mul r3.y, r3.y, -cb5[10].y
      mul r3.x, r3.x, r3.y
      mul r3.x, r3.x, l(1.442695)
      exp_sat r3.x, r3.x
      div r2.z, r2.z, r2.w
      mul r2.z, r2.z, cb0[14].z
      eq r2.w, r2.z, l(0.000000)
      mul r3.y, r1.w, -r2.z
      mul r3.y, r3.y, l(1.442695)
      exp r3.y, r3.y
      add r3.y, -r3.y, l(1.000000)
      div r2.z, r3.y, r2.z
      movc r1.w, r2.w, r1.w, r2.z
      add r2.z, r1.y, -cb0[14].x
      mul r2.z, r2.z, -cb0[14].z
      mul r2.z, r2.z, l(1.442695)
      exp r2.z, r2.z
      mul r2.z, r2.z, -cb0[14].y
      mul r1.w, r1.w, r2.z
      mul r1.w, r1.w, l(1.442695)
      exp_sat r1.w, r1.w
      mul r3.x, r1.w, r3.x
    else 
      mov r3.x, l(1.000000)
    endif 
    mul r1.w, r2.x, -cb5[12].w
    mul r1.w, r1.w, l(1.442695)
    exp_sat r3.y, r1.w
  else 
    add r1.w, -v8.y, cb6[9].y
    max r1.w, r1.w, l(0.000000)
    add r1.w, r1.w, l(0.000010)
    add r2.x, -r1.y, cb6[9].y
    div_sat r1.w, r2.x, r1.w
    mul r2.y, r1.w, r1.z
    mad r2.x, -r1.z, r1.w, r1.z
    max r1.y, r1.y, v8.y
    add r2.z, r1.y, -cb6[9].y
    mad r1.z, r1.z, r1.w, l(0.000010)
    div r1.w, |r2.z|, r1.z
    mul r1.w, r1.w, cb5[10].x
    eq r2.w, r1.w, l(0.000000)
    mul r3.z, r2.y, -r1.w
    mul r3.z, r3.z, l(1.442695)
    exp r3.z, r3.z
    add r3.z, -r3.z, l(1.000000)
    div r1.w, r3.z, r1.w
    movc r1.w, r2.w, r2.y, r1.w
    min r1.y, r1.y, cb6[9].y
    mul r1.y, r1.y, -cb5[10].x
    mul r1.y, r1.y, l(1.442695)
    exp r1.y, r1.y
    mul r1.y, r1.y, -cb5[10].y
    mul r1.y, r1.w, r1.y
    mul r1.y, r1.y, l(1.442695)
    exp_sat r1.y, r1.y
    div r1.z, r2.z, r1.z
    mul r1.z, r1.z, cb0[14].z
    eq r1.w, r1.z, l(0.000000)
    mul r2.z, r2.y, -r1.z
    mul r2.z, r2.z, l(1.442695)
    exp r2.z, r2.z
    add r2.z, -r2.z, l(1.000000)
    div r1.z, r2.z, r1.z
    movc r1.z, r1.w, r2.y, r1.z
    add r1.w, -cb0[14].x, cb6[9].y
    mul r1.w, r1.w, -cb0[14].z
    mul r1.w, r1.w, l(1.442695)
    exp r1.w, r1.w
    mul r1.w, r1.w, -cb0[14].y
    mul r1.z, r1.z, r1.w
    mul r1.z, r1.z, l(1.442695)
    exp_sat r1.z, r1.z
    mul r3.x, r1.z, r1.y
    mul r1.y, r2.x, -cb5[12].w
    mul r1.y, r1.y, l(1.442695)
    exp_sat r3.y, r1.y
  endif 
  add r1.y, -r2.y, cb5[12].x
  mul_sat r1.y, r1.y, cb5[12].y
  mul r1.y, r1.y, r3.x
  mul r1.x, r3.y, r1.y
  break 
  default 
  mov r1.x, l(1.000000)
  break 
endswitch 
mul o0.xyzw, r0.xywz, r1.xxxx
ret 
// Approximately 0 instruction slots used

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