6 #include "dimensions.h"
11 INTEGER jjmax,llmax,jjb,jje
12 REAL q(iip1,jjmax,llmax)
20 INTEGER i,j,l,ig,ig2,j1,j2,i0,jd
32 INTEGER j_start, j_finish
34 REAL,
SAVE :: airen_tab(iip1,
jjp1,0:1)
35 REAL,
SAVE :: aires_tab(iip1,
jjp1,0:1)
38 LOGICAL,
SAVE :: first = .
true.
40 INTEGER,
SAVE :: i_index(
iim,ngroup)
42 REAL :: qsum(
iim/ngroup)
58 j_start = max(jjb, j1-jd)
59 j_finish = min(jje, j2-jd)
62 DO j=j_start, j_finish
66 q(i0,j,l)=q(i0,j,l)+q(i0+offset,j,l)
71 DO j=j_start, j_finish
75 q(i,j,l)=q(i-mod(i-1,2**(ngroup-ig+1)),j,l)
79 DO j=j_start, j_finish
83 q(i,j,l)=q(i,j,l)*airen_tab(i,j,jd)
89 j_start = max(1+
jjp1-jje-jd, j1-jd)
90 j_finish = min(1+
jjp1-jjb-jd, j2-jd)
93 DO j=j_start, j_finish
97 q(i0,
jjp1-j+1-jd,l)= q(i0,
jjp1-j+1-jd,l)
98 & +q(i0+offset,
jjp1-j+1-jd,l)
104 DO j=j_start, j_finish
108 q(i,
jjp1-j+1-jd,l)=q(i-mod(i-1,2**(ngroup-ig+1)),
113 DO j=j_start, j_finish
117 q(i,
jjp1-j+1-jd,l)=q(i,
jjp1-j+1-jd,l)*
118 & aires_tab(i,
jjp1-j+1,jd)
120 q(iip1,
jjp1-j+1-jd,l)=q(1,
jjp1-j+1-jd,l)
140 #include "dimensions.h"
142 #include "comconst.h"
143 #include "comgeom2.h"
151 INTEGER i,j,l,ig,j1,j2,i0,jd
153 INTEGER j_start, j_finish
155 REAL :: airen_tab(iip1,
jjp1,0:1)
156 REAL :: aires_tab(iip1,
jjp1,0:1)
166 DO j=j_start, j_finish
167 DO i0=1,
iim,2**(ngroup-ig+1)
169 DO i=i0,i0+2**(ngroup-ig+1)-1
170 airen = airen+
aire(i,j)
172 DO i=i0,i0+2**(ngroup-ig+1)-1
182 DO j=j_start, j_finish
183 DO i0=1,
iim,2**(ngroup-ig+1)
185 DO i=i0,i0+2**(ngroup-ig+1)-1
188 DO i=i0,i0+2**(ngroup-ig+1)-1
189 aires_tab(i,
jjp1-j+1,jd) =
subroutine init_groupeun_p(airen_tab, aires_tab)
!$Id Turb_fcg_gcssold get_uvd hqturb_gcssold endif!large scale llm day day1 day day1 *dt_toga endif!time annee_ref dt_toga u_toga vq_toga w_prof vq_prof llm day day1 day day1 *dt_dice endif!time annee_ref dt_dice swup_dice vg_dice omega_dice tg_prof vg_profd w_profd omega_profd!do llm!print llm l llm
!$Header!CDK comgeom COMMON comgeom aire
!$Id itapm1 ENDIF!IM on interpole les champs sur les niveaux STD de pression!IM a chaque pas de temps de la physique c!positionnement de l argument logique a false c!pour ne pas recalculer deux fois la meme chose!c!a cet effet un appel a plevel_new a ete deplace c!a la fin de la serie d appels c!la boucle DO nlevSTD a ete internalisee c!dans d ou la creation de cette routine c c!CALL false
!$Header!integer nvarmx parameter(nfmx=10, imx=200, jmx=150, lmx=200, nvarmx=1000) real xd(imx
!$Id itapm1 ENDIF!IM on interpole les champs sur les niveaux STD de pression!IM a chaque pas de temps de la physique c!positionnement de l argument logique a false c!pour ne pas recalculer deux fois la meme chose!c!a cet effet un appel a plevel_new a ete deplace c!a la fin de la serie d appels c!la boucle DO nlevSTD a ete internalisee c!dans d ou la creation de cette routine c c!CALL ulevSTD CALL &zphi philevSTD CALL &zx_rh rhlevSTD!DO klev DO klon klev DO klon klev DO klon klev DO klon klev DO klon klev DO klon klev DO klon klev DO klon klev DO klon klev DO klon du jour ou toutes les read_climoz CALL true
c c zjulian c cym CALL iim cym klev iim
subroutine groupeun_p(jjmax, llmax, jjb, jje, q)