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

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

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

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


Texture2D<float4> StereoParams : register(t125);
Texture1D<float4> IniParams : register(t120);

void main(
  float4 v0 : SV_POSITION0,
  float2 v1 : TEXCOORD0,
  float3 v2 : NORMAL0,
  out float4 o0 : SV_POSITION0,
  out float4 o1 : COLOR0,
  out float3 o2 : TEXCOORD0,
  out float4 o3 : TEXCOORD1)
{
  float4 r0,r1,r2,r3;
  uint4 bitmask, uiDest;
  float4 fDest;

  r0.w = -cb2[24].x + cb0[0].w;
  r0.xyz = cb0[0].xyz;
  r1.xyz = v0.xyz;
  r1.w = 1.000000000e+000;
  r0.x = dot(r1.xyzw, r0.xyzw);
  r2.w = -cb2[24].y + cb0[1].w;
  r2.xyz = cb0[1].xyz;
  r0.y = dot(r1.xyzw, r2.xyzw);
  r2.w = -cb2[24].z + cb0[2].w;
  r2.xyz = cb0[2].xyz;
  r0.z = dot(r1.xyzw, r2.xyzw);
  r0.w = dot(r1.xyzw, cb0[3].xyzw);
  r1.z = dot(r0.xyzw, cb1[2].xyzw);
  r1.w = dot(r0.xyzw, cb1[3].xyzw);
  r2.x = -cb3[1].x + r1.w;
  r2.y = r2.x < r1.z;
  r2.w = r2.y ? r1.z : r2.x;
  r2.z = r2.w / r1.w;
  r1.x = dot(r0.xyzw, cb1[0].xyzw);
  r1.y = dot(r0.xyzw, cb1[1].xyzw);
  r2.xy = r1.xy * r2.zz;
  r0.w = r1.z < r1.w;
  r2.xyz = r0.www ? r2.xyw : r1.xyw;
  o0.xyw = r2.xyz;
  r0.w = cb3[0].x * r2.z;
  
  float4 stereoParams = StereoParams.Load(0);
  float4  r24 = r1;  
  r1.x += stereoParams.x * (r1.w - stereoParams.y);
  o0.xyzw = r24.xyzw;
  
  //o0.z = r1.z;
  r2.x = dot(r0.xyz, r0.xyz);
  r2.x = rsqrt(r2.x);
  r0.xyz = r2.xxx * r0.xyz;
  r2.xyz = v2.xyz * float3(2.000000e+000,2.000000e+000,2.000000e+000) + float3(-1.000000e+000,-1.000000e+000,-1.000000e+000);
  r2.w = dot(r2.xyz, r2.xyz);
  r2.w = rsqrt(r2.w);
  r2.xyz = r2.xyz * r2.www;
  r3.x = dot(r2.xyz, cb0[0].xyz);
  r3.y = dot(r2.xyz, cb0[1].xyz);
  r3.z = dot(r2.xyz, cb0[2].xyz);
  r2.x = dot(r3.xyz, r3.xyz);
  r2.x = rsqrt(r2.x);
  r2.xyz = r3.xyz * r2.xxx;
  r0.x = dot(r0.xyz, r2.xyz);
  r0.x = r0.x * r0.x;
  r0.x = saturate(r0.x * cb3[2].z + cb3[2].w);
  r2.xyz = -cb3[4].xyz + cb3[3].xyz;
  r2.xyz = r0.xxx * r2.xyz + cb3[4].xyz;
  o1.xyz = r2.xyz * r0.xxx;
  r0.y = saturate(r0.w);
  o2.z = r0.w;
  o1.w = r0.y * r0.x;
  o2.xy = v1.xy;
  r0.xyzw = cb2[21].xyzw * r1.wwww;
  o3.xyzw = r1.xyzw * cb2[20].xyzw + r0.xyzw;
  //o3 = 0;
  return;
}

/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
//
// Generated by Microsoft (R) D3D Shader Disassembler
//
//   using 3Dmigoto v1.1.17 on Thu Jun 11 09:12:10 2015
//
//
// Input signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0     NONE   float   xyz 
// TEXCOORD                 0   xy          1     NONE   float   xy  
// NORMAL                   0   xyz         2     NONE   float   xyz 
//
//
// Output signature:
//
// Name                 Index   Mask Register SysValue  Format   Used
// -------------------- ----- ------ -------- -------- ------- ------
// SV_POSITION              0   xyzw        0      POS   float   xyzw
// COLOR                    0   xyzw        1     NONE   float   xyzw
// TEXCOORD                 0   xyz         2     NONE   float   xyz 
// TEXCOORD                 1   xyzw        3     NONE   float   xyzw
//
vs_5_0
dcl_globalFlags refactoringAllowed
dcl_constantbuffer cb0[4], immediateIndexed
dcl_constantbuffer cb1[4], immediateIndexed
dcl_constantbuffer cb2[25], immediateIndexed
dcl_constantbuffer cb3[5], immediateIndexed
dcl_input v0.xyz
dcl_input v1.xy
dcl_input v2.xyz
dcl_output_siv o0.xyzw, position
dcl_output o1.xyzw
dcl_output o2.xyz
dcl_output o3.xyzw
dcl_temps 4
add r0.w, cb0[0].w, -cb2[24].x
mov r0.xyz, cb0[0].xyzx
mov r1.xyz, v0.xyzx
mov r1.w, l(1.000000)
dp4 r0.x, r1.xyzw, r0.xyzw
add r2.w, cb0[1].w, -cb2[24].y
mov r2.xyz, cb0[1].xyzx
dp4 r0.y, r1.xyzw, r2.xyzw
add r2.w, cb0[2].w, -cb2[24].z
mov r2.xyz, cb0[2].xyzx
dp4 r0.z, r1.xyzw, r2.xyzw
dp4 r0.w, r1.xyzw, cb0[3].xyzw
dp4 r1.z, r0.xyzw, cb1[2].xyzw
dp4 r1.w, r0.xyzw, cb1[3].xyzw
add r2.x, r1.w, -cb3[1].x
lt r2.y, r2.x, r1.z
movc r2.w, r2.y, r1.z, r2.x
div r2.z, r2.w, r1.w
dp4 r1.x, r0.xyzw, cb1[0].xyzw
dp4 r1.y, r0.xyzw, cb1[1].xyzw
mul r2.xy, r2.zzzz, r1.xyxx
lt r0.w, r1.z, r1.w
movc r2.xyz, r0.wwww, r2.xywx, r1.xywx
mov o0.xyw, r2.xyxz
mul r0.w, r2.z, cb3[0].x
mov o0.z, r1.z
dp3 r2.x, r0.xyzx, r0.xyzx
rsq r2.x, r2.x
mul r0.xyz, r0.xyzx, r2.xxxx
mad r2.xyz, v2.xyzx, l(2.000000, 2.000000, 2.000000, 0.000000), l(-1.000000, -1.000000, -1.000000, 0.000000)
dp3 r2.w, r2.xyzx, r2.xyzx
rsq r2.w, r2.w
mul r2.xyz, r2.wwww, r2.xyzx
dp3 r3.x, r2.xyzx, cb0[0].xyzx
dp3 r3.y, r2.xyzx, cb0[1].xyzx
dp3 r3.z, r2.xyzx, cb0[2].xyzx
dp3 r2.x, r3.xyzx, r3.xyzx
rsq r2.x, r2.x
mul r2.xyz, r2.xxxx, r3.xyzx
dp3 r0.x, r0.xyzx, r2.xyzx
mul r0.x, r0.x, r0.x
mad_sat r0.x, r0.x, cb3[2].z, cb3[2].w
add r2.xyz, cb3[3].xyzx, -cb3[4].xyzx
mad r2.xyz, r0.xxxx, r2.xyzx, cb3[4].xyzx
mul o1.xyz, r0.xxxx, r2.xyzx
mov_sat r0.y, r0.w
mov o2.z, r0.w
mul o1.w, r0.x, r0.y
mov o2.xy, v1.xyxx
mul r0.xyzw, r1.wwww, cb2[21].xyzw
mad o3.xyzw, r1.xyzw, cb2[20].xyzw, r0.xyzw
ret 
// Approximately 0 instruction slots used

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