source: dynamico_lmdz/aquaplanet/LMDZ5/libf/phylmd/moy_undefSTD.F90 @ 3882

Last change on this file since 3882 was 3838, checked in by millour, 10 years ago

Fixed call to iniphysiq from gcm and removed unused "pdayref" argument (day_ini is known from temps.h).
Removed "dtime" from phys_state_var_mod.F90; pdtphys (from time_phylmdz_mod) must be used instead.
With this revision seq and parallel MPI/OpenMP bench runs yield identical restart files.
EM

File size: 4.8 KB
Line 
1
2! $Id: moy_undefSTD.F90 1992 2014-03-05 13:19:12Z lguez $
3
4SUBROUTINE moy_undefstd(itap, itapm1)
5  USE netcdf
6  USE dimphy
7  USE phys_state_var_mod
8  USE phys_cal_mod, ONLY: mth_len
9  USE time_phylmdz_mod, ONLY: pdtphys
10  IMPLICIT NONE
11  include "clesphys.h"
12
13  ! ====================================================================
14
15  ! I. Musat : 09.2004
16
17  ! Moyenne - a des frequences differentes - des valeurs bien definies
18  ! (.NE.missing_val) des variables interpolees a un niveau de
19  ! pression.
20  ! 1) les variables de type "day" (nout=1) ou "mth" (nout=2) sont sommees
21  ! tous les pas de temps de la physique
22
23  ! 2) les variables de type "NMC" (nout=3) sont calculees a partir
24  ! des valeurs instantannees toutes les 6 heures
25
26
27  ! NB: mettre "inst(X)" dans le write_hist*NMC.h !
28  ! ====================================================================
29  ! ym#include "dimensions.h"
30  ! ym      integer jjmp1
31  ! ym      parameter (jjmp1=jjm+1-1/jjm)
32  ! ym#include "dimphy.h"
33
34
35  ! variables Input
36  ! INTEGER nlevSTD, klevSTD, itap
37  ! PARAMETER(klevSTD=17)
38  INTEGER itap, itapm1
39
40  ! variables locales
41  ! INTEGER i, k, nout, n
42  ! PARAMETER(nout=3) !nout=1 day/nout=2 mth/nout=3 NMC
43  INTEGER i, k, n
44  ! REAL dtime, freq_outNMC(nout), freq_moyNMC(nout)
45  ! REAL freq_outNMC(nout), freq_calNMC(nout)
46  REAL freq_moynmc(nout)
47
48  ! variables Output
49  ! REAL tnondef(klon,klevSTD,nout)
50  ! REAL tsumSTD(klon,klevSTD,nout)
51
52  REAL un_jour
53  PARAMETER (un_jour=86400.)
54  REAL missing_val
55
56  missing_val = nf90_fill_real
57
58  DO n = 1, nout
59    IF (freq_outnmc(n)<0) THEN
60      freq_moynmc(n) = (mth_len*un_jour)/freq_calnmc(n)
61      ! print*,'moy_undefSTD n freq_out freq_moy =',
62      ! $n,freq_moyNMC(n)
63    ELSE
64      freq_moynmc(n) = freq_outnmc(n)/freq_calnmc(n)
65    END IF
66
67    ! calcul 1 fois pas mois, 1 fois par jour ou toutes les 6h
68
69    IF (n==1 .AND. itap==itapm1 .OR. n>1 .AND. mod(itap,nint(freq_outnmc(n)/ &
70        pdtphys))==0) THEN
71
72      ! print*,'moy_undefSTD n itap itapm1',n,itap,itapm1
73
74      DO k = 1, nlevstd
75        DO i = 1, klon
76          IF (tnondef(i,k,n)/=(freq_moynmc(n))) THEN
77            tsumstd(i, k, n) = tsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
78              ))
79            usumstd(i, k, n) = usumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
80              ))
81            vsumstd(i, k, n) = vsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
82              ))
83            wsumstd(i, k, n) = wsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
84              ))
85            phisumstd(i, k, n) = phisumstd(i, k, n)/ &
86              (freq_moynmc(n)-tnondef(i,k,n))
87            qsumstd(i, k, n) = qsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
88              ))
89            rhsumstd(i, k, n) = rhsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
90              ,n))
91            uvsumstd(i, k, n) = uvsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
92              ,n))
93            vqsumstd(i, k, n) = vqsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
94              ,n))
95            vtsumstd(i, k, n) = vtsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
96              ,n))
97            wqsumstd(i, k, n) = wqsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
98              ,n))
99            vphisumstd(i, k, n) = vphisumstd(i, k, n)/ &
100              (freq_moynmc(n)-tnondef(i,k,n))
101            wtsumstd(i, k, n) = wtsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
102              ,n))
103            u2sumstd(i, k, n) = u2sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
104              ,n))
105            v2sumstd(i, k, n) = v2sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
106              ,n))
107            t2sumstd(i, k, n) = t2sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
108              ,n))
109            o3sumstd(i, k, n) = o3sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
110              ,n))
111            o3daysumstd(i, k, n) = o3daysumstd(i, k, n)/ &
112              (freq_moynmc(n)-tnondef(i,k,n))
113          ELSE
114            tsumstd(i, k, n) = missing_val
115            usumstd(i, k, n) = missing_val
116            vsumstd(i, k, n) = missing_val
117            wsumstd(i, k, n) = missing_val
118            phisumstd(i, k, n) = missing_val
119            qsumstd(i, k, n) = missing_val
120            rhsumstd(i, k, n) = missing_val
121            uvsumstd(i, k, n) = missing_val
122            vqsumstd(i, k, n) = missing_val
123            vtsumstd(i, k, n) = missing_val
124            wqsumstd(i, k, n) = missing_val
125            vphisumstd(i, k, n) = missing_val
126            wtsumstd(i, k, n) = missing_val
127            u2sumstd(i, k, n) = missing_val
128            v2sumstd(i, k, n) = missing_val
129            t2sumstd(i, k, n) = missing_val
130            o3sumstd(i, k, n) = missing_val
131            o3daysumstd(i, k, n) = missing_val
132          END IF !tnondef(i,k,n).NE.(freq_moyNMC(n))
133        END DO !i
134      END DO !k
135    END IF !MOD(itap,NINT(freq_outNMC(n)/pdtphys)).EQ.0
136
137  END DO !n
138
139  RETURN
140END SUBROUTINE moy_undefstd
Note: See TracBrowser for help on using the repository browser.