source: LMDZ5/branches/LMDZ5V2.0-dev/libf/dyn3dpar/etat0_netcdf.F90 @ 5452

Last change on this file since 5452 was 1486, checked in by Laurent Fairhead, 14 years ago

Inclusion de la routine "stats" du modele martien qui permet de sortir
le cycle diurne moyen de différentes variables et l'écart-type.
Pour activer cette routine mettre
callstats=y
dans config.def. Les résultats seront placés dans le fichier stats.nc
Pour rajouter des variables: allez à la fin de physiq.F et prendre modèle sur
les lignes call wstats(...) et ne pas oublier de modifier le nombre de variables
sorties dans statto.h (n2dvar et n2dvar).
Attention: la routine n'est pas optimale (elle stocke ses résultats intermédiaires
dans le fichier stats.nc et les lit et écrit à chaque appel de la physique)
et n'a été testée dans LMDZ pour l'instant que sur PC/gfortran
et sur SX8/monoprocesseur. Encore du travail donc. Mais la routine est utilisée
régulièrement avec le modèle martien :-)


Inclusion of the martian model "stats" routine that outputs the mean diurnal
cycle of variables as well as their standard deviation.
To activate the routine, one needs to put
callstats=y
in the config.def file. Results will be output in a stats.nc file
To add more output variables: go to the end of physiq.F and use the call wstats(...)
lines as a template and do not forget to modify the number of output variables in
statto.h (n2dvar and n3dvar)
Caution: the routine is not optimal (as it stocks preliminary results in the stats.nc
file reading and writing at each physics step) and has only been tested in LMDZ
with a PC/gfortran setup and on a NEC-SX8/monoprocessor setup. Some work then still to
be done. But it is used regularly with the martial model :-)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 19.3 KB
RevLine 
[1000]1!
[1319]2! $Id: etat0_netcdf.F90 1486 2011-02-11 12:07:39Z aborella $
[1000]3!
[1319]4!-------------------------------------------------------------------------------
5!
6SUBROUTINE etat0_netcdf(ib, masque, letat0)
7!
8!-------------------------------------------------------------------------------
9! Purpose: Creates initial states
10!-------------------------------------------------------------------------------
11! Note: This routine is designed to work for Earth
12!-------------------------------------------------------------------------------
[1425]13  USE control_mod
[1319]14#ifdef CPP_EARTH
15  USE startvar
16  USE ioipsl
17  USE dimphy
18  USE infotrac
19  USE fonte_neige_mod
20  USE pbl_surface_mod
21  USE phys_state_var_mod
22  USE filtreg_mod
23  USE regr_lat_time_climoz_m, ONLY: regr_lat_time_climoz
24  USE conf_phys_m,            ONLY: conf_phys
[1406]25! For parameterization of ozone chemistry:
26  use regr_lat_time_coefoz_m, only: regr_lat_time_coefoz
27  use press_coefoz_m, only: press_coefoz
28  use regr_pr_o3_m, only: regr_pr_o3
[1319]29  USE netcdf, ONLY : NF90_OPEN, NF90_NOWRITE, NF90_CLOSE, NF90_NOERR
[1146]30#endif
[1319]31  IMPLICIT NONE
32!-------------------------------------------------------------------------------
33! Arguments:
[1000]34#include "dimensions.h"
35#include "paramet.h"
[1319]36#include "iniprint.h"
37  LOGICAL,                    INTENT(IN)    :: ib     ! barycentric interpolat.
38  REAL, DIMENSION(iip1,jjp1), INTENT(INOUT) :: masque ! land mask
39  LOGICAL,                    INTENT(IN)    :: letat0 ! F: masque only required
40#ifndef CPP_EARTH
41  WRITE(lunout,*)'limit_netcdf: Earth-specific routine, needs Earth physics'
42#else
43!-------------------------------------------------------------------------------
44! Local variables:
[1000]45#include "comgeom2.h"
46#include "comvert.h"
47#include "comconst.h"
48#include "indicesol.h"
49#include "dimsoil.h"
50#include "temps.h"
[1319]51  REAL,    DIMENSION(klon)                 :: tsol, qsol
52  REAL,    DIMENSION(klon)                 :: sn, rugmer, run_off_lic_0
53  REAL,    DIMENSION(iip1,jjp1)            :: orog, rugo, psol, phis
54  REAL,    DIMENSION(iip1,jjp1,llm+1)      :: p3d
55  REAL,    DIMENSION(iip1,jjp1,llm)        :: uvent, t3d, tpot, qsat, qd
56  REAL,    DIMENSION(iip1,jjm ,llm)        :: vvent
57  REAL,    DIMENSION(:,:,:,:), ALLOCATABLE :: q3d
58  REAL,    DIMENSION(klon,nbsrf)           :: qsolsrf, snsrf, evap
59  REAL,    DIMENSION(klon,nbsrf)           :: frugs, agesno
60  REAL,    DIMENSION(klon,nsoilmx,nbsrf)   :: tsoil
[1146]61
[1319]62!--- Local variables for sea-ice reading:
63  INTEGER                                  :: iml_lic, jml_lic, llm_tmp
64  INTEGER                                  :: ttm_tmp, iret, fid
65  INTEGER, DIMENSION(1)                    :: itaul
66  REAL,    DIMENSION(1)                    :: lev
67  REAL                                     :: date
68  REAL,    DIMENSION(:,:),   ALLOCATABLE   ::  lon_lic,  lat_lic, fraclic
69  REAL,    DIMENSION(:),     ALLOCATABLE   :: dlon_lic, dlat_lic
70  REAL,    DIMENSION(iip1,jjp1)            :: flic_tmp
[1000]71
[1319]72!--- Misc
73  CHARACTER(LEN=80)                        :: x, fmt
74  INTEGER                                  :: i, j, l, ji
75  REAL,    DIMENSION(iip1,jjp1,llm)        :: alpha, beta, pk, pls, y
76  REAL,    DIMENSION(ip1jmp1)              :: pks
[1000]77
78#include "comdissnew.h"
79#include "serre.h"
80#include "clesphys.h"
81
[1319]82  REAL,    DIMENSION(iip1,jjp1,llm)        :: masse
83  INTEGER :: itau, iday
84  REAL    :: xpn, xps, time, phystep
85  REAL,    DIMENSION(iim)                  :: xppn, xpps
86  REAL,    DIMENSION(ip1jmp1,llm)          :: pbaru, phi, w
87  REAL,    DIMENSION(ip1jm  ,llm)          :: pbarv
88  REAL,    DIMENSION(klon)                 :: fder
[1000]89
[1319]90!--- Local variables for ocean mask reading:
91  INTEGER :: nid_o2a, iml_omask, jml_omask
92  LOGICAL :: couple=.FALSE.
93  REAL,    DIMENSION(:,:), ALLOCATABLE ::  lon_omask, lat_omask, ocemask, ocetmp
94  REAL,    DIMENSION(:),   ALLOCATABLE :: dlon_omask,dlat_omask
95  REAL,    DIMENSION(klon)             :: ocemask_fi
96  INTEGER, DIMENSION(klon-2)           :: isst
97  REAL,    DIMENSION(iim,jjp1)         :: zx_tmp_2d
98  REAL    :: dummy
99  LOGICAL :: ok_newmicro, ok_journe, ok_mensuel, ok_instan, ok_hf
[1486]100  LOGICAL :: ok_LES, ok_ade, ok_aie, aerosol_couple, new_aod, callstats
[1319]101  INTEGER :: iflag_radia, flag_aerosol
102  REAL    :: bl95_b0, bl95_b1, fact_cldcon, facttemps, ratqsbas, ratqshaut
103  REAL    :: tau_ratqs
104  INTEGER :: iflag_cldcon, iflag_ratqs, iflag_coupl, iflag_clos, iflag_wake
105  INTEGER :: iflag_thermals, nsplit_thermals
106  INTEGER :: iflag_thermals_ed, iflag_thermals_optflux
107  REAL    :: tau_thermals, solarlong0,  seuil_inversion
108  INTEGER :: read_climoz ! read ozone climatology
109!  Allowed values are 0, 1 and 2
110!     0: do not read an ozone climatology
111!     1: read a single ozone climatology that will be used day and night
112!     2: read two ozone climatologies, the average day and night
113!     climatology and the daylight climatology
114!-------------------------------------------------------------------------------
[1406]115  REAL    :: alp_offset
[1425]116  logical found
[1406]117
[1319]118!--- Constants
119  pi     = 4. * ATAN(1.)
120  rad    = 6371229.
121  daysec = 86400.
122  omeg   = 2.*pi/daysec
123  g      = 9.8
124  kappa  = 0.2857143
125  cpp    = 1004.70885
126  preff  = 101325.
127  pa     = 50000.
128  jmp1   = jjm + 1
[1000]129
[1319]130!--- CONSTRUCT A GRID
131  CALL conf_phys(  ok_journe, ok_mensuel, ok_instan, ok_hf, ok_LES,     &
[1486]132                   callstats,                                           &
[1319]133                   solarlong0,seuil_inversion,                          &
134                   fact_cldcon, facttemps,ok_newmicro,iflag_radia,      &
135                   iflag_cldcon,                                        &
136                   iflag_ratqs,ratqsbas,ratqshaut,tau_ratqs,            &
137                   ok_ade, ok_aie, aerosol_couple,                      &
138                   flag_aerosol, new_aod,                               &
139                   bl95_b0, bl95_b1,                                    &
140                   iflag_thermals,nsplit_thermals,tau_thermals,         &
141                   iflag_thermals_ed,iflag_thermals_optflux,            &
[1403]142                   iflag_coupl,iflag_clos,iflag_wake, read_climoz,      &
143                   alp_offset)
[1000]144
[1319]145! co2_ppm0 : initial value of atmospheric CO2 from .def file (co2_ppm value)
146  co2_ppm0 = co2_ppm
[1000]147
[1319]148  dtvr   = daysec/FLOAT(day_step)
149  WRITE(lunout,*)'dtvr',dtvr
[1000]150
[1319]151  CALL iniconst()
152  CALL inigeom()
[1279]153
[1319]154!--- Initializations for tracers
155  CALL infotrac_init
156  ALLOCATE(q3d(iip1,jjp1,llm,nqtot))
[1000]157
[1319]158  CALL inifilr()
159  CALL phys_state_var_init(read_climoz)
[1000]160
[1319]161  rlat(1) = ASIN(1.0)
162  DO j=2,jjm; rlat((j-2)*iim+2:(j-1)*iim+1)=rlatu(j);     END DO
163  rlat(klon) = - ASIN(1.0)
164  rlat(:)=rlat(:)*(180.0/pi)
[1279]165
[1319]166  rlon(1) = 0.0
167  DO j=2,jjm; rlon((j-2)*iim+2:(j-1)*iim+1)=rlonv(1:iim); END DO
168  rlon(klon) = 0.0
169  rlon(:)=rlon(:)*(180.0/pi)
[1000]170
[1319]171! For a coupled simulation, the ocean mask from ocean model is used to compute
172! the weights an to insure ocean fractions are the same for atmosphere and ocean
173! Otherwise, mask is created using Relief file.
[1279]174
[1319]175  WRITE(lunout,*)'Essai de lecture masque ocean'
176  iret = NF90_OPEN("o2a.nc", NF90_NOWRITE, nid_o2a)
177  IF(iret/=NF90_NOERR) THEN
178    WRITE(lunout,*)'ATTENTION!! pas de fichier o2a.nc trouve'
179    WRITE(lunout,*)'Run force'
180    x='masque'
181    masque(:,:)=0.0
[1323]182    CALL startget_phys2d(x, iip1, jjp1, rlonv, rlatu, masque, 0.0, jjm, &
183   &              rlonu, rlatv, ib)
[1319]184    WRITE(lunout,*)'MASQUE construit : Masque'
185    WRITE(lunout,'(97I1)') nINT(masque)
186    CALL gr_dyn_fi(1, iip1, jjp1, klon, masque, zmasq)
187    WHERE(   zmasq(:)<EPSFRA) zmasq(:)=0.
188    WHERE(1.-zmasq(:)<EPSFRA) zmasq(:)=1.
189  ELSE
[1323]190    WRITE(lunout,*)'ATTENTION!! fichier o2a.nc trouve'
191    WRITE(lunout,*)'Run couple'
[1319]192    couple=.true.
193    iret=NF90_CLOSE(nid_o2a)
194    CALL flininfo("o2a.nc", iml_omask, jml_omask, llm_tmp, ttm_tmp, nid_o2a)
195    IF(iml_omask/=iim .OR.jml_omask/=jjp1) THEN
196      WRITE(lunout,*)'Dimensions non compatibles pour masque ocean'
197      WRITE(lunout,*)'iim = ',iim,' iml_omask = ',iml_omask
198      WRITE(lunout,*)'jjp1 = ',jjp1,' jml_omask = ',jml_omask
199      CALL abort_gcm('etat0_netcdf','Dimensions non compatibles pour masque oc&
200     &ean',1)
201    END IF
202    ALLOCATE(   ocemask(iml_omask,jml_omask),   ocetmp(iml_omask,jml_omask))
203    ALLOCATE( lon_omask(iml_omask,jml_omask),lat_omask(iml_omask,jml_omask))
204    ALLOCATE(dlon_omask(iml_omask),         dlat_omask(jml_omask))
[1323]205    CALL flinopen("o2a.nc", .FALSE., iml_omask, jml_omask, llm_tmp, lon_omask,&
206   &              lat_omask, lev, ttm_tmp, itaul, date, dt, fid)
207    CALL flinget(fid, 'OceMask', iml_omask, jml_omask, llm_tmp, ttm_tmp, &
208   &              1, 1, ocetmp)
[1319]209    CALL flinclo(fid)
210    dlon_omask(1:iml_omask) = lon_omask(1:iml_omask,1)
211    dlat_omask(1:jml_omask) = lat_omask(1,1:jml_omask)
212    ocemask = ocetmp
213    IF(dlat_omask(1)<dlat_omask(jml_omask)) THEN
214      DO j=1,jml_omask
215        ocemask(:,j) = ocetmp(:,jml_omask-j+1)
216      END DO
217    END IF
218!
219! Ocean mask to physical grid
220!*******************************************************************************
221    WRITE(lunout,*)'ocemask '
222    WRITE(fmt,"(i4,'i1)')")iml_omask ; fmt='('//ADJUSTL(fmt)
223    WRITE(lunout,fmt)int(ocemask)
224    ocemask_fi(1)=ocemask(1,1)
[1328]225    DO j=2,jjm; ocemask_fi((j-2)*iim+2:(j-1)*iim+1)=ocemask(1:iim,j); END DO
[1319]226    ocemask_fi(klon)=ocemask(1,jjp1)
227    zmasq=1.-ocemask_fi
228  END IF
[1279]229
[1319]230  CALL gr_fi_dyn(1,klon,iip1,jjp1,zmasq,masque)
[1000]231
[1319]232  ! The startget calls need to be replaced by a call to restget to get the
233  ! values in the restart file
234  x = 'relief'; orog(:,:) = 0.0
[1323]235  CALL startget_phys2d(x,iip1,jjp1,rlonv,rlatu, orog, 0.0,jjm,rlonu,rlatv,ib,&
236 &               masque)
[1000]237
[1319]238  x = 'rugosite'; rugo(:,:) = 0.0
[1323]239  CALL startget_phys2d(x,iip1,jjp1,rlonv,rlatu, rugo, 0.0,jjm, rlonu,rlatv,ib)
[1319]240!  WRITE(lunout,'(49I1)') INT(orog(:,:)*10)
241!  WRITE(lunout,'(49I1)') INT(rugo(:,:)*10)
[1000]242
[1319]243! Sub-surfaces initialization
244!*******************************************************************************
245  pctsrf=0.
246  x = 'psol'; psol(:,:) = 0.0
[1323]247  CALL startget_phys2d(x,iip1,jjp1,rlonv,rlatu,psol,0.0,jjm,rlonu,rlatv,ib)
[1319]248!  WRITE(lunout,*) 'PSOL :', psol(10,20)
249!  WRITE(lunout,*) ap(:), bp(:)
[1000]250
[1319]251! Mid-levels pressure computation
252!*******************************************************************************
253  CALL pression(ip1jmp1, ap, bp, psol, p3d)
254  CALL exner_hyb(ip1jmp1, psol, p3d, alpha, beta, pks, pk, y)
255  pls(:,:,:)=preff*(pk(:,:,:)/cpp)**(1./kappa)
256!  WRITE(lunout,*) 'P3D :', p3d(10,20,:)
257!  WRITE(lunout,*) 'PK:',    pk(10,20,:)
258!  WRITE(lunout,*) 'PLS :', pls(10,20,:)
[1000]259
[1319]260  x = 'surfgeo'; phis(:,:) = 0.0
[1323]261  CALL startget_phys2d(x,iip1,jjp1,rlonv,rlatu,phis, 0.0,jjm, rlonu,rlatv,ib)
[1000]262
[1319]263  x = 'u';    uvent(:,:,:) = 0.0
[1323]264  CALL startget_dyn(x,rlonu,rlatu,pls,y,uvent,0.0,  &
265 &                  rlonv,rlatv,ib)
[1000]266
[1319]267  x = 'v';    vvent(:,:,:) = 0.0
[1323]268  CALL startget_dyn(x, rlonv,rlatv,pls(:, :jjm, :),y(:, :jjm, :),vvent,0.0, &
269 &                  rlonu,rlatu(:jjm),ib)
[1279]270
[1319]271  x = 't';    t3d(:,:,:) = 0.0
[1323]272  CALL startget_dyn(x,rlonv,rlatu,pls,y,t3d,0.0,    &
273 &                  rlonu,rlatv,ib)
[1279]274
[1319]275  x = 'tpot'; tpot(:,:,:) = 0.0
[1323]276  CALL startget_dyn(x,rlonv,rlatu,pls,pk,tpot,0.0,  &
277 &                  rlonu,rlatv,ib)
[1000]278
[1319]279  WRITE(lunout,*) 'T3D min,max:',minval(t3d(:,:,:)),maxval(t3d(:,:,:))
280  WRITE(lunout,*) 'PLS min,max:',minval(pls(:,:,:)),maxval(pls(:,:,:))
[1000]281
[1319]282! Humidity at saturation computation
283!*******************************************************************************
284  WRITE(lunout,*) 'avant q_sat'
285  CALL q_sat(llm*jjp1*iip1, t3d, pls, qsat)
286  WRITE(lunout,*) 'apres q_sat'
287  WRITE(lunout,*) 'QSAT min,max:',minval(qsat(:,:,:)),maxval(qsat(:,:,:))
288!  WRITE(lunout,*) 'QSAT :',qsat(10,20,:)
[1000]289
[1319]290  x = 'q';    qd (:,:,:) = 0.0
[1323]291  CALL startget_dyn(x,rlonv,rlatu,pls,qsat,qd,0.0, rlonu,rlatv,ib)
[1319]292  q3d(:,:,:,:) = 0.0 ; q3d(:,:,:,1) = qd(:,:,:)
[1000]293
[1406]294! Parameterization of ozone chemistry:
295! Look for ozone tracer:
296  i = 1
297  DO
298    found = tname(i)=="O3" .OR. tname(i)=="o3"
299    if (found .or. i == nqtot) exit
300    i = i + 1
301  end do
302  if (found) then
303    call regr_lat_time_coefoz
304    call press_coefoz
305    call regr_pr_o3(p3d, q3d(:, :, :, i))
306!   Convert from mole fraction to mass fraction:
307    q3d(:, :, :, i) = q3d(:, :, :, i)  * 48. / 29.
308  end if
309
[1319]310!--- OZONE CLIMATOLOGY
311  IF(read_climoz>=1) CALL regr_lat_time_climoz(read_climoz)
[1000]312
[1319]313  x = 'tsol'; tsol(:) = 0.0
[1323]314  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,tsol,0.0,jjm,rlonu,rlatv,ib)
[1000]315
[1319]316  x = 'qsol';  qsol(:) = 0.0
[1323]317  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,qsol,0.0,jjm,rlonu,rlatv,ib)
[1000]318
[1319]319  x = 'snow';  sn(:) = 0.0
[1323]320  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,sn,0.0,jjm,rlonu,rlatv,ib)
[1000]321
[1319]322  x = 'rads';  radsol(:) = 0.0
[1323]323  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,radsol,0.0,jjm,rlonu,rlatv,ib)
[1000]324
[1319]325  x = 'rugmer'; rugmer(:) = 0.0
[1323]326  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,rugmer,0.0,jjm,rlonu,rlatv,ib)
[1000]327
[1319]328  x = 'zmea';  zmea(:) = 0.0
[1323]329  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,zmea,0.0,jjm,rlonu,rlatv,ib)
[1000]330
[1319]331  x = 'zstd';  zstd(:) = 0.0
[1323]332  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,zstd,0.0,jjm,rlonu,rlatv,ib)
[1000]333
[1319]334  x = 'zsig';  zsig(:) = 0.0
[1323]335  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,zsig,0.0,jjm,rlonu,rlatv,ib)
[1000]336
[1319]337  x = 'zgam';  zgam(:) = 0.0
[1323]338  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,zgam,0.0,jjm,rlonu,rlatv,ib)
[1000]339
[1319]340  x = 'zthe';  zthe(:) = 0.0
[1323]341  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,zthe,0.0,jjm,rlonu,rlatv,ib)
[1000]342
[1319]343  x = 'zpic';  zpic(:) = 0.0
[1323]344  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,zpic,0.0,jjm,rlonu,rlatv,ib)
[1000]345
[1319]346  x = 'zval';  zval(:) = 0.0
[1323]347  CALL startget_phys1d(x,iip1,jjp1,rlonv,rlatu,klon,zval,0.0,jjm,rlonu,rlatv,ib)
[1000]348
[1319]349!  WRITE(lunout,'(48I3)') 'TSOL :', INT(tsol(2:klon)-273)
[1000]350
[1319]351! Soil ice file reading for soil fraction and soil ice fraction
352!*******************************************************************************
353  CALL flininfo("landiceref.nc", iml_lic, jml_lic, llm_tmp, ttm_tmp, fid)
354  ALLOCATE( lat_lic(iml_lic,jml_lic),lon_lic(iml_lic, jml_lic))
355  ALLOCATE(dlat_lic(jml_lic),       dlon_lic(iml_lic))
356  ALLOCATE( fraclic(iml_lic,jml_lic))
[1323]357  CALL flinopen("landiceref.nc", .FALSE., iml_lic, jml_lic, llm_tmp,  &
358 &               lon_lic, lat_lic, lev, ttm_tmp, itaul, date, dt, fid)
[1319]359  CALL flinget(fid, 'landice', iml_lic, jml_lic, llm_tmp, ttm_tmp, 1,1, fraclic)
360  CALL flinclo(fid)
[1000]361
[1319]362! Interpolation on model T-grid
363!*******************************************************************************
364  WRITE(lunout,*)'dimensions de landice iml_lic, jml_lic : ',iml_lic,jml_lic
365! conversion if coordinates are in degrees
366  IF(MAXVAL(lon_lic)>pi) lon_lic=lon_lic*pi/180.
367  IF(MAXVAL(lat_lic)>pi) lat_lic=lat_lic*pi/180.
368  dlon_lic(:)=lon_lic(:,1)
369  dlat_lic(:)=lat_lic(1,:)
[1323]370  CALL grille_m( iml_lic, jml_lic, dlon_lic, dlat_lic, fraclic, iim,jjp1,   &
371 &               rlonv, rlatu, flic_tmp(1:iim,:) )
[1319]372  flic_tmp(iip1,:)=flic_tmp(1,:)
[1000]373
[1319]374!--- To the physical grid
375  CALL gr_dyn_fi(1, iip1, jjp1, klon, flic_tmp, pctsrf(:,is_lic))
[1000]376
[1319]377!--- Adequation with soil/sea mask
378  WHERE(pctsrf(:,is_lic)<EPSFRA) pctsrf(:,is_lic)=0.
379  WHERE(zmasq(:)<EPSFRA)         pctsrf(:,is_lic)=0.
380  pctsrf(:,is_ter)=zmasq(:)
381  DO ji=1,klon
382    IF(zmasq(ji)>EPSFRA) THEN
383      IF(pctsrf(ji,is_lic)>=zmasq(ji)) THEN
384        pctsrf(ji,is_lic)=zmasq(ji)
385        pctsrf(ji,is_ter)=0.
386      ELSE
387        pctsrf(ji,is_ter)=zmasq(ji)-pctsrf(ji,is_lic)
388        IF(pctsrf(ji,is_ter)<EPSFRA) THEN
389          pctsrf(ji,is_ter)=0.
390          pctsrf(ji,is_lic)=zmasq(ji)
391        END IF
392      END IF
393    END IF
394  END DO
[1000]395
[1319]396! sub-surface ocean and sea ice (sea ice set to zero for start)
397!*******************************************************************************
398  pctsrf(:,is_oce)=(1.-zmasq(:))
399  WHERE(pctsrf(:,is_oce)<EPSFRA) pctsrf(:,is_oce)=0.
400  IF(couple) pctsrf(:,is_oce)=ocemask_fi(:)
401  isst=0
402  WHERE(pctsrf(2:klon-1,is_oce)>0.) isst=1
[1000]403
[1319]404! It is checked that the sub-surfaces sum is equal to 1
405!*******************************************************************************
406  ji=COUNT((ABS(SUM(pctsrf(:,:),dim=2))-1.0)>EPSFRA)
407  IF(ji/=0) WRITE(lunout,*) 'pb repartition sous maille pour ',ji,' points'
408  CALL gr_fi_ecrit(1, klon, iim, jjp1, zmasq, zx_tmp_2d)
409!  WRITE(fmt,"(i3,')')")iim; fmt='(i'//ADJUSTL(fmt)
410!  WRITE(lunout,*)'zmasq = '
411!  WRITE(lunout,TRIM(fmt))NINT(zx_tmp_2d)
412  CALL gr_fi_dyn(1, klon, iip1, jjp1, zmasq, masque)
413  WRITE(fmt,"(i4,'i1)')")iip1 ; fmt='('//ADJUSTL(fmt)
414  WRITE(lunout,*) 'MASQUE construit : Masque'
415  WRITE(lunout,TRIM(fmt))NINT(masque(:,:))
[1000]416
[1319]417! Intermediate computation
418!*******************************************************************************
419  CALL massdair(p3d,masse)
420  WRITE(lunout,*)' ALPHAX ',alphax
421  DO l=1,llm
422    xppn(:)=aire(1:iim,1   )*masse(1:iim,1   ,l)
423    xpps(:)=aire(1:iim,jjp1)*masse(1:iim,jjp1,l)
424    xpn=SUM(xppn)/apoln
425    xps=SUM(xpps)/apols
426    masse(:,1   ,l)=xpn
427    masse(:,jjp1,l)=xps
428  END DO
429  q3d(iip1,:,:,:)=q3d(1,:,:,:)
430  phis(iip1,:) = phis(1,:)
[1000]431
[1319]432  IF(.NOT.letat0) RETURN
[1146]433
[1319]434! Writing
435!*******************************************************************************
436  CALL inidissip(lstardis,nitergdiv,nitergrot,niterh,tetagdiv,tetagrot,tetatemp)
437  WRITE(lunout,*)'sortie inidissip'
438  itau=0
439  itau_dyn=0
440  itau_phy=0
441  iday=dayref+itau/day_step
442  time=FLOAT(itau-(iday-dayref)*day_step)/day_step
443  IF(time>1.) THEN
444   time=time-1
445   iday=iday+1
446  END IF
447  day_ref=dayref
448  annee_ref=anneeref
449
450  CALL geopot( ip1jmp1, tpot, pk, pks, phis, phi )
451  WRITE(lunout,*)'sortie geopot'
452
453  CALL caldyn0( itau, uvent, vvent, tpot, psol, masse, pk, phis,               &
454                phi,  w, pbaru, pbarv, time+iday-dayref)
455  WRITE(lunout,*)'sortie caldyn0'     
456  CALL dynredem0( "start.nc", dayref, phis)
457  WRITE(lunout,*)'sortie dynredem0'
458  CALL dynredem1( "start.nc", 0.0, vvent, uvent, tpot, q3d, masse, psol)
459  WRITE(lunout,*)'sortie dynredem1'
460
461! Physical initial state writting
462!*******************************************************************************
463  WRITE(lunout,*)'phystep ',dtvr,iphysiq,nbapp_rad
464  phystep   = dtvr * FLOAT(iphysiq)
465  radpas    = NINT (86400./phystep/ FLOAT(nbapp_rad) )
466  WRITE(lunout,*)'phystep =', phystep, radpas
467
468! Init: tsol, qsol, sn, evap, tsoil, rain_fall, snow_fall, solsw, sollw, frugs
469!*******************************************************************************
470  DO i=1,nbsrf; ftsol(:,i) = tsol; END DO
471  DO i=1,nbsrf; snsrf(:,i) = sn;   END DO
472  falb1(:,is_ter) = 0.08; falb1(:,is_lic) = 0.6
473  falb1(:,is_oce) = 0.5;  falb1(:,is_sic) = 0.6
474  falb2 = falb1
475  evap(:,:) = 0.
476  DO i=1,nbsrf; qsolsrf(:,i)=150.; END DO
477  DO i=1,nbsrf; DO j=1,nsoilmx; tsoil(:,j,i) = tsol; END DO; END DO
478  rain_fall = 0.; snow_fall = 0.
479  solsw = 165.;   sollw = -53.
480  t_ancien = 273.15
481  q_ancien = 0.
482  agesno = 0.
483  frugs(:,is_oce) = rugmer(:)
484  frugs(:,is_ter) = MAX(1.0e-05,zstd(:)*zsig(:)/2.0)
485  frugs(:,is_lic) = MAX(1.0e-05,zstd(:)*zsig(:)/2.0)
486  frugs(:,is_sic) = 0.001
487  fder = 0.0
488  clwcon = 0.0
489  rnebcon = 0.0
490  ratqs = 0.0
491  run_off_lic_0 = 0.0
492  rugoro = 0.0
493
494! Before phyredem calling, surface modules and values to be saved in startphy.nc
495! are initialized
496!*******************************************************************************
497  dummy = 1.0
498  pbl_tke(:,:,:) = 1.e-8
499  zmax0(:) = 40.
500  f0(:) = 1.e-5
501  ema_work1(:,:) = 0.
502  ema_work2(:,:) = 0.
503  wake_deltat(:,:) = 0.
504  wake_deltaq(:,:) = 0.
505  wake_s(:) = 0.
506  wake_cstar(:) = 0.
507  wake_fip(:) = 0.
[1425]508  wake_pe = 0.
509  fm_therm = 0.
510  entr_therm = 0.
511  detr_therm = 0.
512
[1319]513  CALL fonte_neige_init(run_off_lic_0)
514  CALL pbl_surface_init( qsol, fder, snsrf, qsolsrf, evap, frugs, agesno, tsoil )
515  CALL phyredem( "startphy.nc" )
516
[1323]517!  WRITE(lunout,*)'CCCCCCCCCCCCCCCCCC REACTIVER SORTIE VISU DANS ETAT0'
518!  WRITE(lunout,*)'entree histclo'
[1319]519  CALL histclo()
520
[1146]521#endif
522!#endif of #ifdef CPP_EARTH
[1319]523  RETURN
524
525END SUBROUTINE etat0_netcdf
526!
527!-------------------------------------------------------------------------------
Note: See TracBrowser for help on using the repository browser.