[3927] | 1 | SUBROUTINE cv3a_uncompress(nloc, len, ncum, nd, ntra, idcum, compress, & |
---|
| 2 | iflag, kbas, ktop, & |
---|
| 3 | precip, cbmf, plcl, plfc, wbeff, sig, w0, ptop2, & |
---|
| 4 | ft, fq, fu, fv, ftra, & |
---|
| 5 | sigd, ma, mip, vprecip, vprecipi, upwd, dnwd, dnwd0, & |
---|
| 6 | qcondc, wd, cape, cin, & |
---|
| 7 | tvp, & |
---|
| 8 | ftd, fqd, & |
---|
| 9 | plim1, plim2, asupmax, supmax0, & |
---|
| 10 | asupmaxmin, & |
---|
| 11 | da, phi, mp, phi2, d1a, dam, sigij, & ! RomP+AC+jyg |
---|
| 12 | qta, clw, elij, evap, ep, epmlmMm, eplaMm, & ! RomP+jyg |
---|
| 13 | wdtrainA, wdtrainS, wdtrainM, & ! RomP |
---|
| 14 | qtc, sigt, & |
---|
| 15 | epmax_diag, & ! epmax_cape |
---|
| 16 | iflag1, kbas1, ktop1, & |
---|
| 17 | precip1, cbmf1, plcl1, plfc1, wbeff1, sig1, w01, ptop21, & |
---|
| 18 | ft1, fq1, fu1, fv1, ftra1, & |
---|
| 19 | sigd1, ma1, mip1, vprecip1, vprecipi1, upwd1, dnwd1, dnwd01, & |
---|
| 20 | qcondc1, wd1, cape1, cin1, & |
---|
| 21 | tvp1, & |
---|
| 22 | ftd1, fqd1, & |
---|
| 23 | plim11, plim21, asupmax1, supmax01, & |
---|
| 24 | asupmaxmin1, & |
---|
| 25 | da1, phi1, mp1, phi21, d1a1, dam1, sigij1, & ! RomP+AC+jyg |
---|
| 26 | qta1, clw1, elij1, evap1, ep1, epmlmMm1, eplaMm1, & ! RomP+jyg |
---|
| 27 | wdtrainA1, wdtrainS1, wdtrainM1, & ! RomP |
---|
| 28 | qtc1, sigt1, & |
---|
| 29 | epmax_diag1 & ! epmax_cape |
---|
| 30 | #ifdef ISO |
---|
| 31 | & ,xtprecip,fxt,fxtd, xtvprecip,xtvprecipi, xtclw,xtevap,xtwdtraina & |
---|
| 32 | & ,xtprecip1,fxt1,fxtd1, xtvprecip1, xtvprecipi1, xtclw1,xtevap1,xtwdtraina1 & |
---|
| 33 | #ifdef DIAGISO |
---|
| 34 | & , water,xtwater,qp,xtp & |
---|
| 35 | & , fq_detrainement,fq_ddft,fq_fluxmasse,fq_evapprecip & |
---|
| 36 | & , fxt_detrainement,fxt_ddft,fxt_fluxmasse, fxt_evapprecip & |
---|
| 37 | & , f_detrainement,q_detrainement,xt_detrainement & |
---|
| 38 | & , water1,xtwater1,qp1,xtp1 & |
---|
| 39 | & , fq_detrainement1,fq_ddft1,fq_fluxmasse1,fq_evapprecip1 & |
---|
| 40 | & , fxt_detrainement1,fxt_ddft1,fxt_fluxmasse1, fxt_evapprecip1 & |
---|
| 41 | & , f_detrainement1,q_detrainement1,xt_detrainement1 & |
---|
| 42 | #endif |
---|
| 43 | #endif |
---|
| 44 | & ) |
---|
| 45 | |
---|
| 46 | ! ************************************************************** |
---|
| 47 | ! * |
---|
| 48 | ! CV3A_UNCOMPRESS * |
---|
| 49 | ! * |
---|
| 50 | ! * |
---|
| 51 | ! written by : Sandrine Bony-Lena , 17/05/2003, 11.22.15 * |
---|
| 52 | ! modified by : Jean-Yves Grandpeix, 23/06/2003, 10.36.17 * |
---|
| 53 | ! ************************************************************** |
---|
| 54 | |
---|
| 55 | #ifdef ISO |
---|
| 56 | USE infotrac_phy, ONLY : ntraciso |
---|
| 57 | #endif |
---|
| 58 | IMPLICIT NONE |
---|
| 59 | |
---|
| 60 | include "cv3param.h" |
---|
| 61 | |
---|
| 62 | ! inputs: |
---|
| 63 | INTEGER, INTENT (IN) :: nloc, len, ncum, nd, ntra |
---|
| 64 | INTEGER, DIMENSION (nloc), INTENT (IN) :: idcum(nloc) |
---|
| 65 | !jyg< |
---|
| 66 | LOGICAL, INTENT (IN) :: compress |
---|
| 67 | !>jyg |
---|
| 68 | INTEGER, DIMENSION (nloc), INTENT (IN) ::iflag, kbas, ktop |
---|
| 69 | REAL, DIMENSION (nloc), INTENT (IN) :: precip, cbmf, plcl, plfc |
---|
| 70 | REAL, DIMENSION (nloc), INTENT (IN) :: wbeff |
---|
| 71 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: sig, w0 |
---|
| 72 | REAL, DIMENSION (nloc), INTENT (IN) :: ptop2 |
---|
| 73 | REAL, DIMENSION (nloc), INTENT (IN) :: epmax_diag |
---|
| 74 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: ft, fq, fu, fv |
---|
| 75 | REAL, DIMENSION (nloc, nd, ntra), INTENT (IN) :: ftra |
---|
| 76 | REAL, DIMENSION (nloc), INTENT (IN) :: sigd |
---|
| 77 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: ma, mip |
---|
| 78 | REAL, DIMENSION (nloc, nd+1), INTENT (IN) :: vprecip |
---|
| 79 | REAL, DIMENSION (nloc, nd+1), INTENT (IN) :: vprecipi |
---|
| 80 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: upwd, dnwd, dnwd0 |
---|
| 81 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: qcondc |
---|
| 82 | REAL, DIMENSION (nloc), INTENT (IN) :: wd, cape, cin |
---|
| 83 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: tvp |
---|
| 84 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: ftd, fqd |
---|
| 85 | REAL, DIMENSION (nloc), INTENT (IN) :: plim1, plim2 |
---|
| 86 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: asupmax |
---|
| 87 | REAL, DIMENSION (nloc), INTENT (IN) :: supmax0, asupmaxmin |
---|
| 88 | |
---|
| 89 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: da |
---|
| 90 | REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: phi !AC! |
---|
| 91 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: mp !RomP |
---|
| 92 | REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: phi2 !RomP |
---|
| 93 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: d1a, dam !RomP |
---|
| 94 | REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: sigij !RomP |
---|
| 95 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: qta !jyg |
---|
| 96 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: clw !RomP |
---|
| 97 | REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: elij !RomP |
---|
| 98 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: evap, ep !RomP |
---|
| 99 | REAL, DIMENSION (nloc, nd, nd), INTENT (IN) :: epmlmMm !RomP+jyg |
---|
| 100 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: eplamM !RomP+jyg |
---|
| 101 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: qtc, sigt !RomP |
---|
| 102 | REAL, DIMENSION (nloc, nd), INTENT (IN) :: wdtrainA, wdtrainS, wdtrainM !RomP |
---|
| 103 | |
---|
| 104 | #ifdef ISO |
---|
| 105 | real, DIMENSION (ntraciso,nloc), INTENT (IN) :: xtprecip |
---|
| 106 | real, DIMENSION (ntraciso,nloc,nd), INTENT (IN) :: fxt |
---|
| 107 | real, DIMENSION(ntraciso,nloc,nd), INTENT (IN) :: fxtd |
---|
| 108 | real, DIMENSION(ntraciso,nloc,nd+1), INTENT (IN) :: xtvprecip |
---|
| 109 | real, DIMENSION(ntraciso,nloc,nd+1), INTENT (IN) :: xtvprecipi |
---|
| 110 | real xtevap(ntraciso,nloc,nd) |
---|
| 111 | real xtwdtraina(ntraciso,nloc,nd) |
---|
| 112 | real xtclw(ntraciso,nloc,nd) |
---|
| 113 | #endif |
---|
| 114 | |
---|
| 115 | ! outputs: |
---|
| 116 | INTEGER, DIMENSION (len), INTENT (OUT) :: iflag1, kbas1, ktop1 |
---|
| 117 | REAL, DIMENSION (len), INTENT (OUT) :: precip1, cbmf1, plcl1, plfc1 |
---|
| 118 | REAL, DIMENSION (len), INTENT (OUT) :: wbeff1 |
---|
| 119 | REAL, DIMENSION (len, nd), INTENT (OUT) :: sig1, w01 |
---|
| 120 | REAL, DIMENSION (len), INTENT (OUT) :: epmax_diag1 ! epmax_cape |
---|
| 121 | REAL, DIMENSION (len), INTENT (OUT) :: ptop21 |
---|
| 122 | REAL, DIMENSION (len, nd), INTENT (OUT) :: ft1, fq1, fu1, fv1 |
---|
| 123 | REAL, DIMENSION (len, nd, ntra), INTENT (OUT) :: ftra1 |
---|
| 124 | REAL, DIMENSION (len), INTENT (OUT) :: sigd1 |
---|
| 125 | REAL, DIMENSION (len, nd), INTENT (OUT) :: ma1, mip1 |
---|
| 126 | REAL, DIMENSION (len, nd+1), INTENT (OUT) :: vprecip1 |
---|
| 127 | REAL, DIMENSION (len, nd+1), INTENT (OUT) :: vprecipi1 |
---|
| 128 | REAL, DIMENSION (len, nd), INTENT (OUT) :: upwd1, dnwd1, dnwd01 |
---|
| 129 | REAL, DIMENSION (len, nd), INTENT (OUT) :: qcondc1 |
---|
| 130 | REAL, DIMENSION (len), INTENT (OUT) :: wd1, cape1, cin1 |
---|
| 131 | REAL, DIMENSION (len, nd), INTENT (OUT) :: tvp1 |
---|
| 132 | REAL, DIMENSION (len, nd), INTENT (OUT) :: ftd1, fqd1 |
---|
| 133 | REAL, DIMENSION (len), INTENT (OUT) :: plim11, plim21 |
---|
| 134 | REAL, DIMENSION (len, nd), INTENT (OUT) :: asupmax1 |
---|
| 135 | REAL, DIMENSION (len), INTENT (OUT) :: supmax01, asupmaxmin1 |
---|
| 136 | |
---|
| 137 | REAL, DIMENSION (len, nd), INTENT (OUT) :: da1 |
---|
| 138 | REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: phi1 !AC! |
---|
| 139 | REAL, DIMENSION (len, nd), INTENT (OUT) :: mp1 !RomP |
---|
| 140 | REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: phi21 !RomP |
---|
| 141 | REAL, DIMENSION (len, nd), INTENT (OUT) :: d1a1, dam1 !RomP !RomP |
---|
| 142 | REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: sigij1 !RomP |
---|
| 143 | REAL, DIMENSION (len, nd), INTENT (OUT) :: qta1 !jyg |
---|
| 144 | REAL, DIMENSION (len, nd), INTENT (OUT) :: clw1 !RomP |
---|
| 145 | REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: elij1 !RomP |
---|
| 146 | REAL, DIMENSION (len, nd), INTENT (OUT) :: evap1, ep1 !RomP |
---|
| 147 | REAL, DIMENSION (len, nd, nd), INTENT (OUT) :: epmlmMm1 !RomP+jyg |
---|
| 148 | REAL, DIMENSION (len, nd), INTENT (OUT) :: eplamM1 !RomP+jyg |
---|
| 149 | REAL, DIMENSION (len, nd), INTENT (OUT) :: qtc1, sigt1 !RomP |
---|
| 150 | REAL, DIMENSION (len, nd), INTENT (OUT) :: wdtrainA1, wdtrainS1, wdtrainM1 !RomP |
---|
| 151 | |
---|
| 152 | #ifdef ISO |
---|
| 153 | REAL, DIMENSION (ntraciso,len), INTENT (OUT) :: xtprecip1 |
---|
| 154 | real, DIMENSION (ntraciso,len,nd), INTENT (OUT) :: fxt1 |
---|
| 155 | real, DIMENSION (ntraciso,len,nd), INTENT (OUT) :: fxtd1 |
---|
| 156 | real, DIMENSION (ntraciso,len,nd+1), INTENT (OUT) :: xtvprecip1 |
---|
| 157 | real, DIMENSION (ntraciso,len,nd+1), INTENT (OUT) :: xtvprecipi1 |
---|
| 158 | REAL, DIMENSION (ntraciso,len, nd), INTENT (OUT) :: xtevap1 |
---|
| 159 | REAL, DIMENSION (ntraciso,len, nd), INTENT (OUT) :: xtwdtrainA1 |
---|
| 160 | REAL, DIMENSION (ntraciso,len, nd), INTENT (OUT) :: xtclw1 |
---|
| 161 | #endif |
---|
| 162 | |
---|
| 163 | ! local variables: |
---|
| 164 | INTEGER i, k, j |
---|
| 165 | INTEGER jdcum |
---|
| 166 | ! c integer k1,k2 |
---|
| 167 | |
---|
| 168 | #ifdef ISO |
---|
| 169 | integer ixt |
---|
| 170 | #endif |
---|
| 171 | |
---|
| 172 | #ifdef DIAGISO |
---|
| 173 | real water(nloc,nd) |
---|
| 174 | real xtwater(ntraciso,nloc,nd) |
---|
| 175 | real qp(nloc,nd),xtp(ntraciso,nloc,nd) |
---|
| 176 | real fq_detrainement(nloc,nd) |
---|
| 177 | real f_detrainement(nloc,nd) |
---|
| 178 | real q_detrainement(nloc,nd) |
---|
| 179 | real xt_detrainement(ntraciso,nloc,nd) |
---|
| 180 | real fq_ddft(nloc,nd) |
---|
| 181 | real fq_fluxmasse(nloc,nd) |
---|
| 182 | real Amp_diag(nloc,nd) |
---|
| 183 | real tg_save(nloc,nd) ! temperature de cond pour les isos |
---|
| 184 | real fq_evapprecip(nloc,nd) |
---|
| 185 | real fxt_detrainement(ntraciso,nloc,nd) |
---|
| 186 | real fxt_ddft(ntraciso,nloc,nd) |
---|
| 187 | real fxt_fluxmasse(ntraciso,nloc,nd) |
---|
| 188 | real fxt_evapprecip(ntraciso,nloc,nd) |
---|
| 189 | real m(nloc,nd) |
---|
| 190 | |
---|
| 191 | real water1(len,nd) |
---|
| 192 | real xtwater1(ntraciso,len,nd) |
---|
| 193 | real qp1(len,nd),xtp1(ntraciso,len,nd) |
---|
| 194 | real fq_detrainement1(len,nd) |
---|
| 195 | real f_detrainement1(len,nd) |
---|
| 196 | real q_detrainement1(len,nd) |
---|
| 197 | real xt_detrainement1(ntraciso,len,nd) |
---|
| 198 | real fq_ddft1(len,nd) |
---|
| 199 | real fq_fluxmasse1(len,nd) |
---|
| 200 | real fq_evapprecip1(len,nd) |
---|
| 201 | real fxt_detrainement1(ntraciso,len,nd) |
---|
| 202 | real fxt_ddft1(ntraciso,len,nd) |
---|
| 203 | real fxt_fluxmasse1(ntraciso,len,nd) |
---|
| 204 | real fxt_evapprecip1(ntraciso,len,nd) |
---|
| 205 | #endif |
---|
| 206 | |
---|
| 207 | !jyg< |
---|
| 208 | IF (compress) THEN |
---|
| 209 | !>jyg |
---|
| 210 | #ifdef ISOVERIF |
---|
| 211 | write(*,*) 'cv3a_uncompress 151: entrée dans cv3a_uncompress' |
---|
| 212 | #endif |
---|
| 213 | DO i = 1, ncum |
---|
| 214 | sig1(idcum(i), nd) = sig(i, nd) |
---|
| 215 | ptop21(idcum(i)) = ptop2(i) |
---|
| 216 | sigd1(idcum(i)) = sigd(i) |
---|
| 217 | precip1(idcum(i)) = precip(i) |
---|
| 218 | cbmf1(idcum(i)) = cbmf(i) |
---|
| 219 | plcl1(idcum(i)) = plcl(i) |
---|
| 220 | plfc1(idcum(i)) = plfc(i) |
---|
| 221 | wbeff1(idcum(i)) = wbeff(i) |
---|
| 222 | iflag1(idcum(i)) = iflag(i) |
---|
| 223 | kbas1(idcum(i)) = kbas(i) |
---|
| 224 | ktop1(idcum(i)) = ktop(i) |
---|
| 225 | wd1(idcum(i)) = wd(i) |
---|
| 226 | cape1(idcum(i)) = cape(i) |
---|
| 227 | cin1(idcum(i)) = cin(i) |
---|
| 228 | plim11(idcum(i)) = plim1(i) |
---|
| 229 | plim21(idcum(i)) = plim2(i) |
---|
| 230 | supmax01(idcum(i)) = supmax0(i) |
---|
| 231 | asupmaxmin1(idcum(i)) = asupmaxmin(i) |
---|
| 232 | epmax_diag1(idcum(i)) = epmax_diag(i) |
---|
| 233 | #ifdef ISO |
---|
| 234 | do ixt = 1, ntraciso |
---|
| 235 | xtprecip1(ixt,idcum(i))=xtprecip(ixt,i) |
---|
| 236 | enddo |
---|
| 237 | #endif |
---|
| 238 | END DO |
---|
| 239 | |
---|
| 240 | DO k = 1, nl |
---|
| 241 | DO i = 1, ncum |
---|
| 242 | sig1(idcum(i), k) = sig(i, k) |
---|
| 243 | w01(idcum(i), k) = w0(i, k) |
---|
| 244 | ft1(idcum(i), k) = ft(i, k) |
---|
| 245 | fq1(idcum(i), k) = fq(i, k) |
---|
| 246 | fu1(idcum(i), k) = fu(i, k) |
---|
| 247 | fv1(idcum(i), k) = fv(i, k) |
---|
| 248 | ma1(idcum(i), k) = ma(i, k) |
---|
| 249 | mip1(idcum(i), k) = mip(i, k) |
---|
| 250 | vprecip1(idcum(i), k) = vprecip(i, k) |
---|
| 251 | vprecipi1(idcum(i), k) = vprecipi(i, k) |
---|
| 252 | upwd1(idcum(i), k) = upwd(i, k) |
---|
| 253 | dnwd1(idcum(i), k) = dnwd(i, k) |
---|
| 254 | dnwd01(idcum(i), k) = dnwd0(i, k) |
---|
| 255 | qcondc1(idcum(i), k) = qcondc(i, k) |
---|
| 256 | tvp1(idcum(i), k) = tvp(i, k) |
---|
| 257 | ftd1(idcum(i), k) = ftd(i, k) |
---|
| 258 | fqd1(idcum(i), k) = fqd(i, k) |
---|
| 259 | asupmax1(idcum(i), k) = asupmax(i, k) |
---|
| 260 | |
---|
| 261 | da1(idcum(i), k) = da(i, k) !AC! |
---|
| 262 | mp1(idcum(i), k) = mp(i, k) !RomP |
---|
| 263 | d1a1(idcum(i), k) = d1a(i, k) !RomP |
---|
| 264 | dam1(idcum(i), k) = dam(i, k) !RomP |
---|
| 265 | qta1(idcum(i), k) = qta(i, k) !jyg |
---|
| 266 | clw1(idcum(i), k) = clw(i, k) !RomP |
---|
| 267 | evap1(idcum(i), k) = evap(i, k) !RomP |
---|
| 268 | ep1(idcum(i), k) = ep(i, k) !RomP |
---|
| 269 | eplamM1(idcum(i), k) = eplamM(i, k) !RomP+jyg |
---|
| 270 | wdtrainA1(idcum(i), k) = wdtrainA(i, k) !RomP |
---|
| 271 | wdtrainS1(idcum(i), k) = wdtrainS(i, k) !RomP |
---|
| 272 | wdtrainM1(idcum(i), k) = wdtrainM(i, k) !RomP |
---|
| 273 | qtc1(idcum(i), k) = qtc(i, k) |
---|
| 274 | sigt1(idcum(i), k) = sigt(i, k) |
---|
| 275 | |
---|
| 276 | #ifdef ISO |
---|
| 277 | do ixt = 1, ntraciso |
---|
| 278 | fxt1(ixt,idcum(i),k)=fxt(ixt,i,k) |
---|
| 279 | fxtd1(ixt,idcum(i),k)=fxtd(ixt,i,k) |
---|
| 280 | xtvprecip1(ixt,idcum(i),k)=xtvprecip(ixt,i,k) |
---|
| 281 | xtvprecipi1(ixt,idcum(i),k)=xtvprecipi(ixt,i,k) |
---|
| 282 | xtevap1(ixt,idcum(i),k)=xtevap(ixt,i,k) |
---|
| 283 | xtwdtraina1(ixt,idcum(i),k)=xtwdtraina(ixt,i,k) |
---|
| 284 | xtclw1(ixt,idcum(i),k)=xtclw(ixt,i,k) |
---|
| 285 | enddo |
---|
| 286 | #endif |
---|
| 287 | END DO |
---|
| 288 | END DO |
---|
| 289 | |
---|
| 290 | #ifdef ISO |
---|
| 291 | #ifdef DIAGISO |
---|
| 292 | do k=1,nl |
---|
| 293 | do i=1,ncum |
---|
| 294 | water1(idcum(i),k)=water(i,k) |
---|
| 295 | qp1(idcum(i),k)=qp(i,k) |
---|
| 296 | fq_detrainement1(idcum(i),k)=fq_detrainement(i,k) |
---|
| 297 | f_detrainement1(idcum(i),k)=f_detrainement(i,k) |
---|
| 298 | q_detrainement1(idcum(i),k)=q_detrainement(i,k) |
---|
| 299 | fq_ddft1(idcum(i),k)=fq_ddft(i,k) |
---|
| 300 | fq_fluxmasse1(idcum(i),k)=fq_fluxmasse(i,k) |
---|
| 301 | fq_evapprecip1(idcum(i),k)=fq_evapprecip(i,k) |
---|
| 302 | do ixt = 1, ntraciso |
---|
| 303 | xtwater1(ixt,idcum(i),k)=xtwater(ixt,i,k) |
---|
| 304 | xtp1(ixt,idcum(i),k)=xtp(ixt,i,k) |
---|
| 305 | fxt_detrainement1(ixt,idcum(i),k)=fxt_detrainement(ixt,i,k) |
---|
| 306 | xt_detrainement1(ixt,idcum(i),k)=xt_detrainement(ixt,i,k) |
---|
| 307 | fxt_ddft1(ixt,idcum(i),k)=fxt_ddft(ixt,i,k) |
---|
| 308 | fxt_fluxmasse1(ixt,idcum(i),k)=fxt_fluxmasse(ixt,i,k) |
---|
| 309 | fxt_evapprecip1(ixt,idcum(i),k)=fxt_evapprecip(ixt,i,k) |
---|
| 310 | enddo |
---|
| 311 | enddo |
---|
| 312 | enddo |
---|
| 313 | #endif |
---|
| 314 | #endif |
---|
| 315 | |
---|
| 316 | |
---|
| 317 | ! Fluxes are defined on a staggered grid and extend up to nl+1 |
---|
| 318 | DO i = 1, ncum |
---|
| 319 | ma1(idcum(i), nlp) = 0. |
---|
| 320 | vprecip1(idcum(i), nlp) = 0. |
---|
| 321 | vprecipi1(idcum(i), nlp) = 0. |
---|
| 322 | upwd1(idcum(i), nlp) = 0. |
---|
| 323 | dnwd1(idcum(i), nlp) = 0. |
---|
| 324 | dnwd01(idcum(i), nlp) = 0. |
---|
| 325 | #ifdef ISO |
---|
| 326 | do ixt=1,ntraciso |
---|
| 327 | xtvprecip1(ixt,idcum(i), nlp) = 0. |
---|
| 328 | xtvprecipi1(ixt,idcum(i), nlp) = 0. |
---|
| 329 | enddo |
---|
| 330 | #endif |
---|
| 331 | END DO |
---|
| 332 | |
---|
| 333 | ! AC! do 2100 j=1,ntra |
---|
| 334 | ! AC!c oct3 do 2110 k=1,nl |
---|
| 335 | ! AC! do 2110 k=1,nd ! oct3 |
---|
| 336 | ! AC! do 2120 i=1,ncum |
---|
| 337 | ! AC! ftra1(idcum(i),k,j)=ftra(i,k,j) |
---|
| 338 | ! AC! 2120 continue |
---|
| 339 | ! AC! 2110 continue |
---|
| 340 | ! AC! 2100 continue |
---|
| 341 | |
---|
| 342 | ! AC! |
---|
| 343 | !jyg< |
---|
| 344 | ! Essais pour gagner du temps en diminuant l'adressage indirect |
---|
| 345 | !! DO j = 1, nd |
---|
| 346 | !! DO k = 1, nd |
---|
| 347 | !! DO i = 1, ncum |
---|
| 348 | !! phi1(idcum(i), k, j) = phi(i, k, j) !AC! |
---|
| 349 | !! phi21(idcum(i), k, j) = phi2(i, k, j) !RomP |
---|
| 350 | !! sigij1(idcum(i), k, j) = sigij(i, k, j) !RomP |
---|
| 351 | !! elij1(idcum(i), k, j) = elij(i, k, j) !RomP |
---|
| 352 | !! epmlmMm(idcum(i), k, j) = epmlmMm(i, k, j) !RomP+jyg |
---|
| 353 | !! END DO |
---|
| 354 | !! END DO |
---|
| 355 | !! END DO |
---|
| 356 | |
---|
| 357 | !! DO i = 1, ncum |
---|
| 358 | !! jdcum=idcum(i) |
---|
| 359 | !! phi1 (jdcum, 1:nl+1, 1:nl+1) = phi (i, 1:nl+1, 1:nl+1) !AC! |
---|
| 360 | !! phi21 (jdcum, 1:nl+1, 1:nl+1) = phi2 (i, 1:nl+1, 1:nl+1) !RomP |
---|
| 361 | !! sigij1 (jdcum, 1:nl+1, 1:nl+1) = sigij (i, 1:nl+1, 1:nl+1) !RomP |
---|
| 362 | !! elij1 (jdcum, 1:nl+1, 1:nl+1) = elij (i, 1:nl+1, 1:nl+1) !RomP |
---|
| 363 | !! epmlmMm1(jdcum, 1:nl+1, 1:nl+1) = epmlmMm(i, 1:nl+1, 1:nl+1) !RomP+jyg |
---|
| 364 | !! END DO |
---|
| 365 | ! These tracer associated arrays are defined up to nl, not nl+1 |
---|
| 366 | DO i = 1, ncum |
---|
| 367 | jdcum=idcum(i) |
---|
| 368 | DO k = 1,nl |
---|
| 369 | DO j = 1,nl |
---|
| 370 | phi1 (jdcum, j, k) = phi (i, j, k) !AC! |
---|
| 371 | phi21 (jdcum, j, k) = phi2 (i, j, k) !RomP |
---|
| 372 | sigij1 (jdcum, j, k) = sigij (i, j, k) !RomP |
---|
| 373 | elij1 (jdcum, j, k) = elij (i, j, k) !RomP |
---|
| 374 | epmlmMm1(jdcum, j, k) = epmlmMm(i, j, k) !RomP+jyg |
---|
| 375 | END DO |
---|
| 376 | ENDDO |
---|
| 377 | ENDDO |
---|
| 378 | !>jyg |
---|
| 379 | ! AC! |
---|
| 380 | |
---|
| 381 | |
---|
| 382 | ! do 2220 k2=1,nd |
---|
| 383 | ! do 2210 k1=1,nd |
---|
| 384 | ! do 2200 i=1,ncum |
---|
| 385 | ! ment1(idcum(i),k1,k2) = ment(i,k1,k2) |
---|
| 386 | ! sigij1(idcum(i),k1,k2) = sigij(i,k1,k2) |
---|
| 387 | ! 2200 enddo |
---|
| 388 | ! 2210 enddo |
---|
| 389 | ! 2220 enddo |
---|
| 390 | ! |
---|
| 391 | !jyg< |
---|
| 392 | ELSE !(compress) |
---|
| 393 | ! |
---|
| 394 | sig1(:,nd) = sig(:,nd) |
---|
| 395 | ptop21(:) = ptop2(:) |
---|
| 396 | sigd1(:) = sigd(:) |
---|
| 397 | precip1(:) = precip(:) |
---|
| 398 | cbmf1(:) = cbmf(:) |
---|
| 399 | plcl1(:) = plcl(:) |
---|
| 400 | plfc1(:) = plfc(:) |
---|
| 401 | wbeff1(:) = wbeff(:) |
---|
| 402 | iflag1(:) = iflag(:) |
---|
| 403 | kbas1(:) = kbas(:) |
---|
| 404 | ktop1(:) = ktop(:) |
---|
| 405 | wd1(:) = wd(:) |
---|
| 406 | cape1(:) = cape(:) |
---|
| 407 | cin1(:) = cin(:) |
---|
| 408 | plim11(:) = plim1(:) |
---|
| 409 | plim21(:) = plim2(:) |
---|
| 410 | supmax01(:) = supmax0(:) |
---|
| 411 | asupmaxmin1(:) = asupmaxmin(:) |
---|
| 412 | #ifdef ISO |
---|
| 413 | xtprecip1(:,:)=xtprecip(:,:) |
---|
| 414 | #endif |
---|
| 415 | ! |
---|
| 416 | sig1(:, 1:nl) = sig(:, 1:nl) |
---|
| 417 | w01(:, 1:nl) = w0(:, 1:nl) |
---|
| 418 | ft1(:, 1:nl) = ft(:, 1:nl) |
---|
| 419 | fq1(:, 1:nl) = fq(:, 1:nl) |
---|
| 420 | fu1(:, 1:nl) = fu(:, 1:nl) |
---|
| 421 | fv1(:, 1:nl) = fv(:, 1:nl) |
---|
| 422 | ma1(:, 1:nl) = ma(:, 1:nl) |
---|
| 423 | mip1(:, 1:nl) = mip(:, 1:nl) |
---|
| 424 | vprecip1(:, 1:nl) = vprecip(:, 1:nl) |
---|
| 425 | vprecipi1(:, 1:nl) = vprecipi(:, 1:nl) |
---|
| 426 | upwd1(:, 1:nl) = upwd(:, 1:nl) |
---|
| 427 | dnwd1(:, 1:nl) = dnwd(:, 1:nl) |
---|
| 428 | dnwd01(:, 1:nl) = dnwd0(:, 1:nl) |
---|
| 429 | qcondc1(:, 1:nl) = qcondc(:, 1:nl) |
---|
| 430 | tvp1(:, 1:nl) = tvp(:, 1:nl) |
---|
| 431 | ftd1(:, 1:nl) = ftd(:, 1:nl) |
---|
| 432 | fqd1(:, 1:nl) = fqd(:, 1:nl) |
---|
| 433 | asupmax1(:, 1:nl) = asupmax(:, 1:nl) |
---|
| 434 | |
---|
| 435 | da1(:, 1:nl) = da(:, 1:nl) !AC! |
---|
| 436 | mp1(:, 1:nl) = mp(:, 1:nl) !RomP |
---|
| 437 | d1a1(:, 1:nl) = d1a(:, 1:nl) !RomP |
---|
| 438 | dam1(:, 1:nl) = dam(:, 1:nl) !RomP |
---|
| 439 | qta1(:, 1:nl) = qta(:, 1:nl) !jyg |
---|
| 440 | clw1(:, 1:nl) = clw(:, 1:nl) !RomP |
---|
| 441 | evap1(:, 1:nl) = evap(:, 1:nl) !RomP |
---|
| 442 | ep1(:, 1:nl) = ep(:, 1:nl) !RomP |
---|
| 443 | eplamM1(:, 1:nl) = eplamM(:, 1:nl) !RomP+jyg |
---|
| 444 | wdtrainA1(:, 1:nl) = wdtrainA(:, 1:nl) !RomP |
---|
| 445 | wdtrainS1(:, 1:nl) = wdtrainS(:, 1:nl) !RomP |
---|
| 446 | wdtrainM1(:, 1:nl) = wdtrainM(:, 1:nl) !RomP |
---|
| 447 | qtc1(:, 1:nl) = qtc(:, 1:nl) |
---|
| 448 | sigt1(:, 1:nl) = sigt(:, 1:nl) |
---|
| 449 | ! |
---|
| 450 | ma1(:, nlp) = 0. |
---|
| 451 | vprecip1(:, nlp) = 0. |
---|
| 452 | vprecipi1(:, nlp) = 0. |
---|
| 453 | upwd1(:, nlp) = 0. |
---|
| 454 | dnwd1(:, nlp) = 0. |
---|
| 455 | dnwd01(:, nlp) = 0. |
---|
| 456 | |
---|
| 457 | ! |
---|
| 458 | phi1 (:, 1:nl, 1:nl) = phi (:, 1:nl, 1:nl) !AC! |
---|
| 459 | phi21 (:, 1:nl, 1:nl) = phi2 (:, 1:nl, 1:nl) !RomP |
---|
| 460 | sigij1 (:, 1:nl, 1:nl) = sigij (:, 1:nl, 1:nl) !RomP |
---|
| 461 | elij1 (:, 1:nl, 1:nl) = elij (:, 1:nl, 1:nl) !RomP |
---|
| 462 | epmlmMm1(:, 1:nl, 1:nl) = epmlmMm(:, 1:nl, 1:nl) !RomP+jyg |
---|
| 463 | |
---|
| 464 | #ifdef ISO |
---|
| 465 | do ixt = 1, ntraciso |
---|
| 466 | fxt1(:,:,1:nl)=fxt(:,:,1:nl) |
---|
| 467 | fxtd1(:,:,1:nl)=fxtd(:,:,1:nl) |
---|
| 468 | xtvprecip1(:,:,1:nlp)=xtvprecip(:,:,1:nlp) |
---|
| 469 | xtvprecipi1(:,:,1:nlp)=xtvprecipi(:,:,1:nlp) |
---|
| 470 | xtevap1(:,:,1:nl)=xtevap(:,:,1:nl) |
---|
| 471 | xtwdtrainA1(:,:,1:nl)=xtwdtrainA(:,:,1:nl) |
---|
| 472 | xtclw1(:,:,1:nl)=xtclw(:,:,1:nl) |
---|
| 473 | enddo |
---|
| 474 | #endif |
---|
| 475 | |
---|
| 476 | |
---|
| 477 | #ifdef ISO |
---|
| 478 | #ifdef DIAGISO |
---|
| 479 | water1(:,1:nl)=water(:,1:nl) |
---|
| 480 | qp1(:,1:nl)=qp(:,1:nl) |
---|
| 481 | fq_detrainement1(:,1:nl)=fq_detrainement(:,1:nl) |
---|
| 482 | f_detrainement1(:,1:nl)=f_detrainement(:,1:nl) |
---|
| 483 | q_detrainement1(:,1:nl)=q_detrainement(:,1:nl) |
---|
| 484 | fq_ddft1(:,1:nl)=fq_ddft(:,1:nl) |
---|
| 485 | fq_fluxmasse1(:,1:nl)=fq_fluxmasse(:,1:nl) |
---|
| 486 | fq_evapprecip1(:,1:nl)=fq_evapprecip(:,1:nl) |
---|
| 487 | do ixt = 1, ntraciso |
---|
| 488 | xtwater1(:,:,1:nl)=xtwater(:,:,1:nl) |
---|
| 489 | xtp1(:,:,1:nl)=xtp(:,:,1:nl) |
---|
| 490 | fxt_detrainement1(:,:,1:nl)=fxt_detrainement(:,:,1:nl) |
---|
| 491 | xt_detrainement1(:,:,1:nl)=xt_detrainement(:,:,1:nl) |
---|
| 492 | fxt_ddft1(:,:,1:nl)=fxt_ddft(:,:,1:nl) |
---|
| 493 | fxt_fluxmasse1(:,:,1:nl)=fxt_fluxmasse(:,:,1:nl) |
---|
| 494 | fxt_evapprecip1(:,:,1:nl)=fxt_evapprecip(:,:,1:nl) |
---|
| 495 | enddo |
---|
| 496 | #endif |
---|
| 497 | #endif |
---|
| 498 | |
---|
| 499 | |
---|
| 500 | ENDIF !(compress) |
---|
| 501 | !>jyg |
---|
| 502 | |
---|
| 503 | RETURN |
---|
| 504 | END SUBROUTINE cv3a_uncompress |
---|
| 505 | |
---|