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

Texture2D<float4> t13 : register(t13);

Texture2D<float4> t12 : register(t12);

Texture2D<float4> t11 : register(t11);

Texture2D<float4> t10 : register(t10);

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);

SamplerComparisonState s15_s : register(s15);

SamplerState s13_s : register(s13);

SamplerState s12_s : register(s12);

SamplerState s11_s : register(s11);

SamplerState s10_s : register(s10);

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[13];
}

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,
  uint v9 : SV_IsFrontFace0,
  out float4 o0 : SV_Target0)
{
  float4 r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11,r12,r13;
  uint4 bitmask, uiDest;
  float4 fDest;


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

  r0.xyz = cb6[6].xyz + -v1.xyz;
  r0.w = dot(r0.xyz, r0.xyz);
  r0.w = sqrt(r0.w);
  r0.w = 9.99999975e-005 + r0.w;
  r0.xyz = r0.xyz / r0.www;
  r1.xy = t1.Sample(s1_s, v4.xy).yw;
  r1.zw = t1.Sample(s1_s, v4.zw).yw;
  r1.xy = r1.xy * float2(2,2) + float2(-1,-1);
  r1.zw = r1.zw * float2(2,2) + float2(-1,-1);
  r2.xyzw = float4(0.25,0.25,0.5,0.5) + v4.zwzw;
  r2.xy = t1.Sample(s1_s, r2.xy).yw;
  r2.zw = t1.Sample(s1_s, r2.zw).yw;
  r3.xy = float2(0.75,0.75) + v4.zw;
  r3.xy = t1.Sample(s1_s, r3.xy).yw;
  r3.zw = t3.Sample(s3_s, v5.xy).yw;
  r4.xyzw = float4(0.25,0.25,0.5,0.5) + v5.xyxy;
  r4.xy = t3.Sample(s3_s, r4.xy).yw;
  r4.zw = t3.Sample(s3_s, r4.zw).yw;
  r5.xy = float2(0.75,0.75) + v5.xy;
  r5.xy = t3.Sample(s3_s, r5.xy).yw;
  r2.xy = r2.xy * float2(2,2) + float2(-1,-1);
  r2.zw = r2.zw * float2(2,2) + float2(-1,-1);
  r3.xy = r3.xy * float2(2,2) + float2(-1,-1);
  r3.zw = r3.zw * float2(2,2) + float2(-1,-1);
  r4.xy = r4.xy * float2(2,2) + float2(-1,-1);
  r4.zw = r4.zw * float2(2,2) + float2(-1,-1);
  r5.xy = r5.xy * float2(2,2) + float2(-1,-1);
  r5.zw = cb9[5].xx * float2(0.800000012,0.600000024) + float2(0.400000006,0.200000003);
  r6.xyzw = cb9[1].xyzw * r5.zzzz;
  r6.xyzw = v5.zzzz * r6.xyzw;
  r7.xyzw = cb9[2].xyzw * r5.zzzz;
  r7.xyzw = v5.wwww * r7.xyzw;
  r2.xy = r6.yy * r2.xy;
  r2.xy = r1.zw * r6.xx + r2.xy;
  r2.xy = r2.zw * r6.zz + r2.xy;
  r2.xy = r3.xy * r6.ww + r2.xy;
  r2.zw = r7.yy * r4.xy;
  r2.zw = r3.zw * r7.xx + r2.zw;
  r2.zw = r4.zw * r7.zz + r2.zw;
  r2.zw = r5.xy * r7.ww + r2.zw;
  r1.xy = r1.xy + r1.zw;
  r1.zw = r1.xy * float2(1.79999995,1.79999995) + r2.xy;
  r2.xy = r1.zw + r2.zw;
  r1.xy = r1.xy + r1.xy;
  r1.z = 1;
  r0.w = dot(r1.xyz, r1.xyz);
  r0.w = rsqrt(r0.w);
  r2.z = cb9[4].y;
  r1.x = dot(r2.xyz, r2.xyz);
  r1.x = rsqrt(r1.x);
  r1.xyz = r2.xyz * r1.xxx;
  r2.xyz = float3(1,0,0) * v3.zxy;
  r2.xyz = v3.xyz * float3(0,1,0) + -r2.xyz;
  r1.w = dot(r2.xy, r2.xy);
  r1.w = rsqrt(r1.w);
  r2.xyz = r2.xyz * r1.www;
  r3.xyz = v3.zxy * r2.xyz;
  r3.xyz = v3.yzx * r2.yzx + -r3.xyz;
  r4.xyz = v3.xyz * r1.zzz;
  r3.xyz = r3.yzx * r1.yyy + r4.yzx;
  r3.xy = r2.xy * -r1.xx + r3.xy;
  r1.x = dot(-r3.zxy, r0.xyz);
  r1.x = max(0, r1.x);
  r1.x = 1 + -r1.x;
  r1.x = 1.512146 * r1.x;
  r1.x = r1.x * r1.x;
  r1.x = r1.x * r1.x;
  r1.x = min(1, r1.x);
  r1.y = dot(r3.zxy, r0.xyz);
  r1.y = max(0, r1.y);
  r1.y = 1 + -r1.y;
  r1.z = r1.y * r1.y;
  r1.z = r1.z * r1.z;
  r1.y = r1.y * r1.z;
  r1.y = r1.y * 0.980000019 + 0.0199999996;
  r1.x = v9.x ? r1.x : r1.y;
  r1.y = dot(-r0.yzx, r3.xyz);
  r1.y = r1.y + r1.y;
  r1.yz = r3.zy * -r1.yy + -r0.xz;
  r1.w = dot(r1.yz, r1.yz);
  r1.yz = r1.yz * r1.ww;
  r1.yz = r1.yz * float2(0.449999988,0.449999988) + float2(0.5,0.5);
  r2.xyz = t4.Sample(s4_s, r1.yz).xyz;
  r1.yzw = t5.Sample(s5_s, r1.yz).xyz;
  if (v9.x == 0) {
    r2.xyz = r2.xyz + -r1.yzw;
    r1.yzw = v6.yyy * r2.xyz + r1.yzw;
    r1.yzw = cb1[2].xyz * r1.yzw;
  } else {
    r1.yzw = cb0[7].xyz;
  }
  r2.xyz = -r15.xyz + r3.zxy;
  r2.xyz = cb9[33].www * r2.xyz + v3.xyz;
  r2.w = dot(r2.xyz, r2.xyz);
  r2.w = rsqrt(r2.w);
  r2.xyz = r2.xyz * r2.www;
  r2.w = dot(-r0.xyz, r2.xyz);
  r2.w = r2.w + r2.w;
  r2.w = r2.y * -r2.w + -r0.y;
  r4.x = v9.x ? 0 : 1;
  r2.w = saturate(-100 * r2.w);
  r2.w = r4.x + r2.w;
  r2.w = cb9[33].x * r2.w;
  r2.w = cmp(0.00100000005 < r2.w);
  if (r2.w != 0) {
    r2.w = cb9[33].y + -v2.z;
    r4.x = cmp(0 < r2.w);
    if (r4.x != 0) {

//r2.x -= stereo.x*(r2.z - stereo.y) * 1.24;

      r4.x = dot(r2.xyz, cb9[40].xyz);
      r4.y = dot(r2.xyz, cb9[41].xyz);
      r4.z = dot(r2.xyz, cb9[42].xyz);

      r2.x = dot(v2.xyz, v2.xyz);

      r2.x = rsqrt(r2.x);

      r2.xyz = r14.xyz * r2.xxx;

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

        r4.yzw = cb9[29].xyw * r14.xxx + r4.yzw;

        r4.yzw = cb9[31].xyw * v2.zzz + r4.yzw;
        r4.yzw = cb9[32].xyw + r4.yzw;
        r5.xyz = cb9[30].xyw * r2.yyy;
        r2.xyw = cb9[29].xyw * r2.xxx + r5.xyz;
        r2.xyz = cb9[31].xyw * r2.zzz + r2.xyw;
        r2.xyz = cb9[32].xyw + r2.xyz;
        r2.w = 1 / r4.w;
        r2.z = 1 / r2.z;
        r5.xy = r4.yz * r2.ww;
        r6.xy = r2.xy * r2.zz;
        r5.z = -r5.y;
        r2.xy = float2(1,1) + r5.xz;
        r4.yz = float2(0.5,0.5) * r2.xy;
        r6.z = -r6.y;
        r5.xy = float2(1,1) + r6.xz;
        r5.xy = r5.xy * float2(0.5,0.5) + -r4.yz;
        r6.xy = cmp(float2(0,0) < r5.xy);
        r2.xy = -r2.xy * float2(0.5,0.5) + float2(1,1);
        r2.xy = saturate(r2.xy / r5.xy);
        r6.zw = float2(9.99999975e-005,9.99999975e-005) + -r5.xy;
        r6.zw = saturate(r4.yz / r6.zw);
        r2.xy = r6.xy ? r2.xy : r6.zw;
        r2.x = min(r2.x, r2.y);
        r5.xy = r5.xy * r2.xx;
        r2.y = r2.z + -r2.w;
        r2.x = r2.y * r2.x;
        r2.y = 0.125 * r2.x;
        r2.z = cb9[33].y * 0.75;
        r2.z = min(100, r2.z);
        r4.w = cb9[33].y + -r2.z;
        r4.w = 1 / r4.w;
        r6.xyzw = r5.xyxy * float4(0.0125000002,0.0125000002,0.0437499993,0.0437499993) + r4.yzyz;
        r7.xyz = r2.xxx * float3(0.0125000002,0.0437499993,0.075000003) + r2.www;
        r5.z = t13.SampleLevel(s13_s, r6.xy, 0).x;
        r7.w = saturate(9.99999975e-005 + -r5.z);
        r7.w = r7.w + r5.z;
        r7.w = 1 / r7.w;
        r7.x = r7.x + -r7.w;
        r7.x = cmp(abs(r7.x) < abs(r2.y));
        if (r7.x != 0) {
          r8.xy = float2(-0.5,-0.5) + r6.xy;
          r7.w = max(abs(r8.x), abs(r8.y));
          r7.w = r7.w + r7.w;
          r7.w = log2(r7.w);
          r7.w = cb9[34].x * r7.w;
          r7.w = exp2(r7.w);
          r7.w = min(1, r7.w);
          r7.w = 1 + -r7.w;
          r5.z = r5.z + -r2.z;
          r5.z = saturate(r5.z * r4.w);
          r5.z = 1 + -r5.z;
          r5.z = log2(r5.z);
          r5.z = cb9[34].y * r5.z;
          r5.z = exp2(r5.z);
          r8.xyz = t12.SampleLevel(s12_s, r6.xy, 0).xyz;
          r5.z = r7.w * r5.z;
          r8.xyz = r8.xyz + -r1.yzw;
          r8.xyz = r5.zzz * r8.xyz + r1.yzw;
        } else {
          r8.xyz = r1.yzw;
        }
        r5.z = r7.x ? 0.0125000002 : 0.137500003;
        if (r7.x == 0) {
          if (r7.x == 0) {
            r6.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r6.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r6.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r6.xy, 0).xyz;
              r6.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r8.xyz = r6.xxx * r9.xyz + r1.yzw;
            }
            r6.x = r7.x ? 0.137500003 : 0.262499988;
            r5.z = r7.w ? r5.z : r6.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r7.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xw = r5.zz * r5.xy + r4.yz;
            r6.y = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xw, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r6.y = -r9.x + r6.y;
            r6.y = cmp(abs(r6.y) < abs(r2.y));
            if (r6.y != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xw;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xw, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r8.xyz = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r6.y ? r5.z : r7.x;
          } else {
            r6.y = -1;
          }
          r6.x = (int)r6.x | (int)r6.y;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xw = r5.zz * r5.xy + r4.yz;
            r6.y = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xw, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r6.y = -r9.x + r6.y;
            r6.y = cmp(abs(r6.y) < abs(r2.y));
            if (r6.y != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xw;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xw, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r8.xyz = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r6.y ? r5.z : r7.x;
          } else {
            r6.y = -1;
          }
          r6.x = (int)r6.x | (int)r6.y;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xw = r5.zz * r5.xy + r4.yz;
            r6.y = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xw, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r6.y = -r9.x + r6.y;
            r6.y = cmp(abs(r6.y) < abs(r2.y));
            if (r6.y != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xw;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xw, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r8.xyz = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r6.y ? r5.z : r7.x;
          } else {
            r6.y = -1;
          }
          r6.x = (int)r6.x | (int)r6.y;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xw = r5.zz * r5.xy + r4.yz;
            r6.y = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xw, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r6.y = -r9.x + r6.y;
            r6.y = cmp(abs(r6.y) < abs(r2.y));
            if (r6.y != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xw;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xw, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r8.xyz = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r6.y ? r5.z : r7.x;
          } else {
            r6.y = -1;
          }
          r6.x = (int)r6.x | (int)r6.y;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xw = r5.zz * r5.xy + r4.yz;
            r6.y = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xw, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r6.y = -r9.x + r6.y;
            r6.y = cmp(abs(r6.y) < abs(r2.y));
            if (r6.y != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xw;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xw, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r8.xyz = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r6.y ? r5.z : r7.x;
          } else {
            r6.y = -1;
          }
          r6.x = (int)r6.x | (int)r6.y;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xw = r5.zz * r5.xy + r4.yz;
            r6.y = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xw, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r6.y = -r9.x + r6.y;
            r6.y = cmp(abs(r6.y) < abs(r2.y));
            if (r6.y != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xw;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xw, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r8.xyz = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r6.y ? r5.z : r7.x;
          } else {
            r6.y = -1;
          }
          r6.x = (int)r6.x | (int)r6.y;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r6.xy = r5.zz * r5.xy + r4.yz;
            r5.z = r5.z * r2.x + r2.w;
            r7.x = t13.SampleLevel(s13_s, r6.xy, 0).x;
            r7.w = saturate(9.99999975e-005 + -r7.x);
            r7.w = r7.x + r7.w;
            r7.w = 1 / r7.w;
            r5.z = -r7.w + r5.z;
            r5.z = cmp(abs(r5.z) < abs(r2.y));
            if (r5.z != 0) {
              r9.xy = float2(-0.5,-0.5) + r6.xy;
              r5.z = max(abs(r9.x), abs(r9.y));
              r5.z = r5.z + r5.z;
              r5.z = log2(r5.z);
              r5.z = cb9[34].x * r5.z;
              r5.z = exp2(r5.z);
              r5.z = min(1, r5.z);
              r5.z = 1 + -r5.z;
              r7.x = r7.x + -r2.z;
              r7.x = saturate(r7.x * r4.w);
              r7.x = 1 + -r7.x;
              r7.x = log2(r7.x);
              r7.x = cb9[34].y * r7.x;
              r7.x = exp2(r7.x);
              r9.xyz = t12.SampleLevel(s12_s, r6.xy, 0).xyz;
              r5.z = r7.x * r5.z;
              r9.xyz = r9.xyz + -r1.yzw;
              r8.xyz = r5.zzz * r9.xyz + r1.yzw;
            }
          }
        }
        r5.z = t13.SampleLevel(s13_s, r6.zw, 0).x;
        r6.x = saturate(9.99999975e-005 + -r5.z);
        r6.x = r6.x + r5.z;
        r6.x = 1 / r6.x;
        r6.x = r7.y + -r6.x;
        r6.x = cmp(abs(r6.x) < abs(r2.y));
        if (r6.x != 0) {
          r7.xy = float2(-0.5,-0.5) + r6.zw;
          r6.y = max(abs(r7.x), abs(r7.y));
          r6.y = r6.y + r6.y;
          r6.y = log2(r6.y);
          r6.y = cb9[34].x * r6.y;
          r6.y = exp2(r6.y);
          r6.y = min(1, r6.y);
          r6.y = 1 + -r6.y;
          r5.z = r5.z + -r2.z;
          r5.z = saturate(r5.z * r4.w);
          r5.z = 1 + -r5.z;
          r5.z = log2(r5.z);
          r5.z = cb9[34].y * r5.z;
          r5.z = exp2(r5.z);
          r7.xyw = t12.SampleLevel(s12_s, r6.zw, 0).xyz;
          r5.z = r6.y * r5.z;
          r6.yzw = r7.xyw + -r1.yzw;
          r6.yzw = r5.zzz * r6.yzw + r1.yzw;
        } else {
          r6.yzw = r1.yzw;
        }
        r5.z = r6.x ? 0.0437499993 : 0.168750003;
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r6.yzw = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = r6.x ? 0.168750003 : 0.293749988;
            r5.z = r7.w ? r5.z : r7.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r6.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r6.yzw = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r7.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r6.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r6.yzw = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r7.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r6.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r6.yzw = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r7.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r6.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r6.yzw = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r7.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r6.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r6.yzw = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r7.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r6.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r8.w = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r9.x = saturate(9.99999975e-005 + -r8.w);
            r9.x = r9.x + r8.w;
            r9.x = 1 / r9.x;
            r7.w = -r9.x + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r9.x = max(abs(r9.x), abs(r9.y));
              r9.x = r9.x + r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].x * r9.x;
              r9.x = exp2(r9.x);
              r9.x = min(1, r9.x);
              r9.x = 1 + -r9.x;
              r8.w = r8.w + -r2.z;
              r8.w = saturate(r8.w * r4.w);
              r8.w = 1 + -r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].y * r8.w;
              r8.w = exp2(r8.w);
              r9.yzw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r7.x = r9.x * r8.w;
              r9.xyz = r9.yzw + -r1.yzw;
              r6.yzw = r7.xxx * r9.xyz + r1.yzw;
            }
            r7.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r7.x;
          } else {
            r7.w = -1;
          }
          r6.x = (int)r6.x | (int)r7.w;
        } else {
          r6.x = -1;
        }
        if (r6.x == 0) {
          if (r6.x == 0) {
            r7.xy = r5.zz * r5.xy + r4.yz;
            r5.z = r5.z * r2.x + r2.w;
            r6.x = t13.SampleLevel(s13_s, r7.xy, 0).x;
            r7.w = saturate(9.99999975e-005 + -r6.x);
            r7.w = r7.w + r6.x;
            r7.w = 1 / r7.w;
            r5.z = -r7.w + r5.z;
            r5.z = cmp(abs(r5.z) < abs(r2.y));
            if (r5.z != 0) {
              r9.xy = float2(-0.5,-0.5) + r7.xy;
              r5.z = max(abs(r9.x), abs(r9.y));
              r5.z = r5.z + r5.z;
              r5.z = log2(r5.z);
              r5.z = cb9[34].x * r5.z;
              r5.z = exp2(r5.z);
              r5.z = min(1, r5.z);
              r5.z = 1 + -r5.z;
              r6.x = r6.x + -r2.z;
              r6.x = saturate(r6.x * r4.w);
              r6.x = 1 + -r6.x;
              r6.x = log2(r6.x);
              r6.x = cb9[34].y * r6.x;
              r6.x = exp2(r6.x);
              r7.xyw = t12.SampleLevel(s12_s, r7.xy, 0).xyz;
              r5.z = r6.x * r5.z;
              r7.xyw = r7.xyw + -r1.yzw;
              r6.yzw = r5.zzz * r7.xyw + r1.yzw;
            }
          }
        }
        r6.xyz = r8.xyz + r6.yzw;
        r8.xyzw = r5.xyxy * float4(0.075000003,0.075000003,0.106250003,0.106250003) + r4.yzyz;
        r5.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
        r6.w = saturate(9.99999975e-005 + -r5.z);
        r6.w = r6.w + r5.z;
        r6.w = 1 / r6.w;
        r6.w = r7.z + -r6.w;
        r6.w = cmp(abs(r6.w) < abs(r2.y));
        if (r6.w != 0) {
          r7.xy = float2(-0.5,-0.5) + r8.xy;
          r7.x = max(abs(r7.x), abs(r7.y));
          r7.x = r7.x + r7.x;
          r7.x = log2(r7.x);
          r7.x = cb9[34].x * r7.x;
          r7.x = exp2(r7.x);
          r7.x = min(1, r7.x);
          r7.x = 1 + -r7.x;
          r5.z = r5.z + -r2.z;
          r5.z = saturate(r5.z * r4.w);
          r5.z = 1 + -r5.z;
          r5.z = log2(r5.z);
          r5.z = cb9[34].y * r5.z;
          r5.z = exp2(r5.z);
          r7.yzw = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
          r5.z = r7.x * r5.z;
          r7.xyz = r7.yzw + -r1.yzw;
          r7.xyz = r5.zzz * r7.xyz + r1.yzw;
        } else {
          r7.xyz = r1.yzw;
        }
        r5.z = r6.w ? 0.075000003 : 0.200000003;
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r9.x = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r9.y = saturate(9.99999975e-005 + -r9.x);
            r9.y = r9.x + r9.y;
            r9.y = 1 / r9.y;
            r7.w = -r9.y + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.yz = float2(-0.5,-0.5) + r8.xy;
              r9.y = max(abs(r9.y), abs(r9.z));
              r9.y = r9.y + r9.y;
              r9.y = log2(r9.y);
              r9.y = cb9[34].x * r9.y;
              r9.y = exp2(r9.y);
              r9.y = min(1, r9.y);
              r9.y = 1 + -r9.y;
              r9.x = r9.x + -r2.z;
              r9.x = saturate(r9.x * r4.w);
              r9.x = 1 + -r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].y * r9.x;
              r9.x = exp2(r9.x);
              r10.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r9.y * r9.x;
              r9.xyz = r10.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r9.xyz + r1.yzw;
            }
            r8.x = r6.w ? 0.200000003 : 0.324999988;
            r5.z = r7.w ? r5.z : r8.x;
          } else {
            r7.w = -1;
          }
          r6.w = (int)r6.w | (int)r7.w;
        } else {
          r6.w = -1;
        }
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r9.x = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r9.y = saturate(9.99999975e-005 + -r9.x);
            r9.y = r9.x + r9.y;
            r9.y = 1 / r9.y;
            r7.w = -r9.y + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.yz = float2(-0.5,-0.5) + r8.xy;
              r9.y = max(abs(r9.y), abs(r9.z));
              r9.y = r9.y + r9.y;
              r9.y = log2(r9.y);
              r9.y = cb9[34].x * r9.y;
              r9.y = exp2(r9.y);
              r9.y = min(1, r9.y);
              r9.y = 1 + -r9.y;
              r9.x = r9.x + -r2.z;
              r9.x = saturate(r9.x * r4.w);
              r9.x = 1 + -r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].y * r9.x;
              r9.x = exp2(r9.x);
              r10.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r9.y * r9.x;
              r9.xyz = r10.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r9.xyz + r1.yzw;
            }
            r8.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r8.x;
          } else {
            r7.w = -1;
          }
          r6.w = (int)r6.w | (int)r7.w;
        } else {
          r6.w = -1;
        }
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r9.x = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r9.y = saturate(9.99999975e-005 + -r9.x);
            r9.y = r9.x + r9.y;
            r9.y = 1 / r9.y;
            r7.w = -r9.y + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.yz = float2(-0.5,-0.5) + r8.xy;
              r9.y = max(abs(r9.y), abs(r9.z));
              r9.y = r9.y + r9.y;
              r9.y = log2(r9.y);
              r9.y = cb9[34].x * r9.y;
              r9.y = exp2(r9.y);
              r9.y = min(1, r9.y);
              r9.y = 1 + -r9.y;
              r9.x = r9.x + -r2.z;
              r9.x = saturate(r9.x * r4.w);
              r9.x = 1 + -r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].y * r9.x;
              r9.x = exp2(r9.x);
              r10.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r9.y * r9.x;
              r9.xyz = r10.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r9.xyz + r1.yzw;
            }
            r8.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r8.x;
          } else {
            r7.w = -1;
          }
          r6.w = (int)r6.w | (int)r7.w;
        } else {
          r6.w = -1;
        }
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r9.x = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r9.y = saturate(9.99999975e-005 + -r9.x);
            r9.y = r9.x + r9.y;
            r9.y = 1 / r9.y;
            r7.w = -r9.y + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.yz = float2(-0.5,-0.5) + r8.xy;
              r9.y = max(abs(r9.y), abs(r9.z));
              r9.y = r9.y + r9.y;
              r9.y = log2(r9.y);
              r9.y = cb9[34].x * r9.y;
              r9.y = exp2(r9.y);
              r9.y = min(1, r9.y);
              r9.y = 1 + -r9.y;
              r9.x = r9.x + -r2.z;
              r9.x = saturate(r9.x * r4.w);
              r9.x = 1 + -r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].y * r9.x;
              r9.x = exp2(r9.x);
              r10.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r9.y * r9.x;
              r9.xyz = r10.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r9.xyz + r1.yzw;
            }
            r8.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r8.x;
          } else {
            r7.w = -1;
          }
          r6.w = (int)r6.w | (int)r7.w;
        } else {
          r6.w = -1;
        }
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r9.x = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r9.y = saturate(9.99999975e-005 + -r9.x);
            r9.y = r9.x + r9.y;
            r9.y = 1 / r9.y;
            r7.w = -r9.y + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.yz = float2(-0.5,-0.5) + r8.xy;
              r9.y = max(abs(r9.y), abs(r9.z));
              r9.y = r9.y + r9.y;
              r9.y = log2(r9.y);
              r9.y = cb9[34].x * r9.y;
              r9.y = exp2(r9.y);
              r9.y = min(1, r9.y);
              r9.y = 1 + -r9.y;
              r9.x = r9.x + -r2.z;
              r9.x = saturate(r9.x * r4.w);
              r9.x = 1 + -r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].y * r9.x;
              r9.x = exp2(r9.x);
              r10.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r9.y * r9.x;
              r9.xyz = r10.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r9.xyz + r1.yzw;
            }
            r8.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r8.x;
          } else {
            r7.w = -1;
          }
          r6.w = (int)r6.w | (int)r7.w;
        } else {
          r6.w = -1;
        }
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r9.x = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r9.y = saturate(9.99999975e-005 + -r9.x);
            r9.y = r9.x + r9.y;
            r9.y = 1 / r9.y;
            r7.w = -r9.y + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.yz = float2(-0.5,-0.5) + r8.xy;
              r9.y = max(abs(r9.y), abs(r9.z));
              r9.y = r9.y + r9.y;
              r9.y = log2(r9.y);
              r9.y = cb9[34].x * r9.y;
              r9.y = exp2(r9.y);
              r9.y = min(1, r9.y);
              r9.y = 1 + -r9.y;
              r9.x = r9.x + -r2.z;
              r9.x = saturate(r9.x * r4.w);
              r9.x = 1 + -r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].y * r9.x;
              r9.x = exp2(r9.x);
              r10.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r9.y * r9.x;
              r9.xyz = r10.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r9.xyz + r1.yzw;
            }
            r8.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r8.x;
          } else {
            r7.w = -1;
          }
          r6.w = (int)r6.w | (int)r7.w;
        } else {
          r6.w = -1;
        }
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r7.w = r5.z * r2.x + r2.w;
            r9.x = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r9.y = saturate(9.99999975e-005 + -r9.x);
            r9.y = r9.x + r9.y;
            r9.y = 1 / r9.y;
            r7.w = -r9.y + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.yz = float2(-0.5,-0.5) + r8.xy;
              r9.y = max(abs(r9.y), abs(r9.z));
              r9.y = r9.y + r9.y;
              r9.y = log2(r9.y);
              r9.y = cb9[34].x * r9.y;
              r9.y = exp2(r9.y);
              r9.y = min(1, r9.y);
              r9.y = 1 + -r9.y;
              r9.x = r9.x + -r2.z;
              r9.x = saturate(r9.x * r4.w);
              r9.x = 1 + -r9.x;
              r9.x = log2(r9.x);
              r9.x = cb9[34].y * r9.x;
              r9.x = exp2(r9.x);
              r10.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r9.y * r9.x;
              r9.xyz = r10.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r9.xyz + r1.yzw;
            }
            r8.x = 0.125 + r5.z;
            r5.z = r7.w ? r5.z : r8.x;
          } else {
            r7.w = -1;
          }
          r6.w = (int)r6.w | (int)r7.w;
        } else {
          r6.w = -1;
        }
        if (r6.w == 0) {
          if (r6.w == 0) {
            r8.xy = r5.zz * r5.xy + r4.yz;
            r5.z = r5.z * r2.x + r2.w;
            r6.w = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r7.w = saturate(9.99999975e-005 + -r6.w);
            r7.w = r7.w + r6.w;
            r7.w = 1 / r7.w;
            r5.z = -r7.w + r5.z;
            r5.z = cmp(abs(r5.z) < abs(r2.y));
            if (r5.z != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r5.z = max(abs(r9.x), abs(r9.y));
              r5.z = r5.z + r5.z;
              r5.z = log2(r5.z);
              r5.z = cb9[34].x * r5.z;
              r5.z = exp2(r5.z);
              r5.z = min(1, r5.z);
              r5.z = 1 + -r5.z;
              r6.w = r6.w + -r2.z;
              r6.w = saturate(r6.w * r4.w);
              r6.w = 1 + -r6.w;
              r6.w = log2(r6.w);
              r6.w = cb9[34].y * r6.w;
              r6.w = exp2(r6.w);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r5.z = r6.w * r5.z;
              r9.xyz = r9.xyz + -r1.yzw;
              r7.xyz = r5.zzz * r9.xyz + r1.yzw;
            }
          }
        }
        r6.xyz = r7.xyz + r6.xyz;
        r5.z = r2.x * 0.106250003 + r2.w;
        r6.w = t13.SampleLevel(s13_s, r8.zw, 0).x;
        r7.x = saturate(9.99999975e-005 + -r6.w);
        r7.x = r7.x + r6.w;
        r7.x = 1 / r7.x;
        r5.z = -r7.x + r5.z;
        r5.z = cmp(abs(r5.z) < abs(r2.y));
        if (r5.z != 0) {
          r7.xy = float2(-0.5,-0.5) + r8.zw;
          r7.x = max(abs(r7.x), abs(r7.y));
          r7.x = r7.x + r7.x;
          r7.x = log2(r7.x);
          r7.x = cb9[34].x * r7.x;
          r7.x = exp2(r7.x);
          r7.x = min(1, r7.x);
          r7.x = 1 + -r7.x;
          r6.w = r6.w + -r2.z;
          r6.w = saturate(r6.w * r4.w);
          r6.w = 1 + -r6.w;
          r6.w = log2(r6.w);
          r6.w = cb9[34].y * r6.w;
          r6.w = exp2(r6.w);
          r7.yzw = t12.SampleLevel(s12_s, r8.zw, 0).xyz;
          r6.w = r7.x * r6.w;
          r7.xyz = r7.yzw + -r1.yzw;
          r7.xyz = r6.www * r7.xyz + r1.yzw;
        } else {
          r7.xyz = r1.yzw;
        }
        r6.w = r5.z ? 0.106250003 : 0.231250003;
        if (r5.z == 0) {
          if (r5.z == 0) {
            r8.xy = r6.ww * r5.xy + r4.yz;
            r7.w = r6.w * r2.x + r2.w;
            r8.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r8.w = saturate(9.99999975e-005 + -r8.z);
            r8.w = r8.z + r8.w;
            r8.w = 1 / r8.w;
            r7.w = -r8.w + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r8.w = max(abs(r9.x), abs(r9.y));
              r8.w = r8.w + r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].x * r8.w;
              r8.w = exp2(r8.w);
              r8.w = min(1, r8.w);
              r8.w = 1 + -r8.w;
              r8.z = r8.z + -r2.z;
              r8.z = saturate(r8.z * r4.w);
              r8.z = 1 + -r8.z;
              r8.z = log2(r8.z);
              r8.z = cb9[34].y * r8.z;
              r8.z = exp2(r8.z);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r8.w * r8.z;
              r8.yzw = r9.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r8.yzw + r1.yzw;
            }
            r8.x = r5.z ? 0.231250003 : 0.356249988;
            r6.w = r7.w ? r6.w : r8.x;
          } else {
            r7.w = -1;
          }
          r5.z = (int)r5.z | (int)r7.w;
        } else {
          r5.z = -1;
        }
        if (r5.z == 0) {
          if (r5.z == 0) {
            r8.xy = r6.ww * r5.xy + r4.yz;
            r7.w = r6.w * r2.x + r2.w;
            r8.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r8.w = saturate(9.99999975e-005 + -r8.z);
            r8.w = r8.z + r8.w;
            r8.w = 1 / r8.w;
            r7.w = -r8.w + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r8.w = max(abs(r9.x), abs(r9.y));
              r8.w = r8.w + r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].x * r8.w;
              r8.w = exp2(r8.w);
              r8.w = min(1, r8.w);
              r8.w = 1 + -r8.w;
              r8.z = r8.z + -r2.z;
              r8.z = saturate(r8.z * r4.w);
              r8.z = 1 + -r8.z;
              r8.z = log2(r8.z);
              r8.z = cb9[34].y * r8.z;
              r8.z = exp2(r8.z);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r8.w * r8.z;
              r8.yzw = r9.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r8.yzw + r1.yzw;
            }
            r8.x = 0.125 + r6.w;
            r6.w = r7.w ? r6.w : r8.x;
          } else {
            r7.w = -1;
          }
          r5.z = (int)r5.z | (int)r7.w;
        } else {
          r5.z = -1;
        }
        if (r5.z == 0) {
          if (r5.z == 0) {
            r8.xy = r6.ww * r5.xy + r4.yz;
            r7.w = r6.w * r2.x + r2.w;
            r8.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r8.w = saturate(9.99999975e-005 + -r8.z);
            r8.w = r8.z + r8.w;
            r8.w = 1 / r8.w;
            r7.w = -r8.w + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r8.w = max(abs(r9.x), abs(r9.y));
              r8.w = r8.w + r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].x * r8.w;
              r8.w = exp2(r8.w);
              r8.w = min(1, r8.w);
              r8.w = 1 + -r8.w;
              r8.z = r8.z + -r2.z;
              r8.z = saturate(r8.z * r4.w);
              r8.z = 1 + -r8.z;
              r8.z = log2(r8.z);
              r8.z = cb9[34].y * r8.z;
              r8.z = exp2(r8.z);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r8.w * r8.z;
              r8.yzw = r9.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r8.yzw + r1.yzw;
            }
            r8.x = 0.125 + r6.w;
            r6.w = r7.w ? r6.w : r8.x;
          } else {
            r7.w = -1;
          }
          r5.z = (int)r5.z | (int)r7.w;
        } else {
          r5.z = -1;
        }
        if (r5.z == 0) {
          if (r5.z == 0) {
            r8.xy = r6.ww * r5.xy + r4.yz;
            r7.w = r6.w * r2.x + r2.w;
            r8.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r8.w = saturate(9.99999975e-005 + -r8.z);
            r8.w = r8.z + r8.w;
            r8.w = 1 / r8.w;
            r7.w = -r8.w + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r8.w = max(abs(r9.x), abs(r9.y));
              r8.w = r8.w + r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].x * r8.w;
              r8.w = exp2(r8.w);
              r8.w = min(1, r8.w);
              r8.w = 1 + -r8.w;
              r8.z = r8.z + -r2.z;
              r8.z = saturate(r8.z * r4.w);
              r8.z = 1 + -r8.z;
              r8.z = log2(r8.z);
              r8.z = cb9[34].y * r8.z;
              r8.z = exp2(r8.z);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r8.w * r8.z;
              r8.yzw = r9.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r8.yzw + r1.yzw;
            }
            r8.x = 0.125 + r6.w;
            r6.w = r7.w ? r6.w : r8.x;
          } else {
            r7.w = -1;
          }
          r5.z = (int)r5.z | (int)r7.w;
        } else {
          r5.z = -1;
        }
        if (r5.z == 0) {
          if (r5.z == 0) {
            r8.xy = r6.ww * r5.xy + r4.yz;
            r7.w = r6.w * r2.x + r2.w;
            r8.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r8.w = saturate(9.99999975e-005 + -r8.z);
            r8.w = r8.z + r8.w;
            r8.w = 1 / r8.w;
            r7.w = -r8.w + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r8.w = max(abs(r9.x), abs(r9.y));
              r8.w = r8.w + r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].x * r8.w;
              r8.w = exp2(r8.w);
              r8.w = min(1, r8.w);
              r8.w = 1 + -r8.w;
              r8.z = r8.z + -r2.z;
              r8.z = saturate(r8.z * r4.w);
              r8.z = 1 + -r8.z;
              r8.z = log2(r8.z);
              r8.z = cb9[34].y * r8.z;
              r8.z = exp2(r8.z);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r8.w * r8.z;
              r8.yzw = r9.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r8.yzw + r1.yzw;
            }
            r8.x = 0.125 + r6.w;
            r6.w = r7.w ? r6.w : r8.x;
          } else {
            r7.w = -1;
          }
          r5.z = (int)r5.z | (int)r7.w;
        } else {
          r5.z = -1;
        }
        if (r5.z == 0) {
          if (r5.z == 0) {
            r8.xy = r6.ww * r5.xy + r4.yz;
            r7.w = r6.w * r2.x + r2.w;
            r8.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r8.w = saturate(9.99999975e-005 + -r8.z);
            r8.w = r8.z + r8.w;
            r8.w = 1 / r8.w;
            r7.w = -r8.w + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r8.w = max(abs(r9.x), abs(r9.y));
              r8.w = r8.w + r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].x * r8.w;
              r8.w = exp2(r8.w);
              r8.w = min(1, r8.w);
              r8.w = 1 + -r8.w;
              r8.z = r8.z + -r2.z;
              r8.z = saturate(r8.z * r4.w);
              r8.z = 1 + -r8.z;
              r8.z = log2(r8.z);
              r8.z = cb9[34].y * r8.z;
              r8.z = exp2(r8.z);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r8.w * r8.z;
              r8.yzw = r9.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r8.yzw + r1.yzw;
            }
            r8.x = 0.125 + r6.w;
            r6.w = r7.w ? r6.w : r8.x;
          } else {
            r7.w = -1;
          }
          r5.z = (int)r5.z | (int)r7.w;
        } else {
          r5.z = -1;
        }
        if (r5.z == 0) {
          if (r5.z == 0) {
            r8.xy = r6.ww * r5.xy + r4.yz;
            r7.w = r6.w * r2.x + r2.w;
            r8.z = t13.SampleLevel(s13_s, r8.xy, 0).x;
            r8.w = saturate(9.99999975e-005 + -r8.z);
            r8.w = r8.z + r8.w;
            r8.w = 1 / r8.w;
            r7.w = -r8.w + r7.w;
            r7.w = cmp(abs(r7.w) < abs(r2.y));
            if (r7.w != 0) {
              r9.xy = float2(-0.5,-0.5) + r8.xy;
              r8.w = max(abs(r9.x), abs(r9.y));
              r8.w = r8.w + r8.w;
              r8.w = log2(r8.w);
              r8.w = cb9[34].x * r8.w;
              r8.w = exp2(r8.w);
              r8.w = min(1, r8.w);
              r8.w = 1 + -r8.w;
              r8.z = r8.z + -r2.z;
              r8.z = saturate(r8.z * r4.w);
              r8.z = 1 + -r8.z;
              r8.z = log2(r8.z);
              r8.z = cb9[34].y * r8.z;
              r8.z = exp2(r8.z);
              r9.xyz = t12.SampleLevel(s12_s, r8.xy, 0).xyz;
              r8.x = r8.w * r8.z;
              r8.yzw = r9.xyz + -r1.yzw;
              r7.xyz = r8.xxx * r8.yzw + r1.yzw;
            }
            r8.x = 0.125 + r6.w;
            r6.w = r7.w ? r6.w : r8.x;
          } else {
            r7.w = -1;
          }
          r5.z = (int)r5.z | (int)r7.w;
        } else {
          r5.z = -1;
        }
        if (r5.z == 0) {
          if (r5.z == 0) {
            r4.yz = r6.ww * r5.xy + r4.yz;
            r2.x = r6.w * r2.x + r2.w;
            r2.w = t13.SampleLevel(s13_s, r4.yz, 0).x;
            r5.x = saturate(9.99999975e-005 + -r2.w);
            r5.x = r5.x + r2.w;
            r5.x = 1 / r5.x;
            r2.x = -r5.x + r2.x;
            r2.x = cmp(abs(r2.x) < abs(r2.y));
            if (r2.x != 0) {
              r2.xy = float2(-0.5,-0.5) + r4.yz;
              r2.x = max(abs(r2.x), abs(r2.y));
              r2.x = r2.x + r2.x;
              r2.x = log2(r2.x);
              r2.x = cb9[34].x * r2.x;
              r2.x = exp2(r2.x);
              r2.x = min(1, r2.x);
              r2.x = 1 + -r2.x;
              r2.y = r2.w + -r2.z;
              r2.y = saturate(r2.y * r4.w);
              r2.y = 1 + -r2.y;
              r2.y = log2(r2.y);
              r2.y = cb9[34].y * r2.y;
              r2.y = exp2(r2.y);
              r4.yzw = t12.SampleLevel(s12_s, r4.yz, 0).xyz;
              r2.x = r2.x * r2.y;
              r2.yzw = r4.yzw + -r1.yzw;
              r7.xyz = r2.xxx * r2.yzw + r1.yzw;
            }
          }
        }
        r2.xyz = r7.xyz + r6.xyz;
        r2.w = cb9[33].x * r4.x;
        r2.xyz = r2.xyz * float3(0.25,0.25,0.25) + -r1.yzw;
        r1.yzw = r2.www * r2.xyz + r1.yzw;
      }
    }
  }
  r2.xy = v0.xy * cb9[3].xy + cb9[3].zw;
  r2.z = t11.SampleLevel(s11_s, r2.xy, 0).x;
  r2.w = -v2.z + r2.z;
  r4.x = saturate(cb9[35].z * r2.w);
  r4.y = cb9[35].y + -cb9[35].x;
  r4.x = r4.x * r4.y + cb9[35].x;
  r4.z = cb9[29].x * 10;
  r4.z = r4.z / v2.z;
  r4.z = max(0.100000001, r4.z);
  r4.z = min(1, r4.z);
  r4.x = r4.x * r4.z;
  r4.w = 0.00999999978 + r2.w;
  r4.w = saturate(100000 * r4.w);
  r4.x = r4.x * r4.w;
  r5.xy = float2(-0.5,-0.5) + r2.xy;
  r4.w = max(abs(r5.x), abs(r5.y));
  r4.w = 0.5 + -r4.w;
  r4.w = saturate(10 * r4.w);
  r4.x = r4.x * r4.w;
  r2.w = saturate(5 * r2.w);
  r2.w = r4.x * r2.w;
  r4.x = cmp(r2.w < 0.00100000005);
  if (r4.x != 0) {
    r5.xyz = t10.SampleLevel(s10_s, r2.xy, 0).xyz;
  } else {
    r6.xyzw = r3.zyzy * r2.wwww + r2.xyxy;
    r4.x = t11.SampleLevel(s11_s, r6.zw, 0).x;
    r7.xyzw = cb9[3].xyxy * float4(1,0,-1,0) + r6.zwzw;
    r4.w = t11.SampleLevel(s11_s, r7.xy, 0).x;
    r4.x = min(r4.x, r4.w);
    r4.w = t11.SampleLevel(s11_s, r7.zw, 0).x;
    r4.x = min(r4.x, r4.w);
    r6.xyzw = cb9[3].xyxy * float4(0,1,0,-1) + r6.xyzw;
    r4.w = t11.SampleLevel(s11_s, r6.xy, 0).x;
    r4.x = min(r4.x, r4.w);
    r4.w = t11.SampleLevel(s11_s, r6.zw, 0).x;
    r4.x = min(r4.x, r4.w);
    r4.x = -v2.z + r4.x;
    r4.w = saturate(cb9[35].z * r4.x);
    r4.y = r4.w * r4.y + cb9[35].x;
    r4.y = r4.y * r4.z;
    r4.x = 0.00999999978 + r4.x;
    r4.x = saturate(100000 * r4.x);
    r4.x = r4.y * r4.x;
    r2.w = min(r4.x, r2.w);
    r4.xy = r3.zy * r2.ww + r2.xy;
    r2.w = t11.SampleLevel(s11_s, r4.xy, 0).x;
    r6.xyzw = cb9[3].xyxy * float4(1,0,-1,0) + r4.xyxy;
    r4.z = t11.SampleLevel(s11_s, r6.xy, 0).x;
    r2.w = min(r4.z, r2.w);
    r4.z = t11.SampleLevel(s11_s, r6.zw, 0).x;
    r2.w = min(r4.z, r2.w);
    r7.xyzw = cb9[3].xyxy * float4(0,1,0,-1) + r4.xyxy;
    r4.z = t11.SampleLevel(s11_s, r7.xy, 0).x;
    r2.w = min(r4.z, r2.w);
    r4.z = t11.SampleLevel(s11_s, r7.zw, 0).x;
    r2.w = min(r4.z, r2.w);
    r4.z = -v2.z + r2.w;
    r4.z = cmp(r4.z >= 0);
    if (r4.z != 0) {
      r5.xyz = t10.SampleLevel(s10_s, r4.xy, 0).xyz;
      r4.xyz = cb0[13].xyz + -r5.xyz;
      r4.x = dot(r4.xyz, r4.xyz);
      r4.yzw = t10.SampleLevel(s10_s, r6.xy, 0).xyz;
      r4.yzw = cb0[13].xyz + -r4.yzw;
      r4.y = dot(r4.yzw, r4.yzw);
      r4.x = min(r4.x, r4.y);
      r4.yzw = t10.SampleLevel(s10_s, r6.zw, 0).xyz;
      r4.yzw = cb0[13].xyz + -r4.yzw;
      r4.y = dot(r4.yzw, r4.yzw);
      r4.x = min(r4.x, r4.y);
      r4.yzw = t10.SampleLevel(s10_s, r7.xy, 0).xyz;
      r4.yzw = cb0[13].xyz + -r4.yzw;
      r4.y = dot(r4.yzw, r4.yzw);
      r4.x = min(r4.x, r4.y);
      r4.yzw = t10.SampleLevel(s10_s, r7.zw, 0).xyz;
      r4.yzw = cb0[13].xyz + -r4.yzw;
      r4.y = dot(r4.yzw, r4.yzw);
      r4.x = min(r4.x, r4.y);
      r4.x = cmp(r4.x < 0.00499999989);
      if (r4.x != 0) {
        r5.xyz = t10.SampleLevel(s10_s, r2.xy, 0).xyz;
      }
      r2.z = r2.w;
    } else {
      r5.xyz = t10.SampleLevel(s10_s, r2.xy, 0).xyz;
    }
  }
  r2.x = v2.z + -r2.z;
  r2.x = -0.144269511 * abs(r2.x);
  r2.x = exp2(r2.x);
  r2.x = 1 + -r2.x;
  r2.y = -abs(r0.y) * 4 + 1;
  r2.y = max(0, r2.y);
  r2.x = r2.x * r2.y;
  r4.xyz = cb0[7].xyz + -r5.xyz;
  r2.xyw = r2.xxx * r4.xyz + r5.xyz;
  r4.x = cmp(0.00999999978 < cb9[36].x);
  if (r4.x != 0) {
    r4.x = max(abs(cb6[9].y), 0.200000003);
    r2.z = -v2.z + r2.z;
    r2.z = r4.x * r2.z;
    r2.z = r2.z / v2.z;
    r4.xy = cb9[36].yy * r3.zy;
    r4.xy = v1.xz * cb9[36].zz + r4.xy;
    r4.xy = cb9[37].xy + r4.xy;
    r4.x = t2.Sample(s2_s, r4.xy).x;
    r4.yz = float2(-0.100000001,-0.0500000007) + r2.zz;
    r2.z = cb9[36].w * r4.y;
    r4.y = saturate(0.5 * r2.z);
    r4.y = 0.200000003 + r4.y;
    r4.x = saturate(r4.x + -r4.y);
    r2.z = saturate(r2.z);
    r2.z = 1 + -r2.z;
    r2.z = r2.z * r2.z;
    r2.z = r4.x * r2.z;
    r4.x = saturate(10 * r4.z);
    r2.z = r4.x * r2.z;
    r2.z = saturate(cb9[36].x * r2.z);
  } else {
    r4.x = 1;
    r2.z = 0;
  }
  r4.yzw = cb0[7].xyz + -r2.xyw;
  r2.xyw = cb9[37].www * r4.yzw + r2.xyw;
  r0.w = -0.699999988 + r0.w;
  r0.w = saturate(5 * r0.w);
  r4.yz = float2(1,1.5) + -r0.ww;
  r0.w = r4.y * r4.z;
  r4.y = v6.x * v6.x;
  r4.y = r4.y * r4.y + 0.100000001;
  r6.xyzw = float4(50.0999985,50.0999985,10.1999998,10.1999998) * v4.xyzw;
  r4.zw = float2(0.109999999,0.109999999) * v5.xy;
  r5.x = t2.Sample(s2_s, r6.xy).x;
  r5.y = t2.Sample(s2_s, r6.zw).x;
  r4.z = t2.Sample(s2_s, r4.zw).x;
  r4.w = r5.x + r5.y;
  r4.z = r4.w + r4.z;
  r4.z = saturate(-2.4000001 + r4.z);
  r4.w = saturate(-cb9[5].x + 0.5);
  r4.y = r4.w * r4.y;
  r0.w = r4.y * r0.w;
  r0.w = r0.w * r4.z;
  r0.w = max(r0.w, r2.z);
  r1.yzw = -r2.xyw + r1.yzw;
  r1.yzw = r1.xxx * r1.yzw + r2.xyw;
  r3.w = 0.600000024;
  r2.x = dot(r3.yzw, r3.yzw);
  r2.x = rsqrt(r2.x);
  r2.xyz = r3.zwy * r2.xxx + -r3.zxy;
  r2.xyz = cb9[37].zzz * r2.xyz + r3.zxy;
  r2.w = dot(r2.xyz, r2.xyz);
  r2.w = rsqrt(r2.w);
  r2.xyz = r2.xyz * r2.www;
  r5.xy = -cb5[5].yz;
  r5.z = cb5[5].x;
  r2.w = dot(r5.xyz, r2.xyz);
  r2.w = r2.w + r2.w;
  r2.xyz = r2.xyz * -r2.www + r5.xyz;
  r2.x = saturate(dot(r2.xyz, r0.xyz));
  r2.x = log2(r2.x);
  r2.x = cb9[4].w * r2.x;
  r2.x = exp2(r2.x);
  r1.x = r2.x * r1.x;
  r2.xyz = cb5[6].xyz * r1.xxx;
  r2.xyz = saturate(cb9[4].zzz * r2.xyz);
  r5.x = 1;
  r4.yzw = float3(0,0,0);
  r6.xyz = float3(0,0,0);
  r7.xyz = float3(0,0,0);
  r1.x = 0;
  while (true) {
    r2.w = cmp((int)r1.x >= asint(cb10[0].x));
    if (r2.w != 0) break;
    r2.w = (int)r1.x * 6;
    r8.xyz = cb11[r2.w+0].xyz + -v1.xyz;
    r2.w = dot(r8.xyz, r8.xyz);
    r2.w = sqrt(r2.w);
    r3.w = 9.99999975e-005 + r2.w;
    r8.xyz = r8.xyz / r3.www;
    r9.xyzw = mad((int4)r1.xxxx, int4(6,6,6,6), int4(4,5,2,3));
    r3.w = r2.w * cb10[2].x + -cb11[r9.x+0].x;
    r5.y = max(0, r3.w);
    r5.z = r5.y * r5.y;
    r3.w = dot(cb11[r9.x+0].yzw, r5.xyz);
    r3.w = 9.99999975e-005 + r3.w;
    r3.w = 1 / r3.w;
    r3.w = saturate(r3.w);
    r2.w = r2.w * cb10[2].x + -cb11[r9.y+0].x;
    r2.w = saturate(cb11[r9.y+0].y * r2.w);
    r2.w = 1 + -r2.w;
    r2.w = r3.w * r2.w;
    r10.xyz = r8.xyz + r0.xyz;
    r3.w = dot(r10.xyz, r10.xyz);
    r3.w = rsqrt(r3.w);
    r10.xyz = r10.xyz * r3.www;
    r3.w = dot(r3.zxy, r8.xyz);
    r5.y = dot(r3.zxy, r10.xyz);
    r5.z = cmp(r3.w >= 0);
    r3.w = max(0, r3.w);
    r6.w = cmp(r5.y >= 0);
    r5.z = r5.z ? r6.w : 0;
    r5.y = log2(r5.y);
    r5.y = cb9[4].w * r5.y;
    r5.y = exp2(r5.y);
    r5.y = r5.z ? r5.y : 0;
    r5.y = min(1, r5.y);
    r8.xyz = cb11[r9.z+0].xyz * cb10[3].xyz;
    r8.xyz = r8.xyz * r3.www;
    r8.xyz = r8.xyz * r2.www;
    r4.yzw = r8.xyz * float3(0.5,0.5,0.5) + r4.yzw;
    r6.xyz = cb11[r9.w+0].xyz * r2.www + r6.xyz;
    r8.xyz = cb11[r9.z+0].xyz * cb5[7].xyz;
    r8.xyz = r8.xyz * r5.yyy;
    r7.xyz = r8.xyz * r2.www + r7.xyz;
    r1.x = (int)r1.x + 1;
  }
  r2.w = asint(cb10[0].x) + asint(cb10[1].x);
  r5.x = 1;
  r8.xyz = r4.yzw;
  r9.xyz = r6.xyz;
  r10.xyz = r7.xyz;
  r3.w = r1.x;
  while (true) {
    r6.w = cmp((int)r3.w >= (int)r2.w);
    if (r6.w != 0) break;
    r6.w = (int)r3.w * 6;
    r11.xyz = cb11[r6.w+0].xyz + -v1.xyz;
    r6.w = dot(r11.xyz, r11.xyz);
    r6.w = sqrt(r6.w);
    r7.w = 9.99999975e-005 + r6.w;
    r11.xyz = r11.xyz / r7.www;
    r7.w = mad((int)r3.w, 6, 1);
    r8.w = dot(-cb11[r7.w+0].xyz, r11.xyz);
    r7.w = -cb11[r7.w+0].w + r8.w;
    r12.xyzw = mad((int4)r3.wwww, int4(6,6,6,6), int4(2,3,4,5));
    r7.w = saturate(cb11[r12.x+0].w * r7.w);
    r7.w = log2(r7.w);
    r7.w = cb11[r12.y+0].w * r7.w;
    r7.w = exp2(r7.w);
    r8.w = r6.w * cb10[2].x + -cb11[r12.z+0].x;
    r5.y = max(0, r8.w);
    r5.z = r5.y * r5.y;
    r5.y = dot(cb11[r12.z+0].yzw, r5.xyz);
    r5.y = 9.99999975e-005 + r5.y;
    r5.y = 1 / r5.y;
    r5.y = saturate(r5.y);
    r5.z = r6.w * cb10[2].x + -cb11[r12.w+0].x;
    r5.z = saturate(cb11[r12.w+0].y * r5.z);
    r5.z = 1 + -r5.z;
    r5.y = r5.y * r5.z;
    r5.y = r5.y * r7.w;
    r13.xyz = r11.xyz + r0.xyz;
    r5.z = dot(r13.xyz, r13.xyz);
    r5.z = rsqrt(r5.z);
    r13.xyz = r13.xyz * r5.zzz;
    r5.z = dot(r3.zxy, r11.xyz);
    r6.w = dot(r3.zxy, r13.xyz);
    r7.w = cmp(r5.z >= 0);
    r5.z = max(0, r5.z);
    r8.w = cmp(r6.w >= 0);
    r7.w = r7.w ? r8.w : 0;
    r6.w = log2(r6.w);
    r6.w = cb9[4].w * r6.w;
    r6.w = exp2(r6.w);
    r6.w = r7.w ? r6.w : 0;
    r6.w = min(1, r6.w);
    r11.xyz = cb11[r12.x+0].xyz * cb10[3].xyz;
    r11.xyz = r11.xyz * r5.zzz;
    r11.xyz = r11.xyz * r5.yyy;
    r8.xyz = r11.xyz * float3(0.5,0.5,0.5) + r8.xyz;
    r9.xyz = cb11[r12.y+0].xyz * r5.yyy + r9.xyz;
    r11.xyz = cb11[r12.x+0].xyz * cb5[7].xyz;
    r11.xyz = r11.xyz * r6.www;
    r10.xyz = r11.xyz * r5.yyy + r10.xyz;
    r3.w = (int)r3.w + 1;
  }
  r0.xyz = cb9[0].xyz + -r1.yzw;
  r0.xyz = r0.www * r0.xyz + r1.yzw;
  r1.xyz = r0.xyz * r5.www + -r0.xyz;
  r1.xyz = r4.xxx * r1.xyz + r0.xyz;
  r0.w = 1 + -r0.w;
  r0.w = r4.x * r0.w;
  r2.xyz = r0.www * r2.xyz;
  r0.w = 1 + -r5.w;
  r0.xyz = r0.www * r0.xyz;
  r0.xyz = r4.xxx * r0.xyz;
  r4.yzw = r9.xyz * r4.xxx;
  r5.xyz = r10.xyz * r4.xxx;
  r4.yzw = r8.xyz * r4.xxx + r4.yzw;
  r6.xyz = cb6[9].xyz + -v8.xyz;
  r0.w = dot(r6.xyz, r6.xyz);
  r0.w = sqrt(r0.w);
  if (v9.x != 0) {
    r1.w = -cb5[12].w * r0.w;
    r1.w = 1.44269502 * r1.w;
    r1.w = exp2(r1.w);
    r1.w = min(1, r1.w);
    r2.w = cb5[12].x + -r0.w;
    r2.w = saturate(cb5[12].y * r2.w);
    r3.x = r2.w * r1.w;
    r1.w = -r1.w * r2.w + 1;
    r6.xyz = -cb6[9].xyz + v8.xyz;
    r2.w = dot(r6.xyz, r6.xyz);
    r2.w = rsqrt(r2.w);
    r3.w = r6.y * r2.w;
    r5.w = cmp(r3.w < 0);
    r2.w = r6.y * r2.w + 1;
    r2.w = r2.w * r2.w;
    r6.xy = cb0[17].yz + -cb0[17].xy;
    r2.w = r2.w * r6.x + cb0[17].x;
    r3.w = r3.w * r6.y + cb0[17].y;
    r2.w = r5.w ? r2.w : r3.w;
    r6.xyz = cb0[7].xyz * r2.www;
    r2.w = 0;
  } else {
    r3.w = -cb6[9].y + v8.y;
    r5.w = 9.99999975e-006 + r0.w;
    r6.w = abs(r3.w) / r5.w;
    r6.w = cb5[10].x * r6.w;
    r7.x = cmp(r6.w == 0.000000);
    r7.y = -r6.w * r0.w;
    r7.y = 1.44269502 * r7.y;
    r7.y = exp2(r7.y);
    r7.y = 1 + -r7.y;
    r6.w = r7.y / r6.w;
    r6.w = r7.x ? r0.w : r6.w;
    r7.x = min(cb6[9].y, v8.y);
    r7.x = -cb5[10].x * r7.x;
    r7.x = 1.44269502 * r7.x;
    r7.x = exp2(r7.x);
    r7.x = -cb5[10].y * r7.x;
    r6.w = r7.x * r6.w;
    r6.w = 1.44269502 * r6.w;
    r6.w = exp2(r6.w);
    r6.w = min(1, r6.w);
    r3.w = r3.w / r5.w;
    r3.w = cb0[14].z * r3.w;
    r5.w = cmp(r3.w == 0.000000);
    r7.x = -r3.w * r0.w;
    r7.x = 1.44269502 * r7.x;
    r7.x = exp2(r7.x);
    r7.x = 1 + -r7.x;
    r3.w = r7.x / r3.w;
    r3.w = r5.w ? r0.w : r3.w;
    r5.w = cb6[9].y + -cb0[14].x;
    r5.w = -cb0[14].z * r5.w;
    r5.w = 1.44269502 * r5.w;
    r5.w = exp2(r5.w);
    r5.w = -cb0[14].y * r5.w;
    r3.w = r5.w * r3.w;
    r3.w = 1.44269502 * r3.w;
    r3.w = exp2(r3.w);
    r3.w = min(1, r3.w);
    r3.w = r6.w * r3.w;
    r0.w = cb5[12].x + -r0.w;
    r0.w = saturate(cb5[12].y * r0.w);
    r3.x = r3.w * r0.w;
    r2.w = -r3.w * r0.w + 1;
    r6.xyz = cb0[7].xyz;
    r1.w = 0;
  }
  r3.yz = r3.zy * float2(0.00499999989,0.00499999989) + v7.xy;
  r0.w = -cb6[2].w + v7.w;
  r0.w = saturate(r0.w / cb6[2].w);
  r3.y = t15.SampleCmpLevelZero(s15_s, r3.yz, v7.z).x;
  r3.z = 1 + -r0.w;
  r0.w = r3.y * r3.z + r0.w;
  r0.w = -1 + r0.w;
  r0.w = cb6[2].x * r0.w + 1;
  r3.y = max(cb5[0].w, r4.x);
  r3.z = max(cb5[12].z, 0);
  r7.xyz = cb0[15].xyz * -r3.zzz;
  r7.xyz = float3(1.44269502,1.44269502,1.44269502) * r7.xyz;
  r7.xyz = exp2(r7.xyz);
  r8.xyz = cb0[16].xyz * -r3.zzz;
  r8.xyz = float3(1.44269502,1.44269502,1.44269502) * r8.xyz;
  r8.xyz = exp2(r8.xyz);
  r1.xyz = r8.xyz * r1.xyz;
  r2.xyz = r8.xyz * r2.xyz;
  r0.xyz = r0.xyz * r7.xyz + r5.xyz;
  r0.w = 1 + -r0.w;
  r0.w = saturate(-r0.w * cb9[35].w + 1);
  r1.xyz = r1.xyz * r0.www + r4.yzw;
  r0.xyz = r2.xyz * r0.www + r0.xyz;
  r0.xyz = r1.xyz * r3.yyy + r0.xyz;
  r1.xyz = cb0[1].xyz * r3.yyy;
  r2.xyz = r6.xyz * r3.yyy;
  r2.xyz = r2.xyz * r1.www;
  r1.xyz = r1.xyz * r2.www + r2.xyz;
  o0.xyz = r0.xyz * r3.xxx + r1.xyz;
  o0.w = r3.y;
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.2.67 on Wed Nov 29 11:28:27 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   xyz 
// TEXCOORD                 3   xyzw        4     NONE   float   xyzw
// TEXCOORD                 4   xyzw        5     NONE   float   xyzw
// TEXCOORD                 5   xy          6     NONE   float   xy  
// TEXCOORD                 6   xyzw        7     NONE   float   xyzw
// TEXCOORD                 8   xyzw        8     NONE   float   xyz 
// SV_IsFrontFace           0   x           9    FFACE    uint   x   
//
//
// 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[13], 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 s10, mode_default
dcl_sampler s11, mode_default
dcl_sampler s12, mode_default
dcl_sampler s13, mode_default
dcl_sampler s15, mode_comparison
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) 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_resource_texture2d (float,float,float,float) t15
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.xyz
dcl_input_ps linear centroid v4.xyzw
dcl_input_ps linear centroid v5.xyzw
dcl_input_ps linear centroid v6.xy
dcl_input_ps linear centroid v7.xyzw
dcl_input_ps linear centroid v8.xyz
dcl_input_ps_sgv v9.x, is_front_face
dcl_output o0.xyzw
dcl_temps 14
add r0.xyz, -v1.xyzx, cb6[6].xyzx
dp3 r0.w, r0.xyzx, r0.xyzx
sqrt r0.w, r0.w
add r0.w, r0.w, l(0.000100)
div r0.xyz, r0.xyzx, r0.wwww
sample_indexable(texture2d)(float,float,float,float) r1.xy, v4.xyxx, t1.ywxz, s1
sample_indexable(texture2d)(float,float,float,float) r1.zw, v4.zwzz, t1.xzyw, s1
mad r1.xy, r1.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mad r1.zw, r1.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
add r2.xyzw, v4.zwzw, l(0.250000, 0.250000, 0.500000, 0.500000)
sample_indexable(texture2d)(float,float,float,float) r2.xy, r2.xyxx, t1.ywxz, s1
sample_indexable(texture2d)(float,float,float,float) r2.zw, r2.zwzz, t1.xzyw, s1
add r3.xy, v4.zwzz, l(0.750000, 0.750000, 0.000000, 0.000000)
sample_indexable(texture2d)(float,float,float,float) r3.xy, r3.xyxx, t1.ywxz, s1
sample_indexable(texture2d)(float,float,float,float) r3.zw, v5.xyxx, t3.xzyw, s3
add r4.xyzw, v5.xyxy, l(0.250000, 0.250000, 0.500000, 0.500000)
sample_indexable(texture2d)(float,float,float,float) r4.xy, r4.xyxx, t3.ywxz, s3
sample_indexable(texture2d)(float,float,float,float) r4.zw, r4.zwzz, t3.xzyw, s3
add r5.xy, v5.xyxx, l(0.750000, 0.750000, 0.000000, 0.000000)
sample_indexable(texture2d)(float,float,float,float) r5.xy, r5.xyxx, t3.ywxz, s3
mad r2.xy, r2.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mad r2.zw, r2.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
mad r3.xy, r3.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mad r3.zw, r3.zzzw, l(0.000000, 0.000000, 2.000000, 2.000000), l(0.000000, 0.000000, -1.000000, -1.000000)
mad r4.xy, r4.xyxx, l(2.000000, 2.000000, 0.000000, 0.000000), l(-1.000000, -1.000000, 0.000000, 0.000000)
mad r4.zw, r4.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)
mad r5.zw, cb9[5].xxxx, l(0.000000, 0.000000, 0.800000, 0.600000), l(0.000000, 0.000000, 0.400000, 0.200000)
mul r6.xyzw, r5.zzzz, cb9[1].xyzw
mul r6.xyzw, r6.xyzw, v5.zzzz
mul r7.xyzw, r5.zzzz, cb9[2].xyzw
mul r7.xyzw, r7.xyzw, v5.wwww
mul r2.xy, r2.xyxx, r6.yyyy
mad r2.xy, r1.zwzz, r6.xxxx, r2.xyxx
mad r2.xy, r2.zwzz, r6.zzzz, r2.xyxx
mad r2.xy, r3.xyxx, r6.wwww, r2.xyxx
mul r2.zw, r4.xxxy, r7.yyyy
mad r2.zw, r3.zzzw, r7.xxxx, r2.zzzw
mad r2.zw, r4.zzzw, r7.zzzz, r2.zzzw
mad r2.zw, r5.xxxy, r7.wwww, r2.zzzw
add r1.xy, r1.zwzz, r1.xyxx
mad r1.zw, r1.xxxy, l(0.000000, 0.000000, 1.800000, 1.800000), r2.xxxy
add r2.xy, r2.zwzz, r1.zwzz
add r1.xy, r1.xyxx, r1.xyxx
mov r1.z, l(1.000000)
dp3 r0.w, r1.xyzx, r1.xyzx
rsq r0.w, r0.w
mov r2.z, cb9[4].y
dp3 r1.x, r2.xyzx, r2.xyzx
rsq r1.x, r1.x
mul r1.xyz, r1.xxxx, r2.xyzx
mul r2.xyz, v3.zxyz, l(1.000000, 0.000000, 0.000000, 0.000000)
mad r2.xyz, v3.xyzx, l(0.000000, 1.000000, 0.000000, 0.000000), -r2.xyzx
dp2 r1.w, r2.xyxx, r2.xyxx
rsq r1.w, r1.w
mul r2.xyz, r1.wwww, r2.xyzx
mul r3.xyz, r2.xyzx, v3.zxyz
mad r3.xyz, v3.yzxy, r2.yzxy, -r3.xyzx
mul r4.xyz, r1.zzzz, v3.xyzx
mad r3.xyz, r3.yzxy, r1.yyyy, r4.yzxy
mad r3.xy, r2.xyxx, -r1.xxxx, r3.xyxx
dp3 r1.x, -r3.zxyz, r0.xyzx
max r1.x, r1.x, l(0.000000)
add r1.x, -r1.x, l(1.000000)
mul r1.x, r1.x, l(1.512146)
mul r1.x, r1.x, r1.x
mul r1.x, r1.x, r1.x
min r1.x, r1.x, l(1.000000)
dp3 r1.y, r3.zxyz, r0.xyzx
max r1.y, r1.y, l(0.000000)
add r1.y, -r1.y, l(1.000000)
mul r1.z, r1.y, r1.y
mul r1.z, r1.z, r1.z
mul r1.y, r1.z, r1.y
mad r1.y, r1.y, l(0.980000), l(0.020000)
movc r1.x, v9.x, r1.x, r1.y
dp3 r1.y, -r0.yzxy, r3.xyzx
add r1.y, r1.y, r1.y
mad r1.yz, r3.zzyz, -r1.yyyy, -r0.xxzx
dp2 r1.w, r1.yzyy, r1.yzyy
mul r1.yz, r1.wwww, r1.yyzy
mad r1.yz, r1.yyzy, l(0.000000, 0.450000, 0.450000, 0.000000), l(0.000000, 0.500000, 0.500000, 0.000000)
sample_indexable(texture2d)(float,float,float,float) r2.xyz, r1.yzyy, t4.xyzw, s4
sample_indexable(texture2d)(float,float,float,float) r1.yzw, r1.yzyy, t5.wxyz, s5
if_z v9.x
  add r2.xyz, -r1.yzwy, r2.xyzx
  mad r1.yzw, v6.yyyy, r2.xxyz, r1.yyzw
  mul r1.yzw, r1.yyzw, cb1[2].xxyz
else 
  mov r1.yzw, cb0[7].xxyz
endif 
add r2.xyz, r3.zxyz, -v3.xyzx
mad r2.xyz, cb9[33].wwww, r2.xyzx, v3.xyzx
dp3 r2.w, r2.xyzx, r2.xyzx
rsq r2.w, r2.w
mul r2.xyz, r2.wwww, r2.xyzx
dp3 r2.w, -r0.xyzx, r2.xyzx
add r2.w, r2.w, r2.w
mad r2.w, r2.y, -r2.w, -r0.y
movc r4.x, v9.x, l(0), l(1.000000)
mul_sat r2.w, r2.w, l(-100.000000)
add r2.w, r2.w, r4.x
mul r2.w, r2.w, cb9[33].x
lt r2.w, l(0.001000), r2.w
if_nz r2.w
  add r2.w, -v2.z, cb9[33].y
  lt r4.x, l(0.000000), r2.w
  if_nz r4.x
    dp3 r4.x, r2.xyzx, cb9[40].xyzx
    dp3 r4.y, r2.xyzx, cb9[41].xyzx
    dp3 r4.z, r2.xyzx, cb9[42].xyzx
    dp3 r2.x, v2.xyzx, v2.xyzx
    rsq r2.x, r2.x
    mul r2.xyz, r2.xxxx, v2.xyzx
    dp3 r4.w, r2.xyzx, r4.xyzx
    add r4.w, r4.w, r4.w
    mad r2.xyz, r4.xyzx, -r4.wwww, r2.xyzx
    add r4.x, r2.z, l(-0.200000)
    mul_sat r4.x, r4.x, l(5.000000)
    ge r4.y, r4.x, l(0.010000)
    if_nz r4.y
      div r2.w, r2.w, r2.z
      mad r2.xyz, r2.xyzx, r2.wwww, v2.xyzx
      mul r4.yzw, v2.yyyy, cb9[30].xxyw
      mad r4.yzw, cb9[29].xxyw, v2.xxxx, r4.yyzw
      mad r4.yzw, cb9[31].xxyw, v2.zzzz, r4.yyzw
      add r4.yzw, r4.yyzw, cb9[32].xxyw
      mul r5.xyz, r2.yyyy, cb9[30].xywx
      mad r2.xyw, cb9[29].xyxw, r2.xxxx, r5.xyxz
      mad r2.xyz, cb9[31].xywx, r2.zzzz, r2.xywx
      add r2.xyz, r2.xyzx, cb9[32].xywx
      div r2.w, l(1.000000, 1.000000, 1.000000, 1.000000), r4.w
      div r2.z, l(1.000000, 1.000000, 1.000000, 1.000000), r2.z
      mul r5.xy, r2.wwww, r4.yzyy
      mul r6.xy, r2.zzzz, r2.xyxx
      mov r5.z, -r5.y
      add r2.xy, r5.xzxx, l(1.000000, 1.000000, 0.000000, 0.000000)
      mul r4.yz, r2.xxyx, l(0.000000, 0.500000, 0.500000, 0.000000)
      mov r6.z, -r6.y
      add r5.xy, r6.xzxx, l(1.000000, 1.000000, 0.000000, 0.000000)
      mad r5.xy, r5.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000), -r4.yzyy
      lt r6.xy, l(0.000000, 0.000000, 0.000000, 0.000000), r5.xyxx
      mad r2.xy, -r2.xyxx, l(0.500000, 0.500000, 0.000000, 0.000000), l(1.000000, 1.000000, 0.000000, 0.000000)
      div_sat r2.xy, r2.xyxx, r5.xyxx
      add r6.zw, -r5.xxxy, l(0.000000, 0.000000, 0.000100, 0.000100)
      div_sat r6.zw, r4.yyyz, r6.zzzw
      movc r2.xy, r6.xyxx, r2.xyxx, r6.zwzz
      min r2.x, r2.y, r2.x
      mul r5.xy, r2.xxxx, r5.xyxx
      add r2.y, -r2.w, r2.z
      mul r2.x, r2.x, r2.y
      mul r2.y, r2.x, l(0.125000)
      mul r2.z, l(0.750000), cb9[33].y
      min r2.z, r2.z, l(100.000000)
      add r4.w, -r2.z, cb9[33].y
      div r4.w, l(1.000000, 1.000000, 1.000000, 1.000000), r4.w
      mad r6.xyzw, r5.xyxy, l(0.012500, 0.012500, 0.043750, 0.043750), r4.yzyz
      mad r7.xyz, r2.xxxx, l(0.012500, 0.043750, 0.075000, 0.000000), r2.wwww
      sample_l_indexable(texture2d)(float,float,float,float) r5.z, r6.xyxx, t13.yzxw, s13, l(0.000000)
      add_sat r7.w, -r5.z, l(0.000100)
      add r7.w, r5.z, r7.w
      div r7.w, l(1.000000, 1.000000, 1.000000, 1.000000), r7.w
      add r7.x, -r7.w, r7.x
      lt r7.x, |r7.x|, |r2.y|
      if_nz r7.x
        add r8.xy, r6.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
        max r7.w, |r8.y|, |r8.x|
        add r7.w, r7.w, r7.w
        log r7.w, r7.w
        mul r7.w, r7.w, cb9[34].x
        exp r7.w, r7.w
        min r7.w, r7.w, l(1.000000)
        add r7.w, -r7.w, l(1.000000)
        add r5.z, -r2.z, r5.z
        mul_sat r5.z, r4.w, r5.z
        add r5.z, -r5.z, l(1.000000)
        log r5.z, r5.z
        mul r5.z, r5.z, cb9[34].y
        exp r5.z, r5.z
        sample_l_indexable(texture2d)(float,float,float,float) r8.xyz, r6.xyxx, t12.xyzw, s12, l(0.000000)
        mul r5.z, r5.z, r7.w
        add r8.xyz, -r1.yzwy, r8.xyzx
        mad r8.xyz, r5.zzzz, r8.xyzx, r1.yzwy
      else 
        mov r8.xyz, r1.yzwy
      endif 
      movc r5.z, r7.x, l(0.012500), l(0.137500)
      if_z r7.x
        if_z r7.x
          mad r6.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r6.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r6.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r6.xyxx, t12.wxyz, s12, l(0.000000)
            mul r6.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r8.xyz, r6.xxxx, r9.xyzx, r1.yzwy
          endif 
          movc r6.x, r7.x, l(0.137500), l(0.262500)
          movc r5.z, r7.w, r5.z, r6.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r7.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xw, r5.zzzz, r5.xxxy, r4.yyyz
          mad r6.y, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xwxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r6.y, r6.y, -r9.x
          lt r6.y, |r6.y|, |r2.y|
          if_nz r6.y
            add r9.xy, r7.xwxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xwxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r8.xyz, r7.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r6.y, r5.z, r7.x
        else 
          mov r6.y, l(-1)
        endif 
        or r6.x, r6.x, r6.y
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xw, r5.zzzz, r5.xxxy, r4.yyyz
          mad r6.y, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xwxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r6.y, r6.y, -r9.x
          lt r6.y, |r6.y|, |r2.y|
          if_nz r6.y
            add r9.xy, r7.xwxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xwxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r8.xyz, r7.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r6.y, r5.z, r7.x
        else 
          mov r6.y, l(-1)
        endif 
        or r6.x, r6.x, r6.y
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xw, r5.zzzz, r5.xxxy, r4.yyyz
          mad r6.y, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xwxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r6.y, r6.y, -r9.x
          lt r6.y, |r6.y|, |r2.y|
          if_nz r6.y
            add r9.xy, r7.xwxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xwxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r8.xyz, r7.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r6.y, r5.z, r7.x
        else 
          mov r6.y, l(-1)
        endif 
        or r6.x, r6.x, r6.y
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xw, r5.zzzz, r5.xxxy, r4.yyyz
          mad r6.y, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xwxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r6.y, r6.y, -r9.x
          lt r6.y, |r6.y|, |r2.y|
          if_nz r6.y
            add r9.xy, r7.xwxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xwxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r8.xyz, r7.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r6.y, r5.z, r7.x
        else 
          mov r6.y, l(-1)
        endif 
        or r6.x, r6.x, r6.y
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xw, r5.zzzz, r5.xxxy, r4.yyyz
          mad r6.y, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xwxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r6.y, r6.y, -r9.x
          lt r6.y, |r6.y|, |r2.y|
          if_nz r6.y
            add r9.xy, r7.xwxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xwxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r8.xyz, r7.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r6.y, r5.z, r7.x
        else 
          mov r6.y, l(-1)
        endif 
        or r6.x, r6.x, r6.y
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xw, r5.zzzz, r5.xxxy, r4.yyyz
          mad r6.y, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xwxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r6.y, r6.y, -r9.x
          lt r6.y, |r6.y|, |r2.y|
          if_nz r6.y
            add r9.xy, r7.xwxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xwxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r8.xyz, r7.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r6.y, r5.z, r7.x
        else 
          mov r6.y, l(-1)
        endif 
        or r6.x, r6.x, r6.y
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r6.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r5.z, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r7.x, r6.xyxx, t13.xyzw, s13, l(0.000000)
          add_sat r7.w, -r7.x, l(0.000100)
          add r7.w, r7.w, r7.x
          div r7.w, l(1.000000, 1.000000, 1.000000, 1.000000), r7.w
          add r5.z, r5.z, -r7.w
          lt r5.z, |r5.z|, |r2.y|
          if_nz r5.z
            add r9.xy, r6.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r5.z, |r9.y|, |r9.x|
            add r5.z, r5.z, r5.z
            log r5.z, r5.z
            mul r5.z, r5.z, cb9[34].x
            exp r5.z, r5.z
            min r5.z, r5.z, l(1.000000)
            add r5.z, -r5.z, l(1.000000)
            add r7.x, -r2.z, r7.x
            mul_sat r7.x, r4.w, r7.x
            add r7.x, -r7.x, l(1.000000)
            log r7.x, r7.x
            mul r7.x, r7.x, cb9[34].y
            exp r7.x, r7.x
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r6.xyxx, t12.xyzw, s12, l(0.000000)
            mul r5.z, r5.z, r7.x
            add r9.xyz, -r1.yzwy, r9.xyzx
            mad r8.xyz, r5.zzzz, r9.xyzx, r1.yzwy
          endif 
        endif 
      endif 
      sample_l_indexable(texture2d)(float,float,float,float) r5.z, r6.zwzz, t13.yzxw, s13, l(0.000000)
      add_sat r6.x, -r5.z, l(0.000100)
      add r6.x, r5.z, r6.x
      div r6.x, l(1.000000, 1.000000, 1.000000, 1.000000), r6.x
      add r6.x, -r6.x, r7.y
      lt r6.x, |r6.x|, |r2.y|
      if_nz r6.x
        add r7.xy, r6.zwzz, l(-0.500000, -0.500000, 0.000000, 0.000000)
        max r6.y, |r7.y|, |r7.x|
        add r6.y, r6.y, r6.y
        log r6.y, r6.y
        mul r6.y, r6.y, cb9[34].x
        exp r6.y, r6.y
        min r6.y, r6.y, l(1.000000)
        add r6.y, -r6.y, l(1.000000)
        add r5.z, -r2.z, r5.z
        mul_sat r5.z, r4.w, r5.z
        add r5.z, -r5.z, l(1.000000)
        log r5.z, r5.z
        mul r5.z, r5.z, cb9[34].y
        exp r5.z, r5.z
        sample_l_indexable(texture2d)(float,float,float,float) r7.xyw, r6.zwzz, t12.xywz, s12, l(0.000000)
        mul r5.z, r5.z, r6.y
        add r6.yzw, -r1.yyzw, r7.xxyw
        mad r6.yzw, r5.zzzz, r6.yyzw, r1.yyzw
      else 
        mov r6.yzw, r1.yyzw
      endif 
      movc r5.z, r6.x, l(0.043750), l(0.168750)
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xyxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r6.yzw, r7.xxxx, r9.xxyz, r1.yyzw
          endif 
          movc r7.x, r6.x, l(0.168750), l(0.293750)
          movc r5.z, r7.w, r5.z, r7.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r6.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xyxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r6.yzw, r7.xxxx, r9.xxyz, r1.yyzw
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r7.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r6.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xyxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r6.yzw, r7.xxxx, r9.xxyz, r1.yyzw
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r7.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r6.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xyxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r6.yzw, r7.xxxx, r9.xxyz, r1.yyzw
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r7.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r6.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xyxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r6.yzw, r7.xxxx, r9.xxyz, r1.yyzw
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r7.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r6.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xyxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r6.yzw, r7.xxxx, r9.xxyz, r1.yyzw
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r7.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r6.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.w, r7.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r9.x, -r8.w, l(0.000100)
          add r9.x, r8.w, r9.x
          div r9.x, l(1.000000, 1.000000, 1.000000, 1.000000), r9.x
          add r7.w, r7.w, -r9.x
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r9.x, |r9.y|, |r9.x|
            add r9.x, r9.x, r9.x
            log r9.x, r9.x
            mul r9.x, r9.x, cb9[34].x
            exp r9.x, r9.x
            min r9.x, r9.x, l(1.000000)
            add r9.x, -r9.x, l(1.000000)
            add r8.w, -r2.z, r8.w
            mul_sat r8.w, r4.w, r8.w
            add r8.w, -r8.w, l(1.000000)
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].y
            exp r8.w, r8.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.yzw, r7.xyxx, t12.wxyz, s12, l(0.000000)
            mul r7.x, r8.w, r9.x
            add r9.xyz, -r1.yzwy, r9.yzwy
            mad r6.yzw, r7.xxxx, r9.xxyz, r1.yyzw
          endif 
          add r7.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r7.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.x, r6.x, r7.w
      else 
        mov r6.x, l(-1)
      endif 
      if_z r6.x
        if_z r6.x
          mad r7.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r5.z, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r6.x, r7.xyxx, t13.xyzw, s13, l(0.000000)
          add_sat r7.w, -r6.x, l(0.000100)
          add r7.w, r6.x, r7.w
          div r7.w, l(1.000000, 1.000000, 1.000000, 1.000000), r7.w
          add r5.z, r5.z, -r7.w
          lt r5.z, |r5.z|, |r2.y|
          if_nz r5.z
            add r9.xy, r7.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r5.z, |r9.y|, |r9.x|
            add r5.z, r5.z, r5.z
            log r5.z, r5.z
            mul r5.z, r5.z, cb9[34].x
            exp r5.z, r5.z
            min r5.z, r5.z, l(1.000000)
            add r5.z, -r5.z, l(1.000000)
            add r6.x, -r2.z, r6.x
            mul_sat r6.x, r4.w, r6.x
            add r6.x, -r6.x, l(1.000000)
            log r6.x, r6.x
            mul r6.x, r6.x, cb9[34].y
            exp r6.x, r6.x
            sample_l_indexable(texture2d)(float,float,float,float) r7.xyw, r7.xyxx, t12.xywz, s12, l(0.000000)
            mul r5.z, r5.z, r6.x
            add r7.xyw, -r1.yzyw, r7.xyxw
            mad r6.yzw, r5.zzzz, r7.xxyw, r1.yyzw
          endif 
        endif 
      endif 
      add r6.xyz, r6.yzwy, r8.xyzx
      mad r8.xyzw, r5.xyxy, l(0.075000, 0.075000, 0.106250, 0.106250), r4.yzyz
      sample_l_indexable(texture2d)(float,float,float,float) r5.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
      add_sat r6.w, -r5.z, l(0.000100)
      add r6.w, r5.z, r6.w
      div r6.w, l(1.000000, 1.000000, 1.000000, 1.000000), r6.w
      add r6.w, -r6.w, r7.z
      lt r6.w, |r6.w|, |r2.y|
      if_nz r6.w
        add r7.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
        max r7.x, |r7.y|, |r7.x|
        add r7.x, r7.x, r7.x
        log r7.x, r7.x
        mul r7.x, r7.x, cb9[34].x
        exp r7.x, r7.x
        min r7.x, r7.x, l(1.000000)
        add r7.x, -r7.x, l(1.000000)
        add r5.z, -r2.z, r5.z
        mul_sat r5.z, r4.w, r5.z
        add r5.z, -r5.z, l(1.000000)
        log r5.z, r5.z
        mul r5.z, r5.z, cb9[34].y
        exp r5.z, r5.z
        sample_l_indexable(texture2d)(float,float,float,float) r7.yzw, r8.xyxx, t12.wxyz, s12, l(0.000000)
        mul r5.z, r5.z, r7.x
        add r7.xyz, -r1.yzwy, r7.yzwy
        mad r7.xyz, r5.zzzz, r7.xyzx, r1.yzwy
      else 
        mov r7.xyz, r1.yzwy
      endif 
      movc r5.z, r6.w, l(0.075000), l(0.200000)
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r9.x, r8.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 r7.w, r7.w, -r9.y
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.yz, r8.xxyx, l(0.000000, -0.500000, -0.500000, 0.000000)
            max r9.y, |r9.z|, |r9.y|
            add r9.y, r9.y, r9.y
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].x
            exp r9.y, r9.y
            min r9.y, r9.y, l(1.000000)
            add r9.y, -r9.y, l(1.000000)
            add r9.x, -r2.z, r9.x
            mul_sat r9.x, r4.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.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r9.x, r9.y
            add r9.xyz, -r1.yzwy, r10.xyzx
            mad r7.xyz, r8.xxxx, r9.xyzx, r1.yzwy
          endif 
          movc r8.x, r6.w, l(0.200000), l(0.325000)
          movc r5.z, r7.w, r5.z, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.w, r6.w, r7.w
      else 
        mov r6.w, l(-1)
      endif 
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r9.x, r8.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 r7.w, r7.w, -r9.y
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.yz, r8.xxyx, l(0.000000, -0.500000, -0.500000, 0.000000)
            max r9.y, |r9.z|, |r9.y|
            add r9.y, r9.y, r9.y
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].x
            exp r9.y, r9.y
            min r9.y, r9.y, l(1.000000)
            add r9.y, -r9.y, l(1.000000)
            add r9.x, -r2.z, r9.x
            mul_sat r9.x, r4.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.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r9.x, r9.y
            add r9.xyz, -r1.yzwy, r10.xyzx
            mad r7.xyz, r8.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r8.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.w, r6.w, r7.w
      else 
        mov r6.w, l(-1)
      endif 
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r9.x, r8.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 r7.w, r7.w, -r9.y
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.yz, r8.xxyx, l(0.000000, -0.500000, -0.500000, 0.000000)
            max r9.y, |r9.z|, |r9.y|
            add r9.y, r9.y, r9.y
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].x
            exp r9.y, r9.y
            min r9.y, r9.y, l(1.000000)
            add r9.y, -r9.y, l(1.000000)
            add r9.x, -r2.z, r9.x
            mul_sat r9.x, r4.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.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r9.x, r9.y
            add r9.xyz, -r1.yzwy, r10.xyzx
            mad r7.xyz, r8.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r8.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.w, r6.w, r7.w
      else 
        mov r6.w, l(-1)
      endif 
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r9.x, r8.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 r7.w, r7.w, -r9.y
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.yz, r8.xxyx, l(0.000000, -0.500000, -0.500000, 0.000000)
            max r9.y, |r9.z|, |r9.y|
            add r9.y, r9.y, r9.y
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].x
            exp r9.y, r9.y
            min r9.y, r9.y, l(1.000000)
            add r9.y, -r9.y, l(1.000000)
            add r9.x, -r2.z, r9.x
            mul_sat r9.x, r4.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.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r9.x, r9.y
            add r9.xyz, -r1.yzwy, r10.xyzx
            mad r7.xyz, r8.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r8.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.w, r6.w, r7.w
      else 
        mov r6.w, l(-1)
      endif 
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r9.x, r8.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 r7.w, r7.w, -r9.y
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.yz, r8.xxyx, l(0.000000, -0.500000, -0.500000, 0.000000)
            max r9.y, |r9.z|, |r9.y|
            add r9.y, r9.y, r9.y
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].x
            exp r9.y, r9.y
            min r9.y, r9.y, l(1.000000)
            add r9.y, -r9.y, l(1.000000)
            add r9.x, -r2.z, r9.x
            mul_sat r9.x, r4.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.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r9.x, r9.y
            add r9.xyz, -r1.yzwy, r10.xyzx
            mad r7.xyz, r8.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r8.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.w, r6.w, r7.w
      else 
        mov r6.w, l(-1)
      endif 
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r9.x, r8.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 r7.w, r7.w, -r9.y
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.yz, r8.xxyx, l(0.000000, -0.500000, -0.500000, 0.000000)
            max r9.y, |r9.z|, |r9.y|
            add r9.y, r9.y, r9.y
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].x
            exp r9.y, r9.y
            min r9.y, r9.y, l(1.000000)
            add r9.y, -r9.y, l(1.000000)
            add r9.x, -r2.z, r9.x
            mul_sat r9.x, r4.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.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r9.x, r9.y
            add r9.xyz, -r1.yzwy, r10.xyzx
            mad r7.xyz, r8.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r8.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.w, r6.w, r7.w
      else 
        mov r6.w, l(-1)
      endif 
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r7.w, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r9.x, r8.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 r7.w, r7.w, -r9.y
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.yz, r8.xxyx, l(0.000000, -0.500000, -0.500000, 0.000000)
            max r9.y, |r9.z|, |r9.y|
            add r9.y, r9.y, r9.y
            log r9.y, r9.y
            mul r9.y, r9.y, cb9[34].x
            exp r9.y, r9.y
            min r9.y, r9.y, l(1.000000)
            add r9.y, -r9.y, l(1.000000)
            add r9.x, -r2.z, r9.x
            mul_sat r9.x, r4.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.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r9.x, r9.y
            add r9.xyz, -r1.yzwy, r10.xyzx
            mad r7.xyz, r8.xxxx, r9.xyzx, r1.yzwy
          endif 
          add r8.x, r5.z, l(0.125000)
          movc r5.z, r7.w, r5.z, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r6.w, r6.w, r7.w
      else 
        mov r6.w, l(-1)
      endif 
      if_z r6.w
        if_z r6.w
          mad r8.xy, r5.zzzz, r5.xyxx, r4.yzyy
          mad r5.z, r5.z, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r6.w, r8.xyxx, t13.yzwx, s13, l(0.000000)
          add_sat r7.w, -r6.w, l(0.000100)
          add r7.w, r6.w, r7.w
          div r7.w, l(1.000000, 1.000000, 1.000000, 1.000000), r7.w
          add r5.z, r5.z, -r7.w
          lt r5.z, |r5.z|, |r2.y|
          if_nz r5.z
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r5.z, |r9.y|, |r9.x|
            add r5.z, r5.z, r5.z
            log r5.z, r5.z
            mul r5.z, r5.z, cb9[34].x
            exp r5.z, r5.z
            min r5.z, r5.z, l(1.000000)
            add r5.z, -r5.z, l(1.000000)
            add r6.w, -r2.z, r6.w
            mul_sat r6.w, r4.w, r6.w
            add r6.w, -r6.w, l(1.000000)
            log r6.w, r6.w
            mul r6.w, r6.w, cb9[34].y
            exp r6.w, r6.w
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r5.z, r5.z, r6.w
            add r9.xyz, -r1.yzwy, r9.xyzx
            mad r7.xyz, r5.zzzz, r9.xyzx, r1.yzwy
          endif 
        endif 
      endif 
      add r6.xyz, r6.xyzx, r7.xyzx
      mad r5.z, r2.x, l(0.106250), r2.w
      sample_l_indexable(texture2d)(float,float,float,float) r6.w, r8.zwzz, t13.yzwx, s13, l(0.000000)
      add_sat r7.x, -r6.w, l(0.000100)
      add r7.x, r6.w, r7.x
      div r7.x, l(1.000000, 1.000000, 1.000000, 1.000000), r7.x
      add r5.z, r5.z, -r7.x
      lt r5.z, |r5.z|, |r2.y|
      if_nz r5.z
        add r7.xy, r8.zwzz, l(-0.500000, -0.500000, 0.000000, 0.000000)
        max r7.x, |r7.y|, |r7.x|
        add r7.x, r7.x, r7.x
        log r7.x, r7.x
        mul r7.x, r7.x, cb9[34].x
        exp r7.x, r7.x
        min r7.x, r7.x, l(1.000000)
        add r7.x, -r7.x, l(1.000000)
        add r6.w, -r2.z, r6.w
        mul_sat r6.w, r4.w, r6.w
        add r6.w, -r6.w, l(1.000000)
        log r6.w, r6.w
        mul r6.w, r6.w, cb9[34].y
        exp r6.w, r6.w
        sample_l_indexable(texture2d)(float,float,float,float) r7.yzw, r8.zwzz, t12.wxyz, s12, l(0.000000)
        mul r6.w, r6.w, r7.x
        add r7.xyz, -r1.yzwy, r7.yzwy
        mad r7.xyz, r6.wwww, r7.xyzx, r1.yzwy
      else 
        mov r7.xyz, r1.yzwy
      endif 
      movc r6.w, r5.z, l(0.106250), l(0.231250)
      if_z r5.z
        if_z r5.z
          mad r8.xy, r6.wwww, r5.xyxx, r4.yzyy
          mad r7.w, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
          add_sat r8.w, -r8.z, l(0.000100)
          add r8.w, r8.w, r8.z
          div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
          add r7.w, r7.w, -r8.w
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r8.w, |r9.y|, |r9.x|
            add r8.w, r8.w, r8.w
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].x
            exp r8.w, r8.w
            min r8.w, r8.w, l(1.000000)
            add r8.w, -r8.w, l(1.000000)
            add r8.z, -r2.z, r8.z
            mul_sat r8.z, r4.w, r8.z
            add r8.z, -r8.z, l(1.000000)
            log r8.z, r8.z
            mul r8.z, r8.z, cb9[34].y
            exp r8.z, r8.z
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r8.z, r8.w
            add r8.yzw, -r1.yyzw, r9.xxyz
            mad r7.xyz, r8.xxxx, r8.yzwy, r1.yzwy
          endif 
          movc r8.x, r5.z, l(0.231250), l(0.356250)
          movc r6.w, r7.w, r6.w, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r5.z, r5.z, r7.w
      else 
        mov r5.z, l(-1)
      endif 
      if_z r5.z
        if_z r5.z
          mad r8.xy, r6.wwww, r5.xyxx, r4.yzyy
          mad r7.w, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
          add_sat r8.w, -r8.z, l(0.000100)
          add r8.w, r8.w, r8.z
          div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
          add r7.w, r7.w, -r8.w
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r8.w, |r9.y|, |r9.x|
            add r8.w, r8.w, r8.w
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].x
            exp r8.w, r8.w
            min r8.w, r8.w, l(1.000000)
            add r8.w, -r8.w, l(1.000000)
            add r8.z, -r2.z, r8.z
            mul_sat r8.z, r4.w, r8.z
            add r8.z, -r8.z, l(1.000000)
            log r8.z, r8.z
            mul r8.z, r8.z, cb9[34].y
            exp r8.z, r8.z
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r8.z, r8.w
            add r8.yzw, -r1.yyzw, r9.xxyz
            mad r7.xyz, r8.xxxx, r8.yzwy, r1.yzwy
          endif 
          add r8.x, r6.w, l(0.125000)
          movc r6.w, r7.w, r6.w, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r5.z, r5.z, r7.w
      else 
        mov r5.z, l(-1)
      endif 
      if_z r5.z
        if_z r5.z
          mad r8.xy, r6.wwww, r5.xyxx, r4.yzyy
          mad r7.w, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
          add_sat r8.w, -r8.z, l(0.000100)
          add r8.w, r8.w, r8.z
          div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
          add r7.w, r7.w, -r8.w
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r8.w, |r9.y|, |r9.x|
            add r8.w, r8.w, r8.w
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].x
            exp r8.w, r8.w
            min r8.w, r8.w, l(1.000000)
            add r8.w, -r8.w, l(1.000000)
            add r8.z, -r2.z, r8.z
            mul_sat r8.z, r4.w, r8.z
            add r8.z, -r8.z, l(1.000000)
            log r8.z, r8.z
            mul r8.z, r8.z, cb9[34].y
            exp r8.z, r8.z
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r8.z, r8.w
            add r8.yzw, -r1.yyzw, r9.xxyz
            mad r7.xyz, r8.xxxx, r8.yzwy, r1.yzwy
          endif 
          add r8.x, r6.w, l(0.125000)
          movc r6.w, r7.w, r6.w, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r5.z, r5.z, r7.w
      else 
        mov r5.z, l(-1)
      endif 
      if_z r5.z
        if_z r5.z
          mad r8.xy, r6.wwww, r5.xyxx, r4.yzyy
          mad r7.w, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
          add_sat r8.w, -r8.z, l(0.000100)
          add r8.w, r8.w, r8.z
          div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
          add r7.w, r7.w, -r8.w
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r8.w, |r9.y|, |r9.x|
            add r8.w, r8.w, r8.w
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].x
            exp r8.w, r8.w
            min r8.w, r8.w, l(1.000000)
            add r8.w, -r8.w, l(1.000000)
            add r8.z, -r2.z, r8.z
            mul_sat r8.z, r4.w, r8.z
            add r8.z, -r8.z, l(1.000000)
            log r8.z, r8.z
            mul r8.z, r8.z, cb9[34].y
            exp r8.z, r8.z
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r8.z, r8.w
            add r8.yzw, -r1.yyzw, r9.xxyz
            mad r7.xyz, r8.xxxx, r8.yzwy, r1.yzwy
          endif 
          add r8.x, r6.w, l(0.125000)
          movc r6.w, r7.w, r6.w, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r5.z, r5.z, r7.w
      else 
        mov r5.z, l(-1)
      endif 
      if_z r5.z
        if_z r5.z
          mad r8.xy, r6.wwww, r5.xyxx, r4.yzyy
          mad r7.w, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
          add_sat r8.w, -r8.z, l(0.000100)
          add r8.w, r8.w, r8.z
          div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
          add r7.w, r7.w, -r8.w
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r8.w, |r9.y|, |r9.x|
            add r8.w, r8.w, r8.w
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].x
            exp r8.w, r8.w
            min r8.w, r8.w, l(1.000000)
            add r8.w, -r8.w, l(1.000000)
            add r8.z, -r2.z, r8.z
            mul_sat r8.z, r4.w, r8.z
            add r8.z, -r8.z, l(1.000000)
            log r8.z, r8.z
            mul r8.z, r8.z, cb9[34].y
            exp r8.z, r8.z
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r8.z, r8.w
            add r8.yzw, -r1.yyzw, r9.xxyz
            mad r7.xyz, r8.xxxx, r8.yzwy, r1.yzwy
          endif 
          add r8.x, r6.w, l(0.125000)
          movc r6.w, r7.w, r6.w, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r5.z, r5.z, r7.w
      else 
        mov r5.z, l(-1)
      endif 
      if_z r5.z
        if_z r5.z
          mad r8.xy, r6.wwww, r5.xyxx, r4.yzyy
          mad r7.w, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
          add_sat r8.w, -r8.z, l(0.000100)
          add r8.w, r8.w, r8.z
          div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
          add r7.w, r7.w, -r8.w
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r8.w, |r9.y|, |r9.x|
            add r8.w, r8.w, r8.w
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].x
            exp r8.w, r8.w
            min r8.w, r8.w, l(1.000000)
            add r8.w, -r8.w, l(1.000000)
            add r8.z, -r2.z, r8.z
            mul_sat r8.z, r4.w, r8.z
            add r8.z, -r8.z, l(1.000000)
            log r8.z, r8.z
            mul r8.z, r8.z, cb9[34].y
            exp r8.z, r8.z
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r8.z, r8.w
            add r8.yzw, -r1.yyzw, r9.xxyz
            mad r7.xyz, r8.xxxx, r8.yzwy, r1.yzwy
          endif 
          add r8.x, r6.w, l(0.125000)
          movc r6.w, r7.w, r6.w, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r5.z, r5.z, r7.w
      else 
        mov r5.z, l(-1)
      endif 
      if_z r5.z
        if_z r5.z
          mad r8.xy, r6.wwww, r5.xyxx, r4.yzyy
          mad r7.w, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r8.z, r8.xyxx, t13.yzxw, s13, l(0.000000)
          add_sat r8.w, -r8.z, l(0.000100)
          add r8.w, r8.w, r8.z
          div r8.w, l(1.000000, 1.000000, 1.000000, 1.000000), r8.w
          add r7.w, r7.w, -r8.w
          lt r7.w, |r7.w|, |r2.y|
          if_nz r7.w
            add r9.xy, r8.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r8.w, |r9.y|, |r9.x|
            add r8.w, r8.w, r8.w
            log r8.w, r8.w
            mul r8.w, r8.w, cb9[34].x
            exp r8.w, r8.w
            min r8.w, r8.w, l(1.000000)
            add r8.w, -r8.w, l(1.000000)
            add r8.z, -r2.z, r8.z
            mul_sat r8.z, r4.w, r8.z
            add r8.z, -r8.z, l(1.000000)
            log r8.z, r8.z
            mul r8.z, r8.z, cb9[34].y
            exp r8.z, r8.z
            sample_l_indexable(texture2d)(float,float,float,float) r9.xyz, r8.xyxx, t12.xyzw, s12, l(0.000000)
            mul r8.x, r8.z, r8.w
            add r8.yzw, -r1.yyzw, r9.xxyz
            mad r7.xyz, r8.xxxx, r8.yzwy, r1.yzwy
          endif 
          add r8.x, r6.w, l(0.125000)
          movc r6.w, r7.w, r6.w, r8.x
        else 
          mov r7.w, l(-1)
        endif 
        or r5.z, r5.z, r7.w
      else 
        mov r5.z, l(-1)
      endif 
      if_z r5.z
        if_z r5.z
          mad r4.yz, r6.wwww, r5.xxyx, r4.yyzy
          mad r2.x, r6.w, r2.x, r2.w
          sample_l_indexable(texture2d)(float,float,float,float) r2.w, r4.yzyy, t13.yzwx, s13, l(0.000000)
          add_sat r5.x, -r2.w, l(0.000100)
          add r5.x, r2.w, r5.x
          div r5.x, l(1.000000, 1.000000, 1.000000, 1.000000), r5.x
          add r2.x, r2.x, -r5.x
          lt r2.x, |r2.x|, |r2.y|
          if_nz r2.x
            add r2.xy, r4.yzyy, l(-0.500000, -0.500000, 0.000000, 0.000000)
            max r2.x, |r2.y|, |r2.x|
            add r2.x, r2.x, r2.x
            log r2.x, r2.x
            mul r2.x, r2.x, cb9[34].x
            exp r2.x, r2.x
            min r2.x, r2.x, l(1.000000)
            add r2.x, -r2.x, l(1.000000)
            add r2.y, -r2.z, r2.w
            mul_sat r2.y, r4.w, r2.y
            add r2.y, -r2.y, l(1.000000)
            log r2.y, r2.y
            mul r2.y, r2.y, cb9[34].y
            exp r2.y, r2.y
            sample_l_indexable(texture2d)(float,float,float,float) r4.yzw, r4.yzyy, t12.wxyz, s12, l(0.000000)
            mul r2.x, r2.y, r2.x
            add r2.yzw, -r1.yyzw, r4.yyzw
            mad r7.xyz, r2.xxxx, r2.yzwy, r1.yzwy
          endif 
        endif 
      endif 
      add r2.xyz, r6.xyzx, r7.xyzx
      mul r2.w, r4.x, cb9[33].x
      mad r2.xyz, r2.xyzx, l(0.250000, 0.250000, 0.250000, 0.000000), -r1.yzwy
      mad r1.yzw, r2.wwww, r2.xxyz, r1.yyzw
    endif 
  endif 
endif 
mad r2.xy, v0.xyxx, cb9[3].xyxx, cb9[3].zwzz
sample_l_indexable(texture2d)(float,float,float,float) r2.z, r2.xyxx, t11.yzxw, s11, l(0.000000)
add r2.w, r2.z, -v2.z
mul_sat r4.x, r2.w, cb9[35].z
add r4.y, -cb9[35].x, cb9[35].y
mad r4.x, r4.x, r4.y, cb9[35].x
mul r4.z, l(10.000000), cb9[29].x
div r4.z, r4.z, v2.z
max r4.z, r4.z, l(0.100000)
min r4.z, r4.z, l(1.000000)
mul r4.x, r4.z, r4.x
add r4.w, r2.w, l(0.010000)
mul_sat r4.w, r4.w, l(100000.000000)
mul r4.x, r4.w, r4.x
add r5.xy, r2.xyxx, l(-0.500000, -0.500000, 0.000000, 0.000000)
max r4.w, |r5.y|, |r5.x|
add r4.w, -r4.w, l(0.500000)
mul_sat r4.w, r4.w, l(10.000000)
mul r4.x, r4.w, r4.x
mul_sat r2.w, r2.w, l(5.000000)
mul r2.w, r2.w, r4.x
lt r4.x, r2.w, l(0.001000)
if_nz r4.x
  sample_l_indexable(texture2d)(float,float,float,float) r5.xyz, r2.xyxx, t10.xyzw, s10, l(0.000000)
else 
  mad r6.xyzw, r3.zyzy, r2.wwww, r2.xyxy
  sample_l_indexable(texture2d)(float,float,float,float) r4.x, r6.zwzz, t11.xyzw, s11, l(0.000000)
  mad r7.xyzw, cb9[3].xyxy, l(1.000000, 0.000000, -1.000000, 0.000000), r6.zwzw
  sample_l_indexable(texture2d)(float,float,float,float) r4.w, r7.xyxx, t11.yzwx, s11, l(0.000000)
  min r4.x, r4.w, r4.x
  sample_l_indexable(texture2d)(float,float,float,float) r4.w, r7.zwzz, t11.yzwx, s11, l(0.000000)
  min r4.x, r4.w, r4.x
  mad r6.xyzw, cb9[3].xyxy, l(0.000000, 1.000000, 0.000000, -1.000000), r6.xyzw
  sample_l_indexable(texture2d)(float,float,float,float) r4.w, r6.xyxx, t11.yzwx, s11, l(0.000000)
  min r4.x, r4.w, r4.x
  sample_l_indexable(texture2d)(float,float,float,float) r4.w, r6.zwzz, t11.yzwx, s11, l(0.000000)
  min r4.x, r4.w, r4.x
  add r4.x, r4.x, -v2.z
  mul_sat r4.w, r4.x, cb9[35].z
  mad r4.y, r4.w, r4.y, cb9[35].x
  mul r4.y, r4.z, r4.y
  add r4.x, r4.x, l(0.010000)
  mul_sat r4.x, r4.x, l(100000.000000)
  mul r4.x, r4.x, r4.y
  min r2.w, r2.w, r4.x
  mad r4.xy, r3.zyzz, r2.wwww, r2.xyxx
  sample_l_indexable(texture2d)(float,float,float,float) r2.w, r4.xyxx, t11.yzwx, s11, l(0.000000)
  mad r6.xyzw, cb9[3].xyxy, l(1.000000, 0.000000, -1.000000, 0.000000), r4.xyxy
  sample_l_indexable(texture2d)(float,float,float,float) r4.z, r6.xyxx, t11.yzxw, s11, l(0.000000)
  min r2.w, r2.w, r4.z
  sample_l_indexable(texture2d)(float,float,float,float) r4.z, r6.zwzz, t11.yzxw, s11, l(0.000000)
  min r2.w, r2.w, r4.z
  mad r7.xyzw, cb9[3].xyxy, l(0.000000, 1.000000, 0.000000, -1.000000), r4.xyxy
  sample_l_indexable(texture2d)(float,float,float,float) r4.z, r7.xyxx, t11.yzxw, s11, l(0.000000)
  min r2.w, r2.w, r4.z
  sample_l_indexable(texture2d)(float,float,float,float) r4.z, r7.zwzz, t11.yzxw, s11, l(0.000000)
  min r2.w, r2.w, r4.z
  add r4.z, r2.w, -v2.z
  ge r4.z, r4.z, l(0.000000)
  if_nz r4.z
    sample_l_indexable(texture2d)(float,float,float,float) r5.xyz, r4.xyxx, t10.xyzw, s10, l(0.000000)
    add r4.xyz, -r5.xyzx, cb0[13].xyzx
    dp3 r4.x, r4.xyzx, r4.xyzx
    sample_l_indexable(texture2d)(float,float,float,float) r4.yzw, r6.xyxx, t10.wxyz, s10, l(0.000000)
    add r4.yzw, -r4.yyzw, cb0[13].xxyz
    dp3 r4.y, r4.yzwy, r4.yzwy
    min r4.x, r4.y, r4.x
    sample_l_indexable(texture2d)(float,float,float,float) r4.yzw, r6.zwzz, t10.wxyz, s10, l(0.000000)
    add r4.yzw, -r4.yyzw, cb0[13].xxyz
    dp3 r4.y, r4.yzwy, r4.yzwy
    min r4.x, r4.y, r4.x
    sample_l_indexable(texture2d)(float,float,float,float) r4.yzw, r7.xyxx, t10.wxyz, s10, l(0.000000)
    add r4.yzw, -r4.yyzw, cb0[13].xxyz
    dp3 r4.y, r4.yzwy, r4.yzwy
    min r4.x, r4.y, r4.x
    sample_l_indexable(texture2d)(float,float,float,float) r4.yzw, r7.zwzz, t10.wxyz, s10, l(0.000000)
    add r4.yzw, -r4.yyzw, cb0[13].xxyz
    dp3 r4.y, r4.yzwy, r4.yzwy
    min r4.x, r4.y, r4.x
    lt r4.x, r4.x, l(0.005000)
    if_nz r4.x
      sample_l_indexable(texture2d)(float,float,float,float) r5.xyz, r2.xyxx, t10.xyzw, s10, l(0.000000)
    endif 
    mov r2.z, r2.w
  else 
    sample_l_indexable(texture2d)(float,float,float,float) r5.xyz, r2.xyxx, t10.xyzw, s10, l(0.000000)
  endif 
endif 
add r2.x, -r2.z, v2.z
mul r2.x, |r2.x|, l(-0.144269511)
exp r2.x, r2.x
add r2.x, -r2.x, l(1.000000)
mad r2.y, -|r0.y|, l(4.000000), l(1.000000)
max r2.y, r2.y, l(0.000000)
mul r2.x, r2.y, r2.x
add r4.xyz, -r5.xyzx, cb0[7].xyzx
mad r2.xyw, r2.xxxx, r4.xyxz, r5.xyxz
lt r4.x, l(0.010000), cb9[36].x
if_nz r4.x
  max r4.x, l(0.200000), |cb6[9].y|
  add r2.z, r2.z, -v2.z
  mul r2.z, r2.z, r4.x
  div r2.z, r2.z, v2.z
  mul r4.xy, r3.zyzz, cb9[36].yyyy
  mad r4.xy, v1.xzxx, cb9[36].zzzz, r4.xyxx
  add r4.xy, r4.xyxx, cb9[37].xyxx
  sample_indexable(texture2d)(float,float,float,float) r4.x, r4.xyxx, t2.xyzw, s2
  add r4.yz, r2.zzzz, l(0.000000, -0.100000, -0.050000, 0.000000)
  mul r2.z, r4.y, cb9[36].w
  mul_sat r4.y, r2.z, l(0.500000)
  add r4.y, r4.y, l(0.200000)
  add_sat r4.x, -r4.y, r4.x
  mov_sat r2.z, r2.z
  add r2.z, -r2.z, l(1.000000)
  mul r2.z, r2.z, r2.z
  mul r2.z, r2.z, r4.x
  mul_sat r4.x, r4.z, l(10.000000)
  mul r2.z, r2.z, r4.x
  mul_sat r2.z, r2.z, cb9[36].x
else 
  mov r4.x, l(1.000000)
  mov r2.z, l(0)
endif 
add r4.yzw, -r2.xxyw, cb0[7].xxyz
mad r2.xyw, cb9[37].wwww, r4.yzyw, r2.xyxw
add r0.w, r0.w, l(-0.700000)
mul_sat r0.w, r0.w, l(5.000000)
add r4.yz, -r0.wwww, l(0.000000, 1.000000, 1.500000, 0.000000)
mul r0.w, r4.z, r4.y
mul r4.y, v6.x, v6.x
mad r4.y, r4.y, r4.y, l(0.100000)
mul r6.xyzw, v4.xyzw, l(50.099998, 50.099998, 10.200000, 10.200000)
mul r4.zw, v5.xxxy, l(0.000000, 0.000000, 0.110000, 0.110000)
sample_indexable(texture2d)(float,float,float,float) r5.x, r6.xyxx, t2.xyzw, s2
sample_indexable(texture2d)(float,float,float,float) r5.y, r6.zwzz, t2.yxzw, s2
sample_indexable(texture2d)(float,float,float,float) r4.z, r4.zwzz, t2.yzxw, s2
add r4.w, r5.y, r5.x
add r4.z, r4.z, r4.w
add_sat r4.z, r4.z, l(-2.400000)
add_sat r4.w, l(0.500000), -cb9[5].x
mul r4.y, r4.y, r4.w
mul r0.w, r0.w, r4.y
mul r0.w, r4.z, r0.w
max r0.w, r2.z, r0.w
add r1.yzw, r1.yyzw, -r2.xxyw
mad r1.yzw, r1.xxxx, r1.yyzw, r2.xxyw
mov r3.w, l(0.600000)
dp3 r2.x, r3.yzwy, r3.yzwy
rsq r2.x, r2.x
mad r2.xyz, r3.zwyz, r2.xxxx, -r3.zxyz
mad r2.xyz, cb9[37].zzzz, r2.xyzx, r3.zxyz
dp3 r2.w, r2.xyzx, r2.xyzx
rsq r2.w, r2.w
mul r2.xyz, r2.wwww, r2.xyzx
mov r5.xy, -cb5[5].yzyy
mov r5.z, cb5[5].x
dp3 r2.w, r5.xyzx, r2.xyzx
add r2.w, r2.w, r2.w
mad r2.xyz, r2.xyzx, -r2.wwww, r5.xyzx
dp3_sat r2.x, r2.xyzx, r0.xyzx
log r2.x, r2.x
mul r2.x, r2.x, cb9[4].w
exp r2.x, r2.x
mul r1.x, r1.x, r2.x
mul r2.xyz, r1.xxxx, cb5[6].xyzx
mul_sat r2.xyz, r2.xyzx, cb9[4].zzzz
mov r5.x, l(1.000000)
mov r4.yzw, l(0,0,0,0)
mov r6.xyz, l(0,0,0,0)
mov r7.xyz, l(0,0,0,0)
mov r1.x, l(0)
loop 
  ige r2.w, r1.x, cb10[0].x
  breakc_nz r2.w
  imul null, r2.w, r1.x, l(6)
  add r8.xyz, -v1.xyzx, cb11[r2.w + 0].xyzx
  dp3 r2.w, r8.xyzx, r8.xyzx
  sqrt r2.w, r2.w
  add r3.w, r2.w, l(0.000100)
  div r8.xyz, r8.xyzx, r3.wwww
  imad r9.xyzw, r1.xxxx, l(6, 6, 6, 6), l(4, 5, 2, 3)
  mad r3.w, r2.w, cb10[2].x, -cb11[r9.x + 0].x
  max r5.y, r3.w, l(0.000000)
  mul r5.z, r5.y, r5.y
  dp3 r3.w, cb11[r9.x + 0].yzwy, r5.xyzx
  add r3.w, r3.w, l(0.000100)
  div r3.w, l(1.000000, 1.000000, 1.000000, 1.000000), r3.w
  mov_sat r3.w, r3.w
  mad r2.w, r2.w, cb10[2].x, -cb11[r9.y + 0].x
  mul_sat r2.w, r2.w, cb11[r9.y + 0].y
  add r2.w, -r2.w, l(1.000000)
  mul r2.w, r2.w, r3.w
  add r10.xyz, r0.xyzx, r8.xyzx
  dp3 r3.w, r10.xyzx, r10.xyzx
  rsq r3.w, r3.w
  mul r10.xyz, r3.wwww, r10.xyzx
  dp3 r3.w, r3.zxyz, r8.xyzx
  dp3 r5.y, r3.zxyz, r10.xyzx
  ge r5.z, r3.w, l(0.000000)
  max r3.w, r3.w, l(0.000000)
  ge r6.w, r5.y, l(0.000000)
  and r5.z, r5.z, r6.w
  log r5.y, r5.y
  mul r5.y, r5.y, cb9[4].w
  exp r5.y, r5.y
  and r5.y, r5.y, r5.z
  min r5.y, r5.y, l(1.000000)
  mul r8.xyz, cb10[3].xyzx, cb11[r9.z + 0].xyzx
  mul r8.xyz, r3.wwww, r8.xyzx
  mul r8.xyz, r2.wwww, r8.xyzx
  mad r4.yzw, r8.xxyz, l(0.000000, 0.500000, 0.500000, 0.500000), r4.yyzw
  mad r6.xyz, cb11[r9.w + 0].xyzx, r2.wwww, r6.xyzx
  mul r8.xyz, cb5[7].xyzx, cb11[r9.z + 0].xyzx
  mul r8.xyz, r5.yyyy, r8.xyzx
  mad r7.xyz, r8.xyzx, r2.wwww, r7.xyzx
  iadd r1.x, r1.x, l(1)
endloop 
iadd r2.w, cb10[0].x, cb10[1].x
mov r5.x, l(1.000000)
mov r8.xyz, r4.yzwy
mov r9.xyz, r6.xyzx
mov r10.xyz, r7.xyzx
mov r3.w, r1.x
loop 
  ige r6.w, r3.w, r2.w
  breakc_nz r6.w
  imul null, r6.w, r3.w, l(6)
  add r11.xyz, -v1.xyzx, cb11[r6.w + 0].xyzx
  dp3 r6.w, r11.xyzx, r11.xyzx
  sqrt r6.w, r6.w
  add r7.w, r6.w, l(0.000100)
  div r11.xyz, r11.xyzx, r7.wwww
  imad r7.w, r3.w, l(6), l(1)
  dp3 r8.w, -cb11[r7.w + 0].xyzx, r11.xyzx
  add r7.w, r8.w, -cb11[r7.w + 0].w
  imad r12.xyzw, r3.wwww, l(6, 6, 6, 6), l(2, 3, 4, 5)
  mul_sat r7.w, r7.w, cb11[r12.x + 0].w
  log r7.w, r7.w
  mul r7.w, r7.w, cb11[r12.y + 0].w
  exp r7.w, r7.w
  mad r8.w, r6.w, cb10[2].x, -cb11[r12.z + 0].x
  max r5.y, r8.w, l(0.000000)
  mul r5.z, r5.y, r5.y
  dp3 r5.y, cb11[r12.z + 0].yzwy, r5.xyzx
  add r5.y, r5.y, l(0.000100)
  div r5.y, l(1.000000, 1.000000, 1.000000, 1.000000), r5.y
  mov_sat r5.y, r5.y
  mad r5.z, r6.w, cb10[2].x, -cb11[r12.w + 0].x
  mul_sat r5.z, r5.z, cb11[r12.w + 0].y
  add r5.z, -r5.z, l(1.000000)
  mul r5.y, r5.z, r5.y
  mul r5.y, r7.w, r5.y
  add r13.xyz, r0.xyzx, r11.xyzx
  dp3 r5.z, r13.xyzx, r13.xyzx
  rsq r5.z, r5.z
  mul r13.xyz, r5.zzzz, r13.xyzx
  dp3 r5.z, r3.zxyz, r11.xyzx
  dp3 r6.w, r3.zxyz, r13.xyzx
  ge r7.w, r5.z, l(0.000000)
  max r5.z, r5.z, l(0.000000)
  ge r8.w, r6.w, l(0.000000)
  and r7.w, r7.w, r8.w
  log r6.w, r6.w
  mul r6.w, r6.w, cb9[4].w
  exp r6.w, r6.w
  and r6.w, r6.w, r7.w
  min r6.w, r6.w, l(1.000000)
  mul r11.xyz, cb10[3].xyzx, cb11[r12.x + 0].xyzx
  mul r11.xyz, r5.zzzz, r11.xyzx
  mul r11.xyz, r5.yyyy, r11.xyzx
  mad r8.xyz, r11.xyzx, l(0.500000, 0.500000, 0.500000, 0.000000), r8.xyzx
  mad r9.xyz, cb11[r12.y + 0].xyzx, r5.yyyy, r9.xyzx
  mul r11.xyz, cb5[7].xyzx, cb11[r12.x + 0].xyzx
  mul r11.xyz, r6.wwww, r11.xyzx
  mad r10.xyz, r11.xyzx, r5.yyyy, r10.xyzx
  iadd r3.w, r3.w, l(1)
endloop 
add r0.xyz, -r1.yzwy, cb9[0].xyzx
mad r0.xyz, r0.wwww, r0.xyzx, r1.yzwy
mad r1.xyz, r0.xyzx, r5.wwww, -r0.xyzx
mad r1.xyz, r4.xxxx, r1.xyzx, r0.xyzx
add r0.w, -r0.w, l(1.000000)
mul r0.w, r0.w, r4.x
mul r2.xyz, r2.xyzx, r0.wwww
add r0.w, -r5.w, l(1.000000)
mul r0.xyz, r0.xyzx, r0.wwww
mul r0.xyz, r0.xyzx, r4.xxxx
mul r4.yzw, r4.xxxx, r9.xxyz
mul r5.xyz, r4.xxxx, r10.xyzx
mad r4.yzw, r8.xxyz, r4.xxxx, r4.yyzw
add r6.xyz, -v8.xyzx, cb6[9].xyzx
dp3 r0.w, r6.xyzx, r6.xyzx
sqrt r0.w, r0.w
if_nz v9.x
  mul r1.w, r0.w, -cb5[12].w
  mul r1.w, r1.w, l(1.442695)
  exp r1.w, r1.w
  min r1.w, r1.w, l(1.000000)
  add r2.w, -r0.w, cb5[12].x
  mul_sat r2.w, r2.w, cb5[12].y
  mul r3.x, r1.w, r2.w
  mad r1.w, -r1.w, r2.w, l(1.000000)
  add r6.xyz, v8.xyzx, -cb6[9].xyzx
  dp3 r2.w, r6.xyzx, r6.xyzx
  rsq r2.w, r2.w
  mul r3.w, r2.w, r6.y
  lt r5.w, r3.w, l(0.000000)
  mad r2.w, r6.y, r2.w, l(1.000000)
  mul r2.w, r2.w, r2.w
  add r6.xy, -cb0[17].xyxx, cb0[17].yzyy
  mad r2.w, r2.w, r6.x, cb0[17].x
  mad r3.w, r3.w, r6.y, cb0[17].y
  movc r2.w, r5.w, r2.w, r3.w
  mul r6.xyz, r2.wwww, cb0[7].xyzx
  mov r2.w, l(0)
else 
  add r3.w, v8.y, -cb6[9].y
  add r5.w, r0.w, l(0.000010)
  div r6.w, |r3.w|, r5.w
  mul r6.w, r6.w, cb5[10].x
  eq r7.x, r6.w, l(0.000000)
  mul r7.y, r0.w, -r6.w
  mul r7.y, r7.y, l(1.442695)
  exp r7.y, r7.y
  add r7.y, -r7.y, l(1.000000)
  div r6.w, r7.y, r6.w
  movc r6.w, r7.x, r0.w, r6.w
  min r7.x, v8.y, cb6[9].y
  mul r7.x, r7.x, -cb5[10].x
  mul r7.x, r7.x, l(1.442695)
  exp r7.x, r7.x
  mul r7.x, r7.x, -cb5[10].y
  mul r6.w, r6.w, r7.x
  mul r6.w, r6.w, l(1.442695)
  exp r6.w, r6.w
  min r6.w, r6.w, l(1.000000)
  div r3.w, r3.w, r5.w
  mul r3.w, r3.w, cb0[14].z
  eq r5.w, r3.w, l(0.000000)
  mul r7.x, r0.w, -r3.w
  mul r7.x, r7.x, l(1.442695)
  exp r7.x, r7.x
  add r7.x, -r7.x, l(1.000000)
  div r3.w, r7.x, r3.w
  movc r3.w, r5.w, r0.w, r3.w
  add r5.w, -cb0[14].x, cb6[9].y
  mul r5.w, r5.w, -cb0[14].z
  mul r5.w, r5.w, l(1.442695)
  exp r5.w, r5.w
  mul r5.w, r5.w, -cb0[14].y
  mul r3.w, r3.w, r5.w
  mul r3.w, r3.w, l(1.442695)
  exp r3.w, r3.w
  min r3.w, r3.w, l(1.000000)
  mul r3.w, r3.w, r6.w
  add r0.w, -r0.w, cb5[12].x
  mul_sat r0.w, r0.w, cb5[12].y
  mul r3.x, r0.w, r3.w
  mad r2.w, -r3.w, r0.w, l(1.000000)
  mov r6.xyz, cb0[7].xyzx
  mov r1.w, l(0)
endif 
mad r3.yz, r3.zzyz, l(0.000000, 0.005000, 0.005000, 0.000000), v7.xxyx
add r0.w, v7.w, -cb6[2].w
div_sat r0.w, r0.w, cb6[2].w
sample_c_lz_indexable(texture2d)(float,float,float,float) r3.y, r3.yzyy, t15.xxxx, s15, v7.z
add r3.z, -r0.w, l(1.000000)
mad r0.w, r3.y, r3.z, r0.w
add r0.w, r0.w, l(-1.000000)
mad r0.w, cb6[2].x, r0.w, l(1.000000)
max r3.y, r4.x, cb5[0].w
max r3.z, l(0.000000), cb5[12].z
mul r7.xyz, -r3.zzzz, cb0[15].xyzx
mul r7.xyz, r7.xyzx, l(1.442695, 1.442695, 1.442695, 0.000000)
exp r7.xyz, r7.xyzx
mul r8.xyz, -r3.zzzz, cb0[16].xyzx
mul r8.xyz, r8.xyzx, l(1.442695, 1.442695, 1.442695, 0.000000)
exp r8.xyz, r8.xyzx
mul r1.xyz, r1.xyzx, r8.xyzx
mul r2.xyz, r2.xyzx, r8.xyzx
mad r0.xyz, r0.xyzx, r7.xyzx, r5.xyzx
add r0.w, -r0.w, l(1.000000)
mad_sat r0.w, -r0.w, cb9[35].w, l(1.000000)
mad r1.xyz, r1.xyzx, r0.wwww, r4.yzwy
mad r0.xyz, r2.xyzx, r0.wwww, r0.xyzx
mad r0.xyz, r1.xyzx, r3.yyyy, r0.xyzx
mul r1.xyz, r3.yyyy, cb0[1].xyzx
mul r2.xyz, r3.yyyy, r6.xyzx
mul r2.xyz, r1.wwww, r2.xyzx
mad r1.xyz, r1.xyzx, r2.wwww, r2.xyzx
mad o0.xyz, r0.xyzx, r3.xxxx, r1.xyzx
mov o0.w, r3.y
ret 
// Approximately 0 instruction slots used

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