Changeset 999 for trunk


Ignore:
Timestamp:
Jul 2, 2013, 9:40:28 AM (12 years ago)
Author:
tnavarro
Message:

Possibility to store multiple initial states in one start/startfi. This is RETROCOMPATIBLE. New option ecrithist in run.def to write data in start/startfi every ecrithist dynamical timestep. New option timestart in run.def to initialize the GCM with the time timestart stored in start

Location:
trunk/LMDZ.MARS
Files:
1 added
16 edited

Legend:

Unmodified
Added
Removed
  • trunk/LMDZ.MARS/README

    r954 r999  
    18501850== 10/05/2013 == FGG
    18511851- bug correction in "extract" utility
     1852
     1853== 02/07/2013 == TN
     1854>> Added the possibility to store multiple initial states in one start/startfi
     1855>> New option 'ecrithist' in run.def to write data in start/startfi every ecrithist
     1856   dynamical timestep (default is to write it at the end of the GCM run).
     1857>> New option 'timestart' in run.def to initialize the GCM with the time timestart
     1858   stored in start (default is last time).
     1859>> This new feature is (supposedly) totally RETROCOMPATIBLE. Changes are:
     1860  - Time axis added in startfi
     1861  - Time axis can be longer than one in start/startfi
     1862  - Possibility to initialize the GCM with old start/startfi
     1863  - Compatibility with start2diagfi, newstart, testphys1d, expandstartfi
     1864  - Absolute date is stored in diagfi for less-than-a-day runs
     1865>> Quick documentation about dates :
     1866  - Day at the beginning of the start (integer) is stored in controle(4)
     1867    for start and diagfi and controle(3) for startfi.
     1868  - Fraction of the day at the beginning of the start (real between 0 included and 1 excluded)
     1869    is stored in controle(27) for start and diagfi and controle(29) for startfi.
     1870  - The "Time" variable stores all the dates from the beginning of the start (positive real)
     1871    for start, startfi and diagfi
     1872  - Time is stored in start_archive in the "Time" variable.
     1873  - Time-related data in the controle field of start_archive are useless.
     1874For instance the i-th date of diagfi is controle(4)+controle(27)+Time(i)
     1875
     1876
     1877
  • trunk/LMDZ.MARS/libf/dyn3d/control.h

    r831 r999  
    77      COMMON/control_i/ndynstep,day_step,                               &
    88     &              iperiod,iconser,idissip,iphysiq ,                   &
    9      &              anneeref
    10       COMMON/control_r/periodav,ecritphy,nday_r
     9     &              anneeref,ecritstart
     10      COMMON/control_r/periodav,ecritphy,nday_r,timestart
    1111
    1212      INTEGER ndynstep ! # of dynamical time steps to run (if negative or not specified in run.def, nday_r is used instead)
     
    1919      REAL periodav
    2020      REAL ecritphy ! output data in "diagfi.nc" every ecritphy dynamical steps
     21      INTEGER ecritstart ! output data in "start.nc" every ecritstart dynamical steps
     22      REAL timestart ! time start for run in "start.nc"
    2123      real nday_r ! number of days to run (possibly including a fraction of day)
    2224
  • trunk/LMDZ.MARS/libf/dyn3d/defrun_new.F

    r828 r999  
    252252        else
    253253          WRITE(tapeout,*)" ecritphy = ",ecritphy
     254        endif
     255       
     256ccc   .... T.Navarro, read start time (06/2013) ...
     257c
     258        WRITE(tapeout,*) ""
     259        WRITE(tapeout,*) "date de debut dans le fichier start.nc"
     260        timestart=-9999
     261        call getin("timestart",timestart)
     262        WRITE(tapeout,*)" timestart = ",timestart
     263
     264ccc   .... T.Navarro, start output (01/2013) ...
     265c
     266        WRITE(tapeout,*) ""
     267        WRITE(tapeout,*) "frequence (en pas) de l'ecriture ",
     268     & "du fichier start.nc"
     269        ecritstart=0
     270        call getin("ecritstart",ecritstart)
     271        ! verify that ecritstart is indeed a multiple of iphysiq
     272        if ( ((real(ecritstart))/iphysiq)
     273     &       .ne.(real(ecritstart)/iphysiq) ) then
     274          write(tapeout,*)" Error! ecritstart must be a multiple",
     275     &    " of iphysiq, but ecritstart=",ecritstart," and iphysiq=",
     276     &    iphysiq
     277        else
     278          WRITE(tapeout,*)" ecritstart = ",ecritstart
    254279        endif
    255280
  • trunk/LMDZ.MARS/libf/dyn3d/dynetat0.F

    r791 r999  
    11      SUBROUTINE dynetat0(fichnom,nq,vcov,ucov,
    2      .                    teta,q,masse,ps,phis,time)
     2     .                    teta,q,masse,ps,phis,time0)
    33     
    44      use netcdf
     
    2020c                    r4 or r8 restarts independently of having compiled
    2121c                    the GCM in r4 or r8)
    22 c
     22c           June 2013 TN : Possibility to read files with a time axis.
     23c                          NOW defrun_new MUST BE CALLED BEFORE dynetat0.
    2324c=======================================================================
    2425c-----------------------------------------------------------------------
     
    3637#include "serre.h"
    3738#include "logic.h"
    38 #include"advtrac.h"
     39#include "advtrac.h"
     40#include "control.h"
    3941
    4042c   Arguments:
     
    4850      REAL ps(iip1,jjp1),phis(iip1,jjp1)
    4951
    50       REAL time ! fraction of day the fields correspond to
     52      REAL time0 ! fraction of day the fields correspond to
    5153
    5254c   Variables
     
    5860      INTEGER ierr, nid, nvarid, nqold
    5961      CHARACTER  str3*3,yes*1
     62     
     63      REAL,ALLOCATABLE :: time(:) ! times stored in start
     64      INTEGER timelen ! number of times stored in the file
     65      INTEGER indextime ! index of selected time
     66      !REAL  hour_ini ! fraction of day of stored date. Equivalent of day_ini, but 0=<hour_ini<1
     67
     68      INTEGER edges(4),corner(4)
    6069
    6170c-----------------------------------------------------------------------
     
    102111      pa         = tab_cntrl(17)
    103112      preff      = tab_cntrl(18)
     113     
     114      hour_ini   = tab_cntrl(29)
     115
    104116c
    105117      clon       = tab_cntrl(19)
     
    119131        IF( tab_cntrl(26).EQ.1. ) ysinus = . TRUE.
    120132      ENDIF
     133     
    121134c   .................................................................
    122135c
     
    239252      ENDIF
    240253
     254
     255! read time axis
     256      ierr = nf90_inq_dimid(nid,"Time",nvarid)
     257      ierr = nf90_inquire_dimension(nid,nvarid,len=timelen)
     258
     259      ALLOCATE(time(timelen))
     260
    241261      ierr=nf90_inq_varid(nid,"Time",nvarid)
    242262      IF (ierr .NE. nf90_noerr) THEN
     
    254274         CALL abort
    255275      ENDIF
    256 
     276     
     277! select desired time
     278      IF (timestart .lt. 0) THEN  ! default: we use the last time value
     279        indextime = timelen
     280      ELSE  ! else we look for the desired value in the time axis
     281       indextime = 0
     282        DO i=1,timelen
     283          IF (abs(time(i) - timestart) .lt. 0.01) THEN
     284             indextime = i
     285             EXIT
     286          ENDIF
     287        ENDDO
     288        IF (indextime .eq. 0) THEN
     289          PRINT*, "Time", timestart," is not in "//fichnom//"!!"
     290          PRINT*, "Stored times are:"
     291          DO i=1,timelen
     292             PRINT*, time(i)
     293          ENDDO
     294          CALL abort
     295        ENDIF
     296      ENDIF
     297     
     298      ! In start the absolute date is day_ini + hour_ini + time
     299      ! For now on, in the GCMdynamics, it is day_ini + time0
     300      time0 = time(indextime) + hour_ini
     301      day_ini = day_ini + INT(time0)
     302      time0 = time0 - INT(time0) ! time0 devient le nouveau hour_ini
     303      hour_ini = time0
     304     
     305      PRINT*, "dynetat0: Selected time ",time(indextime),
     306     .        " at index ",indextime
     307     
     308      DEALLOCATE(time)
     309
     310
     311! read vcov
     312      corner(1)=1
     313      corner(2)=1
     314      corner(3)=1
     315      corner(4)=indextime
     316      edges(1)=iip1
     317      edges(2)=jjm
     318      edges(3)=llm
     319      edges(4)=1
     320      ierr=nf90_inq_varid(nid,"vcov",nvarid)
     321      IF (ierr .NE. nf90_noerr) THEN
     322         PRINT*, "dynetat0: Le champ <vcov> est absent"
     323         write(*,*)trim(nf90_strerror(ierr))
     324         CALL abort
     325      ENDIF
     326      !ierr=nf90_get_var(nid,nvarid,vcov)
     327      ierr=nf90_get_var(nid,nvarid,vcov,corner,edges)
     328      IF (ierr .NE. nf90_noerr) THEN
     329         PRINT*, "dynetat0: Lecture echouee pour <vcov>"
     330         write(*,*)trim(nf90_strerror(ierr))
     331         CALL abort
     332      ENDIF
     333     
     334! read ucov
     335      corner(1)=1
     336      corner(2)=1
     337      corner(3)=1
     338      corner(4)=indextime
     339      edges(1)=iip1
     340      edges(2)=jjp1
     341      edges(3)=llm
     342      edges(4)=1
    257343      ierr=nf90_inq_varid(nid,"ucov",nvarid)
    258344      IF (ierr .NE. nf90_noerr) THEN
     
    261347         CALL abort
    262348      ENDIF
    263       ierr=nf90_get_var(nid,nvarid,ucov)
     349      ierr=nf90_get_var(nid,nvarid,ucov,corner,edges)
    264350      IF (ierr .NE. nf90_noerr) THEN
    265351         PRINT*, "dynetat0: Lecture echouee pour <ucov>"
     
    267353         CALL abort
    268354      ENDIF
    269  
    270       ierr=nf90_inq_varid(nid,"vcov",nvarid)
    271       IF (ierr .NE. nf90_noerr) THEN
    272          PRINT*, "dynetat0: Le champ <vcov> est absent"
    273          write(*,*)trim(nf90_strerror(ierr))
    274          CALL abort
    275       ENDIF
    276       ierr=nf90_get_var(nid,nvarid,vcov)
    277       IF (ierr .NE. nf90_noerr) THEN
    278          PRINT*, "dynetat0: Lecture echouee pour <vcov>"
    279          write(*,*)trim(nf90_strerror(ierr))
    280          CALL abort
    281       ENDIF
    282 
     355
     356! read teta
    283357      ierr=nf90_inq_varid(nid,"teta",nvarid)
    284358      IF (ierr .NE. nf90_noerr) THEN
     
    287361         CALL abort
    288362      ENDIF
    289       ierr=nf90_get_var(nid,nvarid,teta)
     363      ierr=nf90_get_var(nid,nvarid,teta,corner,edges)
    290364      IF (ierr .NE. nf90_noerr) THEN
    291365         PRINT*, "dynetat0: Lecture echouee pour <teta>"
     
    294368      ENDIF
    295369
    296 
     370! read tracers
    297371      IF(nq.GE.1) THEN
    298372        write(*,*) 'dynetat0: loading tracers'
     
    318392           ELSE
    319393           !ierr=nf90_get_var(nid,nvarid,q(1,1,1,iq))
    320            ierr=nf90_get_var(nid,nvarid,traceur)
     394           ierr=nf90_get_var(nid,nvarid,traceur,corner,edges)
    321395             IF (ierr .NE. nf90_noerr) THEN
    322396!                 PRINT*, "dynetat0: Lecture echouee pour "//str3
     
    355429      ENDIF
    356430
     431! read masse
    357432      ierr=nf90_inq_varid(nid,"masse",nvarid)
    358433      IF (ierr .NE. nf90_noerr) THEN
     
    361436         CALL abort
    362437      ENDIF
    363       ierr=nf90_get_var(nid,nvarid,masse)
     438      ierr=nf90_get_var(nid,nvarid,masse,corner,edges)
    364439      IF (ierr .NE. nf90_noerr) THEN
    365440         PRINT*, "dynetat0: Lecture echouee pour <masse>"
     
    368443      ENDIF
    369444
     445! read ps
     446      corner(1)=1
     447      corner(2)=1
     448      corner(3)=indextime
     449      edges(1)=iip1
     450      edges(2)=jjp1
     451      edges(3)=1
    370452      ierr=nf90_inq_varid(nid,"ps",nvarid)
    371453      IF (ierr .NE. nf90_noerr) THEN
     
    374456         CALL abort
    375457      ENDIF
    376       ierr=nf90_get_var(nid,nvarid,ps)
     458      ierr=nf90_get_var(nid,nvarid,ps,corner,edges)
    377459      IF (ierr .NE. nf90_noerr) THEN
    378460         PRINT*, "dynetat0: Lecture echouee pour <ps>"
  • trunk/LMDZ.MARS/libf/dyn3d/dynredem.F

    r410 r999  
    3636      character*80 abort_message
    3737      character(len=80) :: txt ! to store some text
     38     
     39      !REAL  hour_ini ! fraction of day of stored date. Equivalent of day_ini, but 0=<hour_ini<1
     40
    3841
    3942c   Variables locales pour NetCDF:
     
    7275       tab_cntrl(7)  = g
    7376       tab_cntrl(8)  = cpp
    74        tab_cntrl(9) = kappa
     77       tab_cntrl(9)  = kappa
    7578       tab_cntrl(10) = daysec
    7679       tab_cntrl(11) = dtvr
     
    8285       tab_cntrl(17) = pa
    8386       tab_cntrl(18) = preff
     87       
     88       tab_cntrl(29) = hour_ini
     89
    8490c
    8591c    .....    parametres  pour le zoom      ......   
     
    106112       IF( ysinus )  tab_cntrl(26) = 1.
    107113      ENDIF
     114     
     115
    108116c
    109117c    .........................................................
     
    983991      character*80 abort_message
    984992c
     993
     994      INTEGER edges(4),corner(4)
     995
    985996      INTEGER nb,i,j
    986       SAVE nb
    987       DATA nb / 0 /
     997     
    988998
    989999      modname = 'dynredem1'
     
    9931003         CALL abort
    9941004      ENDIF
     1005     
     1006c On a single run, different files can be written with dynredem1.
     1007c Therefore, get the last time index from the file itself:
     1008      ierr = NF_INQ_DIMID(nid,"Time",nvarid)
     1009      ierr = NF_INQ_DIMLEN(nid,nvarid,nb)
    9951010
    9961011c  Ecriture/extension de la coordonnee temps
     
    10081023      ierr = NF_PUT_VAR1_REAL (nid,nvarid,nb,time)
    10091024#endif
    1010       PRINT*, "Enregistrement pour ", nb, time
     1025      IF (ierr .NE. NF_NOERR) THEN
     1026         print*, "Erreur ecriture temps!!"
     1027         print*, NF_STRERROR(ierr)
     1028      ENDIF
     1029      !PRINT*, "Enregistrement pour ", nb, time
    10111030
    10121031c  Ecriture des champs
    10131032c
     1033      corner(1)=1
     1034      corner(2)=1
     1035      corner(3)=1
     1036      corner(4)=nb
     1037      edges(1)=iip1
     1038      edges(2)=jjm
     1039      edges(3)=llm
     1040      edges(4)=1
     1041      ierr = NF_INQ_VARID(nid, "vcov", nvarid)
     1042      IF (ierr .NE. NF_NOERR) THEN
     1043         PRINT*, "Variable vcov n est pas definie"
     1044         CALL abort
     1045      ENDIF
     1046#ifdef NC_DOUBLE
     1047      ierr = NF_PUT_VARA_DOUBLE (nid,nvarid,corner,edges,vcov)
     1048#else
     1049      ierr = NF_PUT_VARA_REAL (nid,nvarid,corner,edges,vcov)
     1050#endif
     1051      IF (ierr .NE. NF_NOERR) THEN
     1052         print*, "Erreur ecriture vcov!!"
     1053         print*, NF_STRERROR(ierr)
     1054      ENDIF
     1055     
     1056c Following corner and egdes are the same for ucov, teta, tracers and masse:
     1057      corner(1)=1
     1058      corner(2)=1
     1059      corner(3)=1
     1060      corner(4)=nb
     1061      edges(1)=iip1
     1062      edges(2)=jjp1
     1063      edges(3)=llm
     1064      edges(4)=1
    10141065      ierr = NF_INQ_VARID(nid, "ucov", nvarid)
    10151066      IF (ierr .NE. NF_NOERR) THEN
     
    10181069      ENDIF
    10191070#ifdef NC_DOUBLE
    1020       ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,ucov)
    1021 #else
    1022       ierr = NF_PUT_VAR_REAL (nid,nvarid,ucov)
    1023 #endif
    1024 
    1025       ierr = NF_INQ_VARID(nid, "vcov", nvarid)
    1026       IF (ierr .NE. NF_NOERR) THEN
    1027          PRINT*, "Variable vcov n est pas definie"
    1028          CALL abort
    1029       ENDIF
    1030 #ifdef NC_DOUBLE
    1031       ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,vcov)
    1032 #else
    1033       ierr = NF_PUT_VAR_REAL (nid,nvarid,vcov)
    1034 #endif
     1071      ierr = NF_PUT_VARA_DOUBLE (nid,nvarid,corner,edges,ucov)
     1072#else
     1073      ierr = NF_PUT_VARA_REAL (nid,nvarid,corner,edges,ucov)
     1074#endif
     1075      IF (ierr .NE. NF_NOERR) THEN
     1076         print*, "Erreur ecriture ucov!!"
     1077         print*, NF_STRERROR(ierr)
     1078      ENDIF
     1079     
    10351080
    10361081      ierr = NF_INQ_VARID(nid, "teta", nvarid)
     
    10401085      ENDIF
    10411086#ifdef NC_DOUBLE
    1042       ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,teta)
    1043 #else
    1044       ierr = NF_PUT_VAR_REAL (nid,nvarid,teta)
    1045 #endif
     1087      ierr = NF_PUT_VARA_DOUBLE (nid,nvarid,corner,edges,teta)
     1088#else
     1089      ierr = NF_PUT_VARA_REAL (nid,nvarid,corner,edges,teta)
     1090#endif
     1091      IF (ierr .NE. NF_NOERR) THEN
     1092         print*, "Erreur ecriture teta!!"
     1093         print*, NF_STRERROR(ierr)
     1094      ENDIF
    10461095
    10471096      IF (nq.GT.99) THEN
     
    10681117            enddo
    10691118#ifdef NC_DOUBLE
    1070             ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,q3d)
    1071 #else
    1072             ierr = NF_PUT_VAR_REAL (nid,nvarid,q3d)
     1119            ierr = NF_PUT_VARA_DOUBLE (nid,nvarid,corner,edgesq3d)
     1120#else
     1121            ierr = NF_PUT_VARA_REAL (nid,nvarid,corner,edges,q3d)
    10731122#endif
    10741123            IF (ierr .NE. NF_NOERR) THEN
     
    10791128      ENDIF
    10801129c
     1130
    10811131      ierr = NF_INQ_VARID(nid, "masse", nvarid)
    10821132      IF (ierr .NE. NF_NOERR) THEN
     
    10851135      ENDIF
    10861136#ifdef NC_DOUBLE
    1087       ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,masse)
    1088 #else
    1089       ierr = NF_PUT_VAR_REAL (nid,nvarid,masse)
    1090 #endif
    1091 c
     1137      ierr = NF_PUT_VARA_DOUBLE (nid,nvarid,corner,edges,masse)
     1138#else
     1139      ierr = NF_PUT_VARA_REAL (nid,nvarid,corner,edges,masse)
     1140#endif
     1141      IF (ierr .NE. NF_NOERR) THEN
     1142         print*, "Erreur ecriture masse!!"
     1143         print*, NF_STRERROR(ierr)
     1144      ENDIF
     1145c
     1146
     1147      corner(1)=1
     1148      corner(2)=1
     1149      corner(3)=nb
     1150      edges(1)=iip1
     1151      edges(2)=jjp1
     1152      edges(3)=1
    10921153      ierr = NF_INQ_VARID(nid, "ps", nvarid)
    10931154      IF (ierr .NE. NF_NOERR) THEN
     
    10961157      ENDIF
    10971158#ifdef NC_DOUBLE
    1098       ierr = NF_PUT_VAR_DOUBLE (nid,nvarid,ps)
    1099 #else
    1100       ierr = NF_PUT_VAR_REAL (nid,nvarid,ps)
    1101 #endif
     1159      ierr = NF_PUT_VARA_DOUBLE (nid,nvarid,corner,edges,ps)
     1160#else
     1161      ierr = NF_PUT_VARA_REAL (nid,nvarid,corner,edges,ps)
     1162#endif
     1163      IF (ierr .NE. NF_NOERR) THEN
     1164         print*, "Erreur ecriture ps!!"
     1165         print*, NF_STRERROR(ierr)
     1166      ENDIF
    11021167
    11031168      ierr = NF_CLOSE(nid)
  • trunk/LMDZ.MARS/libf/dyn3d/gcm.F

    r828 r999  
    143143c-----------------------------------------------------------------------
    144144c  Initialize tracers using iniadvtrac (Ehouarn, oct 2008)
     145      CALL defrun_new( 99, .TRUE. )
     146
    145147      CALL iniadvtrac(nq,numvanle)
    146 
     148     
    147149      CALL dynetat0("start.nc",nqmx,vcov,ucov,
    148      .              teta,q,masse,ps,phis, time_0)
    149 
    150       CALL defrun_new( 99, .TRUE. )
     150     .              teta,q,masse,ps,phis,time_0)
     151
    151152      ! in case time_0 (because of roundoffs) is close to zero,
    152153      ! set it to zero to avoid roundoff propagation issues
     
    244245     . 'c''est a dire du jour',i7,3x,'au jour',i7//)
    245246
    246       CALL dynredem0("restart.nc",day_end,anne_ini,phis,nqmx)
     247      CALL dynredem0("restart.nc",day_ini,anne_ini,phis,nqmx)
    247248
    248249      ecripar = .TRUE.
     
    517518              iday= day_ini+itau/day_step
    518519              time= REAL(itau-(iday-day_ini)*day_step)/day_step+time_0
    519                 IF(time.GT.1.) THEN
     520                !IF(time.GT.1.) THEN
     521                IF(time.GE.1.) THEN
    520522                  time = time-1.
    521523                  iday = iday+1
     
    544546c-----------------------------------------------------------------------
    545547
    546 
    547             IF(itau.EQ.itaufin) THEN
    548 
    549 
    550        write(*,*)' GCM: Appel test_period avant redem ; itau=',itau
     548            IF( (ecritstart.GT.0) .and. (MOD(itau,ecritstart).EQ.0)
     549     .        .or. (itau.EQ.itaufin) ) THEN
     550           
     551       !write(*,*)' GCM: Appel test_period avant redem ; itau=',itau
    551552       CALL test_period ( ucov,vcov,teta,q,p,phis )
    552        CALL dynredem1("restart.nc",time,
    553      .                     vcov,ucov,teta,q,nqmx,masse,ps)
    554 
    555               CLOSE(99)
     553       
     554       write(*,'(A,I7,A,F12.5)')
     555     .  'GCM:    Ecriture du fichier restart   ; itau=  ',itau,
     556     .  ' date=',REAL(itau)/REAL(day_step)
     557       CALL dynredem1("restart.nc",REAL(itau)/REAL(day_step),
     558     .                vcov,ucov,teta,q,nqmx,masse,ps)
     559     
     560      CLOSE(99)
     561     
    556562            ENDIF
     563
    557564
    558565c-----------------------------------------------------------------------
     
    598605             time = REAL(itau-(iday-day_ini)*day_step)/day_step+time_0
    599606
    600                   IF(time.GT.1.) THEN
     607                  IF(time.GE.1.) THEN
    601608                   time = time-1.
    602609                   iday = iday+1
     
    624631
    625632
    626                  IF(itau.EQ.itaufin)
    627      . CALL dynredem1("restart.nc",time,
    628      .                     vcov,ucov,teta,q,nqmx,masse,ps)
    629 
    630                  forward = .TRUE.
    631                  GO TO  1
     633            IF( (ecritstart.GT.0) .and. (MOD(itau,ecritstart).EQ.0)
     634     .      .or. (itau.EQ.itaufin) ) THEN
     635           
     636              CALL dynredem1("restart.nc",
     637     .                REAL(itau)/REAL(day_step),
     638     .                vcov,ucov,teta,q,nqmx,masse,ps)
     639     
     640              forward = .TRUE.
     641              GO TO  1
     642             
     643            ENDIF
    632644
    633645
  • trunk/LMDZ.MARS/libf/dyn3d/lect_start_archive.F

    r563 r999  
    617617c       call solarlong(timelist(i),sollong(i))
    618618c       sollong(i) = sollong(i)*180./pi
    619         write(*,*) 'initial state at martian day: ',int(timelist(i))
     619c        write(*,*) 'initial state at martian day: ',int(timelist(i))
     620        write(*,*) 'initial state at martian day: ',timelist(i)
    620621c       write(*,6) nint(timelist(i)),nint(mod(timelist(i),669)),
    621622c    .    sollong(i)
     
    630631      memo = 0
    631632      do i=1,timelen
    632         if (date.eq.int(timelist(i))) then
     633c        if (date.eq.int(timelist(i))) then
     634        if (abs(date-timelist(i)).lt.0.01) then
    633635            memo = i
    634636        endif
     
    643645        write(*,*) '~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~'
    644646        do i=1,timelen
    645           write(*,*) 'initial state at martian day: ',nint(timelist(i))
     647          write(*,*) 'initial state at martian day: ',timelist(i)
    646648c         write(*,6) nint(timelist(i)),nint(mod(timelist(i),669))
    647649        end do
    648650        goto 123
    649651      endif
    650 
     652     
    651653!-----------------------------------------------------------------------
    652654! 5. Read (time-dependent) data from datafile
  • trunk/LMDZ.MARS/libf/dyn3d/newstart.F

    r697 r999  
    14491449      if (choix_1.eq.0) then
    14501450         day_ini=int(date)
     1451         hour_ini=date-int(date)
    14511452      endif
    14521453c
     
    14601461
    14611462      CALL dynredem0("restart.nc",day_ini,anneeref,phis,nqmx)
    1462       CALL dynredem1("restart.nc",0.0,vcov,ucov,teta,q,nqmx,masse,ps)
     1463      CALL dynredem1("restart.nc",hour_ini,vcov,ucov,teta,q,
     1464     .               nqmx,masse,ps)
    14631465C
    14641466C Ecriture etat initial physique
    14651467C
    14661468
    1467       call physdem1("restartfi.nc",lonfi,latfi,nsoilmx,nqmx,
    1468      .              dtphys,real(day_ini),
    1469      .              time,tsurf,tsoil,co2ice,emis,q2,qsurf,
     1469      call physdem0("restartfi.nc",lonfi,latfi,nsoilmx,nqmx,
     1470     .              dtphys,real(day_ini),0.0,
    14701471     .              airefi,albfi,ithfi,zmea,zstd,zsig,zgam,zthe)
     1472      call physdem1("restartfi.nc",nsoilmx,nqmx,
     1473     .              dtphys,hour_ini,
     1474     .              tsurf,tsoil,co2ice,emis,q2,qsurf)
    14711475
    14721476c=======================================================================
  • trunk/LMDZ.MARS/libf/dyn3d/start2archive.F

    r410 r999  
    110110c-----------------------------------------------------------------------
    111111
     112      CALL defrun_new(99, .TRUE. )
    112113      grireg   = .TRUE.
    113114
     
    290291c-----------------------------------------------------------------------
    291292
    292       date = day_ini
     293      date = day_ini + hour_ini
    293294      ierr= NF_INQ_VARID(nid,"Time",varid)
    294295      ierr= NF_INQ_DIMID(nid,"Time",dimid)
  • trunk/LMDZ.MARS/libf/dyn3d/temps.h

    r791 r999  
    33
    44      COMMON/temps_i/day_ini,day_end,anne_ini,itaufin
    5       COMMON/temps_r/dt
     5      COMMON/temps_r/dt,hour_ini
    66
    77      INTEGER  itaufin  ! total number of dynamical steps for the run
     
    99      INTEGER*4 day_end ! final day # ; i.e. day # when this simulation ends
    1010      INTEGER*4 anne_ini ! initial year # of simulation sequence ? Not used.
    11       REAL dt ! (dynamics) time step (changes if doing Matsuno or LF step)
     11      REAL dt ! (dynamics) time step (changes if doing Matsuno or LF step)
     12      REAL hour_ini ! initial fraction of day of simulation sequence (0=<hour_ini<1)
    1213
    1314c-----------------------------------------------------------------------
  • trunk/LMDZ.MARS/libf/phymars/iniwrite.F

    r164 r999  
    7272      tab_cntrl(15) = stot0
    7373      tab_cntrl(16) = ang0
     74
     75      tab_cntrl(27) = hour_ini
    7476c
    7577c    ..........    P.Le Van  ( ajout le 8/04/96 )    .........
  • trunk/LMDZ.MARS/libf/phymars/phyetat0.F

    r697 r999  
    11      SUBROUTINE phyetat0 (fichnom,tab0,Lmodif,nsoil,nq,
    2      .           day_ini,time,
     2     .           day_ini,time0,
    33     .           tsurf,tsoil,emis,q2,qsurf,co2ice)
    44
     
    1313!                      r4 or r8 restarts independently of having compiled
    1414!                      the GCM in r4 or r8)
     15!         June 2013 TN : Possibility to read files with a time axis
    1516c======================================================================
    1617!#include "netcdf.inc"
     
    2425#include "comcstfi.h"
    2526!#include "tracer.h"
    26 #include"advtrac.h"
     27#include "advtrac.h"
     28#include "control.h"
    2729c======================================================================
    2830      INTEGER nbsrf !Mars nbsrf a 1 au lieu de 4
     
    3840      integer nq
    3941      integer day_ini
    40       real time
     42      real time0
    4143
    4244!  outputs:
     
    7274      character(len=30) :: txt ! to store some text
    7375
    74  
     76! specific for time
     77      REAL,ALLOCATABLE :: time(:) ! times stored in start
     78      INTEGER timelen ! number of times stored in the file
     79      INTEGER indextime ! index of selected time
     80
     81      INTEGER edges(3),corner(3)
     82
     83
    7584c
    7685c Ouvrir le fichier contenant l etat initial:
     
    111120      write(*,*) 'TABFI de phyeta0',Lmodif,tab0
    112121      call tabfi (nid,Lmodif,tab0,day_ini,lmax,p_rad,
    113      .              p_omeg,p_g,p_mugaz,p_daysec,time)
     122     .              p_omeg,p_g,p_mugaz,p_daysec,time0)
    114123c
    115124c Read latitudes (coordinates): No need, these are provided by the dynamics
     
    333342      ENDDO
    334343      PRINT*,'<zthe>:', xmin, xmax
     344     
     345c
     346c Time axis
     347c
     348      ierr = nf90_inq_dimid(nid,"Time",nvarid)
     349
     350      IF (ierr .NE. nf90_noerr) THEN
     351        indextime = 1
     352        print*, "phyetat0: No time axis found in "//fichnom
     353     
     354      ELSE
     355        print*, "phyetat0: Time axis found in "//fichnom
     356       
     357        ierr = nf90_inquire_dimension(nid,nvarid,len=timelen)
     358       
     359        ALLOCATE(time(timelen))
     360 
     361        ierr=nf90_inq_varid(nid,"Time",nvarid)
     362        IF (ierr .NE. nf90_noerr) THEN
     363             ierr=nf90_inq_varid(nid,"temps", nvarid)
     364                 IF (ierr .NE. nf90_noerr) THEN
     365             PRINT*, "dynetat0: <Time> or <temps> absent"
     366             write(*,*)trim(nf90_strerror(ierr))
     367             CALL abort
     368           ENDIF
     369        ENDIF
     370        ierr=nf90_get_var(nid,nvarid,time)
     371        IF (ierr .NE. nf90_noerr) THEN
     372           PRINT*, "dynetat0: Lecture echouee <Time>/<temps>"
     373           write(*,*)trim(nf90_strerror(ierr))
     374           CALL abort
     375        ENDIF
     376c     
     377c Select desired time
     378c
     379        IF (timestart .lt. 0) THEN  ! default: we use the last time value
     380          indextime = timelen
     381        ELSE  ! else we look for the desired value in the time axis
     382         indextime = 0
     383          DO i=1,timelen
     384            IF (abs(time(i) - timestart) .lt. 0.01) THEN
     385               indextime = i
     386               EXIT
     387            ENDIF
     388          ENDDO
     389          IF (indextime .eq. 0) THEN
     390            PRINT*, "Time", timestart," is not in "//fichnom//"!!"
     391            PRINT*, "Stored times are:"
     392            DO i=1,timelen
     393               PRINT*, time(i)
     394            ENDDO
     395            CALL abort
     396          ENDIF
     397        ENDIF
     398       
     399        ! In startfi the absolute date is day_ini + time0 + time
     400        ! For now on, in the GCM physics, it is day_ini + time0
     401        time0 = time(indextime) + time0
     402        day_ini = day_ini + INT(time0)
     403        time0 = time0 - INT(time0)
     404       
     405        PRINT*, "phyetat0: Selected time ",time(indextime),
     406     .          " at index ",indextime
     407     
     408        DEALLOCATE(time)
     409       
     410      ENDIF ! of IF (Time not in file)
     411     
     412     
    335413c
    336414c CO2 ice cover
    337415c
     416      corner(1)=1
     417      corner(2)=indextime
     418      edges(1)=ngridmx
     419      edges(2)=1
    338420      ierr=nf90_inq_varid(nid,"co2ice",nvarid)
    339421      IF (ierr.NE.nf90_noerr) THEN
     
    342424         CALL abort
    343425      ENDIF
    344       ierr=nf90_get_var(nid,nvarid,co2ice)
     426      ierr=nf90_get_var(nid,nvarid,co2ice,corner,edges)
    345427      IF (ierr.NE.nf90_noerr) THEN
    346428         PRINT*, 'phyetat0: Lecture echouee pour <co2ice>'
     
    389471         PRINT*, '          J ignore donc les autres temperatures TS**'
    390472         !ierr=nf90_get_var(nid,nvarid,tsurf(1,1))
    391          ierr=nf90_get_var(nid,nvarid,tsurf)
     473         ierr=nf90_get_var(nid,nvarid,tsurf,corner,edges)
    392474         IF (ierr.NE.nf90_noerr) THEN
    393475            PRINT*, "phyetat0: Lecture echouee pour <TSURF>"
     
    453535         CALL abort
    454536      ENDIF
    455       ierr=nf90_get_var(nid,nvarid,emis)
     537      ierr=nf90_get_var(nid,nvarid,emis,corner,edges)
    456538      IF (ierr.NE.nf90_noerr) THEN
    457539         PRINT*, 'phyetat0: Lecture echouee pour <emis>'
     
    491573c pbl wind variance
    492574c
     575      corner(1)=1
     576      corner(2)=1
     577      corner(3)=indextime
     578      edges(1)=ngridmx
     579      edges(2)=llm+1
     580      edges(3)=1
    493581      ierr=nf90_inq_varid(nid,"q2",nvarid)
    494582      IF (ierr.NE.nf90_noerr) THEN
     
    497585         CALL abort
    498586      ENDIF
    499       ierr=nf90_get_var(nid,nvarid,q2)
     587      ierr=nf90_get_var(nid,nvarid,q2,corner,edges)
    500588      IF (ierr.NE.nf90_noerr) THEN
    501589         PRINT*, 'phyetat0: Lecture echouee pour <q2>'
     
    511599c tracer on surface
    512600c
    513 
     601      corner(1)=1
     602      corner(2)=indextime
     603      edges(1)=ngridmx
     604      edges(2)=1
    514605      IF(nq.GE.1) THEN
    515606         nqold=nq
     
    542633           ELSE
    543634           !ierr=nf90_get_var(nid,nvarid,qsurf(1,iq))
    544            ierr=nf90_get_var(nid,nvarid,surffield)
     635           ierr=nf90_get_var(nid,nvarid,surffield,corner,edges)
    545636           qsurf(1:ngridmx,iq)=surffield(1:ngridmx)
    546637             IF (ierr.NE.nf90_noerr) THEN
     
    583674! as well as thermal inertia and volumetric heat capacity
    584675
    585       call soil_settings(nid,ngridmx,nsoil,tsurf,tsoil)
     676      call soil_settings(nid,ngridmx,nsoil,tsurf,tsoil,indextime)
    586677c
    587678c Fermer le fichier:
  • trunk/LMDZ.MARS/libf/phymars/physiq.F

    r900 r999  
    162162
    163163      REAL pday
    164       REAL ptime 
     164      REAL ptime
    165165      logical tracerdyn
    166166
     
    214214      REAL sky
    215215
    216       SAVE day_ini, icount
     216      SAVE day_ini, icount, time_phys
    217217      SAVE aerosol, tsurf,tsoil
    218218      SAVE co2ice,albedo,emis, q2
     
    478478#ifndef MESOSCALE
    479479         if (callslope) call getslopes(phisfi)
     480                           
     481         call physdem0("restartfi.nc",long,lati,nsoilmx,nq,
     482     .                 ptimestep,pday,time_phys,area,
     483     .                 albedodat,inertiedat,zmea,zstd,zsig,zgam,zthe)
     484     
    480485#endif
    481486                   
     
    13541359     
    13551360
     1361
    13561362c-----------------------------------------------------------------------
    13571363c  10. Write output files
     
    15201526c              thus we store for time=time+dtvr
    15211527
    1522          IF(lastcall) THEN
    1523             ztime_fin = ptime + ptimestep/(float(iphysiq)*daysec)
    1524             write(*,*)'PHYSIQ: for physdem ztime_fin =',ztime_fin
    1525             call physdem1("restartfi.nc",long,lati,nsoilmx,nq,
    1526      .              ptimestep,pday,
    1527      .              ztime_fin,tsurf,tsoil,co2ice,emis,q2,qsurf,
    1528      .              area,albedodat,inertiedat,zmea,zstd,zsig,
    1529      .              zgam,zthe)
     1528         IF(   ((ecritstart.GT.0) .and.
     1529     .          (MOD(icount*iphysiq,ecritstart).EQ.0))
     1530     .    .or. lastcall  ) THEN
     1531         
     1532          ztime_fin = pday + ptime  + ptimestep/(float(iphysiq)*daysec)
     1533     .               - day_ini - time_phys
     1534          print*, pday,ptime,day_ini, time_phys
     1535          write(*,'(A,I7,A,F12.5)')
     1536     .         'PHYSIQ: Ecriture du fichier restartfi ; icount=',
     1537     .          icount,' date=',ztime_fin
     1538           
     1539           
     1540          call physdem1("restartfi.nc",nsoilmx,nq,
     1541     .                ptimestep,ztime_fin,
     1542     .                tsurf,tsoil,co2ice,emis,q2,qsurf)
     1543         
    15301544         ENDIF
    15311545#endif
  • trunk/LMDZ.MARS/libf/phymars/soil_settings.F

    r38 r999  
    1       subroutine soil_settings(nid,ngrid,nsoil,tsurf,tsoil)
     1      subroutine soil_settings(nid,ngrid,nsoil,tsurf,tsoil,indextime)
    22
    33      use netcdf
     
    1212!                      r4 or r8 restarts independently of having compiled
    1313!                      the GCM in r4 or r8)
     14!                June 2013 TN : Possibility to read files with a time axis
     15!
    1416!
    1517!  This subroutine reads from a NetCDF file (opened by the caller)
     
    4244      integer nsoil     ! # of soil layers
    4345      real tsurf(ngrid) ! surface temperature
     46      integer indextime ! position on time axis
    4447!  output:
    4548      real tsoil(ngridmx,nsoilmx)       ! soil temperature
     
    5356      integer ndims     ! # of dimensions of read <inertiedat> data
    5457      integer ig,iloop  ! loop counters
     58     
     59      integer edges(3),corner(3) ! to read a specific time
    5560
    5661      logical :: olddepthdef=.false. ! flag
     
    298303        endif
    299304       else ! put values in tsoil
     305        corner(1)=1
     306        corner(2)=1
     307        corner(3)=indextime
     308        edges(1)=ngridmx
     309        edges(2)=nsoilmx
     310        edges(3)=1
     311        !ierr=nf90_get_var(nid,nvarid,tsoil,corner,edges)
    300312        ierr=nf90_get_var(nid,nvarid,tsoil)
    301313        if (ierr.ne.nf90_noerr) then
  • trunk/LMDZ.MARS/libf/phymars/testphys1d.F

    r899 r999  
    641641c  It is needed to transfert physics variables to "physiq"...
    642642
    643       call physdem1("startfi.nc",long,lati,nsoilmx,nqmx,
    644      .              dtphys,float(day0),time,tsurf,
    645      .              tsoil,co2ice,emis,q2,qsurf,area,albedodat,
    646      .              inertiedat,zmea,zstd,zsig,zgam,zthe)
     643      call physdem0("startfi.nc",long,lati,nsoilmx,nqmx,
     644     .              dtphys,float(day0),time,area,
     645     .              albedodat,inertiedat,zmea,zstd,zsig,zgam,zthe)
     646      call physdem1("startfi.nc",nsoilmx,nqmx,
     647     .              dtphys,time,
     648     .              tsurf,tsoil,co2ice,emis,q2,qsurf)
    647649
    648650c=======================================================================
  • trunk/LMDZ.MARS/util/expandstartfi.F90

    r803 r999  
    2020integer :: varid ! to store the ID of a variable
    2121integer :: datashape(4) ! to store dimension IDs of a given dataset
     22integer :: corner(3),edges(3) ! to read data with a time axis
    2223character(len=90) :: varname ! name of a variable
    2324character(len=90) :: varatt ! name of attribute of a variable
     
    2829integer :: nlayer_plus_1_dimid
    2930integer :: number_of_advected_fields_dimid
     31integer :: time_dimid
    3032integer :: nbindims ! number of dimensions in input file
    3133integer :: nbinvars ! number of variables in input file
     
    3638integer :: nlayer_plus_1
    3739integer :: number_of_advected_fields
     40integer :: timelen
    3841real,allocatable :: surf_field(:) ! to store a 1D field of physical_points elements
    3942real,allocatable :: subsurf_field(:,:) ! to store subsurface (2D field)
     
    155158endif
    156159
     160status=nf90_inq_dimid(inid,"Time",time_dimid)
     161if (status.ne.nf90_noerr) then
     162  write(*,*)"Failed to find Time dimension"
     163  write(*,*)trim(nf90_strerror(status))
     164  timelen = 0
     165else
     166  status=nf90_inquire_dimension(inid,time_dimid,len=timelen)
     167  if (status.ne.nf90_noerr) then
     168    write(*,*)"Failed to read Time dimension"
     169    write(*,*)trim(nf90_strerror(status))
     170   stop
     171  else
     172    write(*,*) " time length = ",timelen
     173  endif
     174endif
     175
    157176! 1.3 Allocate memory for input fields
    158177allocate(surf_field(physical_points))
     
    361380allocate(out_surf_field(lonlen,latlen))
    362381
     382shape(:) = 0
    363383do ivar=1,nbinvars ! loop on all input variables
    364384  ! find out what dimensions are linked to this variable
    365385  status=nf90_inquire_variable(inid,ivar,name=varname,ndims=nbdim,&
    366386                               dimids=shape,natts=nbatt)
    367   if ((nbdim==1).and.(shape(1)==physical_points_dimid)) then
     387  if (((nbdim==1).and.(shape(1)==physical_points_dimid))&
     388  .or.((nbdim==2).and.(shape(1)==physical_points_dimid)&
     389                 .and.(shape(2)==time_dimid))) then
     390 
     391    corner(1) = 1
     392    corner(2) = timelen
     393    edges(1)  = physical_points
     394    edges(2)  = 1
    368395   
    369396    ! skip "longitude" and "latitude"
     
    375402    ! load input data:
    376403    status=nf90_inq_varid(inid,varname,invarid)
    377     status=nf90_get_var(inid,invarid,surf_field)
     404    status=nf90_get_var(inid,invarid,surf_field,corner,edges)
    378405   
    379406    ! switch output file to to define mode
     
    455482  status=nf90_inquire_variable(inid,ivar,name=varname,ndims=nbdim,&
    456483                               dimids=shape,natts=nbatt)
    457   if ((nbdim==2).and.(shape(1)==physical_points_dimid) &
    458                 .and.(shape(2)==subsurface_layers_dimid)) then
     484  if (((nbdim==2).and.(shape(1)==physical_points_dimid)&
     485                 .and.(shape(2)==subsurface_layers_dimid))&
     486  .or.((nbdim==3).and.(shape(1)==physical_points_dimid)&
     487                 .and.(shape(2)==subsurface_layers_dimid)&
     488                 .and.(shape(3)==time_dimid))) then
     489   
     490    corner(1) = 1
     491    corner(2) = 1
     492    corner(3) = timelen
     493    edges(1)  = physical_points
     494    edges(2)  = subsurface_layers
     495    edges(3)  = 1
    459496   
    460497    write(*,*) " processing: ",trim(varname)
     
    462499    ! load input data:
    463500    status=nf90_inq_varid(inid,varname,invarid)
    464     status=nf90_get_var(inid,invarid,subsurf_field)
     501    status=nf90_get_var(inid,invarid,subsurf_field,corner,edges)
    465502   
    466503    ! switch output file to to define mode
Note: See TracChangeset for help on using the changeset viewer.