source: trunk/LMDZ.COMMON/libf/dyn3d/ce0l.F90 @ 1242

Last change on this file since 1242 was 1019, checked in by emillour, 11 years ago

Common dynamics; keep up with updates (seq and ) in LMDZ5 (up tio rev 1845):

  • General stuff:
  • makelmdz_fcm: add options -j # (compile using # threads) and -full, and to keep up

with Earth model, possibility to compile with various versions of orchidee

  • bld.cfg: adaptations to enable compiling using multiple threads
  • build_gcm: adaptations to enable compiling using multiple threads
  • makelmdz: keep up with Earth model: possibility to compile with various versions of orchidee + cosmetic changes + library directory name change
  • bibio:
  • wxios.F90 : Added for possible future use of XIOS library
  • filtrez:
  • mkl_dft_type.f90 & mkl_dfti.f90 : MKL (for MKL FFT) interface definitions
  • filtreg_mod : limit use of FFT to parallel mode
  • mod_filtre_fft.F90 & mod_filtre_fft_lov.F90 : swich to use parallel_lmdz
  • dyn3d:
  • abort_gcm.F : add things for xios
  • advtrac.F90 : minor change in CFL outputs
  • ce0l.F90 : indicesol.h is now module indice_sol_mod
  • comvert.h : cosmetic change on comments
  • gcm.F : add xios and use module indice_sol_mod (for INCA)
  • inigeom.F : move two computations outside loop
  • dyn3dpar:
  • parallel.F90 => parallel_lmdz.F90 : and change all the "use parallel" into "use parallel_lmdz" in all files in dyn3dpar
  • comvert.h : cosmetic change on comments
  • gcm.F : add xios and use module indice_sol_mod (for INCA)
  • leapfrog_p.F : add xios + correction for times in Newtonian case
  • ce0l.F90 : indicesol.h is now module indice_sol_mod
  • inigeom.F : move two computations outside loop

EM

File size: 3.8 KB
Line 
1!
2! $Id: ce0l.F90 1511 2011-04-28 15:21:47Z jghattas $
3!
4!-------------------------------------------------------------------------------
5!
6PROGRAM ce0l
7!-------------------------------------------------------------------------------
8! Purpose: Calls etat0, creates initial states and limit_netcdf
9!
10!     interbar=.T. for barycentric interpolation inter_barxy
11!     extrap  =.T. for data extrapolation, like for the SSTs when file does not
12!                  contain ocean points only.
13!     oldice  =.T. for old-style ice, obtained using grille_m (grid_atob).
14!     masque is created in etat0, passed to limit to ensure consistancy.
15!-------------------------------------------------------------------------------
16  USE control_mod
17#ifdef CPP_EARTH
18! This prog. is designed to work for Earth
19  USE dimphy
20  USE comgeomphy
21  USE infotrac
22  USE indice_sol_mod
23
24#ifdef CPP_IOIPSL
25  USE ioipsl, ONLY: ioconf_calendar
26#endif
27
28#endif
29  IMPLICIT NONE
30#ifndef CPP_EARTH
31#include "iniprint.h"
32  WRITE(lunout,*)'limit_netcdf: Earth-specific program, needs Earth physics'
33#else
34!-------------------------------------------------------------------------------
35! Local variables:
36  LOGICAL, PARAMETER :: interbar=.TRUE., extrap=.FALSE., oldice=.FALSE.
37#include "dimensions.h"
38#include "paramet.h"
39!#include "indicesol.h"
40#include "iniprint.h"
41#include "temps.h"
42#include "logic.h"
43  INTEGER, PARAMETER            :: longcles=20
44  REAL,    DIMENSION(longcles)  :: clesphy0
45  REAL,    DIMENSION(iip1,jjp1) :: masque
46  CHARACTER(LEN=15)             :: calnd
47  REAL,    DIMENSION(iip1,jjp1) :: phis ! geopotentiel au sol
48!-------------------------------------------------------------------------------
49  CALL conf_gcm( 99, .TRUE. , clesphy0 )
50
51  CALL Init_Phys_lmdz(iim,jjp1,llm,1,(/(jjm-1)*iim+2/))
52  WRITE(lunout,*)'---> klon=',klon
53  CALL InitComgeomphy
54
55#ifdef CPP_IOIPSL
56  SELECT CASE(calend)
57    CASE('earth_360d');CALL ioconf_calendar('360d');      calnd='a 360 jours/an'
58    CASE('earth_365d');CALL ioconf_calendar('noleap');    calnd='a 365 jours/an'
59    CASE('earth_366d');CALL ioconf_calendar('366d');      calnd='bissextile'
60    CASE('gregorian'); CALL ioconf_calendar('gregorian'); calnd='gregorien'
61    CASE('standard');  CALL ioconf_calendar('gregorian'); calnd='gregorien'
62    CASE('julian');    CALL ioconf_calendar('julian');    calnd='julien'
63    CASE('proleptic_gregorian'); CALL ioconf_calendar('gregorian')
64  !--- DC Bof...  => IOIPSL a mettre a jour: proleptic_gregorian /= gregorian
65    CASE DEFAULT
66      CALL abort_gcm('ce0l','Mauvais choix de calendrier',1)
67  END SELECT
68  WRITE(lunout,*)'CALENDRIER CHOISI: Terrestre '//TRIM(calnd)
69#endif
70
71  IF (type_trac == 'inca') THEN
72#ifdef INCA
73    CALL init_const_lmdz(nbtr,anneeref,dayref,iphysiq,day_step,nday)
74    CALL init_inca_para(iim,jjm+1,klon,1,klon_mpi_para_nb,0)
75    WRITE(lunout,*)'nbtr =' , nbtr
76#endif
77  END IF
78
79  WRITE(lunout,'(//)')
80  WRITE(lunout,*) '  *********************  '
81  WRITE(lunout,*) '  ***  etat0_netcdf ***  '
82  WRITE(lunout,*) '  *********************  '
83  WRITE(lunout,'(//)')
84  WRITE(lunout,*) ' interbar = ',interbar
85  CALL etat0_netcdf(interbar,masque,phis,ok_etat0)
86
87  IF(ok_limit) THEN
88  WRITE(lunout,'(//)')
89  WRITE(lunout,*) '  *********************  '
90  WRITE(lunout,*) '  ***  Limit_netcdf ***  '
91  WRITE(lunout,*) '  *********************  '
92  WRITE(lunout,'(//)')
93  CALL limit_netcdf(interbar,extrap,oldice,masque)
94  END IF
95
96  IF (grilles_gcm_netcdf) THEN
97     WRITE(lunout,'(//)')
98     WRITE(lunout,*) '  ***************************  '
99     WRITE(lunout,*) '  ***  grilles_gcm_netcdf ***  '
100     WRITE(lunout,*) '  ***************************  '
101     WRITE(lunout,'(//)')
102     CALL grilles_gcm_netcdf_sub(masque,phis)
103  END IF
104#endif
105! of #ifndef CPP_EARTH #else
106
107END PROGRAM ce0l
108!
109!-------------------------------------------------------------------------------
Note: See TracBrowser for help on using the repository browser.