source: LMDZ4/trunk/libf/dyn3d/ce0l.F90 @ 1319

Last change on this file since 1319 was 1319, checked in by Laurent Fairhead, 14 years ago
  • Modifications to the start and limit creation routines to account for different

calendars

  • Modification to phyetat0 to force the mask read in the start files to match the

surface fractions read in the limit file

  • Force readaerosol.F90 to read in aerosols file with 12 timesteps

  • Modifications aux routines de créations des fichiers start et limit pour prendre

en compte différents calendriers

  • Modification à phyetat0 pour forcer le masque lu dans le fichier start à être

compatible avec les fractions de surface lu dans le fichier limit

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