source: LMDZ6/trunk/libf/phylmd/moy_undefSTD.f90 @ 5687

Last change on this file since 5687 was 5685, checked in by fhourdin, 5 weeks ago

Correction/nettoyage sorties en pression

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