6 SUBROUTINE pack_grid_gauss(KMASK_SIZE,KMASK,KGRID_PAR1,PGRID_PAR1,KGRID_PAR2,OPACK,PGRID_PAR2)
47 INTEGER,
INTENT(IN) :: KMASK_SIZE
48 INTEGER,
DIMENSION(KMASK_SIZE),
INTENT(IN) :: KMASK
49 INTEGER,
INTENT(IN) :: KGRID_PAR1
50 REAL,
DIMENSION(KGRID_PAR1),
INTENT(IN) :: PGRID_PAR1
51 INTEGER,
INTENT(INOUT) :: KGRID_PAR2
52 LOGICAL,
INTENT(IN) :: OPACK
53 REAL,
DIMENSION(KGRID_PAR2),
INTENT(OUT) :: PGRID_PAR2
62 INTEGER,
DIMENSION(:),
ALLOCATABLE :: INLOPA
65 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLAT1
66 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLON1
67 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLAT2
68 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLON2
69 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLAT_XY1
70 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLON_XY1
71 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLAT_XY2
72 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLON_XY2
73 REAL,
DIMENSION(:),
ALLOCATABLE :: ZMESH_SIZE1
74 REAL,
DIMENSION(:),
ALLOCATABLE :: ZMESH_SIZE2
76 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLATSUP1
77 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLONSUP1
78 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLATINF1
79 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLONINF1
81 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLATSUP2
82 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLONSUP2
83 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLATINF2
84 REAL,
DIMENSION(:),
ALLOCATABLE :: ZLONINF2
88 REAL,
DIMENSION(:),
POINTER :: ZGRID_PAR2
89 REAL(KIND=JPRB) :: ZHOOK_HANDLE
92 IF (
lhook)
CALL dr_hook(
'PACK_GRID_GAUSS',0,zhook_handle)
99 ALLOCATE(inlopa(inlati))
100 ALLOCATE(zlat_xy1(il))
101 ALLOCATE(zlon_xy1(il))
104 ALLOCATE(zmesh_size1(il))
105 ALLOCATE(zloninf1(il))
106 ALLOCATE(zlatinf1(il))
107 ALLOCATE(zlonsup1(il))
108 ALLOCATE(zlatsup1(il))
111 il,zlat1,zlon1,zlat_xy1,zlon_xy1,zmesh_size1 , &
112 zloninf1,zlatinf1,zlonsup1,zlatsup1 )
120 ALLOCATE(zlat_xy2(kmask_size))
121 ALLOCATE(zlon_xy2(kmask_size))
122 ALLOCATE(zlat2(kmask_size))
123 ALLOCATE(zlon2(kmask_size))
124 ALLOCATE(zmesh_size2(kmask_size))
125 ALLOCATE(zloninf2(kmask_size))
126 ALLOCATE(zlatinf2(kmask_size))
127 ALLOCATE(zlonsup2(kmask_size))
128 ALLOCATE(zlatsup2(kmask_size))
140 DEALLOCATE(zlat_xy1 )
141 DEALLOCATE(zlon_xy1 )
144 DEALLOCATE(zmesh_size1)
145 DEALLOCATE(zloninf1 )
146 DEALLOCATE(zlatinf1 )
147 DEALLOCATE(zlonsup1 )
148 DEALLOCATE(zlatsup1 )
156 kmask_size,zlat2,zlon2,zlat_xy2,zlon_xy2, &
157 zmesh_size2,zloninf2,zlatinf2,zlonsup2,zlatsup2 )
159 DEALLOCATE(zlat_xy2 )
160 DEALLOCATE(zlon_xy2 )
163 DEALLOCATE(zmesh_size2)
164 DEALLOCATE(zloninf2 )
165 DEALLOCATE(zlatinf2 )
166 DEALLOCATE(zlonsup2 )
167 DEALLOCATE(zlatsup2 )
172 pgrid_par2(:) = zgrid_par2(:)
174 kgrid_par2 =
SIZE(zgrid_par2(:))
177 DEALLOCATE(zgrid_par2)
179 IF (
lhook)
CALL dr_hook(
'PACK_GRID_GAUSS',1,zhook_handle)
subroutine get_gridtype_gauss(PGRID_PAR, KNLATI, PLAPO, PLOPO, PCODIL, KNLOPA, KL, PLAT, PLON, PLAT_XY, PLON_XY, PMESH_SIZE, PLONINF, PLATINF, PLONSUP, PLATSUP)
subroutine put_gridtype_gauss(PGRID_PAR, KNLATI, PLAPO, PLOPO, PCODIL, KNLOPA, KL, PLAT, PLON, PLAT_XY, PLON_XY, PMESH_SIZE, PLONINF, PLATINF, PLONSUP, PLATSUP)
subroutine pack_grid_gauss(KMASK_SIZE, KMASK, KGRID_PAR1, PGRID_PAR1, KGRID_PAR2, OPACK, PGRID_PAR2)