<HTML> <BODY BGCOLOR=#ccccdd LINK=#0000aa VLINK=#0000ff ALINK=#ff0000 ><BASE TARGET="bottom_target"><PRE>
<A NAME='DA_TRANSFER_XATOKMA'><A href='../../html_code/transfer_model/da_transfer_xatokma.inc.html#DA_TRANSFER_XATOKMA' TARGET='top_target'><IMG SRC="../../gif/bar_red.gif" border=0></A>

subroutine da_transfer_xatokma(grid) 1,3

   !---------------------------------------------------------------------------
   !  Purpose: Convert analysis increments into KMA increments 
   !---------------------------------------------------------------------------

   implicit none
   
   type(domain),    intent(inout) :: grid

   integer :: i, j, k
   real    :: PU, PD, coeff

   if (trace_use) call da_trace_entry("da_transfer_xatokma")

   !---------------------------------------------------------------------------
   ! Add increment to the original guess and update xb and "grid"
   !---------------------------------------------------------------------------

   do j=jts,jte
      do i=its,ite
         grid%xb%w(i,j,kte+1)=  grid%xb%w(i,j,kte+1) + grid%xa%w(i,j,kte+1)
      end do
      do i=its,ite
         do k = kts, kte
            grid%xb%u(i,j,k)   = grid%xa%u(i,j,k) + grid%xb%u(i,j,k)
            grid%xb%v(i,j,k)   = grid%xa%v(i,j,k) + grid%xb%v(i,j,k)
            grid%xb%t(i,j,k)   = grid%xa%t(i,j,k) + grid%xb%t(i,j,k)
            grid%xb%w(i,j,k)   = grid%xa%w(i,j,k) + grid%xb%w(i,j,k)
            grid%xb%q(i,j,k)   = grid%xa%q(i,j,k) + grid%xb%q(i,j,k)
            ! compute pressure increments at KMA full levels
            ! Note: Psfc its in hPa in  P = A + B * Psfc 
            if (k == kte) then
               coeff = grid%xb%KMA_B(K)/ &amp;
                  (grid%xb%KMA_A(K)+grid%xb%KMA_B(K)*grid%xb%psfc(I,J)/100.0)
            else
               PU = grid%xb%KMA_A(K+1) + &amp;
                  grid%xb%KMA_B(K+1)*grid%xb%psfc(I,J)/100.0
               PD = grid%xb%KMA_A(K ) + &amp;
                  grid%xb%KMA_B(K )*grid%xb%psfc(I,J)/100.0
               coeff=grid%xb%KMA_B(K) * &amp;
                  1.0/(PD-PU)**2*(-PU*(LOG(PD)-LOG(PU))+PD-PU) &amp;
                  + grid%xb%KMA_B(K+1)* &amp;
                  1.0/(PD-PU)**2*(PD*(LOG(PD)-LOG(PU))-PD+PU)
            end if
            grid%xa%p(i,j,k) = grid%xa%psfc(i,j) * coeff
            grid%xa%p(i,j,k) = grid%xb%psfc(i,j)*grid%xa%psfc(i,j)
            grid%xb%p(i,j,k) = grid%xb%p(i,j,k) + grid%xa%p(I,J,k)
         end do
         grid%xb%psfc(i,j) = grid%xb%psfc(i,j) + grid%xa%psfc(i,j)
      end do
   end do

   if (write_increments) call da_write_kma_increments(grid)

   do j=jts,jte
      do i=its,ite
        grid%w_2(i,j,kte+1)=  grid%w_2(i,j,kte+1) + grid%xa%w(i,j,kte+1)
        grid%psfc(i,j) = grid%psfc(i,j) + grid%xa%psfc(i,j)
      end do
   end do

   do k=kts,kte
      do j=jts,jte
         do i=its,ite
            grid%u_2(i,j,k) = grid%u_2(i,j,k) + grid%xa%u(i,j,k)
            grid%v_2(i,j,k) = grid%v_2(i,j,k) + grid%xa%v(i,j,k)
            grid%w_2(i,j,k) = grid%w_2(i,j,k) + grid%xa%w(i,j,k)
            grid%moist(i,j,k,P_QV) = grid%moist(i,j,k,P_QV) + grid%xa%q(i,j,k)
         end do
      end do
   end do

   if (trace_use) call da_trace_exit("da_transfer_xatokma")

end subroutine da_transfer_xatokma