source: LMDZ6/branches/Amaury_dev/libf/phylmd/moy_undefSTD.F90 @ 5151

Last change on this file since 5151 was 5137, checked in by abarral, 3 months ago

Put gradsdef.h, tracstoke.h, clesphys.h into modules

  • Property copyright set to
    Name of program: LMDZ
    Creation date: 1984
    Version: LMDZ5
    License: CeCILL version 2
    Holder: Laboratoire de m\'et\'eorologie dynamique, CNRS, UMR 8539
    See the license file in the root directory
  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.8 KB
Line 
1
2! $Id: moy_undefSTD.F90 5137 2024-07-28 20:25:12Z abarral $
3
4SUBROUTINE moy_undefstd(itap, itapm1)
5  USE netcdf, ONLY: nf90_fill_real
6  USE dimphy
7  USE phys_state_var_mod
8  USE lmdz_wxios, ONLY: missing_val_xios => missing_val, using_xios
9 
10  USE phys_cal_mod, ONLY: mth_len
11  USE lmdz_clesphys
12
13  IMPLICIT NONE
14  REAL :: missing_val
15
16  ! ====================================================================
17
18  ! I. Musat : 09.2004
19
20  ! Moyenne - a des frequences differentes - des valeurs bien definies
21  ! (.NE.missing_val) des variables interpolees a un niveau de
22  ! pression.
23  ! 1) les variables de type "day" (nout=1) ou "mth" (nout=2) sont sommees
24  ! tous les pas de temps de la physique
25
26  ! 2) les variables de type "NMC" (nout=3) sont calculees a partir
27  ! des valeurs instantannees toutes les 6 heures
28
29
30  ! NB: mettre "inst(X)" dans le write_hist*NMC.h !
31  ! ====================================================================
32
33
34  ! variables Input
35  ! INTEGER nlevSTD, klevSTD, itap
36  ! PARAMETER(klevSTD=17)
37  INTEGER itap, itapm1
38
39  ! variables locales
40  ! INTEGER i, k, nout, n
41  ! PARAMETER(nout=3) !nout=1 day/nout=2 mth/nout=3 NMC
42  INTEGER i, k, n
43  ! REAL dtime, freq_outNMC(nout), freq_moyNMC(nout)
44  ! REAL freq_outNMC(nout), freq_calNMC(nout)
45  REAL freq_moynmc(nout)
46
47  ! variables Output
48  ! REAL tnondef(klon,klevSTD,nout)
49  ! REAL tsumSTD(klon,klevSTD,nout)
50
51  REAL un_jour
52  PARAMETER (un_jour=86400.)
53! REAL missing_val
54
55! missing_val = nf90_fill_real
56  IF (using_xios) THEN
57    missing_val = missing_val_xios
58  ELSE
59    missing_val=missing_val_nf90
60  ENDIF
61
62  DO n = 1, nout
63    IF (freq_outnmc(n)<0) THEN
64      freq_moynmc(n) = (mth_len*un_jour)/freq_calnmc(n)
65      ! PRINT*,'moy_undefSTD n freq_out freq_moy =',
66      ! $n,freq_moyNMC(n)
67    ELSE
68      freq_moynmc(n) = freq_outnmc(n)/freq_calnmc(n)
69    END IF
70
71    ! calcul 1 fois pas mois, 1 fois par jour ou toutes les 6h
72
73    IF (n==1 .AND. itap==itapm1 .OR. n>1 .AND. mod(itap,nint(freq_outnmc(n)/ &
74        phys_tstep))==0) THEN
75
76      ! PRINT*,'moy_undefSTD n itap itapm1',n,itap,itapm1
77
78      DO k = 1, nlevstd
79        DO i = 1, klon
80          IF (tnondef(i,k,n)/=(freq_moynmc(n))) THEN
81            tsumstd(i, k, n) = tsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
82              ))
83            usumstd(i, k, n) = usumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
84              ))
85            vsumstd(i, k, n) = vsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
86              ))
87            wsumstd(i, k, n) = wsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
88              ))
89            phisumstd(i, k, n) = phisumstd(i, k, n)/ &
90              (freq_moynmc(n)-tnondef(i,k,n))
91            qsumstd(i, k, n) = qsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k,n &
92              ))
93            rhsumstd(i, k, n) = rhsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
94              ,n))
95            uvsumstd(i, k, n) = uvsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
96              ,n))
97            vqsumstd(i, k, n) = vqsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
98              ,n))
99            vtsumstd(i, k, n) = vtsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
100              ,n))
101            wqsumstd(i, k, n) = wqsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
102              ,n))
103            vphisumstd(i, k, n) = vphisumstd(i, k, n)/ &
104              (freq_moynmc(n)-tnondef(i,k,n))
105            wtsumstd(i, k, n) = wtsumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
106              ,n))
107            u2sumstd(i, k, n) = u2sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
108              ,n))
109            v2sumstd(i, k, n) = v2sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
110              ,n))
111            t2sumstd(i, k, n) = t2sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
112              ,n))
113            o3sumstd(i, k, n) = o3sumstd(i, k, n)/(freq_moynmc(n)-tnondef(i,k &
114              ,n))
115            o3daysumstd(i, k, n) = o3daysumstd(i, k, n)/ &
116              (freq_moynmc(n)-tnondef(i,k,n))
117          ELSE
118            tsumstd(i, k, n) = missing_val
119            usumstd(i, k, n) = missing_val
120            vsumstd(i, k, n) = missing_val
121            wsumstd(i, k, n) = missing_val
122            phisumstd(i, k, n) = missing_val
123            qsumstd(i, k, n) = missing_val
124            rhsumstd(i, k, n) = missing_val
125            uvsumstd(i, k, n) = missing_val
126            vqsumstd(i, k, n) = missing_val
127            vtsumstd(i, k, n) = missing_val
128            wqsumstd(i, k, n) = missing_val
129            vphisumstd(i, k, n) = missing_val
130            wtsumstd(i, k, n) = missing_val
131            u2sumstd(i, k, n) = missing_val
132            v2sumstd(i, k, n) = missing_val
133            t2sumstd(i, k, n) = missing_val
134            o3sumstd(i, k, n) = missing_val
135            o3daysumstd(i, k, n) = missing_val
136          END IF !tnondef(i,k,n).NE.(freq_moyNMC(n))
137        END DO !i
138      END DO !k
139    END IF !MOD(itap,NINT(freq_outNMC(n)/phys_tstep)).EQ.0
140
141  END DO !n
142
143
144END SUBROUTINE moy_undefstd
Note: See TracBrowser for help on using the repository browser.