//
// Generated by Microsoft (R) D3DX9 Shader Compiler 
//
// Parameters:
//
//   float4 Ambient;
//   sampler2D Texture2D_0;
//   sampler2D Texture2D_1;
//   sampler2D Texture2D_2;
//   float4 UniformVector_0;
//   float4 UniformVector_1;
//   float4 UniformVector_2;
//   float4 UniformVector_3;
//   float4 UniformVector_4;
//   float4 UniformVector_5;
//   float4 fogColor;
//   float globalOpacity;
//   
//   struct
//   {
//       float4 worldVector;
//       float4 color;
//       float4 channelMask;
//
//   } lights[3];
//   
//   float4 nvidiaHack;
//   sampler2D s_shadowMask;
//   float sceneDepthAlphaMask;
//   row_major float4x4 screenToWorld;
//
//
// Registers:
//
//   Name                Reg   Size
//   ------------------- ----- ----
//   lights              c0       9
//   screenToWorld       c9       4
//   fogColor            c13      1
//   sceneDepthAlphaMask c14      1
//   globalOpacity       c15      1
//   UniformVector_0     c16      1
//   UniformVector_1     c17      1
//   UniformVector_2     c18      1
//   UniformVector_3     c19      1
//   UniformVector_4     c20      1
//   UniformVector_5     c21      1
//   Ambient             c22      1
//   nvidiaHack          c31      1
//   Texture2D_0         s0       1
//   Texture2D_1         s1       1
//   Texture2D_2         s2       1
//   s_shadowMask        s3       1
//
//
// Default values:
//
//   lights
//     c0   = { 0, 0, 0, 0 };
//     c1   = { 0, 0, 0, 0 };
//     c2   = { 0, 0, 0, 0 };
//     c3   = { 0, 0, 0, 0 };
//     c4   = { 0, 0, 0, 0 };
//     c5   = { 0, 0, 0, 0 };
//     c6   = { 0, 0, 0, 0 };
//     c7   = { 0, 0, 0, 0 };
//     c8   = { 0, 0, 0, 0 };
//
//   screenToWorld
//     c9   = { 0, 0, 0, 0 };
//     c10  = { 0, 0, 0, 0 };
//     c11  = { 0, 0, 0, 0 };
//     c12  = { 0, 0, 0, 0 };
//
//   fogColor
//     c13  = { 0, 0, 0, 0 };
//
//   sceneDepthAlphaMask
//     c14  = { 0, 0, 0, 0 };
//
//   globalOpacity
//     c15  = { 0, 0, 0, 0 };
//
//   UniformVector_0
//     c16  = { 0, 0, 0, 0 };
//
//   UniformVector_1
//     c17  = { 0, 0, 0, 0 };
//
//   UniformVector_2
//     c18  = { 0, 0, 0, 0 };
//
//   UniformVector_3
//     c19  = { 0, 0, 0, 0 };
//
//   UniformVector_4
//     c20  = { 0, 0, 0, 0 };
//
//   UniformVector_5
//     c21  = { 0, 0, 0, 0 };
//
//   Ambient
//     c22  = { 0, 0, 0, 0 };
//
//   nvidiaHack
//     c31  = { 0, 0, 0, 0 };
//

    ps_3_0
    def c23, 0.100000001, 0.300000012, 0.200000003, 0.5
    def c24, 1, 3, 4, 10
    def c25, 0.200000003, -0.0500000007, 0.5, 1.5
    def c26, 0, 1, 0, 0
    def c27, 0.200000003, -0.200000003, -0.524999976, -1.02499998
  dcl_texcoord8 v9.x
    dcl_texcoord6 v0
    dcl_texcoord7 v1
    dcl_texcoord3_pp v2.w
    dcl_texcoord4_pp v3.w
    dcl_texcoord5_pp v4
    dcl_texcoord1 v5.xy
    dcl_2d s0
    dcl_2d s1
    dcl_2d s2
    dcl_2d s3
    texldp_pp r0, v0, s3
    dp4_sat_pp r1.x, r0, c5
    add_pp r1.x, -r1.x, c24.x
    mul_sat_pp r1.x, r1.x, v4.w
    mul_pp r1.xyz, r1.x, c4
    mul r2.xyz, c10, v0.y
    mad r2.xyz, v9.x, c9, r2
    mad r2.xyz, v0.w, c11, r2
    add r2.xyz, r2, c12
    mad r3.xyz, r2, -c3.w, c3
    nrm_pp r4.xyz, r3
    nrm_pp r3.xyz, v4
    dp3_sat_pp r1.w, r4, r3
    mul_pp r1.xyz, r1, r1.w
    dp4_sat_pp r1.w, r0, c2
    dp4_sat_pp r0.x, r0, c8
    add_pp r0.y, -r1.w, c24.x
    mul_sat_pp r0.y, r0.y, v3.w
    mul_pp r0.yzw, r0.y, c1.xxyz
    mad r4.xyz, r2, -c0.w, c0
    mad r2.xyz, r2, -c6.w, c6
    nrm_pp r5.xyz, r4
    dp3_sat_pp r1.w, r5, r3
    mad_pp r0.yzw, r1.w, r0, r1.xxyz
    add_pp r0.x, -r0.x, c24.x
    mul_sat_pp r0.x, r0.x, v2.w
    mul_pp r1.xyz, r0.x, c7
    nrm_pp r4.xyz, r2
    dp3_sat_pp r0.x, r4, r3
    mad_pp r0.xyz, r0.x, r1, r0.yzww
    mul r1, c24, v5.xyxy
    nrm r2.xyz, v1
    mad r1, r2.xyxy, c27.zzww, r1
    max r0.w, r2.z, c26.x
    add r1, r1, c20.xyxy
    add r1.zw, r1, c21.xyxy
    mov r2, c23
    mad r2.zw, v5.xyxy, r2, c19.xyxy
    mad r2.xy, v5, r2, c18
    texld r3, r2, s0
    mad r2.xy, r3.y, c27, r2.zwzw
    texld r2, r2, s0
    add r2.x, r3.z, r2.z
    mov_sat r2.y, r2.x
    mad r1.zw, r2.y, c25.xyxy, r1
    texld r3, r1.zwzw, s1
    mad r1.xy, r2.y, c25, r1
    texld r1, r1, s1
    add r1.x, r3.y, r1.y
    mul r1.x, r2.x, r1.x
    mul r1.y, r2.y, c23.w
    mad r1.z, r2.y, -c25.z, c25.w
    mad_sat r1.x, r1.x, r1.z, r1.y
    mov r2.xyz, c16
    add r1.yzw, -r2.xxyz, c17.xxyz
    mad r1.xyz, r1.x, r1.yzww, c16
    add r0.w, -r0.w, c24.x
    pow r1.w, r0.w, c23.y
    mad r1.xyz, r1.w, -r1, r1
    texld r2, v5, s2
    lrp_pp r3.xyz, r2.w, r2, r1
    mul_pp r0.xyz, r0, r3
    mad_sat_pp r0.w, v4.z, c23.w, c23.w
    mul_pp r0.w, r0.w, r0.w
    mov r1.x, c24.x
    lrp_pp r2.x, r0.w, r1.x, c22.w
    mul_pp r1.xyz, r3, r2.x
    mad_pp r0.xyz, c22, r1, r0
    mad_pp r0.xyz, r3, c26.yxxw, r0
    add_pp r1.xyz, -r0, c13
    mad_pp oC0.xyz, v0.z, r1, r0
    mov_pp r0.x, c15.x
    mad_pp r0.x, r0.x, v1.w, c31.x
    add r0.y, -r0.x, v0.w
    mad_pp oC0.w, c14.x, r0.y, r0.x

// approximately 87 instruction slots used (6 texture, 81 arithmetic)
 

