Changeset 5118 for LMDZ6/branches/Amaury_dev/libf/dyn3d_common
- Timestamp:
- Jul 24, 2024, 4:39:59 PM (6 months ago)
- Location:
- LMDZ6/branches/Amaury_dev/libf/dyn3d_common
- Files:
-
- 13 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/advn.f90
r5117 r5118 1 2 1 ! $Header$ 3 2 4 SUBROUTINE advn(q, masse,w,pbaru,pbarv,pdt,mode)3 SUBROUTINE advn(q, masse, w, pbaru, pbarv, pdt, mode) 5 4 ! 6 5 ! Auteur : F. Hourdin … … 15 14 ! 16 15 ! -------------------------------------------------------------------- 16 USE lmdz_iniprint, ONLY: lunout, prt_level 17 17 IMPLICIT NONE 18 18 ! … … 20 20 include "paramet.h" 21 21 include "comgeom.h" 22 include "iniprint.h"23 22 24 23 ! … … 26 25 ! ---------- 27 26 INTEGER :: mode 28 REAL :: masse(ip1jmp1, llm)29 REAL :: pbaru( ip1jmp1,llm ),pbarv( ip1jm,llm)30 REAL :: q(ip1jmp1, llm)31 REAL :: w(ip1jmp1, llm),pdt27 REAL :: masse(ip1jmp1, llm) 28 REAL :: pbaru(ip1jmp1, llm), pbarv(ip1jm, llm) 29 REAL :: q(ip1jmp1, llm) 30 REAL :: w(ip1jmp1, llm), pdt 32 31 ! 33 32 ! Local 34 33 ! --------- 35 34 ! 36 INTEGER :: i, ij,l,j,ii37 INTEGER :: ijlqmin, iqmin,jqmin,lqmin35 INTEGER :: i, ij, l, j, ii 36 INTEGER :: ijlqmin, iqmin, jqmin, lqmin 38 37 INTEGER :: ismin 39 38 ! 40 REAL :: zm(ip1jmp1, llm),newmasse41 REAL :: mu(ip1jmp1, llm)42 REAL :: mv(ip1jm, llm)43 REAL :: mw(ip1jmp1, llm+1)44 REAL :: zq(ip1jmp1, llm),zz,qpn,qps45 REAL :: zqg(ip1jmp1, llm),zqd(ip1jmp1,llm)46 REAL :: zqs(ip1jmp1, llm),zqn(ip1jmp1,llm)47 REAL :: zqh(ip1jmp1, llm),zqb(ip1jmp1,llm)48 REAL :: temps0, temps1,temps2,temps349 REAL :: ztemps1, ztemps2,ssum50 save temps1, temps2,temps351 REAL :: zzpbar, zzw52 53 REAL :: qmin, qmax54 data qmin, qmax/0.,1./55 data temps1, temps2,temps3/0.,0.,0./39 REAL :: zm(ip1jmp1, llm), newmasse 40 REAL :: mu(ip1jmp1, llm) 41 REAL :: mv(ip1jm, llm) 42 REAL :: mw(ip1jmp1, llm + 1) 43 REAL :: zq(ip1jmp1, llm), zz, qpn, qps 44 REAL :: zqg(ip1jmp1, llm), zqd(ip1jmp1, llm) 45 REAL :: zqs(ip1jmp1, llm), zqn(ip1jmp1, llm) 46 REAL :: zqh(ip1jmp1, llm), zqb(ip1jmp1, llm) 47 REAL :: temps0, temps1, temps2, temps3 48 REAL :: ztemps1, ztemps2, ssum 49 save temps1, temps2, temps3 50 REAL :: zzpbar, zzw 51 52 REAL :: qmin, qmax 53 data qmin, qmax/0., 1./ 54 data temps1, temps2, temps3/0., 0., 0./ 56 55 57 56 zzpbar = 0.5 * pdt 58 zzw 59 60 DO l =1,llm61 DO ij = iip2, ip1jm62 mu(ij,l)=pbaru(ij,l) * zzpbar63 64 DO ij=1,ip1jm65 mv(ij,l)=pbarv(ij,l) * zzpbar66 67 DO ij=1,ip1jmp168 mw(ij,l)=w(ij,l) * zzw69 57 zzw = pdt 58 59 DO l = 1, llm 60 DO ij = iip2, ip1jm 61 mu(ij, l) = pbaru(ij, l) * zzpbar 62 ENDDO 63 DO ij = 1, ip1jm 64 mv(ij, l) = pbarv(ij, l) * zzpbar 65 ENDDO 66 DO ij = 1, ip1jmp1 67 mw(ij, l) = w(ij, l) * zzw 68 ENDDO 70 69 ENDDO 71 70 72 DO ij =1,ip1jmp173 mw(ij,llm+1)=0.71 DO ij = 1, ip1jmp1 72 mw(ij, llm + 1) = 0. 74 73 ENDDO 75 74 76 do l =1,llm77 qpn=0.78 qps=0.79 do ij=1,iim80 qpn=qpn+q(ij,l)*masse(ij,l)81 qps=qps+q(ip1jm+ij,l)*masse(ip1jm+ij,l)82 83 qpn=qpn/ssum(iim,masse(1,l),1)84 qps=qps/ssum(iim,masse(ip1jm+1,l),1)85 do ij=1,iip186 q(ij,l)=qpn87 q(ip1jm+ij,l)=qps88 89 enddo 90 91 do ij =1,ip1jmp192 mw(ij,llm+1)=0.93 enddo 94 do l =1,llm95 do ij=1,ip1jmp196 zq(ij,l)=q(ij,l)97 zm(ij,l)=masse(ij,l)98 75 do l = 1, llm 76 qpn = 0. 77 qps = 0. 78 do ij = 1, iim 79 qpn = qpn + q(ij, l) * masse(ij, l) 80 qps = qps + q(ip1jm + ij, l) * masse(ip1jm + ij, l) 81 enddo 82 qpn = qpn / ssum(iim, masse(1, l), 1) 83 qps = qps / ssum(iim, masse(ip1jm + 1, l), 1) 84 do ij = 1, iip1 85 q(ij, l) = qpn 86 q(ip1jm + ij, l) = qps 87 enddo 88 enddo 89 90 do ij = 1, ip1jmp1 91 mw(ij, llm + 1) = 0. 92 enddo 93 do l = 1, llm 94 do ij = 1, ip1jmp1 95 zq(ij, l) = q(ij, l) 96 zm(ij, l) = masse(ij, l) 97 enddo 99 98 enddo 100 99 101 100 ! CALL minmaxq(zq,qmin,qmax,'avant vlx ') 102 CALL advnqx(zq, zqg,zqd)103 CALL advnx(zq, zqg,zqd,zm,mu,mode)104 CALL advnqy(zq, zqs,zqn)105 CALL advny(zq, zqs,zqn,zm,mv)106 CALL advnqz(zq, zqh,zqb)107 CALL advnz(zq, zqh,zqb,zm,mw)101 CALL advnqx(zq, zqg, zqd) 102 CALL advnx(zq, zqg, zqd, zm, mu, mode) 103 CALL advnqy(zq, zqs, zqn) 104 CALL advny(zq, zqs, zqn, zm, mv) 105 CALL advnqz(zq, zqh, zqb) 106 CALL advnz(zq, zqh, zqb, zm, mw) 108 107 ! CALL vlz(zq,0.,zm,mw) 109 CALL advnqy(zq, zqs,zqn)110 CALL advny(zq, zqs,zqn,zm,mv)111 CALL advnqx(zq, zqg,zqd)112 CALL advnx(zq, zqg,zqd,zm,mu,mode)108 CALL advnqy(zq, zqs, zqn) 109 CALL advny(zq, zqs, zqn, zm, mv) 110 CALL advnqx(zq, zqg, zqd) 111 CALL advnx(zq, zqg, zqd, zm, mu, mode) 113 112 ! CALL minmaxq(zq,qmin,qmax,'apres vlx ') 114 113 115 do l =1,llm116 do ij=1,ip1jmp1117 q(ij,l)=zq(ij,l)118 119 do ij=1,ip1jm+1,iip1120 q(ij+iim,l)=q(ij,l)121 114 do l = 1, llm 115 do ij = 1, ip1jmp1 116 q(ij, l) = zq(ij, l) 117 enddo 118 do ij = 1, ip1jm + 1, iip1 119 q(ij + iim, l) = q(ij, l) 120 enddo 122 121 enddo 123 122 … … 125 124 END SUBROUTINE advn 126 125 127 SUBROUTINE advnqx(q, qg,qd)126 SUBROUTINE advnqx(q, qg, qd) 128 127 ! 129 128 ! Auteurs: Calcul des valeurs de q aux point u. 130 129 ! 131 130 ! -------------------------------------------------------------------- 131 USE lmdz_iniprint, ONLY: lunout, prt_level 132 132 IMPLICIT NONE 133 133 ! 134 134 INCLUDE "dimensions.h" 135 135 INCLUDE "paramet.h" 136 INCLUDE "iniprint.h"137 136 ! 138 137 ! 139 138 ! Arguments: 140 139 ! ---------- 141 REAL :: q(ip1jmp1, llm),qg(ip1jmp1,llm),qd(ip1jmp1,llm)140 REAL :: q(ip1jmp1, llm), qg(ip1jmp1, llm), qd(ip1jmp1, llm) 142 141 ! 143 142 ! Local 144 143 ! --------- 145 144 ! 146 INTEGER :: ij, l147 ! 148 REAL :: dxqu(ip1jmp1), zqu(ip1jmp1)149 REAL :: zqmax(ip1jmp1), zqmin(ip1jmp1)145 INTEGER :: ij, l 146 ! 147 REAL :: dxqu(ip1jmp1), zqu(ip1jmp1) 148 REAL :: zqmax(ip1jmp1), zqmin(ip1jmp1) 150 149 LOGICAL :: extremum(ip1jmp1) 151 150 … … 157 156 ! ----------------------- 158 157 IF (mode==0) THEN 159 do l=1,llm160 do ij=1,ip1jm161 qd(ij,l)=q(ij,l)162 qg(ij,l)=q(ij,l)163 164 158 do l = 1, llm 159 do ij = 1, ip1jm 160 qd(ij, l) = q(ij, l) 161 qg(ij, l) = q(ij, l) 162 enddo 163 enddo 165 164 else 166 do l = 1, llm167 do ij=iip2,ip1jm-1168 dxqu(ij) =q(ij+1,l)-q(ij,l)169 zqu(ij) =0.5*(q(ij+1,l)+q(ij,l))170 enddo171 do ij=iip1+iip1,ip1jm,iip1172 dxqu(ij) =dxqu(ij-iim)173 zqu(ij) =zqu(ij-iim)174 enddo175 do ij=iip2,ip1jm-1176 zqu(ij) =zqu(ij)-dxqu(ij+1)/12.177 enddo178 do ij=iip1+iip1,ip1jm,iip1179 zqu(ij) =zqu(ij-iim)180 enddo181 do ij=iip2+1,ip1jm182 zqu(ij) =zqu(ij)+dxqu(ij-1)/12.183 enddo184 do ij=iip1+iip1,ip1jm,iip1185 zqu(ij -iim)=zqu(ij)186 enddo187 188 ! calcul des valeurs max et min acceptees aux interfaces189 190 do ij=iip2,ip1jm-1191 zqmax(ij) =max(q(ij+1,l),q(ij,l))192 zqmin(ij) =min(q(ij+1,l),q(ij,l))193 enddo194 do ij=iip1+iip1,ip1jm,iip1195 zqmax(ij) =zqmax(ij-iim)196 zqmin(ij) =zqmin(ij-iim)197 enddo198 do ij=iip2+1,ip1jm199 extremum(ij) =dxqu(ij)*dxqu(ij-1)<=0.200 enddo201 do ij=iip1+iip1,ip1jm,iip1202 extremum(ij -iim)=extremum(ij)203 enddo204 do ij=iip2,ip1jm205 zqu(ij) =min(max(zqmin(ij),zqu(ij)),zqmax(ij))206 enddo207 do ij=iip2+1,ip1jm165 do l = 1, llm 166 do ij = iip2, ip1jm - 1 167 dxqu(ij) = q(ij + 1, l) - q(ij, l) 168 zqu(ij) = 0.5 * (q(ij + 1, l) + q(ij, l)) 169 enddo 170 do ij = iip1 + iip1, ip1jm, iip1 171 dxqu(ij) = dxqu(ij - iim) 172 zqu(ij) = zqu(ij - iim) 173 enddo 174 do ij = iip2, ip1jm - 1 175 zqu(ij) = zqu(ij) - dxqu(ij + 1) / 12. 176 enddo 177 do ij = iip1 + iip1, ip1jm, iip1 178 zqu(ij) = zqu(ij - iim) 179 enddo 180 do ij = iip2 + 1, ip1jm 181 zqu(ij) = zqu(ij) + dxqu(ij - 1) / 12. 182 enddo 183 do ij = iip1 + iip1, ip1jm, iip1 184 zqu(ij - iim) = zqu(ij) 185 enddo 186 187 ! calcul des valeurs max et min acceptees aux interfaces 188 189 do ij = iip2, ip1jm - 1 190 zqmax(ij) = max(q(ij + 1, l), q(ij, l)) 191 zqmin(ij) = min(q(ij + 1, l), q(ij, l)) 192 enddo 193 do ij = iip1 + iip1, ip1jm, iip1 194 zqmax(ij) = zqmax(ij - iim) 195 zqmin(ij) = zqmin(ij - iim) 196 enddo 197 do ij = iip2 + 1, ip1jm 198 extremum(ij) = dxqu(ij) * dxqu(ij - 1)<=0. 199 enddo 200 do ij = iip1 + iip1, ip1jm, iip1 201 extremum(ij - iim) = extremum(ij) 202 enddo 203 do ij = iip2, ip1jm 204 zqu(ij) = min(max(zqmin(ij), zqu(ij)), zqmax(ij)) 205 enddo 206 do ij = iip2 + 1, ip1jm 208 207 IF(extremum(ij)) THEN 209 qg(ij,l)=q(ij,l)210 qd(ij,l)=q(ij,l)208 qg(ij, l) = q(ij, l) 209 qd(ij, l) = q(ij, l) 211 210 else 212 qd(ij,l)=zqu(ij)213 qg(ij,l)=zqu(ij-1)211 qd(ij, l) = zqu(ij) 212 qg(ij, l) = zqu(ij - 1) 214 213 endif 215 enddo216 do ij=iip1+iip1,ip1jm,iip1217 qd(ij -iim,l)=qd(ij,l)218 qg(ij -iim,l)=qg(ij,l)219 enddo220 221 goto 8888222 223 do ij=iip2+1,ip1jm224 IF(extremum(ij).and..not.extremum(ij -1)) &225 qd(ij-1,l)=q(ij,l)226 enddo227 228 do ij=iip1+iip1,ip1jm,iip1229 qd(ij -iim,l)=qd(ij,l)230 enddo231 do ij=iip2,ip1jm-1232 IF (extremum(ij).and..not.extremum(ij +1)) &233 qg(ij+1,l)=q(ij,l)234 enddo235 236 do ij=iip1+iip1,ip1jm,iip1237 qg(ij, l)=qg(ij-iim,l)238 enddo239 8888 continue240 enddo214 enddo 215 do ij = iip1 + iip1, ip1jm, iip1 216 qd(ij - iim, l) = qd(ij, l) 217 qg(ij - iim, l) = qg(ij, l) 218 enddo 219 220 goto 8888 221 222 do ij = iip2 + 1, ip1jm 223 IF(extremum(ij).and..not.extremum(ij - 1)) & 224 qd(ij - 1, l) = q(ij, l) 225 enddo 226 227 do ij = iip1 + iip1, ip1jm, iip1 228 qd(ij - iim, l) = qd(ij, l) 229 enddo 230 do ij = iip2, ip1jm - 1 231 IF (extremum(ij).and..not.extremum(ij + 1)) & 232 qg(ij + 1, l) = q(ij, l) 233 enddo 234 235 do ij = iip1 + iip1, ip1jm, iip1 236 qg(ij, l) = qg(ij - iim, l) 237 enddo 238 8888 continue 239 enddo 241 240 ENDIF 242 241 RETURN 243 242 END SUBROUTINE advnqx 244 SUBROUTINE advnqy(q, qs,qn)243 SUBROUTINE advnqy(q, qs, qn) 245 244 ! 246 245 ! Auteurs: Calcul des valeurs de q aux point v. 247 246 ! 248 247 ! -------------------------------------------------------------------- 248 USE lmdz_iniprint, ONLY: lunout, prt_level 249 249 IMPLICIT NONE 250 250 ! 251 251 INCLUDE "dimensions.h" 252 252 INCLUDE "paramet.h" 253 INCLUDE "iniprint.h"254 253 ! 255 254 ! 256 255 ! Arguments: 257 256 ! ---------- 258 REAL :: q(ip1jmp1, llm),qs(ip1jmp1,llm),qn(ip1jmp1,llm)257 REAL :: q(ip1jmp1, llm), qs(ip1jmp1, llm), qn(ip1jmp1, llm) 259 258 ! 260 259 ! Local 261 260 ! --------- 262 261 ! 263 INTEGER :: ij, l264 ! 265 REAL :: dyqv(ip1jm), zqv(ip1jm,llm)266 REAL :: zqmax(ip1jm), zqmin(ip1jm)262 INTEGER :: ij, l 263 ! 264 REAL :: dyqv(ip1jm), zqv(ip1jm, llm) 265 REAL :: zqmax(ip1jm), zqmin(ip1jm) 267 266 LOGICAL :: extremum(ip1jmp1) 268 267 … … 272 271 273 272 IF (mode==0) THEN 274 do l=1,llm275 do ij=1,ip1jmp1276 qn(ij,l)=q(ij,l)277 qs(ij,l)=q(ij,l)278 279 273 do l = 1, llm 274 do ij = 1, ip1jmp1 275 qn(ij, l) = q(ij, l) 276 qs(ij, l) = q(ij, l) 277 enddo 278 enddo 280 279 else 281 280 282 ! calcul des pentes en u:283 ! -----------------------284 do l = 1, llm285 do ij=1,ip1jm286 dyqv(ij) =q(ij,l)-q(ij+iip1,l)287 enddo288 289 do ij=iip2,ip1jm-iip1290 zqv(ij, l)=0.5*(q(ij+iip1,l)+q(ij,l))291 zqv(ij, l)=zqv(ij,l)+(dyqv(ij+iip1)-dyqv(ij-iip1))/12.292 enddo293 294 do ij=iip2,ip1jm295 extremum(ij) =dyqv(ij)*dyqv(ij-iip1)<=0.296 enddo297 298 ! Pas de pentes aux poles299 do ij=1,iip1300 zqv(ij, l)=q(ij,l)301 zqv(ip1jm -iip1+ij,l)=q(ip1jm+ij,l)302 extremum(ij) =.TRUE.303 extremum(ip1jmp1 -iip1+ij)=.TRUE.304 enddo305 306 ! calcul des valeurs max et min acceptees aux interfaces307 do ij=1,ip1jm308 zqmax(ij) =max(q(ij+iip1,l),q(ij,l))309 zqmin(ij) =min(q(ij+iip1,l),q(ij,l))310 enddo311 312 do ij=1,ip1jm313 zqv(ij, l)=min(max(zqmin(ij),zqv(ij,l)),zqmax(ij))314 enddo315 316 do ij=iip2,ip1jm281 ! calcul des pentes en u: 282 ! ----------------------- 283 do l = 1, llm 284 do ij = 1, ip1jm 285 dyqv(ij) = q(ij, l) - q(ij + iip1, l) 286 enddo 287 288 do ij = iip2, ip1jm - iip1 289 zqv(ij, l) = 0.5 * (q(ij + iip1, l) + q(ij, l)) 290 zqv(ij, l) = zqv(ij, l) + (dyqv(ij + iip1) - dyqv(ij - iip1)) / 12. 291 enddo 292 293 do ij = iip2, ip1jm 294 extremum(ij) = dyqv(ij) * dyqv(ij - iip1)<=0. 295 enddo 296 297 ! Pas de pentes aux poles 298 do ij = 1, iip1 299 zqv(ij, l) = q(ij, l) 300 zqv(ip1jm - iip1 + ij, l) = q(ip1jm + ij, l) 301 extremum(ij) = .TRUE. 302 extremum(ip1jmp1 - iip1 + ij) = .TRUE. 303 enddo 304 305 ! calcul des valeurs max et min acceptees aux interfaces 306 do ij = 1, ip1jm 307 zqmax(ij) = max(q(ij + iip1, l), q(ij, l)) 308 zqmin(ij) = min(q(ij + iip1, l), q(ij, l)) 309 enddo 310 311 do ij = 1, ip1jm 312 zqv(ij, l) = min(max(zqmin(ij), zqv(ij, l)), zqmax(ij)) 313 enddo 314 315 do ij = iip2, ip1jm 317 316 IF(extremum(ij)) THEN 318 qs(ij,l)=q(ij,l)319 qn(ij,l)=q(ij,l)320 321 317 qs(ij, l) = q(ij, l) 318 qn(ij, l) = q(ij, l) 319 ! if (.NOT.extremum(ij-iip1)) qs(ij-iip1,l)=q(ij,l) 320 ! if (.NOT.extremum(ij+iip1)) qn(ij+iip1,l)=q(ij,l) 322 321 else 323 qs(ij,l)=zqv(ij,l)324 qn(ij,l)=zqv(ij-iip1,l)322 qs(ij, l) = zqv(ij, l) 323 qn(ij, l) = zqv(ij - iip1, l) 325 324 endif 326 enddo327 328 do ij=1,iip1329 qs(ij, l)=q(ij,l)330 qn(ij, l)=q(ij,l)331 qs(ip1jm +ij,l)=q(ip1jm+ij,l)332 qn(ip1jm +ij,l)=q(ip1jm+ij,l)333 enddo334 335 enddo325 enddo 326 327 do ij = 1, iip1 328 qs(ij, l) = q(ij, l) 329 qn(ij, l) = q(ij, l) 330 qs(ip1jm + ij, l) = q(ip1jm + ij, l) 331 qn(ip1jm + ij, l) = q(ip1jm + ij, l) 332 enddo 333 334 enddo 336 335 ENDIF 337 336 RETURN 338 337 END SUBROUTINE advnqy 339 338 340 SUBROUTINE advnqz(q, qh,qb)339 SUBROUTINE advnqz(q, qh, qb) 341 340 ! 342 341 ! Auteurs: Calcul des valeurs de q aux point v. 343 342 ! 344 343 ! -------------------------------------------------------------------- 344 USE lmdz_iniprint, ONLY: lunout, prt_level 345 345 IMPLICIT NONE 346 346 ! 347 347 INCLUDE "dimensions.h" 348 348 INCLUDE "paramet.h" 349 INCLUDE "iniprint.h"350 349 ! 351 350 ! 352 351 ! Arguments: 353 352 ! ---------- 354 REAL :: q(ip1jmp1, llm),qh(ip1jmp1,llm),qb(ip1jmp1,llm)353 REAL :: q(ip1jmp1, llm), qh(ip1jmp1, llm), qb(ip1jmp1, llm) 355 354 ! 356 355 ! Local 357 356 ! --------- 358 357 ! 359 INTEGER :: ij, l360 ! 361 REAL :: dzqw(ip1jmp1, llm+1),zqw(ip1jmp1,llm+1)362 REAL :: zqmax(ip1jmp1, llm),zqmin(ip1jmp1,llm)363 LOGICAL :: extremum(ip1jmp1, llm)358 INTEGER :: ij, l 359 ! 360 REAL :: dzqw(ip1jmp1, llm + 1), zqw(ip1jmp1, llm + 1) 361 REAL :: zqmax(ip1jmp1, llm), zqmin(ip1jmp1, llm) 362 LOGICAL :: extremum(ip1jmp1, llm) 364 363 365 364 INTEGER :: mode … … 372 371 373 372 IF (mode==0) THEN 374 do l=1,llm375 do ij=1,ip1jmp1376 qb(ij,l)=q(ij,l)377 qh(ij,l)=q(ij,l)378 379 373 do l = 1, llm 374 do ij = 1, ip1jmp1 375 qb(ij, l) = q(ij, l) 376 qh(ij, l) = q(ij, l) 377 enddo 378 enddo 380 379 else 381 do l = 2, llm382 do ij=1,ip1jmp1383 dzqw(ij, l)=q(ij,l-1)-q(ij,l)384 zqw(ij, l)=0.5*(q(ij,l-1)+q(ij,l))385 enddo386 enddo387 do ij=1,ip1jmp1388 dzqw(ij,1)=0.389 dzqw(ij,llm+1)=0.390 enddo391 do l=2,llm392 do ij=1,ip1jmp1393 zqw(ij, l)=zqw(ij,l)+(dzqw(ij,l+1)-dzqw(ij,l-1))/12.394 enddo395 enddo396 do l=2,llm-1397 do ij=1,ip1jmp1398 extremum(ij, l)=dzqw(ij,l)*dzqw(ij,l+1)<=0.399 enddo400 enddo401 402 ! Pas de pentes en bas et en haut403 do ij=1,ip1jmp1404 zqw(ij,2)=q(ij,1)405 zqw(ij,llm)=q(ij,llm)406 extremum(ij,1)=.TRUE.407 extremum(ij,llm)=.TRUE.408 409 410 ! calcul des valeurs max et min acceptees aux interfaces411 do l=2,llm412 do ij=1,ip1jmp1413 zqmax(ij, l)=max(q(ij,l-1),q(ij,l))414 zqmin(ij, l)=min(q(ij,l-1),q(ij,l))415 enddo416 enddo417 418 do l=2,llm419 do ij=1,ip1jmp1420 zqw(ij, l)=min(max(zqmin(ij,l),zqw(ij,l)),zqmax(ij,l))421 enddo422 enddo423 424 do l=2,llm-1425 do ij=1,ip1jmp1426 IF(extremum(ij, l)) THEN427 qh(ij,l)=q(ij,l)428 qb(ij,l)=q(ij,l)380 do l = 2, llm 381 do ij = 1, ip1jmp1 382 dzqw(ij, l) = q(ij, l - 1) - q(ij, l) 383 zqw(ij, l) = 0.5 * (q(ij, l - 1) + q(ij, l)) 384 enddo 385 enddo 386 do ij = 1, ip1jmp1 387 dzqw(ij, 1) = 0. 388 dzqw(ij, llm + 1) = 0. 389 enddo 390 do l = 2, llm 391 do ij = 1, ip1jmp1 392 zqw(ij, l) = zqw(ij, l) + (dzqw(ij, l + 1) - dzqw(ij, l - 1)) / 12. 393 enddo 394 enddo 395 do l = 2, llm - 1 396 do ij = 1, ip1jmp1 397 extremum(ij, l) = dzqw(ij, l) * dzqw(ij, l + 1)<=0. 398 enddo 399 enddo 400 401 ! Pas de pentes en bas et en haut 402 do ij = 1, ip1jmp1 403 zqw(ij, 2) = q(ij, 1) 404 zqw(ij, llm) = q(ij, llm) 405 extremum(ij, 1) = .TRUE. 406 extremum(ij, llm) = .TRUE. 407 enddo 408 409 ! calcul des valeurs max et min acceptees aux interfaces 410 do l = 2, llm 411 do ij = 1, ip1jmp1 412 zqmax(ij, l) = max(q(ij, l - 1), q(ij, l)) 413 zqmin(ij, l) = min(q(ij, l - 1), q(ij, l)) 414 enddo 415 enddo 416 417 do l = 2, llm 418 do ij = 1, ip1jmp1 419 zqw(ij, l) = min(max(zqmin(ij, l), zqw(ij, l)), zqmax(ij, l)) 420 enddo 421 enddo 422 423 do l = 2, llm - 1 424 do ij = 1, ip1jmp1 425 IF(extremum(ij, l)) THEN 426 qh(ij, l) = q(ij, l) 427 qb(ij, l) = q(ij, l) 429 428 else 430 qh(ij,l)=zqw(ij,l+1)431 qb(ij,l)=zqw(ij,l)429 qh(ij, l) = zqw(ij, l + 1) 430 qb(ij, l) = zqw(ij, l) 432 431 endif 433 enddo434 enddo435 ! do l=2,llm-1436 ! do ij=1,ip1jmp1437 ! IF(extremum(ij,l)) THEN438 ! if (.NOT.extremum(ij,l-1)) qh(ij,l-1)=q(ij,l)439 ! if (.NOT.extremum(ij,l+1)) qb(ij,l+1)=q(ij,l)440 ! endif441 ! enddo442 ! enddo443 444 do ij=1,ip1jmp1445 qb(ij,1)=q(ij,1)446 qh(ij,1)=q(ij,1)447 qb(ij,llm)=q(ij,llm)448 qh(ij,llm)=q(ij,llm)449 enddo432 enddo 433 enddo 434 ! do l=2,llm-1 435 ! do ij=1,ip1jmp1 436 ! IF(extremum(ij,l)) THEN 437 ! if (.NOT.extremum(ij,l-1)) qh(ij,l-1)=q(ij,l) 438 ! if (.NOT.extremum(ij,l+1)) qb(ij,l+1)=q(ij,l) 439 ! endif 440 ! enddo 441 ! enddo 442 443 do ij = 1, ip1jmp1 444 qb(ij, 1) = q(ij, 1) 445 qh(ij, 1) = q(ij, 1) 446 qb(ij, llm) = q(ij, llm) 447 qh(ij, llm) = q(ij, llm) 448 enddo 450 449 451 450 ENDIF … … 454 453 END SUBROUTINE advnqz 455 454 456 SUBROUTINE advnx(q, qg,qd,masse,u_m,mode)455 SUBROUTINE advnx(q, qg, qd, masse, u_m, mode) 457 456 ! 458 457 ! Auteur : F. Hourdin … … 465 464 ! 466 465 ! -------------------------------------------------------------------- 466 USE lmdz_iniprint, ONLY: lunout, prt_level 467 467 IMPLICIT NONE 468 468 ! 469 469 include "dimensions.h" 470 470 include "paramet.h" 471 include "iniprint.h"472 471 ! 473 472 ! … … 475 474 ! ---------- 476 475 INTEGER :: mode 477 REAL :: masse(ip1jmp1, llm)478 REAL :: u_m( ip1jmp1,llm)479 REAL :: q(ip1jmp1, llm),qd(ip1jmp1,llm),qg(ip1jmp1,llm)476 REAL :: masse(ip1jmp1, llm) 477 REAL :: u_m(ip1jmp1, llm) 478 REAL :: q(ip1jmp1, llm), qd(ip1jmp1, llm), qg(ip1jmp1, llm) 480 479 ! 481 480 ! Local 482 481 ! --------- 483 482 ! 484 INTEGER :: i, j,ij,l,indu(ip1jmp1),niju,iju,ijq485 INTEGER :: n0, nl(llm)486 ! 487 REAL :: new_m, zu_m,zdq,zz488 REAL :: zsigg(ip1jmp1, llm),zsigd(ip1jmp1,llm),zsig489 REAL :: u_mq(ip1jmp1, llm)490 491 REAL :: zm, zq,zsigm,zsigp,zqm,zqp,zu492 493 LOGICAL :: ladvplus(ip1jmp1, llm)483 INTEGER :: i, j, ij, l, indu(ip1jmp1), niju, iju, ijq 484 INTEGER :: n0, nl(llm) 485 ! 486 REAL :: new_m, zu_m, zdq, zz 487 REAL :: zsigg(ip1jmp1, llm), zsigd(ip1jmp1, llm), zsig 488 REAL :: u_mq(ip1jmp1, llm) 489 490 REAL :: zm, zq, zsigm, zsigp, zqm, zqp, zu 491 492 LOGICAL :: ladvplus(ip1jmp1, llm) 494 493 495 494 REAL :: prec … … 498 497 data prec/1.e-15/ 499 498 500 do l =1,llm501 do ij=iip2,ip1jm502 zdq=qd(ij,l)-qg(ij,l)503 504 505 506 507 508 509 510 zsigd(ij,l)=(q(ij,l)-qg(ij,l))/zdq511 zsigg(ij,l)=1.-zsigd(ij,l)512 513 ! s zsigg(ij,l).ge.0..or.zsigg(ij,l).le.1.) ) THEN514 515 516 517 518 519 520 zsigd(ij,l)=0.5521 zsigg(ij,l)=0.5522 qd(ij,l)=q(ij,l)523 qg(ij,l)=q(ij,l)524 525 526 499 do l = 1, llm 500 do ij = iip2, ip1jm 501 zdq = qd(ij, l) - qg(ij, l) 502 ! if((qd(ij,l)-q(ij,l))*(q(ij,l)-qg(ij,l)).lt.0.) THEN 503 ! PRINT*,'probleme au point ij=',ij,' l=',l 504 ! PRINT*,qd(ij,l),q(ij,l),qg(ij,l) 505 ! qd(ij,l)=q(ij,l) 506 ! qg(ij,l)=q(ij,l) 507 ! END IF 508 IF(abs(zdq)>prec) THEN 509 zsigd(ij, l) = (q(ij, l) - qg(ij, l)) / zdq 510 zsigg(ij, l) = 1. - zsigd(ij, l) 511 ! IF(.NOT.(zsigd(ij,l).ge.0..and.zsigd(ij,l).le.1. .AND. 512 ! s zsigg(ij,l).ge.0..or.zsigg(ij,l).le.1.) ) THEN 513 ! PRINT*,'probleme au point ij=',ij,' l=',l 514 ! PRINT*,'sigg=',zsigg(ij,l),' sigd=',zsigd(ij,l) 515 ! PRINT*,'q d,c,g ',qd(ij,l),q(ij,l),qg(ij,l),zdq 516 ! stop 517 ! END IF 518 else 519 zsigd(ij, l) = 0.5 520 zsigg(ij, l) = 0.5 521 qd(ij, l) = q(ij, l) 522 qg(ij, l) = q(ij, l) 523 endif 524 enddo 525 enddo 527 526 528 527 ! calcul de la pente maximum dans la maille en valeur absolue 529 528 530 do l=1,llm531 do ij=iip2,ip1jm-1532 IF (u_m(ij, l)>=0.) THEN533 zsigp=zsigd(ij,l)534 zsigm=zsigg(ij,l)535 zqp=qd(ij,l)536 zqm=qg(ij,l)537 zm=masse(ij,l)538 zq=q(ij,l)529 do l = 1, llm 530 do ij = iip2, ip1jm - 1 531 IF (u_m(ij, l)>=0.) THEN 532 zsigp = zsigd(ij, l) 533 zsigm = zsigg(ij, l) 534 zqp = qd(ij, l) 535 zqm = qg(ij, l) 536 zm = masse(ij, l) 537 zq = q(ij, l) 539 538 else 540 zsigm=zsigd(ij+1,l)541 zsigp=zsigg(ij+1,l)542 zqm=qd(ij+1,l)543 zqp=qg(ij+1,l)544 zm=masse(ij+1,l)545 zq=q(ij+1,l)546 endif 547 zu =abs(u_m(ij,l))548 ladvplus(ij, l)=zu>zm549 zsig =zu/zm550 IF(zsig==0.) zsigp =0.1539 zsigm = zsigd(ij + 1, l) 540 zsigp = zsigg(ij + 1, l) 541 zqm = qd(ij + 1, l) 542 zqp = qg(ij + 1, l) 543 zm = masse(ij + 1, l) 544 zq = q(ij + 1, l) 545 endif 546 zu = abs(u_m(ij, l)) 547 ladvplus(ij, l) = zu>zm 548 zsig = zu / zm 549 IF(zsig==0.) zsigp = 0.1 551 550 IF (mode==1) THEN 552 553 u_mq(ij,l)=u_m(ij,l)*zqp554 555 u_mq(ij,l)= &556 sign(zm,u_m(ij,l))*(zsigp*zqp+(zsig-zsigp)*zqm)557 551 IF (zsig<=zsigp) THEN 552 u_mq(ij, l) = u_m(ij, l) * zqp 553 ELSE IF (mode==1) THEN 554 u_mq(ij, l) = & 555 sign(zm, u_m(ij, l)) * (zsigp * zqp + (zsig - zsigp) * zqm) 556 endif 558 557 else 559 560 u_mq(ij,l)=u_m(ij,l)*(zqp-0.5*zsig/zsigp*(zqp-zq))561 562 zz=0.5*(zsig-zsigp)/zsigm563 u_mq(ij,l)=sign(zm,u_m(ij,l))*( 0.5*(zq+zqp)*zsigp &564 + (zsig-zsigp)*(zq+zz*(zqm-zq)))565 558 IF (zsig<=zsigp) THEN 559 u_mq(ij, l) = u_m(ij, l) * (zqp - 0.5 * zsig / zsigp * (zqp - zq)) 560 else 561 zz = 0.5 * (zsig - zsigp) / zsigm 562 u_mq(ij, l) = sign(zm, u_m(ij, l)) * (0.5 * (zq + zqp) * zsigp & 563 + (zsig - zsigp) * (zq + zz * (zqm - zq))) 564 endif 566 565 endif 567 566 ! IF(zsig.lt.0.) THEN … … 569 568 ! stop 570 569 ! END IF 571 enddo572 enddo 573 574 do l =1,llm575 do ij=iip1+iip1,ip1jm,iip1576 u_mq(ij, l)=u_mq(ij-iim,l)577 ladvplus(ij, l)=ladvplus(ij-iim,l)578 enddo570 enddo 571 enddo 572 573 do l = 1, llm 574 do ij = iip1 + iip1, ip1jm, iip1 575 u_mq(ij, l) = u_mq(ij - iim, l) 576 ladvplus(ij, l) = ladvplus(ij - iim, l) 577 enddo 579 578 enddo 580 579 … … 583 582 !================================================================= 584 583 ! tris des regions a traiter 585 n0 =0586 do l =1,llm587 nl(l)=0588 do ij=iip2,ip1jm589 IF(ladvplus(ij,l)) THEN590 nl(l)=nl(l)+1591 u_mq(ij,l)=0.592 593 594 n0=n0+nl(l)584 n0 = 0 585 do l = 1, llm 586 nl(l) = 0 587 do ij = iip2, ip1jm 588 IF(ladvplus(ij, l)) THEN 589 nl(l) = nl(l) + 1 590 u_mq(ij, l) = 0. 591 endif 592 enddo 593 n0 = n0 + nl(l) 595 594 enddo 596 595 597 596 IF(n0>1) THEN 598 IF (prt_level > 9) WRITE(lunout,*) & 599 'Nombre de points pour lesquels on advect plus que le' & 600 ,'contenu de la maille : ',n0 601 602 do l=1,llm 603 IF(nl(l)>0) THEN 604 iju=0 605 ! indicage des mailles concernees par le traitement special 606 do ij=iip2,ip1jm 607 IF(ladvplus(ij,l).AND.mod(ij,iip1)/=0) THEN 608 iju=iju+1 609 indu(iju)=ij 597 IF (prt_level > 9) WRITE(lunout, *) & 598 'Nombre de points pour lesquels on advect plus que le' & 599 , 'contenu de la maille : ', n0 600 601 do l = 1, llm 602 IF(nl(l)>0) THEN 603 iju = 0 604 ! indicage des mailles concernees par le traitement special 605 do ij = iip2, ip1jm 606 IF(ladvplus(ij, l).AND.mod(ij, iip1)/=0) THEN 607 iju = iju + 1 608 indu(iju) = ij 609 endif 610 enddo 611 niju = iju 612 ! PRINT*,'niju,nl',niju,nl(l) 613 614 ! traitement des mailles 615 do iju = 1, niju 616 ij = indu(iju) 617 j = (ij - 1) / iip1 + 1 618 zu_m = u_m(ij, l) 619 u_mq(ij, l) = 0. 620 IF(zu_m>0.) THEN 621 ijq = ij 622 i = ijq - (j - 1) * iip1 623 ! accumulation pour les mailles completements advectees 624 do while(zu_m>masse(ijq, l)) 625 u_mq(ij, l) = u_mq(ij, l) + q(ijq, l) * masse(ijq, l) 626 zu_m = zu_m - masse(ijq, l) 627 i = mod(i - 2 + iim, iim) + 1 628 ijq = (j - 1) * iip1 + i 629 enddo 630 ! MODIFS SPECIFIQUES DU SCHEMA 631 ! ajout de la maille non completement advectee 632 zsig = zu_m / masse(ijq, l) 633 IF(zsig<=zsigd(ijq, l)) THEN 634 u_mq(ij, l) = u_mq(ij, l) + zu_m * (qd(ijq, l) & 635 - 0.5 * zsig / zsigd(ijq, l) * (qd(ijq, l) - q(ijq, l))) 636 else 637 ! u_mq(ij,l)=u_mq(ij,l)+zu_m*q(ijq,l) 638 ! goto 8888 639 zz = 0.5 * (zsig - zsigd(ijq, l)) / zsigg(ijq, l) 640 IF(.NOT.(zz>0..and.zz<=0.5)) THEN 641 WRITE(lunout, *)'probleme2 au point ij=', ij, & 642 ' l=', l 643 WRITE(lunout, *)'zz=', zz 644 stop 610 645 endif 611 enddo 612 niju=iju 613 ! PRINT*,'niju,nl',niju,nl(l) 614 615 ! traitement des mailles 616 do iju=1,niju 617 ij=indu(iju) 618 j=(ij-1)/iip1+1 619 zu_m=u_m(ij,l) 620 u_mq(ij,l)=0. 621 IF(zu_m>0.) THEN 622 ijq=ij 623 i=ijq-(j-1)*iip1 624 ! accumulation pour les mailles completements advectees 625 do while(zu_m>masse(ijq,l)) 626 u_mq(ij,l)=u_mq(ij,l)+q(ijq,l)*masse(ijq,l) 627 zu_m=zu_m-masse(ijq,l) 628 i=mod(i-2+iim,iim)+1 629 ijq=(j-1)*iip1+i 630 enddo 631 ! MODIFS SPECIFIQUES DU SCHEMA 632 ! ajout de la maille non completement advectee 633 zsig=zu_m/masse(ijq,l) 634 IF(zsig<=zsigd(ijq,l)) THEN 635 u_mq(ij,l)=u_mq(ij,l)+zu_m*(qd(ijq,l) & 636 -0.5*zsig/zsigd(ijq,l)*(qd(ijq,l)-q(ijq,l))) 637 else 638 ! u_mq(ij,l)=u_mq(ij,l)+zu_m*q(ijq,l) 639 ! goto 8888 640 zz=0.5*(zsig-zsigd(ijq,l))/zsigg(ijq,l) 641 IF(.NOT.(zz>0..and.zz<=0.5)) THEN 642 WRITE(lunout,*)'probleme2 au point ij=',ij, & 643 ' l=',l 644 WRITE(lunout,*)'zz=',zz 645 stop 646 u_mq(ij, l) = u_mq(ij, l) + masse(ijq, l) * (& 647 0.5 * (q(ijq, l) + qd(ijq, l)) * zsigd(ijq, l) & 648 + (zsig - zsigd(ijq, l)) * (q(ijq, l) + zz * (qg(ijq, l) - q(ijq, l)))) 646 649 endif 647 u_mq(ij,l)=u_mq(ij,l)+masse(ijq,l)*( & 648 0.5*(q(ijq,l)+qd(ijq,l))*zsigd(ijq,l) & 649 +(zsig-zsigd(ijq,l))*(q(ijq,l)+zz*(qg(ijq,l)-q(ijq,l))) ) 650 endif 651 else 652 ijq=ij+1 653 i=ijq-(j-1)*iip1 654 ! accumulation pour les mailles completements advectees 655 do while(-zu_m>masse(ijq,l)) 656 u_mq(ij,l)=u_mq(ij,l)-q(ijq,l)*masse(ijq,l) 657 zu_m=zu_m+masse(ijq,l) 658 i=mod(i,iim)+1 659 ijq=(j-1)*iip1+i 660 enddo 661 ! ajout de la maille non completement advectee 662 ! 2eme MODIF SPECIFIQUE 663 zsig=-zu_m/masse(ij+1,l) 664 IF(zsig<=zsigg(ijq,l)) THEN 665 u_mq(ij,l)=u_mq(ij,l)+zu_m*(qg(ijq,l) & 666 -0.5*zsig/zsigg(ijq,l)*(qg(ijq,l)-q(ijq,l))) 667 else 668 ! u_mq(ij,l)=u_mq(ij,l)+zu_m*q(ijq,l) 669 ! goto 9999 670 zz=0.5*(zsig-zsigg(ijq,l))/zsigd(ijq,l) 671 IF(.NOT.(zz>0..and.zz<=0.5)) THEN 672 WRITE(lunout,*)'probleme22 au point ij=',ij & 673 ,' l=',l 674 WRITE(lunout,*)'zz=',zz 675 stop 650 else 651 ijq = ij + 1 652 i = ijq - (j - 1) * iip1 653 ! accumulation pour les mailles completements advectees 654 do while(-zu_m>masse(ijq, l)) 655 u_mq(ij, l) = u_mq(ij, l) - q(ijq, l) * masse(ijq, l) 656 zu_m = zu_m + masse(ijq, l) 657 i = mod(i, iim) + 1 658 ijq = (j - 1) * iip1 + i 659 enddo 660 ! ajout de la maille non completement advectee 661 ! 2eme MODIF SPECIFIQUE 662 zsig = -zu_m / masse(ij + 1, l) 663 IF(zsig<=zsigg(ijq, l)) THEN 664 u_mq(ij, l) = u_mq(ij, l) + zu_m * (qg(ijq, l) & 665 - 0.5 * zsig / zsigg(ijq, l) * (qg(ijq, l) - q(ijq, l))) 666 else 667 ! u_mq(ij,l)=u_mq(ij,l)+zu_m*q(ijq,l) 668 ! goto 9999 669 zz = 0.5 * (zsig - zsigg(ijq, l)) / zsigd(ijq, l) 670 IF(.NOT.(zz>0..and.zz<=0.5)) THEN 671 WRITE(lunout, *)'probleme22 au point ij=', ij & 672 , ' l=', l 673 WRITE(lunout, *)'zz=', zz 674 stop 675 endif 676 u_mq(ij, l) = u_mq(ij, l) - masse(ijq, l) * (& 677 0.5 * (q(ijq, l) + qg(ijq, l)) * zsigg(ijq, l) & 678 + (zsig - zsigg(ijq, l)) * & 679 (q(ijq, l) + zz * (qd(ijq, l) - q(ijq, l)))) 676 680 endif 677 u_mq(ij,l)=u_mq(ij,l)-masse(ijq,l)*( & 678 0.5*(q(ijq,l)+qg(ijq,l))*zsigg(ijq,l) & 679 +(zsig-zsigg(ijq,l))* & 680 (q(ijq,l)+zz*(qd(ijq,l)-q(ijq,l))) ) 681 endif 682 ! fin de la modif 683 endif 684 enddo 685 endif 686 enddo 681 ! fin de la modif 682 endif 683 enddo 684 endif 685 enddo 687 686 ENDIF ! n0.gt.0 688 687 689 688 ! bouclage en latitude 690 do l =1,llm691 do ij =iip1+iip1,ip1jm,iip1692 u_mq(ij,l)=u_mq(ij-iim,l)689 do l = 1, llm 690 do ij = iip1 + iip1, ip1jm, iip1 691 u_mq(ij, l) = u_mq(ij - iim, l) 693 692 enddo 694 693 enddo … … 698 697 !================================================================= 699 698 700 do l =1,llm701 do ij=iip2+1,ip1jm702 new_m=masse(ij,l)+u_m(ij-1,l)-u_m(ij,l)703 q(ij,l)=(q(ij,l)*masse(ij,l)+ &704 u_mq(ij -1,l)-u_mq(ij,l)) &705 / new_m706 masse(ij,l)=new_m707 708 ! Modif Fred 22 03 96 correction d'un bug (les scopy ci-dessous)709 do ij=iip1+iip1,ip1jm,iip1710 q(ij-iim,l)=q(ij,l)711 masse(ij-iim,l)=masse(ij,l)712 699 do l = 1, llm 700 do ij = iip2 + 1, ip1jm 701 new_m = masse(ij, l) + u_m(ij - 1, l) - u_m(ij, l) 702 q(ij, l) = (q(ij, l) * masse(ij, l) + & 703 u_mq(ij - 1, l) - u_mq(ij, l)) & 704 / new_m 705 masse(ij, l) = new_m 706 enddo 707 ! Modif Fred 22 03 96 correction d'un bug (les scopy ci-dessous) 708 do ij = iip1 + iip1, ip1jm, iip1 709 q(ij - iim, l) = q(ij, l) 710 masse(ij - iim, l) = masse(ij, l) 711 enddo 713 712 enddo 714 713 715 714 RETURN 716 715 END SUBROUTINE advnx 717 SUBROUTINE advny(q, qs,qn,masse,v_m)716 SUBROUTINE advny(q, qs, qn, masse, v_m) 718 717 ! 719 718 ! Auteur : F. Hourdin … … 726 725 ! 727 726 ! -------------------------------------------------------------------- 727 USE lmdz_iniprint, ONLY: lunout, prt_level 728 728 IMPLICIT NONE 729 729 ! … … 731 731 INCLUDE "paramet.h" 732 732 INCLUDE "comgeom.h" 733 INCLUDE "iniprint.h"734 733 ! 735 734 ! 736 735 ! Arguments: 737 736 ! ---------- 738 REAL :: masse(ip1jmp1, llm)739 REAL :: v_m( ip1jm,llm)740 REAL :: q(ip1jmp1, llm),qn(ip1jmp1,llm),qs(ip1jmp1,llm)737 REAL :: masse(ip1jmp1, llm) 738 REAL :: v_m(ip1jm, llm) 739 REAL :: q(ip1jmp1, llm), qn(ip1jmp1, llm), qs(ip1jmp1, llm) 741 740 ! 742 741 ! Local 743 742 ! --------- 744 743 ! 745 INTEGER :: ij, l746 ! 747 REAL :: new_m, zdq,zz748 REAL :: zsigs(ip1jmp1), zsign(ip1jmp1),zsig749 REAL :: v_mq(ip1jm, llm)750 REAL :: convpn, convps,convmpn,convmps,massen,masses751 REAL :: zm, zq,zsigm,zsigp,zqm,zqp744 INTEGER :: ij, l 745 ! 746 REAL :: new_m, zdq, zz 747 REAL :: zsigs(ip1jmp1), zsign(ip1jmp1), zsig 748 REAL :: v_mq(ip1jm, llm) 749 REAL :: convpn, convps, convmpn, convmps, massen, masses 750 REAL :: zm, zq, zsigm, zsigp, zqm, zqp 752 751 REAL :: ssum 753 752 REAL :: prec … … 755 754 756 755 data prec/1.e-15/ 757 do l=1,llm 758 do ij=1,ip1jmp1 759 zdq=qn(ij,l)-qs(ij,l) 760 ! if((qn(ij,l)-q(ij,l))*(q(ij,l)-qs(ij,l)).lt.0.) THEN 761 ! PRINT*,'probleme au point ij=',ij,' l=',l,' advnqx' 762 ! PRINT*,qn(ij,l),q(ij,l),qs(ij,l) 763 ! qn(ij,l)=q(ij,l) 764 ! qs(ij,l)=q(ij,l) 765 ! END IF 766 IF(abs(zdq)>prec) THEN 767 zsign(ij)=(q(ij,l)-qs(ij,l))/zdq 768 zsigs(ij)=1.-zsign(ij) 769 ! IF(.NOT.(zsign(ij).ge.0..and.zsign(ij).le.1. .AND. 770 ! s zsigs(ij).ge.0..or.zsigs(ij).le.1.) ) THEN 771 ! PRINT*,'probleme au point ij=',ij,' l=',l 772 ! PRINT*,'sigs=',zsigs(ij),' sign=',zsign(ij) 773 ! stop 774 ! END IF 775 else 776 zsign(ij)=0.5 777 zsigs(ij)=0.5 778 endif 779 enddo 780 781 ! calcul de la pente maximum dans la maille en valeur absolue 782 783 do ij=1,ip1jm 784 IF (v_m(ij,l)>=0.) THEN 785 zsigp=zsign(ij+iip1) 786 zsigm=zsigs(ij+iip1) 787 zqp=qn(ij+iip1,l) 788 zqm=qs(ij+iip1,l) 789 zm=masse(ij+iip1,l) 790 zq=q(ij+iip1,l) 756 do l = 1, llm 757 do ij = 1, ip1jmp1 758 zdq = qn(ij, l) - qs(ij, l) 759 ! if((qn(ij,l)-q(ij,l))*(q(ij,l)-qs(ij,l)).lt.0.) THEN 760 ! PRINT*,'probleme au point ij=',ij,' l=',l,' advnqx' 761 ! PRINT*,qn(ij,l),q(ij,l),qs(ij,l) 762 ! qn(ij,l)=q(ij,l) 763 ! qs(ij,l)=q(ij,l) 764 ! END IF 765 IF(abs(zdq)>prec) THEN 766 zsign(ij) = (q(ij, l) - qs(ij, l)) / zdq 767 zsigs(ij) = 1. - zsign(ij) 768 ! IF(.NOT.(zsign(ij).ge.0..and.zsign(ij).le.1. .AND. 769 ! s zsigs(ij).ge.0..or.zsigs(ij).le.1.) ) THEN 770 ! PRINT*,'probleme au point ij=',ij,' l=',l 771 ! PRINT*,'sigs=',zsigs(ij),' sign=',zsign(ij) 772 ! stop 773 ! END IF 791 774 else 792 zsigm=zsign(ij) 793 zsigp=zsigs(ij) 794 zqm=qn(ij,l) 795 zqp=qs(ij,l) 796 zm=masse(ij,l) 797 zq=q(ij,l) 798 endif 799 zsig=abs(v_m(ij,l))/zm 800 IF(zsig==0.) zsigp=0.1 775 zsign(ij) = 0.5 776 zsigs(ij) = 0.5 777 endif 778 enddo 779 780 ! calcul de la pente maximum dans la maille en valeur absolue 781 782 do ij = 1, ip1jm 783 IF (v_m(ij, l)>=0.) THEN 784 zsigp = zsign(ij + iip1) 785 zsigm = zsigs(ij + iip1) 786 zqp = qn(ij + iip1, l) 787 zqm = qs(ij + iip1, l) 788 zm = masse(ij + iip1, l) 789 zq = q(ij + iip1, l) 790 else 791 zsigm = zsign(ij) 792 zsigp = zsigs(ij) 793 zqm = qn(ij, l) 794 zqp = qs(ij, l) 795 zm = masse(ij, l) 796 zq = q(ij, l) 797 endif 798 zsig = abs(v_m(ij, l)) / zm 799 IF(zsig==0.) zsigp = 0.1 801 800 IF (zsig<=zsigp) THEN 802 v_mq(ij,l)=v_m(ij,l)*(zqp-0.5*zsig/zsigp*(zqp-zq))801 v_mq(ij, l) = v_m(ij, l) * (zqp - 0.5 * zsig / zsigp * (zqp - zq)) 803 802 else 804 zz=0.5*(zsig-zsigp)/zsigm805 v_mq(ij,l)=sign(zm,v_m(ij,l))*( 0.5*(zq+zqp)*zsigp &806 + (zsig-zsigp)*(zq+zz*(zqm-zq)))807 endif 808 enddo809 enddo 810 811 do l =1,llm812 do ij=iip2,ip1jm813 new_m=masse(ij,l) &814 + v_m(ij,l)-v_m(ij-iip1,l)815 q(ij,l)=(q(ij,l)*masse(ij,l)+v_mq(ij,l)-v_mq(ij-iip1,l)) &816 / new_m817 masse(ij,l)=new_m818 819 !.-. ancienne version820 convpn=SSUM(iim,v_mq(1,l),1)821 convmpn=ssum(iim,v_m(1,l),1)822 massen=ssum(iim,masse(1,l),1)823 new_m=massen+convmpn824 q(1,l)=(q(1,l)*massen+convpn)/new_m825 do ij = 1,iip1826 q(ij,l)=q(1,l)827 masse(ij,l)=new_m*aire(ij)/apoln828 829 830 convps=-SSUM(iim,v_mq(ip1jm-iim,l),1)831 convmps=-ssum(iim,v_m(ip1jm-iim,l),1)832 masses=ssum(iim,masse(ip1jm+1,l),1)833 new_m=masses+convmps834 q(ip1jm+1,l)=(q(ip1jm+1,l)*masses+convps)/new_m835 do ij = ip1jm+1,ip1jmp1836 q(ij,l)=q(ip1jm+1,l)837 masse(ij,l)=new_m*aire(ij)/apols838 803 zz = 0.5 * (zsig - zsigp) / zsigm 804 v_mq(ij, l) = sign(zm, v_m(ij, l)) * (0.5 * (zq + zqp) * zsigp & 805 + (zsig - zsigp) * (zq + zz * (zqm - zq))) 806 endif 807 enddo 808 enddo 809 810 do l = 1, llm 811 do ij = iip2, ip1jm 812 new_m = masse(ij, l) & 813 + v_m(ij, l) - v_m(ij - iip1, l) 814 q(ij, l) = (q(ij, l) * masse(ij, l) + v_mq(ij, l) - v_mq(ij - iip1, l)) & 815 / new_m 816 masse(ij, l) = new_m 817 enddo 818 !.-. ancienne version 819 convpn = SSUM(iim, v_mq(1, l), 1) 820 convmpn = ssum(iim, v_m(1, l), 1) 821 massen = ssum(iim, masse(1, l), 1) 822 new_m = massen + convmpn 823 q(1, l) = (q(1, l) * massen + convpn) / new_m 824 do ij = 1, iip1 825 q(ij, l) = q(1, l) 826 masse(ij, l) = new_m * aire(ij) / apoln 827 enddo 828 829 convps = -SSUM(iim, v_mq(ip1jm - iim, l), 1) 830 convmps = -ssum(iim, v_m(ip1jm - iim, l), 1) 831 masses = ssum(iim, masse(ip1jm + 1, l), 1) 832 new_m = masses + convmps 833 q(ip1jm + 1, l) = (q(ip1jm + 1, l) * masses + convps) / new_m 834 do ij = ip1jm + 1, ip1jmp1 835 q(ij, l) = q(ip1jm + 1, l) 836 masse(ij, l) = new_m * aire(ij) / apols 837 enddo 839 838 enddo 840 839 841 840 RETURN 842 841 END SUBROUTINE advny 843 SUBROUTINE advnz(q, qh,qb,masse,w_m)842 SUBROUTINE advnz(q, qh, qb, masse, w_m) 844 843 ! 845 844 ! Auteurs: F.Hourdin … … 853 852 ! 854 853 ! -------------------------------------------------------------------- 854 USE lmdz_iniprint, ONLY: lunout, prt_level 855 855 IMPLICIT NONE 856 856 ! … … 858 858 INCLUDE "paramet.h" 859 859 INCLUDE "comgeom.h" 860 INCLUDE "iniprint.h"861 860 ! 862 861 ! 863 862 ! Arguments: 864 863 ! ---------- 865 REAL :: masse(ip1jmp1, llm)866 REAL :: w_m( ip1jmp1,llm+1)867 REAL :: q(ip1jmp1, llm),qb(ip1jmp1,llm),qh(ip1jmp1,llm)864 REAL :: masse(ip1jmp1, llm) 865 REAL :: w_m(ip1jmp1, llm + 1) 866 REAL :: q(ip1jmp1, llm), qb(ip1jmp1, llm), qh(ip1jmp1, llm) 868 867 869 868 ! … … 871 870 ! --------- 872 871 ! 873 INTEGER :: ij, l874 ! 875 REAL :: new_m, zdq,zz876 REAL :: zsigh(ip1jmp1, llm),zsigb(ip1jmp1,llm),zsig877 REAL :: w_mq(ip1jmp1, llm+1)878 REAL :: zm, zq,zsigm,zsigp,zqm,zqp872 INTEGER :: ij, l 873 ! 874 REAL :: new_m, zdq, zz 875 REAL :: zsigh(ip1jmp1, llm), zsigb(ip1jmp1, llm), zsig 876 REAL :: w_mq(ip1jmp1, llm + 1) 877 REAL :: zm, zq, zsigm, zsigp, zqm, zqp 879 878 REAL :: prec 880 879 save prec … … 882 881 data prec/1.e-13/ 883 882 884 do l =1,llm885 do ij=1,ip1jmp1886 zdq=qb(ij,l)-qh(ij,l)887 888 889 890 891 892 893 894 895 zsigb(ij,l)=(q(ij,l)-qh(ij,l))/zdq896 zsigh(ij,l)=1.-zsigb(ij,l)897 zsigb(ij,l)=min(max(zsigb(ij,l),0.),1.)898 899 zsigb(ij,l)=0.5900 zsigh(ij,l)=0.5901 902 903 904 905 883 do l = 1, llm 884 do ij = 1, ip1jmp1 885 zdq = qb(ij, l) - qh(ij, l) 886 ! if((qh(ij,l)-q(ij,l))*(q(ij,l)-qb(ij,l)).lt.0.) THEN 887 ! PRINT*,'probleme au point ij=',ij,' l=',l 888 ! PRINT*,qh(ij,l),q(ij,l),qb(ij,l) 889 ! qh(ij,l)=q(ij,l) 890 ! qb(ij,l)=q(ij,l) 891 ! END IF 892 893 IF(abs(zdq)>prec) THEN 894 zsigb(ij, l) = (q(ij, l) - qh(ij, l)) / zdq 895 zsigh(ij, l) = 1. - zsigb(ij, l) 896 zsigb(ij, l) = min(max(zsigb(ij, l), 0.), 1.) 897 else 898 zsigb(ij, l) = 0.5 899 zsigh(ij, l) = 0.5 900 endif 901 enddo 902 enddo 903 904 ! PRINT*,'ok1' 906 905 ! calcul de la pente maximum dans la maille en valeur absolue 907 do l=2,llm908 do ij=1,ip1jmp1909 IF (w_m(ij, l)>=0.) THEN910 zsigp=zsigb(ij,l)911 zsigm=zsigh(ij,l)912 zqp=qb(ij,l)913 zqm=qh(ij,l)914 zm=masse(ij,l)915 zq=q(ij,l)906 do l = 2, llm 907 do ij = 1, ip1jmp1 908 IF (w_m(ij, l)>=0.) THEN 909 zsigp = zsigb(ij, l) 910 zsigm = zsigh(ij, l) 911 zqp = qb(ij, l) 912 zqm = qh(ij, l) 913 zm = masse(ij, l) 914 zq = q(ij, l) 916 915 else 917 zsigm=zsigb(ij,l-1)918 zsigp=zsigh(ij,l-1)919 zqm=qb(ij,l-1)920 zqp=qh(ij,l-1)921 zm=masse(ij,l-1)922 zq=q(ij,l-1)923 endif 924 zsig =abs(w_m(ij,l))/zm925 IF(zsig==0.) zsigp =0.1916 zsigm = zsigb(ij, l - 1) 917 zsigp = zsigh(ij, l - 1) 918 zqm = qb(ij, l - 1) 919 zqp = qh(ij, l - 1) 920 zm = masse(ij, l - 1) 921 zq = q(ij, l - 1) 922 endif 923 zsig = abs(w_m(ij, l)) / zm 924 IF(zsig==0.) zsigp = 0.1 926 925 IF (zsig<=zsigp) THEN 927 w_mq(ij,l)=w_m(ij,l)*(zqp-0.5*zsig/zsigp*(zqp-zq))926 w_mq(ij, l) = w_m(ij, l) * (zqp - 0.5 * zsig / zsigp * (zqp - zq)) 928 927 else 929 zz=0.5*(zsig-zsigp)/zsigm930 w_mq(ij,l)=sign(zm,w_m(ij,l))*( 0.5*(zq+zqp)*zsigp &931 + (zsig-zsigp)*(zq+zz*(zqm-zq)))932 endif 933 enddo934 enddo 935 936 do ij=1,ip1jmp1937 w_mq(ij,llm+1)=0.938 w_mq(ij,1)=0.939 940 941 do l =1,llm942 do ij=1,ip1jmp1943 new_m=masse(ij,l)+w_m(ij,l+1)-w_m(ij,l)944 q(ij,l)=(q(ij,l)*masse(ij,l)+w_mq(ij,l+1)-w_mq(ij,l)) &945 / new_m946 masse(ij,l)=new_m947 928 zz = 0.5 * (zsig - zsigp) / zsigm 929 w_mq(ij, l) = sign(zm, w_m(ij, l)) * (0.5 * (zq + zqp) * zsigp & 930 + (zsig - zsigp) * (zq + zz * (zqm - zq))) 931 endif 932 enddo 933 enddo 934 935 do ij = 1, ip1jmp1 936 w_mq(ij, llm + 1) = 0. 937 w_mq(ij, 1) = 0. 938 enddo 939 940 do l = 1, llm 941 do ij = 1, ip1jmp1 942 new_m = masse(ij, l) + w_m(ij, l + 1) - w_m(ij, l) 943 q(ij, l) = (q(ij, l) * masse(ij, l) + w_mq(ij, l + 1) - w_mq(ij, l)) & 944 / new_m 945 masse(ij, l) = new_m 946 enddo 948 947 enddo 949 948 ! PRINT*,'ok3' -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/diagedyn.f90
r5117 r5118 53 53 54 54 USE control_mod, ONLY: planet_type 55 USE lmdz_iniprint, ONLY: lunout, prt_level 55 56 56 57 IMPLICIT NONE … … 59 60 INCLUDE "paramet.h" 60 61 INCLUDE "comgeom.h" 61 INCLUDE "iniprint.h"62 62 63 63 ! Ehouarn: for now set these parameters to what is in Earth physics... -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/disvert.F90
r5117 r5118 9 9 pseudoalt, pa, preff, scaleheight, presinter 10 10 USE logic_mod, ONLY: ok_strato 11 USE lmdz_iniprint, ONLY: lunout, prt_level 11 12 12 13 IMPLICIT NONE … … 14 15 include "dimensions.h" 15 16 include "paramet.h" 16 include "iniprint.h"17 17 18 18 !------------------------------------------------------------------------------- -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/disvert_noterre.f90
r5117 r5118 11 11 USE comconst_mod, ONLY: kappa 12 12 USE logic_mod, ONLY: hybrid 13 USE lmdz_iniprint, ONLY: lunout, prt_level 13 14 14 15 IMPLICIT NONE … … 16 17 include "dimensions.h" 17 18 include "paramet.h" 18 include "iniprint.h"19 19 ! 20 20 !======================================================================= -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/infotrac.F90
r5117 r5118 118 118 #endif 119 119 USE lmdz_cppkeys_wrapper, ONLY: CPPKEY_INCA, CPPKEY_STRATAER 120 USE lmdz_iniprint, ONLY: lunout, prt_level 120 121 IMPLICIT NONE 121 122 !============================================================================================================================== … … 139 140 ! Declarations: 140 141 INCLUDE "dimensions.h" 141 INCLUDE "iniprint.h"142 142 143 143 !------------------------------------------------------------------------------------------------------------------------------ … … 228 228 IF(fType == 1 .AND. ANY(['inca', 'inco']==type_trac)) THEN !=== FOUND OLD STYLE INCA "traceur.def" 229 229 !--------------------------------------------------------------------------------------------------------------------------- 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 230 nqo = SIZE(tracers) - nqCO2 231 CALL Init_chem_inca_trac(nqINCA) !--- Get nqINCA from INCA 232 nbtr = nqINCA + nqCO2 !--- Number of tracers passed to phytrac 233 nqtrue = nbtr + nqo !--- Total number of "true" tracers 234 IF(ALL([2, 3] /= nqo)) CALL abort_gcm(modname, 'Only 2 or 3 water phases allowed ; found nqo=' // TRIM(int2str(nqo)), 1) 235 ALLOCATE(hadv(nqtrue), hadv_inca(nqINCA), conv_flg_inca(nqINCA), solsym_inca(nqINCA)) 236 ALLOCATE(vadv(nqtrue), vadv_inca(nqINCA), pbl_flg_inca(nqINCA)) 237 CALL init_transport(solsym_inca, conv_flg_inca, pbl_flg_inca, hadv_inca, vadv_inca) 238 ALLOCATE(ttr(nqtrue)) 239 ttr(1:nqo + nqCO2) = tracers 240 ttr(1:nqo)%component = 'lmdz' 241 ttr(1 + nqo:nqCO2 + nqo)%component = 'co2i' 242 ttr(1 + nqo + nqCO2:nqtrue)%component = 'inca' 243 ttr(1 + nqo:nqtrue)%name = [('CO2 ', iq = 1, nqCO2), solsym_inca] 244 ttr(1 + nqo + nqCO2:nqtrue)%parent = tran0 245 ttr(1 + nqo + nqCO2:nqtrue)%phase = 'g' 246 lerr = getKey('hadv', had, ky = tracers(:)%keys) 247 lerr = getKey('vadv', vad, ky = tracers(:)%keys) 248 hadv(1:nqo + nqCO2) = had(:); hadv(1 + nqo + nqCO2:nqtrue) = hadv_inca 249 vadv(1:nqo + nqCO2) = vad(:); vadv(1 + nqo + nqCO2:nqtrue) = vadv_inca 250 CALL MOVE_ALLOC(FROM = ttr, TO = tracers) 251 DO iq = 1, nqtrue 252 t1 => tracers(iq) 253 CALL addKey('name', t1%name, t1%keys) 254 CALL addKey('component', t1%component, t1%keys) 255 CALL addKey('parent', t1%parent, t1%keys) 256 CALL addKey('phase', t1%phase, t1%keys) 257 END DO 258 IF(setGeneration(tracers)) CALL abort_gcm(modname, 'See above', 1) !- SET FIELDS %iGeneration, %gen0Name 259 DEALLOCATE(had, hadv_inca, vad, vadv_inca, conv_flg_inca, pbl_flg_inca, solsym_inca) 260 260 !--------------------------------------------------------------------------------------------------------------------------- 261 261 ELSE !=== OTHER CASES (OLD OR NEW FORMAT, NO INCA MODULE) … … 266 266 nbtr = nqtrue - COUNT(delPhase(tracers(:)%gen0Name) == 'H2O' & 267 267 .AND. tracers(:)%component == 'lmdz') !--- Number of tracers passed to phytrac 268 268 nqINCA = COUNT(tracers(:)%component == 'inca') 269 269 lerr = getKey('hadv', hadv, ky = tracers(:)%keys) 270 270 lerr = getKey('vadv', vadv, ky = tracers(:)%keys) -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/iniconst.F90
r5117 r5118 1 2 1 ! $Id$ 3 2 … … 7 6 USE IOIPSL 8 7 USE comconst_mod, ONLY: im, imp1, jm, jmp1, lllm, lllmm1, lllmp1, & 9 8 unsim, pi, r, kappa, cpp, dtvr, dtphys 10 9 USE comvert_mod, ONLY: disvert_type, pressure_exner 11 10 USE lmdz_iniprint, ONLY: lunout, prt_level 11 12 12 IMPLICIT NONE 13 13 … … 19 19 include "dimensions.h" 20 20 include "paramet.h" 21 include "iniprint.h"22 21 23 CHARACTER(LEN =*),parameter :: modname="iniconst"24 CHARACTER(LEN =80) :: abort_message22 CHARACTER(LEN = *), parameter :: modname = "iniconst" 23 CHARACTER(LEN = 80) :: abort_message 25 24 26 25 … … 30 29 ! ---------------------- 31 30 32 im 33 jm 34 lllm 35 imp1 = iim36 jmp1 37 lllmm1 38 lllmp1 31 im = iim 32 jm = jjm 33 lllm = llm 34 imp1 = iim 35 jmp1 = jjm + 1 36 lllmm1 = llm - 1 37 lllmp1 = llm + 1 39 38 40 39 !----------------------------------------------------------------------- 41 40 42 dtphys 43 unsim = 1./iim44 pi = 2.*ASIN( 1.)41 dtphys = iphysiq * dtvr 42 unsim = 1. / iim 43 pi = 2. * ASIN(1.) 45 44 46 45 !----------------------------------------------------------------------- 47 46 48 r 47 r = cpp * kappa 49 48 50 WRITE(lunout, *) trim(modname),': R CP Kappa ',r,cpp,kappa49 WRITE(lunout, *) trim(modname), ': R CP Kappa ', r, cpp, kappa 51 50 52 51 !----------------------------------------------------------------------- … … 54 53 ! vertical discretization: default behavior depends on planet_type flag 55 54 IF (planet_type=="earth") THEN 56 disvert_type=155 disvert_type = 1 57 56 else 58 disvert_type=257 disvert_type = 2 59 58 ENDIF 60 59 ! but user can also specify using one or the other in run.def: 61 CALL getin('disvert_type', disvert_type)62 WRITE(lunout, *) trim(modname),': disvert_type=',disvert_type60 CALL getin('disvert_type', disvert_type) 61 WRITE(lunout, *) trim(modname), ': disvert_type=', disvert_type 63 62 64 63 pressure_exner = disvert_type == 1 ! default value … … 66 65 67 66 IF (disvert_type==1) THEN 68 69 67 ! standard case for Earth (automatic generation of levels) 68 CALL disvert() 70 69 ELSE IF (disvert_type==2) THEN 71 72 70 ! standard case for planets (levels generated using z2sig.def file) 71 CALL disvert_noterre 73 72 else 74 WRITE(abort_message,*) "Wrong value for disvert_type: ", disvert_type75 CALL abort_gcm(modname,abort_message,0)73 WRITE(abort_message, *) "Wrong value for disvert_type: ", disvert_type 74 CALL abort_gcm(modname, abort_message, 0) 76 75 ENDIF 77 76 -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/inidissip.F90
r5117 r5118 17 17 USE lmdz_libmath, ONLY: minmax 18 18 USE lmdz_ran1, ONLY: ran1 19 USE lmdz_iniprint, ONLY: lunout, prt_level 19 20 20 21 IMPLICIT NONE … … 22 23 include "paramet.h" 23 24 include "comdissipn.h" 24 include "iniprint.h"25 25 26 26 LOGICAL, INTENT(IN) :: lstardis -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/initdynav.F90
r5117 r5118 1 1 ! $Id$ 2 2 3 SUBROUTINE initdynav(day0, anne0,tstep,t_ops,t_wrt)3 SUBROUTINE initdynav(day0, anne0, tstep, t_ops, t_wrt) 4 4 5 5 USE IOIPSL 6 6 USE infotrac, ONLY: nqtot 7 USE com_io_dyn_mod, ONLY: histaveid, histvaveid,histuaveid, &8 dynhistave_file,dynhistvave_file,dynhistuave_file7 USE com_io_dyn_mod, ONLY: histaveid, histvaveid, histuaveid, & 8 dynhistave_file, dynhistvave_file, dynhistuave_file 9 9 USE comconst_mod, ONLY: pi 10 10 USE comvert_mod, ONLY: presnivs 11 11 USE temps_mod, ONLY: itau_dyn 12 12 USE lmdz_description, ONLY: descript 13 13 USE lmdz_iniprint, ONLY: lunout, prt_level 14 14 15 IMPLICIT NONE 15 16 … … 38 39 include "paramet.h" 39 40 include "comgeom.h" 40 include "iniprint.h"41 41 42 42 ! Arguments … … 51 51 REAL zjulian 52 52 INTEGER iq 53 REAL rlong(iip1, jjp1), rlat(iip1,jjp1)53 REAL rlong(iip1, jjp1), rlat(iip1, jjp1) 54 54 INTEGER uhoriid, vhoriid, thoriid, zvertiid 55 INTEGER ii, jj55 INTEGER ii, jj 56 56 INTEGER zan, dayref 57 57 … … 64 64 ! Appel a histbeg: creation du fichier netcdf et initialisations diverses 65 65 66 67 66 zan = anne0 68 67 dayref = day0 … … 71 70 72 71 do jj = 1, jjp1 73 74 rlong(ii,jj) = rlonv(ii) * 180. / pi75 rlat(ii,jj)= rlatu(jj) * 180. / pi76 72 do ii = 1, iip1 73 rlong(ii, jj) = rlonv(ii) * 180. / pi 74 rlat(ii, jj) = rlatu(jj) * 180. / pi 75 enddo 77 76 enddo 78 77 … … 80 79 ! Restriction de IOIPSL: seulement 2 coordonnees dans le meme fichier 81 80 ! Grille Scalaire 82 CALL histbeg(dynhistave_file, iip1, rlong(:, 1), jjp1, rlat(1,:), &83 1, iip1, 1, jjp1, &84 tau0, zjulian, tstep, thoriid,histaveid)81 CALL histbeg(dynhistave_file, iip1, rlong(:, 1), jjp1, rlat(1, :), & 82 1, iip1, 1, jjp1, & 83 tau0, zjulian, tstep, thoriid, histaveid) 85 84 86 85 ! Creation du fichier histoire pour les grilles en V et U (oblige … … 89 88 ! Grille V 90 89 do jj = 1, jjm 91 92 rlong(ii,jj) = rlonv(ii) * 180. / pi93 rlat(ii,jj) = rlatv(jj) * 180. / pi94 90 do ii = 1, iip1 91 rlong(ii, jj) = rlonv(ii) * 180. / pi 92 rlat(ii, jj) = rlatv(jj) * 180. / pi 93 enddo 95 94 enddo 96 95 97 CALL histbeg(dynhistvave_file, iip1, rlong(:, 1), jjm, rlat(1,:), &98 1, iip1, 1, jjm, &99 tau0, zjulian, tstep, vhoriid,histvaveid)96 CALL histbeg(dynhistvave_file, iip1, rlong(:, 1), jjm, rlat(1, :), & 97 1, iip1, 1, jjm, & 98 tau0, zjulian, tstep, vhoriid, histvaveid) 100 99 ! Grille U 101 100 do jj = 1, jjp1 102 103 rlong(ii,jj) = rlonu(ii) * 180. / pi104 rlat(ii,jj) = rlatu(jj) * 180. / pi105 101 do ii = 1, iip1 102 rlong(ii, jj) = rlonu(ii) * 180. / pi 103 rlat(ii, jj) = rlatu(jj) * 180. / pi 104 enddo 106 105 enddo 107 106 108 CALL histbeg(dynhistuave_file, iip1, rlong(:, 1),jjp1, rlat(1,:), &109 1, iip1, 1, jjp1, &110 tau0, zjulian, tstep, uhoriid,histuaveid)107 CALL histbeg(dynhistuave_file, iip1, rlong(:, 1), jjp1, rlat(1, :), & 108 1, iip1, 1, jjp1, & 109 tau0, zjulian, tstep, uhoriid, histuaveid) 111 110 112 111 ! Appel a histvert pour la grille verticale 113 112 114 CALL histvert(histaveid, 'presnivs','Niveaux Pression approximatifs','mb', &115 llm, presnivs/100., zvertiid,'down')116 CALL histvert(histuaveid, 'presnivs','Niveaux Pression approximatifs','mb', &117 llm, presnivs/100., zvertiid,'down')118 CALL histvert(histvaveid, 'presnivs','Niveaux Pression approximatifs','mb', &119 llm, presnivs/100., zvertiid,'down')113 CALL histvert(histaveid, 'presnivs', 'Niveaux Pression approximatifs', 'mb', & 114 llm, presnivs / 100., zvertiid, 'down') 115 CALL histvert(histuaveid, 'presnivs', 'Niveaux Pression approximatifs', 'mb', & 116 llm, presnivs / 100., zvertiid, 'down') 117 CALL histvert(histvaveid, 'presnivs', 'Niveaux Pression approximatifs', 'mb', & 118 llm, presnivs / 100., zvertiid, 'down') 120 119 121 120 ! Appels a histdef pour la definition des variables a sauvegarder … … 124 123 125 124 CALL histdef(histuaveid, 'u', 'vent u moyen ', & 126 'm/s', iip1, jjp1, uhoriid, llm, 1, llm, zvertiid, &127 32, 'ave(X)', t_ops, t_wrt)125 'm/s', iip1, jjp1, uhoriid, llm, 1, llm, zvertiid, & 126 32, 'ave(X)', t_ops, t_wrt) 128 127 129 128 ! Vents V 130 129 131 130 CALL histdef(histvaveid, 'v', 'vent v moyen', & 132 'm/s', iip1, jjm, vhoriid, llm, 1, llm, zvertiid, &133 32, 'ave(X)', t_ops, t_wrt)131 'm/s', iip1, jjm, vhoriid, llm, 1, llm, zvertiid, & 132 32, 'ave(X)', t_ops, t_wrt) 134 133 135 134 … … 137 136 138 137 CALL histdef(histaveid, 'temp', 'temperature moyenne', 'K', & 139 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, &140 32, 'ave(X)', t_ops, t_wrt)138 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, & 139 32, 'ave(X)', t_ops, t_wrt) 141 140 142 141 ! Temperature potentielle 143 142 144 143 CALL histdef(histaveid, 'theta', 'temperature potentielle', 'K', & 145 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, &146 32, 'ave(X)', t_ops, t_wrt)144 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, & 145 32, 'ave(X)', t_ops, t_wrt) 147 146 148 147 ! Geopotentiel 149 148 150 149 CALL histdef(histaveid, 'phi', 'geopotentiel moyen', '-', & 151 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, &152 32, 'ave(X)', t_ops, t_wrt)150 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, & 151 32, 'ave(X)', t_ops, t_wrt) 153 152 154 153 ! Traceurs … … 164 163 165 164 CALL histdef(histaveid, 'masse', 'masse', 'kg', & 166 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, &167 32, 'ave(X)', t_ops, t_wrt)165 iip1, jjp1, thoriid, llm, 1, llm, zvertiid, & 166 32, 'ave(X)', t_ops, t_wrt) 168 167 169 168 ! Pression au sol 170 169 171 170 CALL histdef(histaveid, 'ps', 'pression naturelle au sol', 'Pa', & 172 iip1, jjp1, thoriid, 1, 1, 1, -99, &173 32, 'ave(X)', t_ops, t_wrt)171 iip1, jjp1, thoriid, 1, 1, 1, -99, & 172 32, 'ave(X)', t_ops, t_wrt) 174 173 175 174 ! Geopotentiel au sol -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/initfluxsto.f90
r5117 r5118 10 10 USE temps_mod, ONLY: annee_ref, day_ref, itau_dyn 11 11 USE lmdz_description, ONLY: descript 12 USE lmdz_iniprint, ONLY: lunout, prt_level 12 13 13 14 IMPLICIT NONE … … 43 44 include "paramet.h" 44 45 include "comgeom.h" 45 include "iniprint.h"46 46 47 47 ! Arguments -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/inithist.F90
r5116 r5118 11 11 USE temps_mod, ONLY: itau_dyn 12 12 USE lmdz_description, ONLY: descript 13 USE lmdz_iniprint, ONLY: lunout, prt_level 13 14 14 15 IMPLICIT NONE … … 42 43 include "paramet.h" 43 44 include "comgeom.h" 44 include "iniprint.h"45 45 46 46 ! Arguments -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/sortvarc.f90
r5117 r5118 1 2 1 ! $Id$ 3 2 4 3 SUBROUTINE sortvarc & 5 (itau, ucov,teta,ps,masse,pk,phis,vorpot,phi,bern,dp,time, &6 vcov 4 (itau, ucov, teta, ps, masse, pk, phis, vorpot, phi, bern, dp, time, & 5 vcov) 7 6 8 7 USE control_mod, ONLY: resetvarc 9 8 USE comconst_mod, ONLY: dtvr, daysec, g, rad, omeg 10 9 USE logic_mod, ONLY: read_start 11 USE ener_mod, ONLY: etot, ptot,ztot,stot,ang, &12 etot0,ptot0,ztot0,stot0,ang0, &13 rmsdpdt,rmsv10 USE ener_mod, ONLY: etot, ptot, ztot, stot, ang, & 11 etot0, ptot0, ztot0, stot0, ang0, & 12 rmsdpdt, rmsv 14 13 USE lmdz_filtreg, ONLY: filtreg 14 USE lmdz_iniprint, ONLY: lunout, prt_level 15 15 IMPLICIT NONE 16 16 … … 34 34 INCLUDE "paramet.h" 35 35 INCLUDE "comgeom.h" 36 INCLUDE "iniprint.h"37 36 38 37 ! Arguments: 39 38 ! ---------- 40 39 41 INTEGER, INTENT(IN) :: itau42 REAL, INTENT(IN) :: ucov(ip1jmp1,llm)43 REAL, INTENT(IN) :: teta(ip1jmp1,llm)44 REAL, INTENT(IN) :: masse(ip1jmp1,llm)45 REAL, INTENT(IN) :: vcov(ip1jm,llm)46 REAL, INTENT(IN) :: ps(ip1jmp1)47 REAL, INTENT(IN) :: phis(ip1jmp1)48 REAL, INTENT(IN) :: vorpot(ip1jm,llm)49 REAL, INTENT(IN) :: phi(ip1jmp1,llm)50 REAL, INTENT(IN) :: bern(ip1jmp1,llm)51 REAL, INTENT(IN) :: dp(ip1jmp1)52 REAL, INTENT(IN) :: time53 REAL, INTENT(IN) :: pk(ip1jmp1,llm)40 INTEGER, INTENT(IN) :: itau 41 REAL, INTENT(IN) :: ucov(ip1jmp1, llm) 42 REAL, INTENT(IN) :: teta(ip1jmp1, llm) 43 REAL, INTENT(IN) :: masse(ip1jmp1, llm) 44 REAL, INTENT(IN) :: vcov(ip1jm, llm) 45 REAL, INTENT(IN) :: ps(ip1jmp1) 46 REAL, INTENT(IN) :: phis(ip1jmp1) 47 REAL, INTENT(IN) :: vorpot(ip1jm, llm) 48 REAL, INTENT(IN) :: phi(ip1jmp1, llm) 49 REAL, INTENT(IN) :: bern(ip1jmp1, llm) 50 REAL, INTENT(IN) :: dp(ip1jmp1) 51 REAL, INTENT(IN) :: time 52 REAL, INTENT(IN) :: pk(ip1jmp1, llm) 54 53 55 54 ! Local: 56 55 ! ------ 57 56 58 REAL :: vor(ip1jm), bernf(ip1jmp1,llm),ztotl(llm)59 REAL :: etotl(llm), stotl(llm),rmsvl(llm),angl(llm),ge(ip1jmp1)60 REAL :: cosphi(ip1jm), omegcosp(ip1jm)61 REAL :: dtvrs1j, rjour,heure,radsg,radomeg62 REAL :: massebxy(ip1jm, llm)57 REAL :: vor(ip1jm), bernf(ip1jmp1, llm), ztotl(llm) 58 REAL :: etotl(llm), stotl(llm), rmsvl(llm), angl(llm), ge(ip1jmp1) 59 REAL :: cosphi(ip1jm), omegcosp(ip1jm) 60 REAL :: dtvrs1j, rjour, heure, radsg, radomeg 61 REAL :: massebxy(ip1jm, llm) 63 62 INTEGER :: l, ij, imjmp1 64 63 65 64 REAL :: SSUM 66 LOGICAL, SAVE :: firstcal=.TRUE.67 CHARACTER(LEN =*),PARAMETER :: modname="sortvarc"65 LOGICAL, SAVE :: firstcal = .TRUE. 66 CHARACTER(LEN = *), PARAMETER :: modname = "sortvarc" 68 67 69 68 !----------------------------------------------------------------------- 70 69 ! Ehouarn: when no initialization fields from file, resetvarc should be 71 72 73 74 resetvarc=.TRUE.75 76 77 78 dtvrs1j = dtvr/daysec79 rjour = REAL( INT( itau * dtvrs1j))80 heure = ( itau*dtvrs1j-rjour) * 24.81 imjmp1= iim * jjp182 IF(ABS(heure - 24.)<=0.0001) heure = 0.83 ! 84 CALL massbarxy ( masse, massebxy)70 ! set to false 71 IF (firstcal) THEN 72 IF (.NOT.read_start) THEN 73 resetvarc = .TRUE. 74 endif 75 endif 76 77 dtvrs1j = dtvr / daysec 78 rjour = REAL(INT(itau * dtvrs1j)) 79 heure = (itau * dtvrs1j - rjour) * 24. 80 imjmp1 = iim * jjp1 81 IF(ABS(heure - 24.)<=0.0001) heure = 0. 82 ! 83 CALL massbarxy (masse, massebxy) 85 84 86 85 ! ..... Calcul de rmsdpdt ..... 87 86 88 ge(:)=dp(:)*dp(:)89 90 rmsdpdt = SSUM(ip1jmp1,ge,1) - SSUM(jjp1,ge,iip1)91 ! 92 rmsdpdt = daysec* 1.e-2 * SQRT(rmsdpdt/imjmp1)93 94 CALL SCOPY( ijp1llm,bern,1,bernf,1)95 CALL filtreg(bernf,jjp1,llm,-2,2,.TRUE.,1)87 ge(:) = dp(:) * dp(:) 88 89 rmsdpdt = SSUM(ip1jmp1, ge, 1) - SSUM(jjp1, ge, iip1) 90 ! 91 rmsdpdt = daysec * 1.e-2 * SQRT(rmsdpdt / imjmp1) 92 93 CALL SCOPY(ijp1llm, bern, 1, bernf, 1) 94 CALL filtreg(bernf, jjp1, llm, -2, 2, .TRUE., 1) 96 95 97 96 ! ..... Calcul du moment angulaire ..... 98 97 99 radsg = rad /g100 radomeg= rad * omeg101 ! 102 DO ij=iip2,ip1jm103 cosphi( ij ) = COS(rlatu((ij-1)/iip1+1))104 omegcosp(ij) = radomeg* cosphi(ij)105 98 radsg = rad / g 99 radomeg = rad * omeg 100 ! 101 DO ij = iip2, ip1jm 102 cosphi(ij) = COS(rlatu((ij - 1) / iip1 + 1)) 103 omegcosp(ij) = radomeg * cosphi(ij) 104 ENDDO 106 105 107 106 ! ... Calcul de l'energie,de l'enstrophie,de l'entropie et de rmsv . 108 107 109 DO l=1,llm110 DO ij = 1,ip1jm111 vor(ij)=vorpot(ij,l)*vorpot(ij,l)*massebxy(ij,l)112 113 ztotl(l)=(SSUM(ip1jm,vor,1)-SSUM(jjm,vor,iip1))114 115 DO ij = 1,ip1jmp1116 ge(ij)= masse(ij,l)*(phis(ij)+teta(ij,l)*pk(ij,l)+ &117 bernf(ij,l)-phi(ij,l))118 119 etotl(l) = SSUM(ip1jmp1,ge,1) - SSUM(jjp1,ge,iip1)120 121 DO ij= 1, ip1jmp1122 ge(ij) = masse(ij,l)*teta(ij,l)123 124 stotl(l)= SSUM(ip1jmp1,ge,1) - SSUM(jjp1,ge,iip1)125 126 DO ij=1,ip1jmp1127 ge(ij)=masse(ij,l)*AMAX1(bernf(ij,l)-phi(ij,l),0.)128 129 rmsvl(l)=2.*(SSUM(ip1jmp1,ge,1)-SSUM(jjp1,ge,iip1))130 131 DO ij =iip2,ip1jm132 ge(ij)=(ucov(ij,l)/cu(ij)+omegcosp(ij))*masse(ij,l) * &133 134 135 136 (SSUM(ip1jm -iip1,ge(iip2),1)-SSUM(jjm-1,ge(iip2),iip1))108 DO l = 1, llm 109 DO ij = 1, ip1jm 110 vor(ij) = vorpot(ij, l) * vorpot(ij, l) * massebxy(ij, l) 111 ENDDO 112 ztotl(l) = (SSUM(ip1jm, vor, 1) - SSUM(jjm, vor, iip1)) 113 114 DO ij = 1, ip1jmp1 115 ge(ij) = masse(ij, l) * (phis(ij) + teta(ij, l) * pk(ij, l) + & 116 bernf(ij, l) - phi(ij, l)) 117 ENDDO 118 etotl(l) = SSUM(ip1jmp1, ge, 1) - SSUM(jjp1, ge, iip1) 119 120 DO ij = 1, ip1jmp1 121 ge(ij) = masse(ij, l) * teta(ij, l) 122 ENDDO 123 stotl(l) = SSUM(ip1jmp1, ge, 1) - SSUM(jjp1, ge, iip1) 124 125 DO ij = 1, ip1jmp1 126 ge(ij) = masse(ij, l) * AMAX1(bernf(ij, l) - phi(ij, l), 0.) 127 ENDDO 128 rmsvl(l) = 2. * (SSUM(ip1jmp1, ge, 1) - SSUM(jjp1, ge, iip1)) 129 130 DO ij = iip2, ip1jm 131 ge(ij) = (ucov(ij, l) / cu(ij) + omegcosp(ij)) * masse(ij, l) * & 132 cosphi(ij) 133 ENDDO 134 angl(l) = rad * & 135 (SSUM(ip1jm - iip1, ge(iip2), 1) - SSUM(jjm - 1, ge(iip2), iip1)) 137 136 ENDDO 138 137 139 DO ij=1,ip1jmp1140 ge(ij)= ps(ij)*aire(ij)141 142 ptot = SSUM(ip1jmp1,ge,1)-SSUM(jjp1,ge,iip1)143 etot = SSUM( llm, etotl, 1)144 ztot = SSUM( llm, ztotl, 1)145 stot = SSUM( llm, stotl, 1)146 rmsv = SSUM( llm, rmsvl, 1)147 ang = SSUM( llm, angl, 1)138 DO ij = 1, ip1jmp1 139 ge(ij) = ps(ij) * aire(ij) 140 ENDDO 141 ptot = SSUM(ip1jmp1, ge, 1) - SSUM(jjp1, ge, iip1) 142 etot = SSUM(llm, etotl, 1) 143 ztot = SSUM(llm, ztotl, 1) 144 stot = SSUM(llm, stotl, 1) 145 rmsv = SSUM(llm, rmsvl, 1) 146 ang = SSUM(llm, angl, 1) 148 147 149 148 IF (firstcal.AND.resetvarc) THEN 150 WRITE(lunout,3500) itau, rjour, heure, time151 WRITE(lunout,*) trim(modname), &152 ' WARNING!!! Recomputing initial values of : '153 WRITE(lunout,*) 'ptot,rmsdpdt,etot,ztot,stot,rmsv,ang'154 WRITE(lunout,*) ptot,rmsdpdt,etot,ztot,stot,rmsv,ang155 156 157 158 159 ang0= ang149 WRITE(lunout, 3500) itau, rjour, heure, time 150 WRITE(lunout, *) trim(modname), & 151 ' WARNING!!! Recomputing initial values of : ' 152 WRITE(lunout, *) 'ptot,rmsdpdt,etot,ztot,stot,rmsv,ang' 153 WRITE(lunout, *) ptot, rmsdpdt, etot, ztot, stot, rmsv, ang 154 etot0 = etot 155 ptot0 = ptot 156 ztot0 = ztot 157 stot0 = stot 158 ang0 = ang 160 159 END IF 161 160 … … 163 162 ! are zero, which can happen when using iniacademic) 164 163 IF (etot0/=0) THEN 165 etot = etot/etot0166 else 167 etot =1.168 ENDIF 169 rmsv = SQRT(rmsv/ptot)164 etot = etot / etot0 165 else 166 etot = 1. 167 ENDIF 168 rmsv = SQRT(rmsv / ptot) 170 169 IF (ptot0/=0) THEN 171 ptot = ptot/ptot0172 else 173 ptot =1.170 ptot = ptot / ptot0 171 else 172 ptot = 1. 174 173 ENDIF 175 174 IF (ztot0/=0) THEN 176 ztot = ztot/ztot0177 else 178 ztot =1.175 ztot = ztot / ztot0 176 else 177 ztot = 1. 179 178 ENDIF 180 179 IF (stot0/=0) THEN 181 stot = stot/stot0182 else 183 stot =1.180 stot = stot / stot0 181 else 182 stot = 1. 184 183 ENDIF 185 184 IF (ang0/=0) THEN 186 ang = ang / ang0187 else 188 ang =1.185 ang = ang / ang0 186 else 187 ang = 1. 189 188 ENDIF 190 189 191 190 firstcal = .FALSE. 192 191 193 WRITE(lunout, 3500) itau, rjour, heure, time194 WRITE(lunout, 4000) ptot,rmsdpdt,etot,ztot,stot,rmsv,ang195 196 3500 FORMAT(10("*"),4x,'pas',i7,5x,'jour',f9.0,'heure',f5.1,4x &197 ,'date',f14.4,4x,10("*"))198 4000 FORMAT(10x,'masse',4x,'rmsdpdt',7x,'energie',2x,'enstrophie' &199 ,2x,'entropie',3x,'rmsv',4x,'mt.ang',/,'GLOB ' &200 ,f10.6,e13.6,5f10.3/ &201 192 WRITE(lunout, 3500) itau, rjour, heure, time 193 WRITE(lunout, 4000) ptot, rmsdpdt, etot, ztot, stot, rmsv, ang 194 195 3500 FORMAT(10("*"), 4x, 'pas', i7, 5x, 'jour', f9.0, 'heure', f5.1, 4x & 196 , 'date', f14.4, 4x, 10("*")) 197 4000 FORMAT(10x, 'masse', 4x, 'rmsdpdt', 7x, 'energie', 2x, 'enstrophie' & 198 , 2x, 'entropie', 3x, 'rmsv', 4x, 'mt.ang', /, 'GLOB ' & 199 , f10.6, e13.6, 5f10.3/ & 200 ) 202 201 END SUBROUTINE sortvarc 203 202 -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/writedynav.F90
r5117 r5118 9 9 USE temps_mod, ONLY: itau_dyn 10 10 USE lmdz_description, ONLY: descript 11 USE lmdz_iniprint, ONLY: lunout, prt_level 11 12 12 13 IMPLICIT NONE … … 33 34 include "paramet.h" 34 35 include "comgeom.h" 35 include "iniprint.h"36 36 37 37 ! Arguments 38 38 39 REAL vcov(ip1jm, llm), ucov(ip1jmp1, llm) 40 REAL teta(ip1jmp1 *llm), phi(ip1jmp1, llm), ppk(ip1jmp1*llm)41 REAL ps(ip1jmp1), masse(ip1jmp1, llm) 42 REAL phis(ip1jmp1) 39 REAL vcov(ip1jm, llm), ucov(ip1jmp1, llm) 40 REAL teta(ip1jmp1 * llm), phi(ip1jmp1, llm), ppk(ip1jmp1 * llm) 41 REAL ps(ip1jmp1), masse(ip1jmp1, llm) 42 REAL phis(ip1jmp1) 43 43 REAL q(ip1jmp1, llm, nqtot) 44 44 INTEGER time … … 47 47 ! Variables locales 48 48 49 INTEGER ndex2d(ip1jmp1), ndexu(ip1jmp1 *llm), ndexv(ip1jm*llm)49 INTEGER ndex2d(ip1jmp1), ndexu(ip1jmp1 * llm), ndexv(ip1jm * llm) 50 50 INTEGER iq, ii, ll 51 REAL tm(ip1jmp1 *llm)51 REAL tm(ip1jmp1 * llm) 52 52 REAL vnat(ip1jm, llm), unat(ip1jmp1, llm) 53 53 LOGICAL ok_sync … … 74 74 ! Vents U 75 75 76 CALL histwrite(histuaveid, 'u', itau_w, unat, 77 iip1*jjp1*llm, ndexu)76 CALL histwrite(histuaveid, 'u', itau_w, unat, & 77 iip1 * jjp1 * llm, ndexu) 78 78 79 79 ! Vents V 80 80 81 CALL histwrite(histvaveid, 'v', itau_w, vnat, 82 iip1*jjm*llm, ndexv)81 CALL histwrite(histvaveid, 'v', itau_w, vnat, & 82 iip1 * jjm * llm, ndexv) 83 83 84 84 ! Temperature potentielle moyennee 85 85 86 CALL histwrite(histaveid, 'theta', itau_w, teta, 87 iip1*jjp1*llm, ndexu)86 CALL histwrite(histaveid, 'theta', itau_w, teta, & 87 iip1 * jjp1 * llm, ndexu) 88 88 89 89 ! Temperature moyennee 90 90 91 91 do ii = 1, ijp1llm 92 tm(ii) = teta(ii) * ppk(ii)/cpp92 tm(ii) = teta(ii) * ppk(ii) / cpp 93 93 enddo 94 CALL histwrite(histaveid, 'temp', itau_w, tm, 95 iip1*jjp1*llm, ndexu)94 CALL histwrite(histaveid, 'temp', itau_w, tm, & 95 iip1 * jjp1 * llm, ndexu) 96 96 97 97 ! Geopotentiel 98 98 99 CALL histwrite(histaveid, 'phi', itau_w, phi, 100 iip1*jjp1*llm, ndexu)99 CALL histwrite(histaveid, 'phi', itau_w, phi, & 100 iip1 * jjp1 * llm, ndexu) 101 101 102 102 ! Traceurs … … 109 109 ! Masse 110 110 111 CALL histwrite(histaveid, 'masse', itau_w, masse, 112 iip1*jjp1*llm, ndexu)111 CALL histwrite(histaveid, 'masse', itau_w, masse, & 112 iip1 * jjp1 * llm, ndexu) 113 113 114 114 ! Pression au sol 115 115 116 CALL histwrite(histaveid, 'ps', itau_w, ps, iip1 *jjp1, ndex2d)116 CALL histwrite(histaveid, 'ps', itau_w, ps, iip1 * jjp1, ndex2d) 117 117 118 118 ! Geopotentiel au sol … … 121 121 122 122 IF (ok_sync) THEN 123 124 125 123 CALL histsync(histaveid) 124 CALL histsync(histvaveid) 125 CALL histsync(histuaveid) 126 126 ENDIF 127 127 -
LMDZ6/branches/Amaury_dev/libf/dyn3d_common/writehist.f90
r5117 r5118 8 8 USE temps_mod, ONLY: itau_dyn 9 9 USE lmdz_description, ONLY: descript 10 USE lmdz_iniprint, ONLY: lunout, prt_level 10 11 11 12 IMPLICIT NONE … … 36 37 include "paramet.h" 37 38 include "comgeom.h" 38 include "iniprint.h"39 39 40 40 !
Note: See TracChangeset
for help on using the changeset viewer.