//
// Generated by Microsoft (R) D3DX9 Shader Compiler 
//
// Parameters:
//
//   sampler2D Texture2D_0;
//   sampler2D Texture2D_2;
//   sampler2D Texture2D_3;
//   sampler2D Texture2D_4;
//   sampler2D Texture2D_5;
//   float UniformScalar_1;
//   float UniformScalar_2;
//   float UniformScalar_3;
//   float UniformScalar_5;
//   float4 UniformVector_0;
//   float4 UniformVector_1;
//   float4 UniformVector_3;
//   float4 fogColor;
//   float globalOpacity;
//   
//   struct
//   {
//       float4 worldVector;
//       float4 color;
//       float4 channelMask;
//
//   } lights;
//   
//   float4 nvidiaHack;
//   sampler2D s_shadowMask;
//   float sceneDepthAlphaMask;
//   row_major float4x4 screenToWorld;
//   float3 worldEyePos;
//
//
// Registers:
//
//   Name                Reg   Size
//   ------------------- ----- ----
//   screenToWorld       c0       4
//   lights              c4       3
//   fogColor            c7       1
//   sceneDepthAlphaMask c8       1
//   globalOpacity       c9       1
//   UniformVector_0     c10      1
//   UniformVector_1     c11      1
//   UniformVector_3     c12      1
//   UniformScalar_1     c13      1
//   UniformScalar_2     c14      1
//   UniformScalar_3     c15      1
//   UniformScalar_5     c16      1
//   worldEyePos         c17      1
//   nvidiaHack          c31      1
//   Texture2D_0         s0       1
//   Texture2D_2         s1       1
//   Texture2D_3         s2       1
//   Texture2D_4         s3       1
//   Texture2D_5         s4       1
//   s_shadowMask        s5       1
//
//
// Default values:
//
//   screenToWorld
//     c0   = { 0, 0, 0, 0 };
//     c1   = { 0, 0, 0, 0 };
//     c2   = { 0, 0, 0, 0 };
//     c3   = { 0, 0, 0, 0 };
//
//   lights
//     c4   = { 0, 0, 0, 0 };
//     c5   = { 0, 0, 0, 0 };
//     c6   = { 0, 0, 0, 0 };
//
//   fogColor
//     c7   = { 0, 0, 0, 0 };
//
//   sceneDepthAlphaMask
//     c8   = { 0, 0, 0, 0 };
//
//   globalOpacity
//     c9   = { 0, 0, 0, 0 };
//
//   UniformVector_0
//     c10  = { 0, 0, 0, 0 };
//
//   UniformVector_1
//     c11  = { 0, 0, 0, 0 };
//
//   UniformVector_3
//     c12  = { 0, 0, 0, 0 };
//
//   UniformScalar_1
//     c13  = { 0, 0, 0, 0 };
//
//   UniformScalar_2
//     c14  = { 0, 0, 0, 0 };
//
//   UniformScalar_3
//     c15  = { 0, 0, 0, 0 };
//
//   UniformScalar_5
//     c16  = { 0, 0, 0, 0 };
//
//   worldEyePos
//     c17  = { 0, 0, 0, 0 };
//
//   nvidiaHack
//     c31  = { 0, 0, 0, 0 };
//

    ps_3_0
    def c18, 2, -1, -0.699999988, 1
    def c19, -2, 3, 1.00000001e-007, 0
  dcl_texcoord8 v9.x
    dcl_texcoord6 v0
    dcl_texcoord7 v1
    dcl_texcoord3_pp v2.xyz
    dcl_texcoord4_pp v3
    dcl_texcoord5_pp v4.xyz
    dcl_texcoord1 v5.xy
    dcl_2d s0
    dcl_2d s1
    dcl_2d s2
    dcl_2d s3
    dcl_2d s4
    dcl_2d s5
    texld r0, v5, s2
    mad r0.y, r0.x, -c18.z, c18.w
    mul r0.x, r0.x, c18.z
    rcp r0.y, r0.y
    mul_sat r0.x, -r0.x, r0.y
    mad r0.y, r0.x, c19.x, c19.y
    mul r0.x, r0.x, r0.x
    mul r0.x, r0.y, r0.x
    mov r1.xyz, c10
    add r0.yzw, -r1.xxyz, c11.xxyz
    mad r0.yzw, r0.x, r0, c10.xxyz
    mul r0.xyz, r0.x, r0.yzww
    mul r1.xyz, r0, r0
    texld r2, v5, s1
    mul r3.xyz, r1, r2
    mul r2.xyz, r2, r2
    mul r1.xyz, r1, r2
    add r1.xyz, r1, r1
    mad r1.xyz, r3, c18.x, -r1
    mad_pp r1.xyz, r2, r0, r1
    texldp_pp r2, v0, s5
    dp4_sat_pp r0.w, r2, c6
    add_pp r0.w, -r0.w, c18.w
    mul_sat_pp r0.w, r0.w, v3.w
    mul_pp r2.xyz, r0.w, c5
    texld_pp r3, v5, s0
    mad_pp r3.xyz, r3.wyzw, c18.x, c18.y
    mul_pp r4.xyz, r3.y, v3
    mad_pp r4.xyz, r3.x, v2, r4
    mad_pp r4.xyz, r3.z, v4, r4
    nrm_pp r5.xyz, r4
    mul r4.xyz, c1, v0.y
    mad r4.xyz, v9.x, c0, r4
    mad r4.xyz, v0.w, c2, r4
    add r4.xyz, r4, c3
    mad r6.xyz, r4, -c4.w, c4
    add r4.xyz, -r4, c17
    nrm_pp r7.xyz, r6
    dp3_sat_pp r0.w, r7, r5
    nrm_pp r6.xyz, r5
    mul_pp r5.xyz, r2, r0.w
    mul_pp r1.xyz, r1, r5
    dp3 r0.w, r4, r4
    rsq r0.w, r0.w
    mad_pp r4.xyz, r4, r0.w, r7
    nrm_pp r5.xyz, r4
    dp3_sat_pp r0.w, r6, r5
    mov r4.z, c19.z
    add_pp r1.w, r4.z, c16.x
    pow_pp r2.w, r0.w, r1.w
    mul_pp r2.xyz, r2, r2.w
    mov r4.x, c15.x
    mul r4.xyz, r4.x, c12
    texld r5, v5, s3
    mul r4.xyz, r4, r5.y
    mul_pp r0.xyz, r0, r4
    mad_pp r0.xyz, r0, r2, r1
    nrm r1.xyz, v1
    dp3 r0.w, r3, r1
    add r0.w, -r0_abs.w, c18.w
    max r1.x, r0.w, c19.w
    pow r0.w, r1.x, c13.x
    mul r0.w, r0.w, c14.x
    mad_pp r0.xyz, r5.y, r0.w, r0
    add_pp r1.xyz, -r0, c7
    mad_pp oC0.xyz, v0.z, r1, r0
    texld_pp r0, v5, s4
    mul r0.y, c9.x, v1.w
    mad_pp r0.x, r0.x, r0.y, c31.x
    add r0.y, -r0.x, v0.w
    mad_pp oC0.w, c8.x, r0.y, r0.x

// approximately 85 instruction slots used (6 texture, 79 arithmetic)
 

