29 type(
qg_geom),
intent(in) :: geom
 
   30 real(kind_real),
intent(in) :: x(geom%nx,geom%ny,geom%nz)
 
   31 real(kind_real),
intent(in) :: x_north(geom%nz)
 
   32 real(kind_real),
intent(in) :: x_south(geom%nz)
 
   33 real(kind_real),
intent(inout) :: q(geom%nx,geom%ny,geom%nz)
 
   37 real(kind_real) :: del2x(geom%nx,geom%ny,geom%nz) 
 
   48       q(ix,iy,iz) = del2x(ix,iy,iz)+sum(geom%f(iz,:)*x(ix,iy,:))
 
   55 zz = 1.0 / (geom%deltay * geom%deltay)
 
   58   q(:,1,iz) = q(:,1,iz)+x_south(iz)*zz
 
   59   q(:,geom%ny,iz) = q(:,geom%ny,iz)+x_north(iz)*zz
 
   66   q(:,iy,:) = q(:,iy,:)+geom%bet(iy)
 
   67   q(:,iy,1) = q(:,iy,1)+geom%heat(:,iy)
 
   79 type(
qg_geom),
intent(in) :: geom
 
   80 real(kind_real),
intent(in) :: x(geom%nx,geom%ny,geom%nz)
 
   81 real(kind_real),
intent(inout) :: q(geom%nx,geom%ny,geom%nz)
 
   85 real(kind_real) :: del2x(geom%nx,geom%ny,geom%nz) 
 
   95       q(ix,iy,iz) = del2x(ix,iy,iz)+sum(geom%f(iz,:)*x(ix,iy,:))
 
  113 type(
qg_geom),
intent(in) :: geom
 
  114 real(kind_real),
intent(in) :: q(geom%nx,geom%ny,geom%nz)
 
  115 real(kind_real),
intent(inout) :: x(geom%nx,geom%ny,geom%nz)
 
  119 real(kind_real) :: del2x(geom%nx,geom%ny,geom%nz) 
 
  132       del2x(ix,iy,iz) = del2x(ix,iy,iz)+q(ix,iy,iz)
 
  133       x(ix,iy,iz) = x(ix,iy,iz)+sum(geom%f(:,iz)*q(ix,iy,:))
 
subroutine, public laplacian_2d_ad(geom, del2x, x)
Horizontal Laplacian operator - adjoint.
subroutine, public laplacian_2d(geom, x, del2x)
Horizontal Laplacian operator.
subroutine, public convert_x_to_q_tl(geom, x, q)
Convert streamfunction to potential vorticity - tangent linear.
subroutine, public convert_x_to_q(geom, x, x_north, x_south, q)
Convert streamfunction to potential vorticity.
subroutine, public convert_x_to_q_ad(geom, q, x)
Convert streamfunction to potential vorticity - adjoint.