source: LMDZ6/branches/Amaury_dev/libf/dynphy_lonlat/phylmd/ce0l.F90 @ 5117

Last change on this file since 5117 was 5117, checked in by abarral, 4 months ago

rename modules properly lmdz_*
move some unused files to obsolete/
(lint) uppercase fortran keywords

  • 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: 9.5 KB
Line 
1PROGRAM ce0l
2
3!-------------------------------------------------------------------------------
4! Purpose: Initial states and boundary conditions files creation:
5!     * start.nc    for dynamics    (using etat0dyn     routine)
6!     * startphy.nc for physics     (using etat0phys    routine)
7!     * limit.nc    for forced runs (using limit_netcdf routine)
8!-------------------------------------------------------------------------------
9! Notes:
10!     * extrap=.T. (default) for data extrapolation, like for the SSTs when file
11!                   does contain ocean points only.
12!     * "masque" can be:
13!       - read from file "o2a.nc"          (for coupled runs).
14!       - read from file "startphy0.nc"    (from a previous run).
15!       - created in etat0phys or etat0dyn (for forced  runs).
16!     It is then passed to limit_netcdf to ensure consistancy.
17!-------------------------------------------------------------------------------
18  USE ioipsl, ONLY: ioconf_calendar, getin, flininfo, flinopen, flinget, flinclo
19  USE control_mod,    ONLY: day_step, dayref, nsplit_phys
20  USE etat0dyn,       ONLY: etat0dyn_netcdf
21  USE etat0phys,      ONLY: etat0phys_netcdf
22  USE limit,          ONLY: limit_netcdf
23  USE netcdf,         ONLY: nf90_open, nf90_nowrite, nf90_close, nf90_noerr,    &
24         nf90_inquire_dimension, nf90_inq_dimid, nf90_inq_varid, nf90_get_var
25  USE infotrac,       ONLY: init_infotrac
26  USE dimphy,         ONLY: klon
27  USE test_disvert_m, ONLY: test_disvert
28  USE lmdz_filtreg,    ONLY: inifilr
29  USE iniphysiq_mod,  ONLY: iniphysiq
30  USE mod_const_mpi,  ONLY: comm_lmdz
31
32#ifdef CPP_PARA
33  USE mod_const_mpi,  ONLY: init_const_mpi
34  USE parallel_lmdz,  ONLY: init_parallel, mpi_rank, omp_rank, using_mpi
35  USE bands,          ONLY: read_distrib, distrib_phys
36  USE mod_hallo,      ONLY: init_mod_hallo
37  USE mod_interface_dyn_phys, ONLY: init_interface_dyn_phys
38  USE lmdz_xios, ONLY: using_xios, xios_finalize
39#endif
40
41  USE comconst_mod, ONLY: cpp, daysec, dtphys, dtvr, g, kappa, omeg, r, rad, &
42                          pi, jmp1
43  USE logic_mod, ONLY: iflag_phys, ok_etat0, ok_limit
44  USE comvert_mod, ONLY: pa, preff, pressure_exner
45  USE temps_mod, ONLY: calend, day_ini, dt
46  USE lmdz_mpi
47
48  IMPLICIT NONE
49
50!-------------------------------------------------------------------------------
51! Local variables:
52  include "dimensions.h"
53  include "paramet.h"
54  include "comgeom2.h"
55  include "iniprint.h"
56 
57  REAL               :: masque(iip1,jjp1)             !--- CONTINENTAL MASK
58  REAL               :: phis  (iip1,jjp1)             !--- GROUND GEOPOTENTIAL
59  CHARACTER(LEN=256) :: modname, fmt, calnd           !--- CALENDAR TYPE
60  LOGICAL            :: use_filtre_fft
61  LOGICAL, PARAMETER :: extrap=.FALSE.
62
63!--- Local variables for ocean mask reading:
64  INTEGER            :: nid_o2a, iml_omask, jml_omask, j
65  INTEGER            :: fid, iret, llm_tmp, ttm_tmp, itaul(1)
66  REAL, ALLOCATABLE  :: lon_omask(:,:), dlon_omask(:), ocemask(:,:)
67  REAL, ALLOCATABLE  :: lat_omask(:,:), dlat_omask(:), ocetmp (:,:)
68  REAL               :: date, lev(1)
69
70!--- Local variables for land mask from startphy0 file reading
71  INTEGER            :: nid_sta, nid_nph, nid_msk, nphys
72  REAL, ALLOCATABLE  :: masktmp(:)
73
74#ifdef CPP_PARA
75  INTEGER ierr
76#else
77! for iniphysiq in serial mode
78  INTEGER,PARAMETER :: mpi_rank=0
79  INTEGER :: distrib_phys(mpi_rank:mpi_rank)=(jjm-1)*iim+2
80#endif
81!-------------------------------------------------------------------------------
82  modname="ce0l"
83
84!--- Constants
85  pi     = 4. * ATAN(1.)
86  rad    = 6371229.
87  daysec = 86400.
88  omeg   = 2.*pi/daysec
89  g      = 9.8
90  kappa  = 0.2857143
91  cpp    = 1004.70885
92  jmp1   = jjm + 1
93  preff   = 101325.
94  pa      = 50000.
95
96  CALL conf_gcm( 99, .TRUE. )
97  dtvr = daysec/REAL(day_step)
98  WRITE(lunout,*)'dtvr',dtvr
99  CALL iniconst()
100  CALL inigeom()
101
102!--- Calendar choice
103  calnd='gregorian'
104  SELECT CASE(calend)
105    CASE('earth_360d');CALL ioconf_calendar('360_day');   calnd='with 360 days/year'
106    CASE('earth_365d');CALL ioconf_calendar('noleap'); calnd='with no leap year'
107    CASE('earth_366d');CALL ioconf_calendar('366d');   calnd='with leap years only'
108    CASE('gregorian'); CALL ioconf_calendar('gregorian')
109    CASE('standard');  CALL ioconf_calendar('gregorian')
110    CASE('julian');    CALL ioconf_calendar('julian'); calnd='julian'
111    CASE('proleptic_gregorian'); CALL ioconf_calendar('gregorian')
112  !--- DC Bof...  => IOIPSL a mettre a jour: proleptic_gregorian /= gregorian
113    CASE DEFAULT
114      CALL abort_gcm('ce0l','Bad choice for calendar',1)
115  END SELECT
116  WRITE(lunout,*)'CHOSEN CALENDAR: Earth '//TRIM(calnd)
117
118#ifdef CPP_PARA
119!--- Physical grid + parallel initializations
120  CALL init_const_mpi()
121  CALL init_parallel()
122  CALL read_distrib()
123  CALL init_mod_hallo()
124#endif
125  WRITE(lunout,*)'---> klon=',klon
126
127!--- Tracers initializations
128  CALL init_infotrac()
129
130  CALL inifilr()
131  CALL iniphysiq(iim,jjm,llm, &
132                 distrib_phys(mpi_rank),comm_lmdz, &
133                 daysec,day_ini,dtphys/nsplit_phys, &
134                 rlatu,rlatv,rlonu,rlonv,aire,cu,cv,rad,g,r,cpp,iflag_phys)
135  IF(pressure_exner) CALL test_disvert
136
137#ifdef CPP_PARA
138  IF (mpi_rank==0.AND.omp_rank==0) THEN
139#endif
140  use_filtre_fft=.FALSE.
141  CALL getin('use_filtre_fft',use_filtre_fft)
142  IF(use_filtre_fft) THEN
143     WRITE(lunout,*)"FFT filter not available for sequential dynamics."
144     WRITE(lunout,*)"Your setting of variable use_filtre_fft is not used."
145  ENDIF
146
147!--- LAND MASK. THREE CASES:
148!   1) read from ocean model    file "o2a.nc"    (coupled runs)
149!   2) read from previous run   file="startphy0.nc"
150!   3) computed from topography file "Relief.nc" (masque(:,:)=-99999.)
151! In the first case, the mask from the ocean model is used compute the
152! weights to ensure ocean fractions are the same for atmosphere and ocean.
153!*******************************************************************************
154  IF(nf90_open("o2a.nc", nf90_nowrite, nid_o2a)==nf90_noerr) THEN
155    iret=nf90_close(nid_o2a)
156    WRITE(lunout,*)'BEWARE !! Ocean mask "o2a.nc" file found'
157    WRITE(lunout,*)'Coupled run.'
158    CALL flininfo("o2a.nc", iml_omask, jml_omask, llm_tmp, ttm_tmp, nid_o2a)
159    IF(iml_omask/=iim .OR.jml_omask/=jjp1) THEN
160      WRITE(lunout,*)'Mismatching dimensions for ocean mask'
161      WRITE(lunout,*)'iim  = ',iim ,' iml_omask = ',iml_omask
162      WRITE(lunout,*)'jjp1 = ',jjp1,' jml_omask = ',jml_omask
163      CALL abort_gcm(modname,'',1)
164    END IF
165    ALLOCATE(ocemask(iim,jjp1),lon_omask(iim,jjp1),dlon_omask(iim ))
166    ALLOCATE(ocetmp (iim,jjp1),lat_omask(iim,jjp1),dlat_omask(jjp1))
167    CALL flinopen("o2a.nc", .FALSE.,iml_omask,jml_omask,llm_tmp,               &
168                  lon_omask,lat_omask,lev,ttm_tmp,itaul,date,dt,fid)
169    CALL flinget(fid, "OceMask",    iim,jjp1,llm_tmp,ttm_tmp,1,1,ocetmp)
170    CALL flinclo(fid)
171    dlon_omask(1:iim ) = lon_omask(1:iim,1)
172    dlat_omask(1:jjp1) = lat_omask(1,1:jjp1)
173    ocemask = ocetmp
174    IF(dlat_omask(1)<dlat_omask(jml_omask)) THEN
175       DO j=1,jjp1
176          ocemask(:,j) = ocetmp(:,jjp1-j+1)
177       END DO
178    END IF
179    DEALLOCATE(ocetmp,lon_omask,lat_omask,dlon_omask,dlat_omask)
180    IF(prt_level>=1) THEN
181      WRITE(fmt,"(i4,'i1)')")iim ; fmt='('//ADJUSTL(fmt)
182      WRITE(lunout,*)'OCEAN MASK :'
183      WRITE(lunout,fmt) NINT(ocemask)
184    END IF
185    masque(1:iim,:)=1.-ocemask(:,:)
186    masque(iip1 ,:)=masque(1,:)
187    DEALLOCATE(ocemask)
188  ELSE IF(nf90_open("startphy0.nc", nf90_nowrite, nid_sta)==nf90_noerr) THEN
189    WRITE(lunout,*)'BEWARE !! File "startphy0.nc" found.'
190    WRITE(lunout,*)'Getting the land mask from a previous run.'
191    iret=nf90_inq_dimid(nid_sta,'points_physiques',nid_nph)
192    iret=nf90_inquire_dimension(nid_sta,nid_nph,len=nphys)
193    IF(nphys/=klon) THEN
194      WRITE(lunout,*)'Mismatching dimensions for land mask'
195      WRITE(lunout,*)'nphys  = ',nphys ,' klon = ',klon
196      iret=nf90_close(nid_sta)
197      CALL abort_gcm(modname,'',1)
198    END IF
199    ALLOCATE(masktmp(klon))
200    iret=nf90_inq_varid(nid_sta,'masque',nid_msk)
201    iret=nf90_get_var(nid_sta,nid_msk,masktmp)
202    iret=nf90_close(nid_sta)
203    CALL gr_fi_dyn(1,klon,iip1,jjp1,masktmp,masque)
204    IF(prt_level>=1) THEN
205      WRITE(fmt,"(i4,'i1)')")iip1 ; fmt='('//ADJUSTL(fmt)
206      WRITE(lunout,*)'LAND MASK :'
207      WRITE(lunout,fmt) NINT(masque)
208    END IF
209    DEALLOCATE(masktmp)
210  ELSE
211    WRITE(lunout,*)'BEWARE !! No ocean mask "o2a.nc" file or "startphy0.nc" file found'
212    WRITE(lunout,*)'Land mask will be built from the topography file.'
213    masque(:,:)=-99999.
214  END IF
215  phis(:,:)=-99999.
216
217  IF(ok_etat0) THEN
218    WRITE(lunout,'(//)')
219    WRITE(lunout,*) '  ************************  '
220    WRITE(lunout,*) '  ***  etat0phy_netcdf ***  '
221    WRITE(lunout,*) '  ************************  '
222    CALL etat0phys_netcdf(masque,phis)
223    WRITE(lunout,'(//)')
224    WRITE(lunout,*) '  ************************  '
225    WRITE(lunout,*) '  ***  etat0dyn_netcdf ***  '
226    WRITE(lunout,*) '  ************************  '
227    CALL etat0dyn_netcdf(masque,phis)
228  END IF
229
230  IF(ok_limit) THEN
231    WRITE(lunout,'(//)')
232    WRITE(lunout,*) '  *********************  '
233    WRITE(lunout,*) '  ***  Limit_netcdf ***  '
234    WRITE(lunout,*) '  *********************  '
235    WRITE(lunout,'(//)')
236    CALL limit_netcdf(masque,phis,extrap)
237  END IF
238
239  WRITE(lunout,'(//)')
240  WRITE(lunout,*) '  ***************************  '
241  WRITE(lunout,*) '  ***  grilles_gcm_netcdf ***  '
242  WRITE(lunout,*) '  ***************************  '
243  WRITE(lunout,'(//)')
244  CALL grilles_gcm_netcdf_sub(masque,phis)
245
246#ifdef CPP_PARA
247  END IF
248  IF (using_xios) CALL xios_finalize
249  IF (using_mpi) CALL MPI_FINALIZE(ierr)
250#endif
251
252END PROGRAM ce0l
253
254!-------------------------------------------------------------------------------
Note: See TracBrowser for help on using the repository browser.