/[lmdze]/trunk/Sources/phylmd/phyredem.f
ViewVC logotype

Diff of /trunk/Sources/phylmd/phyredem.f

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/libf/phylmd/phyredem.f revision 3 by guez, Wed Feb 27 13:16:39 2008 UTC trunk/libf/phylmd/phyredem.f90 revision 19 by guez, Thu Aug 7 15:46:20 2008 UTC
# Line 1  Line 1 
1  !  module phyredem_m
2  ! $Header: /home/cvsroot/LMDZ4/libf/phylmd/phyredem.F,v 1.3 2005/05/25 13:10:09 fairhead Exp $  
3  !    IMPLICIT NONE
4  c  
5        SUBROUTINE phyredem (fichnom,dtime,radpas,  contains
6       .           rlat,rlon, pctsrf,tsol,tsoil,  
7  cIM "slab" ocean    SUBROUTINE phyredem(fichnom, rlat, rlon, pctsrf, tsol, tsoil, tslab, &
8       .           tslab,seaice,         seaice, qsurf, qsol, snow, albedo, alblw, evap, rain_fall,&
9       .           qsurf,qsol,snow,         snow_fall, solsw, sollw, fder, radsol, frugs, agesno, zmea,&
10       .           albedo, alblw, evap, rain_fall, snow_fall,         zstd, zsig, zgam, zthe, zpic, zval, t_ancien, q_ancien,&
11       .           solsw, sollw,fder,         rnebcon, ratqs, clwcon, run_off_lic_0)
12       .           radsol,frugs,agesno,  
13       .           zmea,zstd,zsig,zgam,zthe,zpic,zval,rugsrel,      ! From phylmd/phyredem.F, v 1.3 2005/05/25 13:10:09
14       .           t_ancien, q_ancien, rnebcon, ratqs, clwcon,      ! Auteur(s) Z.X. Li (LMD/CNRS) date: 19930818
15       .           run_off_lic_0)      ! Objet: Ecriture de l'etat de démarrage ou redémarrage pour la physique
16        use dimens_m  
17        use indicesol      USE indicesol, ONLY : is_lic, is_oce, is_sic, is_ter, nbsrf
18        use dimphy      USE dimphy, ONLY : klev, klon, zmasq
19        use conf_gcm_m      USE dimsoil, ONLY : nsoilmx
20        use dimsoil      USE temps, ONLY : itau_phy
21        use temps      USE netcdf95, ONLY : nf95_create, nf95_put_att
22        use clesphys      USE netcdf, ONLY : nf90_clobber, nf90_global
23        IMPLICIT none  
24  c======================================================================      INCLUDE 'netcdf.inc'
25  c Auteur(s) Z.X. Li (LMD/CNRS) date: 19930818  
26  c Objet: Ecriture de l'etat de redemarrage pour la physique      CHARACTER(len=*) fichnom
27  c======================================================================      REAL, INTENT (IN) :: rlat(klon), rlon(klon)
28        include "netcdf.inc"      REAL :: tsol(klon, nbsrf)
29  c======================================================================      REAL :: tsoil(klon, nsoilmx, nbsrf)
30        CHARACTER*(*) fichnom  
31        REAL dtime      REAL :: tslab(klon), seaice(klon) !IM "slab" ocean
32        INTEGER radpas      REAL :: qsurf(klon, nbsrf)
33        REAL, intent(in):: rlat(klon), rlon(klon)      REAL :: qsol(klon)
34        REAL tsol(klon,nbsrf)      REAL :: snow(klon, nbsrf)
35        REAL tsoil(klon,nsoilmx,nbsrf)      REAL :: albedo(klon, nbsrf)
36  cIM "slab" ocean  
37        REAL tslab(klon), seaice(klon)      REAL :: alblw(klon, nbsrf)
38        REAL qsurf(klon,nbsrf)  
39        REAL qsol(klon)      REAL :: evap(klon, nbsrf)
40        REAL snow(klon,nbsrf)      REAL :: rain_fall(klon)
41        REAL albedo(klon,nbsrf)      REAL :: snow_fall(klon)
42  cIM BEG      REAL :: solsw(klon)
43        REAL alblw(klon,nbsrf)      REAL :: sollw(klon)
44  cIM END      REAL :: fder(klon)
45        REAL evap(klon,nbsrf)      REAL :: radsol(klon)
46        REAL rain_fall(klon)      REAL :: frugs(klon, nbsrf)
47        REAL snow_fall(klon)      REAL :: agesno(klon, nbsrf)
48        real solsw(klon)      REAL :: zmea(klon)
49        real sollw(klon)      REAL, intent(in):: zstd(klon)
50        real fder(klon)      REAL, intent(in):: zsig(klon)
51        REAL radsol(klon)      REAL :: zgam(klon)
52        REAL frugs(klon,nbsrf)      REAL :: zthe(klon)
53        REAL agesno(klon,nbsrf)      REAL :: zpic(klon)
54        REAL zmea(klon)      REAL :: zval(klon)
55        REAL zstd(klon)      REAL :: pctsrf(klon, nbsrf)
56        REAL zsig(klon)      REAL :: t_ancien(klon, klev), q_ancien(klon, klev)
57        REAL zgam(klon)      REAL :: clwcon(klon, klev), rnebcon(klon, klev), ratqs(klon, klev)
58        REAL zthe(klon)      REAL :: run_off_lic_0(klon)
59        REAL zpic(klon)  
60        REAL zval(klon)      INTEGER :: nid, nvarid, idim2, idim3
61        REAL rugsrel(klon)      INTEGER :: ierr
62        REAL pctsrf(klon, nbsrf)  
63        REAL t_ancien(klon,klev), q_ancien(klon,klev)      INTEGER :: isoil, nsrf
64        real clwcon(klon,klev),rnebcon(klon,klev),ratqs(klon,klev)      CHARACTER (7) :: str7
65        REAL run_off_lic_0(klon)      CHARACTER (2) :: str2
66  c  
67        INTEGER nid, nvarid, idim1, idim2, idim3      !------------------------------------------------------------
68        INTEGER ierr  
69        INTEGER length      PRINT *, 'Call sequence information: phyredem'
70        PARAMETER (length=100)      CALL nf95_create(fichnom, nf90_clobber, nid)
71        REAL tab_cntrl(length)  
72  c      call nf95_put_att(nid, nf90_global, 'title', &
73        INTEGER isoil, nsrf           'Fichier redémarrage physique')
74        CHARACTER*7 str7      call nf95_put_att(nid, nf90_global, "itau_phy", itau_phy)
75        CHARACTER*2 str2  
76  c      ierr = nf_def_dim(nid, 'points_physiques', klon, idim2)
77        print *, "Call sequence information: phyredem"      ierr = nf_def_dim(nid, 'horizon_vertical', klon*klev, idim3)
78        ierr = NF_CREATE(fichnom, NF_CLOBBER, nid)  
79        IF (ierr.NE.NF_NOERR) THEN      ierr = nf_def_var(nid, 'longitude', nf_float, 1, idim2, nvarid)
80          write(6,*)' Pb d''ouverture du fichier '//fichnom      ierr = nf_put_att_text(nid, nvarid, 'title', 32, &
81          write(6,*)' ierr = ', ierr           'Longitudes de la grille physique')
82          STOP 1      ierr = nf_enddef(nid)
83        ENDIF      ierr = nf_put_var_real(nid, nvarid, rlon)
84  c  
85        ierr = NF_PUT_ATT_TEXT (nid, NF_GLOBAL, "title", 28,      ierr = nf_redef(nid)
86       .                       "Fichier redemmarage physique")      ierr = nf_def_var(nid, 'latitude', nf_float, 1, idim2, nvarid)
87  c      ierr = nf_put_att_text(nid, nvarid, 'title', 31, &
88        ierr = NF_DEF_DIM (nid, "index", length, idim1)           'Latitudes de la grille physique')
89        ierr = NF_DEF_DIM (nid, "points_physiques", klon, idim2)      ierr = nf_enddef(nid)
90        ierr = NF_DEF_DIM (nid, "horizon_vertical", klon*klev, idim3)      ierr = nf_put_var_real(nid, nvarid, rlat)
91  c  
92        ierr = NF_ENDDEF(nid)      ! PB ajout du masque terre/mer
93  c  
94        DO ierr = 1, length      ierr = nf_redef(nid)
95           tab_cntrl(ierr) = 0.0      ierr = nf_def_var(nid, 'masque', nf_float, 1, idim2, nvarid)
96        ENDDO      ierr = nf_put_att_text(nid, nvarid, 'title', 16, 'masque terre mer')
97        tab_cntrl(1) = dtime      ierr = nf_enddef(nid)
98        tab_cntrl(2) = radpas      ierr = nf_put_var_real(nid, nvarid, zmasq)
99        tab_cntrl(3) = co2_ppm      ! BP ajout des fraction de chaque sous-surface
100        tab_cntrl(4) = solaire  
101        tab_cntrl(5) = iflag_con      ! 1. fraction de terre
102        tab_cntrl(6) = nbapp_rad  
103        ierr = nf_redef(nid)
104        IF( cycle_diurne ) tab_cntrl( 7 ) = 1.      ierr = nf_def_var(nid, 'FTER', nf_float, 1, idim2, nvarid)
105        IF(   soil_model ) tab_cntrl( 8 ) = 1.      ierr = nf_put_att_text(nid, nvarid, 'title', 21, 'fraction de continent')
106        IF(     new_oliq ) tab_cntrl( 9 ) = 1.      ierr = nf_enddef(nid)
107        IF(     ok_orodr ) tab_cntrl(10 ) = 1.      ierr = nf_put_var_real(nid, nvarid, pctsrf(1:klon, is_ter))
108        IF(     ok_orolf ) tab_cntrl(11 ) = 1.  
109        ! 2. Fraction de glace de terre
110        tab_cntrl(13) = day_end  
111        tab_cntrl(14) = annee_ref      ierr = nf_redef(nid)
112        tab_cntrl(15) = itau_phy      ierr = nf_def_var(nid, 'FLIC', nf_float, 1, idim2, nvarid)
113  c      ierr = nf_put_att_text(nid, nvarid, 'title', 24, 'fraction glace de terre')
114        ierr = NF_REDEF (nid)      ierr = nf_enddef(nid)
115        ierr = NF_DEF_VAR (nid, "controle", NF_FLOAT, 1, idim1,nvarid)      ierr = nf_put_var_real(nid, nvarid, pctsrf(1:klon, is_lic))
116        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 22,  
117       .                        "Parametres de controle")      ! 3. fraction ocean
118        ierr = NF_ENDDEF(nid)  
119        ierr = NF_PUT_VAR_REAL (nid,nvarid,tab_cntrl)      ierr = nf_redef(nid)
120  c      ierr = nf_def_var(nid, 'FOCE', nf_float, 1, idim2, nvarid)
121        ierr = NF_REDEF (nid)      ierr = nf_put_att_text(nid, nvarid, 'title', 14, 'fraction ocean')
122        ierr = NF_DEF_VAR (nid, "longitude", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_enddef(nid)
123        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 32,      ierr = nf_put_var_real(nid, nvarid, pctsrf(1:klon, is_oce))
124       .                        "Longitudes de la grille physique")  
125        ierr = NF_ENDDEF(nid)      ! 4. Fraction glace de mer
126        ierr = NF_PUT_VAR_REAL (nid,nvarid,rlon)  
127  c      ierr = nf_redef(nid)
128        ierr = NF_REDEF (nid)      ierr = nf_def_var(nid, 'FSIC', nf_float, 1, idim2, nvarid)
129        ierr = NF_DEF_VAR (nid, "latitude", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_put_att_text(nid, nvarid, 'title', 18, 'fraction glace mer')
130        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 31,      ierr = nf_enddef(nid)
131       .                        "Latitudes de la grille physique")      ierr = nf_put_var_real(nid, nvarid, pctsrf(1:klon, is_sic))
132        ierr = NF_ENDDEF(nid)  
133        ierr = NF_PUT_VAR_REAL (nid,nvarid,rlat)  
134  c  
135  C PB ajout du masque terre/mer      DO nsrf = 1, nbsrf
136  C         IF (nsrf<=99) THEN
137        ierr = NF_REDEF (nid)            WRITE (str2, '(i2.2)') nsrf
138        ierr = NF_DEF_VAR (nid, "masque", NF_FLOAT, 1, idim2,nvarid)            ierr = nf_redef(nid)
139        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 16,            ierr = nf_def_var(nid, 'TS'//str2, nf_float, 1, idim2, nvarid)
140       .                        "masque terre mer")            ierr = nf_put_att_text(nid, nvarid, 'title', 28, &
141        ierr = NF_ENDDEF(nid)                 'Temperature de surface No.'//str2)
142        ierr = NF_PUT_VAR_REAL (nid,nvarid,zmasq)            ierr = nf_enddef(nid)
143  c BP ajout des fraction de chaque sous-surface         ELSE
144  C            PRINT *, 'Trop de sous-mailles'
145  C 1. fraction de terre            STOP 1
146  C         END IF
147        ierr = NF_REDEF (nid)         ierr = nf_put_var_real(nid, nvarid, tsol(1, nsrf))
148        ierr = NF_DEF_VAR (nid, "FTER", NF_FLOAT, 1, idim2,nvarid)      END DO
149        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 21,  
150       .                        "fraction de continent")      DO nsrf = 1, nbsrf
151        ierr = NF_ENDDEF(nid)         DO isoil = 1, nsoilmx
152        ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_ter))            IF (isoil<=99 .AND. nsrf<=99) THEN
153  C               WRITE (str7, '(i2.2, "srf", i2.2)') isoil, nsrf
154  C 2. Fraction de glace de terre               ierr = nf_redef(nid)
155  C               ierr = nf_def_var(nid, 'Tsoil'//str7, nf_float, 1, idim2, nvarid)
156        ierr = NF_REDEF (nid)               ierr = nf_put_att_text(nid, nvarid, 'title', 29, &
157        ierr = NF_DEF_VAR (nid, "FLIC", NF_FLOAT, 1, idim2,nvarid)                    'Temperature du sol No.'//str7)
158        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 24,               ierr = nf_enddef(nid)
159       .                        "fraction glace de terre")            ELSE
160        ierr = NF_ENDDEF(nid)               PRINT *, 'Trop de couches'
161        ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_lic))               STOP 1
162  C            END IF
163  C 3. fraction ocean            ierr = nf_put_var_real(nid, nvarid, tsoil(1, isoil, nsrf))
164  C         END DO
165        ierr = NF_REDEF (nid)      END DO
166        ierr = NF_DEF_VAR (nid, "FOCE", NF_FLOAT, 1, idim2,nvarid)  
167        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 14,      !IM "slab" ocean
168       .                        "fraction ocean")      ierr = nf_redef(nid)
169        ierr = NF_ENDDEF(nid)      ierr = nf_def_var(nid, 'TSLAB', nf_float, 1, idim2, nvarid)
170        ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_oce))      ierr = nf_put_att_text(nid, nvarid, 'title', 33, &
171  C           'Ecart de la SST (pour slab-ocean)')
172  C 4. Fraction glace de mer      ierr = nf_enddef(nid)
173  C      ierr = nf_put_var_real(nid, nvarid, tslab)
174        ierr = NF_REDEF (nid)  
175        ierr = NF_DEF_VAR (nid, "FSIC", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_redef(nid)
176        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 18,      ierr = nf_def_var(nid, 'SEAICE', nf_float, 1, idim2, nvarid)
177       .                        "fraction glace mer")      ierr = nf_put_att_text(nid, nvarid, 'title', 33, &
178        ierr = NF_ENDDEF(nid)           'Glace de mer kg/m2 (pour slab-ocean)')
179        ierr = NF_PUT_VAR_REAL (nid,nvarid,pctsrf(1 : klon, is_sic))      ierr = nf_enddef(nid)
180  C      ierr = nf_put_var_real(nid, nvarid, seaice)
181  C  
182  c      DO nsrf = 1, nbsrf
183        DO nsrf = 1, nbsrf         IF (nsrf<=99) THEN
184          IF (nsrf.LE.99) THEN            WRITE (str2, '(i2.2)') nsrf
185          WRITE(str2,'(i2.2)') nsrf            ierr = nf_redef(nid)
186          ierr = NF_REDEF (nid)            ierr = nf_def_var(nid, 'QS'//str2, nf_float, 1, idim2, nvarid)
187          ierr = NF_DEF_VAR (nid, "TS"//str2, NF_FLOAT, 1, idim2,nvarid)            ierr = nf_put_att_text(nid, nvarid, 'title', 25, &
188          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 28,                 'Humidite de surface No.'//str2)
189       .                        "Temperature de surface No."//str2)            ierr = nf_enddef(nid)
190          ierr = NF_ENDDEF(nid)         ELSE
191          ELSE            PRINT *, 'Trop de sous-mailles'
192          PRINT*, "Trop de sous-mailles"            STOP 1
193          stop 1         END IF
194          ENDIF         ierr = nf_put_var_real(nid, nvarid, qsurf(1, nsrf))
195          ierr = NF_PUT_VAR_REAL (nid,nvarid,tsol(1,nsrf))      END DO
196        ENDDO  
197  c      ierr = nf_redef(nid)
198        DO nsrf = 1, nbsrf      ierr = nf_def_var(nid, 'QSOL', nf_float, 1, idim2, nvarid)
199        DO isoil=1, nsoilmx      ierr = nf_put_att_text(nid, nvarid, 'title', 20, 'Eau dans le sol (mm)')
200          IF (isoil.LE.99 .AND. nsrf.LE.99) THEN      ierr = nf_enddef(nid)
201          WRITE(str7,'(i2.2,"srf",i2.2)') isoil,nsrf      ierr = nf_put_var_real(nid, nvarid, qsol)
202          ierr = NF_REDEF (nid)  
203          ierr = NF_DEF_VAR (nid, "Tsoil"//str7,NF_FLOAT,1,idim2,nvarid)      DO nsrf = 1, nbsrf
204          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 29,         IF (nsrf<=99) THEN
205       .                        "Temperature du sol No."//str7)            WRITE (str2, '(i2.2)') nsrf
206          ierr = NF_ENDDEF(nid)            ierr = nf_redef(nid)
207          ELSE            ierr = nf_def_var(nid, 'ALBE'//str2, nf_float, 1, idim2, nvarid)
208          PRINT*, "Trop de couches"            ierr = nf_put_att_text(nid, nvarid, 'title', 23, &
209          stop 1                 'albedo de surface No.'//str2)
210          ENDIF            ierr = nf_enddef(nid)
211          ierr = NF_PUT_VAR_REAL (nid,nvarid,tsoil(1,isoil,nsrf))         ELSE
212        ENDDO            PRINT *, 'Trop de sous-mailles'
213        ENDDO            STOP 1
214  c         END IF
215  cIM "slab" ocean         ierr = nf_put_var_real(nid, nvarid, albedo(1, nsrf))
216        ierr = NF_REDEF (nid)      END DO
217        ierr = NF_DEF_VAR (nid, "TSLAB", NF_FLOAT, 1, idim2,nvarid)  
218        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 33,      !IM BEG albedo LW
219       .                        "Ecart de la SST (pour slab-ocean)")      DO nsrf = 1, nbsrf
220        ierr = NF_ENDDEF(nid)         IF (nsrf<=99) THEN
221        ierr = NF_PUT_VAR_REAL (nid,nvarid,tslab)            WRITE (str2, '(i2.2)') nsrf
222  c            ierr = nf_redef(nid)
223        ierr = NF_REDEF (nid)            ierr = nf_def_var(nid, 'ALBLW'//str2, nf_float, 1, idim2, nvarid)
224        ierr = NF_DEF_VAR (nid, "SEAICE", NF_FLOAT, 1, idim2,nvarid)            ierr = nf_put_att_text(nid, nvarid, 'title', 23, &
225        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 33,                 'albedo LW de surface No.'//str2)
226       .                        "Glace de mer kg/m2 (pour slab-ocean)")            ierr = nf_enddef(nid)
227        ierr = NF_ENDDEF(nid)         ELSE
228        ierr = NF_PUT_VAR_REAL (nid,nvarid,seaice)            PRINT *, 'Trop de sous-mailles'
229  c            STOP 1
230        DO nsrf = 1, nbsrf         END IF
231          IF (nsrf.LE.99) THEN         ierr = nf_put_var_real(nid, nvarid, alblw(1, nsrf))
232          WRITE(str2,'(i2.2)') nsrf      END DO
233          ierr = NF_REDEF (nid)      !IM END albedo LW
234          ierr = NF_DEF_VAR (nid,"QS"//str2,NF_FLOAT,1,idim2,nvarid)  
235          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 25,      DO nsrf = 1, nbsrf
236       .                        "Humidite de surface No."//str2)         IF (nsrf<=99) THEN
237          ierr = NF_ENDDEF(nid)            WRITE (str2, '(i2.2)') nsrf
238          ELSE            ierr = nf_redef(nid)
239          PRINT*, "Trop de sous-mailles"            ierr = nf_def_var(nid, 'EVAP'//str2, nf_float, 1, idim2, nvarid)
240          stop 1            ierr = nf_put_att_text(nid, nvarid, 'title', 28, &
241          ENDIF                 'Evaporation de surface No.'//str2)
242        ierr = NF_PUT_VAR_REAL (nid,nvarid,qsurf(1,nsrf))            ierr = nf_enddef(nid)
243        END DO         ELSE
244  C            PRINT *, 'Trop de sous-mailles'
245        ierr = NF_REDEF (nid)            STOP 1
246        ierr = NF_DEF_VAR (nid,"QSOL",NF_FLOAT,1,idim2,nvarid)         END IF
247        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 20,         ierr = nf_put_var_real(nid, nvarid, evap(1, nsrf))
248       .    "Eau dans le sol (mm)")      END DO
249        ierr = NF_ENDDEF(nid)  
250        ierr = NF_PUT_VAR_REAL (nid,nvarid,qsol)  
251  c      DO nsrf = 1, nbsrf
252        DO nsrf = 1, nbsrf         IF (nsrf<=99) THEN
253          IF (nsrf.LE.99) THEN            WRITE (str2, '(i2.2)') nsrf
254          WRITE(str2,'(i2.2)') nsrf            ierr = nf_redef(nid)
255          ierr = NF_REDEF (nid)            ierr = nf_def_var(nid, 'SNOW'//str2, nf_float, 1, idim2, nvarid)
256          ierr = NF_DEF_VAR (nid,"ALBE"//str2,NF_FLOAT,1,idim2,nvarid)            ierr = nf_put_att_text(nid, nvarid, 'title', 22, &
257          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 23,                 'Neige de surface No.'//str2)
258       .                        "albedo de surface No."//str2)            ierr = nf_enddef(nid)
259          ierr = NF_ENDDEF(nid)         ELSE
260          ELSE            PRINT *, 'Trop de sous-mailles'
261          PRINT*, "Trop de sous-mailles"            STOP 1
262          stop 1         END IF
263          ENDIF         ierr = nf_put_var_real(nid, nvarid, snow(1, nsrf))
264        ierr = NF_PUT_VAR_REAL (nid,nvarid,albedo(1,nsrf))      END DO
265        ENDDO  
266    
267  cIM BEG albedo LW      ierr = nf_redef(nid)
268          DO nsrf = 1, nbsrf      ierr = nf_def_var(nid, 'RADS', nf_float, 1, idim2, nvarid)
269          IF (nsrf.LE.99) THEN      ierr = nf_put_att_text(nid, nvarid, 'title', 28, &
270          WRITE(str2,'(i2.2)') nsrf           'Rayonnement net a la surface')
271          ierr = NF_REDEF (nid)      ierr = nf_enddef(nid)
272          ierr = NF_DEF_VAR (nid,"ALBLW"//str2,NF_FLOAT,1,idim2,nvarid)      ierr = nf_put_var_real(nid, nvarid, radsol)
273          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 23,  
274       .                        "albedo LW de surface No."//str2)      ierr = nf_redef(nid)
275          ierr = NF_ENDDEF(nid)      ierr = nf_def_var(nid, 'solsw', nf_float, 1, idim2, nvarid)
276          ELSE      ierr = nf_put_att_text(nid, nvarid, 'title', 32, &
277          PRINT*, "Trop de sous-mailles"           'Rayonnement solaire a la surface')
278          stop 1      ierr = nf_enddef(nid)
279          ENDIF      ierr = nf_put_var_real(nid, nvarid, solsw)
280        ierr = NF_PUT_VAR_REAL (nid,nvarid,alblw(1,nsrf))  
281        ENDDO      ierr = nf_redef(nid)
282  cIM END albedo LW      ierr = nf_def_var(nid, 'sollw', nf_float, 1, idim2, nvarid)
283  c      ierr = nf_put_att_text(nid, nvarid, 'title', 27, &
284        DO nsrf = 1, nbsrf           'Rayonnement IF a la surface')
285          IF (nsrf.LE.99) THEN      ierr = nf_enddef(nid)
286          WRITE(str2,'(i2.2)') nsrf      ierr = nf_put_var_real(nid, nvarid, sollw)
287          ierr = NF_REDEF (nid)  
288          ierr = NF_DEF_VAR (nid,"EVAP"//str2,NF_FLOAT,1,idim2,nvarid)      ierr = nf_redef(nid)
289          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 28,      ierr = nf_def_var(nid, 'fder', nf_float, 1, idim2, nvarid)
290       .                        "Evaporation de surface No."//str2)      ierr = nf_put_att_text(nid, nvarid, 'title', 14, 'Derive de flux')
291          ierr = NF_ENDDEF(nid)      ierr = nf_enddef(nid)
292          ELSE      ierr = nf_put_var_real(nid, nvarid, fder)
293          PRINT*, "Trop de sous-mailles"  
294          stop 1      ierr = nf_redef(nid)
295          ENDIF      ierr = nf_def_var(nid, 'rain_f', nf_float, 1, idim2, nvarid)
296        ierr = NF_PUT_VAR_REAL (nid,nvarid,evap(1,nsrf))      ierr = nf_put_att_text(nid, nvarid, 'title', 21, 'precipitation liquide')
297        ENDDO      ierr = nf_enddef(nid)
298        ierr = nf_put_var_real(nid, nvarid, rain_fall)
299  c  
300        DO nsrf = 1, nbsrf      ierr = nf_redef(nid)
301          IF (nsrf.LE.99) THEN      ierr = nf_def_var(nid, 'snow_f', nf_float, 1, idim2, nvarid)
302          WRITE(str2,'(i2.2)') nsrf      ierr = nf_put_att_text(nid, nvarid, 'title', 20, 'precipitation solide')
303          ierr = NF_REDEF (nid)      ierr = nf_enddef(nid)
304          ierr = NF_DEF_VAR (nid,"SNOW"//str2,NF_FLOAT,1,idim2,nvarid)      ierr = nf_put_var_real(nid, nvarid, snow_fall)
305          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 22,  
306       .                        "Neige de surface No."//str2)      DO nsrf = 1, nbsrf
307          ierr = NF_ENDDEF(nid)         IF (nsrf<=99) THEN
308          ELSE            WRITE (str2, '(i2.2)') nsrf
309          PRINT*, "Trop de sous-mailles"            ierr = nf_redef(nid)
310          stop 1            ierr = nf_def_var(nid, 'RUG'//str2, nf_float, 1, idim2, nvarid)
311          ENDIF            ierr = nf_put_att_text(nid, nvarid, 'title', 23, &
312        ierr = NF_PUT_VAR_REAL (nid,nvarid,snow(1,nsrf))                 'rugosite de surface No.'//str2)
313        ENDDO            ierr = nf_enddef(nid)
314           ELSE
315  c            PRINT *, 'Trop de sous-mailles'
316        ierr = NF_REDEF (nid)            STOP 1
317        ierr = NF_DEF_VAR (nid, "RADS", NF_FLOAT, 1, idim2,nvarid)         END IF
318        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 28,         ierr = nf_put_var_real(nid, nvarid, frugs(1, nsrf))
319       .                        "Rayonnement net a la surface")      END DO
320        ierr = NF_ENDDEF(nid)  
321        ierr = NF_PUT_VAR_REAL (nid,nvarid,radsol)      DO nsrf = 1, nbsrf
322  c         IF (nsrf<=99) THEN
323        ierr = NF_REDEF (nid)            WRITE (str2, '(i2.2)') nsrf
324        ierr = NF_DEF_VAR (nid, "solsw", NF_FLOAT, 1, idim2,nvarid)            ierr = nf_redef(nid)
325        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 32,            ierr = nf_def_var(nid, 'AGESNO'//str2, nf_float, 1, idim2, nvarid)
326       .                        "Rayonnement solaire a la surface")            ierr = nf_put_att_text(nid, nvarid, 'title', 15, &
327        ierr = NF_ENDDEF(nid)                 'Age de la neige surface No.'//str2)
328        ierr = NF_PUT_VAR_REAL (nid,nvarid,solsw)            ierr = nf_enddef(nid)
329  c         ELSE
330        ierr = NF_REDEF (nid)            PRINT *, 'Trop de sous-mailles'
331        ierr = NF_DEF_VAR (nid, "sollw", NF_FLOAT, 1, idim2,nvarid)            STOP 1
332        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 27,         END IF
333       .                        "Rayonnement IF a la surface")         ierr = nf_put_var_real(nid, nvarid, agesno(1, nsrf))
334        ierr = NF_ENDDEF(nid)      END DO
335        ierr = NF_PUT_VAR_REAL (nid,nvarid,sollw)  
336  c      ierr = nf_redef(nid)
337        ierr = NF_REDEF (nid)      ierr = nf_def_var(nid, 'ZMEA', nf_float, 1, idim2, nvarid)
338        ierr = NF_DEF_VAR (nid, "fder", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_enddef(nid)
339        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 14,      ierr = nf_put_var_real(nid, nvarid, zmea)
340       .                        "Derive de flux")  
341        ierr = NF_ENDDEF(nid)      ierr = nf_redef(nid)
342        ierr = NF_PUT_VAR_REAL (nid,nvarid,fder)      ierr = nf_def_var(nid, 'ZSTD', nf_float, 1, idim2, nvarid)
343  c      ierr = nf_enddef(nid)
344        ierr = NF_REDEF (nid)      ierr = nf_put_var_real(nid, nvarid, zstd)
345        ierr = NF_DEF_VAR (nid, "rain_f", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_redef(nid)
346        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 21,      ierr = nf_def_var(nid, 'ZSIG', nf_float, 1, idim2, nvarid)
347       .                        "precipitation liquide")      ierr = nf_enddef(nid)
348        ierr = NF_ENDDEF(nid)      ierr = nf_put_var_real(nid, nvarid, zsig)
349        ierr = NF_PUT_VAR_REAL (nid,nvarid,rain_fall)      ierr = nf_redef(nid)
350  c      ierr = nf_def_var(nid, 'ZGAM', nf_float, 1, idim2, nvarid)
351        ierr = NF_REDEF (nid)      ierr = nf_enddef(nid)
352        ierr = NF_DEF_VAR (nid, "snow_f", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_put_var_real(nid, nvarid, zgam)
353        ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 20,      ierr = nf_redef(nid)
354       .                        "precipitation solide")      ierr = nf_def_var(nid, 'ZTHE', nf_float, 1, idim2, nvarid)
355        ierr = NF_ENDDEF(nid)      ierr = nf_enddef(nid)
356        ierr = NF_PUT_VAR_REAL (nid,nvarid,snow_fall)      ierr = nf_put_var_real(nid, nvarid, zthe)
357  c      ierr = nf_redef(nid)
358        DO nsrf = 1, nbsrf      ierr = nf_def_var(nid, 'ZPIC', nf_float, 1, idim2, nvarid)
359          IF (nsrf.LE.99) THEN      ierr = nf_enddef(nid)
360          WRITE(str2,'(i2.2)') nsrf      ierr = nf_put_var_real(nid, nvarid, zpic)
361          ierr = NF_REDEF (nid)      ierr = nf_redef(nid)
362          ierr = NF_DEF_VAR (nid,"RUG"//str2,NF_FLOAT,1,idim2,nvarid)      ierr = nf_def_var(nid, 'ZVAL', nf_float, 1, idim2, nvarid)
363          ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 23,      ierr = nf_enddef(nid)
364       .                        "rugosite de surface No."//str2)      ierr = nf_put_var_real(nid, nvarid, zval)
365          ierr = NF_ENDDEF(nid)  
366          ELSE      ierr = nf_redef(nid)
367          PRINT*, "Trop de sous-mailles"      ierr = nf_def_var(nid, 'TANCIEN', nf_float, 1, idim3, nvarid)
368          stop 1      ierr = nf_enddef(nid)
369          ENDIF      ierr = nf_put_var_real(nid, nvarid, t_ancien)
370        ierr = NF_PUT_VAR_REAL (nid,nvarid,frugs(1,nsrf))  
371        ENDDO      ierr = nf_redef(nid)
372  c      ierr = nf_def_var(nid, 'QANCIEN', nf_float, 1, idim3, nvarid)
373        DO nsrf = 1, nbsrf      ierr = nf_enddef(nid)
374          IF (nsrf.LE.99) THEN      ierr = nf_put_var_real(nid, nvarid, q_ancien)
375              WRITE(str2,'(i2.2)') nsrf  
376              ierr = NF_REDEF (nid)      ierr = nf_redef(nid)
377              ierr = NF_DEF_VAR (nid,"AGESNO"//str2,NF_FLOAT,1,idim2      ierr = nf_def_var(nid, 'RUGMER', nf_float, 1, idim2, nvarid)
378       $          ,nvarid)      ierr = nf_put_att_text(nid, nvarid, 'title', 28, &
379              ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 15,           'Longueur de rugosite sur mer')
380       .                        "Age de la neige surface No."//str2)      ierr = nf_enddef(nid)
381              ierr = NF_ENDDEF(nid)      ierr = nf_put_var_real(nid, nvarid, frugs(1, is_oce))
382          ELSE  
383              PRINT*, "Trop de sous-mailles"      ierr = nf_redef(nid)
384              stop 1      ierr = nf_def_var(nid, 'CLWCON', nf_float, 1, idim2, nvarid)
385          ENDIF      ierr = nf_put_att_text(nid, nvarid, 'title', 28, 'Eau liquide convective')
386        ierr = NF_PUT_VAR_REAL (nid,nvarid,agesno(1,nsrf))      ierr = nf_enddef(nid)
387        ENDDO      ierr = nf_put_var_real(nid, nvarid, clwcon)
388  c  
389        ierr = NF_REDEF (nid)      ierr = nf_redef(nid)
390        ierr = NF_DEF_VAR (nid, "ZMEA", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_def_var(nid, 'RNEBCON', nf_float, 1, idim2, nvarid)
391        ierr = NF_ENDDEF(nid)      ierr = nf_put_att_text(nid, nvarid, 'title', 28, 'Nebulosite convective')
392        ierr = NF_PUT_VAR_REAL (nid,nvarid,zmea)      ierr = nf_enddef(nid)
393  c      ierr = nf_put_var_real(nid, nvarid, rnebcon)
394        ierr = NF_REDEF (nid)  
395        ierr = NF_DEF_VAR (nid, "ZSTD", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_redef(nid)
396        ierr = NF_ENDDEF(nid)      ierr = nf_def_var(nid, 'RATQS', nf_float, 1, idim2, nvarid)
397        ierr = NF_PUT_VAR_REAL (nid,nvarid,zstd)      ierr = nf_put_att_text(nid, nvarid, 'title', 5, 'Ratqs')
398        ierr = NF_REDEF (nid)      ierr = nf_enddef(nid)
399        ierr = NF_DEF_VAR (nid, "ZSIG", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_put_var_real(nid, nvarid, ratqs)
400        ierr = NF_ENDDEF(nid)  
401        ierr = NF_PUT_VAR_REAL (nid,nvarid,zsig)      ! run_off_lic_0
402        ierr = NF_REDEF (nid)  
403        ierr = NF_DEF_VAR (nid, "ZGAM", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_redef(nid)
404        ierr = NF_ENDDEF(nid)      ierr = nf_def_var(nid, 'RUNOFFLIC0', nf_float, 1, idim2, nvarid)
405        ierr = NF_PUT_VAR_REAL (nid,nvarid,zgam)      ierr = nf_put_att_text(nid, nvarid, 'title', 10, 'Runofflic0')
406        ierr = NF_REDEF (nid)      ierr = nf_enddef(nid)
407        ierr = NF_DEF_VAR (nid, "ZTHE", NF_FLOAT, 1, idim2,nvarid)      ierr = nf_put_var_real(nid, nvarid, run_off_lic_0)
408        ierr = NF_ENDDEF(nid)  
409        ierr = NF_PUT_VAR_REAL (nid,nvarid,zthe)  
410        ierr = NF_REDEF (nid)      ierr = nf_close(nid)
411        ierr = NF_DEF_VAR (nid, "ZPIC", NF_FLOAT, 1, idim2,nvarid)  
412        ierr = NF_ENDDEF(nid)    END SUBROUTINE phyredem
413        ierr = NF_PUT_VAR_REAL (nid,nvarid,zpic)  
414        ierr = NF_REDEF (nid)  end module phyredem_m
       ierr = NF_DEF_VAR (nid, "ZVAL", NF_FLOAT, 1, idim2,nvarid)  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,zval)  
       ierr = NF_REDEF (nid)  
       ierr = NF_DEF_VAR (nid, "RUGSREL", NF_FLOAT, 1, idim2,nvarid)  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,rugsrel)  
 c  
       ierr = NF_REDEF (nid)  
       ierr = NF_DEF_VAR (nid, "TANCIEN", NF_FLOAT, 1, idim3,nvarid)  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,t_ancien)  
 c  
       ierr = NF_REDEF (nid)  
       ierr = NF_DEF_VAR (nid, "QANCIEN", NF_FLOAT, 1, idim3,nvarid)  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,q_ancien)  
 c  
       ierr = NF_REDEF (nid)  
       ierr = NF_DEF_VAR (nid, "RUGMER", NF_FLOAT, 1, idim2,nvarid)  
       ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 28,  
      .                        "Longueur de rugosite sur mer")  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,frugs(1,is_oce))  
 c  
       ierr = NF_REDEF (nid)  
       ierr = NF_DEF_VAR (nid, "CLWCON", NF_FLOAT, 1, idim2,nvarid)  
       ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 28,  
      .                        "Eau liquide convective")  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,clwcon)  
 c  
       ierr = NF_REDEF (nid)  
       ierr = NF_DEF_VAR (nid, "RNEBCON", NF_FLOAT, 1, idim2,nvarid)  
       ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 28,  
      .                        "Nebulosite convective")  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,rnebcon)  
 c  
       ierr = NF_REDEF (nid)  
       ierr = NF_DEF_VAR (nid, "RATQS", NF_FLOAT, 1, idim2,nvarid)  
       ierr = NF_PUT_ATT_TEXT(nid,nvarid,"title", 5,  
      .                        "Ratqs")  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,ratqs)  
 c  
 c run_off_lic_0  
 c  
       ierr = NF_REDEF (nid)  
       ierr=NF_DEF_VAR(nid,"RUNOFFLIC0",NF_FLOAT, 1,idim2,nvarid)  
       ierr = NF_PUT_ATT_TEXT (nid,nvarid,"title", 10,  
      .                        "Runofflic0")  
       ierr = NF_ENDDEF(nid)  
       ierr = NF_PUT_VAR_REAL (nid,nvarid,run_off_lic_0)  
 c  
 c  
       ierr = NF_CLOSE(nid)  
 c  
       RETURN  
       END  

Legend:
Removed from v.3  
changed lines
  Added in v.19

  ViewVC Help
Powered by ViewVC 1.1.21