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.