- Timestamp:
- Jul 2, 2013, 9:40:28 AM (12 years ago)
- Location:
- trunk/LMDZ.MARS
- Files:
-
- 1 added
- 16 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.MARS/README
r954 r999 1850 1850 == 10/05/2013 == FGG 1851 1851 - 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. 1874 For 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 7 7 COMMON/control_i/ndynstep,day_step, & 8 8 & 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 11 11 12 12 INTEGER ndynstep ! # of dynamical time steps to run (if negative or not specified in run.def, nday_r is used instead) … … 19 19 REAL periodav 20 20 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" 21 23 real nday_r ! number of days to run (possibly including a fraction of day) 22 24 -
trunk/LMDZ.MARS/libf/dyn3d/defrun_new.F
r828 r999 252 252 else 253 253 WRITE(tapeout,*)" ecritphy = ",ecritphy 254 endif 255 256 ccc .... T.Navarro, read start time (06/2013) ... 257 c 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 264 ccc .... T.Navarro, start output (01/2013) ... 265 c 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 254 279 endif 255 280 -
trunk/LMDZ.MARS/libf/dyn3d/dynetat0.F
r791 r999 1 1 SUBROUTINE dynetat0(fichnom,nq,vcov,ucov, 2 . teta,q,masse,ps,phis,time )2 . teta,q,masse,ps,phis,time0) 3 3 4 4 use netcdf … … 20 20 c r4 or r8 restarts independently of having compiled 21 21 c the GCM in r4 or r8) 22 c 22 c June 2013 TN : Possibility to read files with a time axis. 23 c NOW defrun_new MUST BE CALLED BEFORE dynetat0. 23 24 c======================================================================= 24 25 c----------------------------------------------------------------------- … … 36 37 #include "serre.h" 37 38 #include "logic.h" 38 #include"advtrac.h" 39 #include "advtrac.h" 40 #include "control.h" 39 41 40 42 c Arguments: … … 48 50 REAL ps(iip1,jjp1),phis(iip1,jjp1) 49 51 50 REAL time ! fraction of day the fields correspond to52 REAL time0 ! fraction of day the fields correspond to 51 53 52 54 c Variables … … 58 60 INTEGER ierr, nid, nvarid, nqold 59 61 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) 60 69 61 70 c----------------------------------------------------------------------- … … 102 111 pa = tab_cntrl(17) 103 112 preff = tab_cntrl(18) 113 114 hour_ini = tab_cntrl(29) 115 104 116 c 105 117 clon = tab_cntrl(19) … … 119 131 IF( tab_cntrl(26).EQ.1. ) ysinus = . TRUE. 120 132 ENDIF 133 121 134 c ................................................................. 122 135 c … … 239 252 ENDIF 240 253 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 241 261 ierr=nf90_inq_varid(nid,"Time",nvarid) 242 262 IF (ierr .NE. nf90_noerr) THEN … … 254 274 CALL abort 255 275 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 257 343 ierr=nf90_inq_varid(nid,"ucov",nvarid) 258 344 IF (ierr .NE. nf90_noerr) THEN … … 261 347 CALL abort 262 348 ENDIF 263 ierr=nf90_get_var(nid,nvarid,ucov )349 ierr=nf90_get_var(nid,nvarid,ucov,corner,edges) 264 350 IF (ierr .NE. nf90_noerr) THEN 265 351 PRINT*, "dynetat0: Lecture echouee pour <ucov>" … … 267 353 CALL abort 268 354 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 283 357 ierr=nf90_inq_varid(nid,"teta",nvarid) 284 358 IF (ierr .NE. nf90_noerr) THEN … … 287 361 CALL abort 288 362 ENDIF 289 ierr=nf90_get_var(nid,nvarid,teta )363 ierr=nf90_get_var(nid,nvarid,teta,corner,edges) 290 364 IF (ierr .NE. nf90_noerr) THEN 291 365 PRINT*, "dynetat0: Lecture echouee pour <teta>" … … 294 368 ENDIF 295 369 296 370 ! read tracers 297 371 IF(nq.GE.1) THEN 298 372 write(*,*) 'dynetat0: loading tracers' … … 318 392 ELSE 319 393 !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) 321 395 IF (ierr .NE. nf90_noerr) THEN 322 396 ! PRINT*, "dynetat0: Lecture echouee pour "//str3 … … 355 429 ENDIF 356 430 431 ! read masse 357 432 ierr=nf90_inq_varid(nid,"masse",nvarid) 358 433 IF (ierr .NE. nf90_noerr) THEN … … 361 436 CALL abort 362 437 ENDIF 363 ierr=nf90_get_var(nid,nvarid,masse )438 ierr=nf90_get_var(nid,nvarid,masse,corner,edges) 364 439 IF (ierr .NE. nf90_noerr) THEN 365 440 PRINT*, "dynetat0: Lecture echouee pour <masse>" … … 368 443 ENDIF 369 444 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 370 452 ierr=nf90_inq_varid(nid,"ps",nvarid) 371 453 IF (ierr .NE. nf90_noerr) THEN … … 374 456 CALL abort 375 457 ENDIF 376 ierr=nf90_get_var(nid,nvarid,ps )458 ierr=nf90_get_var(nid,nvarid,ps,corner,edges) 377 459 IF (ierr .NE. nf90_noerr) THEN 378 460 PRINT*, "dynetat0: Lecture echouee pour <ps>" -
trunk/LMDZ.MARS/libf/dyn3d/dynredem.F
r410 r999 36 36 character*80 abort_message 37 37 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 38 41 39 42 c Variables locales pour NetCDF: … … 72 75 tab_cntrl(7) = g 73 76 tab_cntrl(8) = cpp 74 tab_cntrl(9) = kappa77 tab_cntrl(9) = kappa 75 78 tab_cntrl(10) = daysec 76 79 tab_cntrl(11) = dtvr … … 82 85 tab_cntrl(17) = pa 83 86 tab_cntrl(18) = preff 87 88 tab_cntrl(29) = hour_ini 89 84 90 c 85 91 c ..... parametres pour le zoom ...... … … 106 112 IF( ysinus ) tab_cntrl(26) = 1. 107 113 ENDIF 114 115 108 116 c 109 117 c ......................................................... … … 983 991 character*80 abort_message 984 992 c 993 994 INTEGER edges(4),corner(4) 995 985 996 INTEGER nb,i,j 986 SAVE nb 987 DATA nb / 0 / 997 988 998 989 999 modname = 'dynredem1' … … 993 1003 CALL abort 994 1004 ENDIF 1005 1006 c On a single run, different files can be written with dynredem1. 1007 c 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) 995 1010 996 1011 c Ecriture/extension de la coordonnee temps … … 1008 1023 ierr = NF_PUT_VAR1_REAL (nid,nvarid,nb,time) 1009 1024 #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 1011 1030 1012 1031 c Ecriture des champs 1013 1032 c 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 1056 c 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 1014 1065 ierr = NF_INQ_VARID(nid, "ucov", nvarid) 1015 1066 IF (ierr .NE. NF_NOERR) THEN … … 1018 1069 ENDIF 1019 1070 #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 1035 1080 1036 1081 ierr = NF_INQ_VARID(nid, "teta", nvarid) … … 1040 1085 ENDIF 1041 1086 #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 1046 1095 1047 1096 IF (nq.GT.99) THEN … … 1068 1117 enddo 1069 1118 #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) 1073 1122 #endif 1074 1123 IF (ierr .NE. NF_NOERR) THEN … … 1079 1128 ENDIF 1080 1129 c 1130 1081 1131 ierr = NF_INQ_VARID(nid, "masse", nvarid) 1082 1132 IF (ierr .NE. NF_NOERR) THEN … … 1085 1135 ENDIF 1086 1136 #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 1145 c 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 1092 1153 ierr = NF_INQ_VARID(nid, "ps", nvarid) 1093 1154 IF (ierr .NE. NF_NOERR) THEN … … 1096 1157 ENDIF 1097 1158 #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 1102 1167 1103 1168 ierr = NF_CLOSE(nid) -
trunk/LMDZ.MARS/libf/dyn3d/gcm.F
r828 r999 143 143 c----------------------------------------------------------------------- 144 144 c Initialize tracers using iniadvtrac (Ehouarn, oct 2008) 145 CALL defrun_new( 99, .TRUE. ) 146 145 147 CALL iniadvtrac(nq,numvanle) 146 148 147 149 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 151 152 ! in case time_0 (because of roundoffs) is close to zero, 152 153 ! set it to zero to avoid roundoff propagation issues … … 244 245 . 'c''est a dire du jour',i7,3x,'au jour',i7//) 245 246 246 CALL dynredem0("restart.nc",day_ end,anne_ini,phis,nqmx)247 CALL dynredem0("restart.nc",day_ini,anne_ini,phis,nqmx) 247 248 248 249 ecripar = .TRUE. … … 517 518 iday= day_ini+itau/day_step 518 519 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 520 522 time = time-1. 521 523 iday = iday+1 … … 544 546 c----------------------------------------------------------------------- 545 547 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 551 552 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 556 562 ENDIF 563 557 564 558 565 c----------------------------------------------------------------------- … … 598 605 time = REAL(itau-(iday-day_ini)*day_step)/day_step+time_0 599 606 600 IF(time.G T.1.) THEN607 IF(time.GE.1.) THEN 601 608 time = time-1. 602 609 iday = iday+1 … … 624 631 625 632 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 632 644 633 645 -
trunk/LMDZ.MARS/libf/dyn3d/lect_start_archive.F
r563 r999 617 617 c call solarlong(timelist(i),sollong(i)) 618 618 c sollong(i) = sollong(i)*180./pi 619 write(*,*) 'initial state at martian day: ',int(timelist(i)) 619 c write(*,*) 'initial state at martian day: ',int(timelist(i)) 620 write(*,*) 'initial state at martian day: ',timelist(i) 620 621 c write(*,6) nint(timelist(i)),nint(mod(timelist(i),669)), 621 622 c . sollong(i) … … 630 631 memo = 0 631 632 do i=1,timelen 632 if (date.eq.int(timelist(i))) then 633 c if (date.eq.int(timelist(i))) then 634 if (abs(date-timelist(i)).lt.0.01) then 633 635 memo = i 634 636 endif … … 643 645 write(*,*) '~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~' 644 646 do i=1,timelen 645 write(*,*) 'initial state at martian day: ', nint(timelist(i))647 write(*,*) 'initial state at martian day: ',timelist(i) 646 648 c write(*,6) nint(timelist(i)),nint(mod(timelist(i),669)) 647 649 end do 648 650 goto 123 649 651 endif 650 652 651 653 !----------------------------------------------------------------------- 652 654 ! 5. Read (time-dependent) data from datafile -
trunk/LMDZ.MARS/libf/dyn3d/newstart.F
r697 r999 1449 1449 if (choix_1.eq.0) then 1450 1450 day_ini=int(date) 1451 hour_ini=date-int(date) 1451 1452 endif 1452 1453 c … … 1460 1461 1461 1462 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) 1463 1465 C 1464 1466 C Ecriture etat initial physique 1465 1467 C 1466 1468 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, 1470 1471 . 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) 1471 1475 1472 1476 c======================================================================= -
trunk/LMDZ.MARS/libf/dyn3d/start2archive.F
r410 r999 110 110 c----------------------------------------------------------------------- 111 111 112 CALL defrun_new(99, .TRUE. ) 112 113 grireg = .TRUE. 113 114 … … 290 291 c----------------------------------------------------------------------- 291 292 292 date = day_ini 293 date = day_ini + hour_ini 293 294 ierr= NF_INQ_VARID(nid,"Time",varid) 294 295 ierr= NF_INQ_DIMID(nid,"Time",dimid) -
trunk/LMDZ.MARS/libf/dyn3d/temps.h
r791 r999 3 3 4 4 COMMON/temps_i/day_ini,day_end,anne_ini,itaufin 5 COMMON/temps_r/dt 5 COMMON/temps_r/dt,hour_ini 6 6 7 7 INTEGER itaufin ! total number of dynamical steps for the run … … 9 9 INTEGER*4 day_end ! final day # ; i.e. day # when this simulation ends 10 10 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) 12 13 13 14 c----------------------------------------------------------------------- -
trunk/LMDZ.MARS/libf/phymars/iniwrite.F
r164 r999 72 72 tab_cntrl(15) = stot0 73 73 tab_cntrl(16) = ang0 74 75 tab_cntrl(27) = hour_ini 74 76 c 75 77 c .......... P.Le Van ( ajout le 8/04/96 ) ......... -
trunk/LMDZ.MARS/libf/phymars/phyetat0.F
r697 r999 1 1 SUBROUTINE phyetat0 (fichnom,tab0,Lmodif,nsoil,nq, 2 . day_ini,time ,2 . day_ini,time0, 3 3 . tsurf,tsoil,emis,q2,qsurf,co2ice) 4 4 … … 13 13 ! r4 or r8 restarts independently of having compiled 14 14 ! the GCM in r4 or r8) 15 ! June 2013 TN : Possibility to read files with a time axis 15 16 c====================================================================== 16 17 !#include "netcdf.inc" … … 24 25 #include "comcstfi.h" 25 26 !#include "tracer.h" 26 #include"advtrac.h" 27 #include "advtrac.h" 28 #include "control.h" 27 29 c====================================================================== 28 30 INTEGER nbsrf !Mars nbsrf a 1 au lieu de 4 … … 38 40 integer nq 39 41 integer day_ini 40 real time 42 real time0 41 43 42 44 ! outputs: … … 72 74 character(len=30) :: txt ! to store some text 73 75 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 75 84 c 76 85 c Ouvrir le fichier contenant l etat initial: … … 111 120 write(*,*) 'TABFI de phyeta0',Lmodif,tab0 112 121 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) 114 123 c 115 124 c Read latitudes (coordinates): No need, these are provided by the dynamics … … 333 342 ENDDO 334 343 PRINT*,'<zthe>:', xmin, xmax 344 345 c 346 c Time axis 347 c 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 376 c 377 c Select desired time 378 c 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 335 413 c 336 414 c CO2 ice cover 337 415 c 416 corner(1)=1 417 corner(2)=indextime 418 edges(1)=ngridmx 419 edges(2)=1 338 420 ierr=nf90_inq_varid(nid,"co2ice",nvarid) 339 421 IF (ierr.NE.nf90_noerr) THEN … … 342 424 CALL abort 343 425 ENDIF 344 ierr=nf90_get_var(nid,nvarid,co2ice )426 ierr=nf90_get_var(nid,nvarid,co2ice,corner,edges) 345 427 IF (ierr.NE.nf90_noerr) THEN 346 428 PRINT*, 'phyetat0: Lecture echouee pour <co2ice>' … … 389 471 PRINT*, ' J ignore donc les autres temperatures TS**' 390 472 !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) 392 474 IF (ierr.NE.nf90_noerr) THEN 393 475 PRINT*, "phyetat0: Lecture echouee pour <TSURF>" … … 453 535 CALL abort 454 536 ENDIF 455 ierr=nf90_get_var(nid,nvarid,emis )537 ierr=nf90_get_var(nid,nvarid,emis,corner,edges) 456 538 IF (ierr.NE.nf90_noerr) THEN 457 539 PRINT*, 'phyetat0: Lecture echouee pour <emis>' … … 491 573 c pbl wind variance 492 574 c 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 493 581 ierr=nf90_inq_varid(nid,"q2",nvarid) 494 582 IF (ierr.NE.nf90_noerr) THEN … … 497 585 CALL abort 498 586 ENDIF 499 ierr=nf90_get_var(nid,nvarid,q2 )587 ierr=nf90_get_var(nid,nvarid,q2,corner,edges) 500 588 IF (ierr.NE.nf90_noerr) THEN 501 589 PRINT*, 'phyetat0: Lecture echouee pour <q2>' … … 511 599 c tracer on surface 512 600 c 513 601 corner(1)=1 602 corner(2)=indextime 603 edges(1)=ngridmx 604 edges(2)=1 514 605 IF(nq.GE.1) THEN 515 606 nqold=nq … … 542 633 ELSE 543 634 !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) 545 636 qsurf(1:ngridmx,iq)=surffield(1:ngridmx) 546 637 IF (ierr.NE.nf90_noerr) THEN … … 583 674 ! as well as thermal inertia and volumetric heat capacity 584 675 585 call soil_settings(nid,ngridmx,nsoil,tsurf,tsoil )676 call soil_settings(nid,ngridmx,nsoil,tsurf,tsoil,indextime) 586 677 c 587 678 c Fermer le fichier: -
trunk/LMDZ.MARS/libf/phymars/physiq.F
r900 r999 162 162 163 163 REAL pday 164 REAL ptime 164 REAL ptime 165 165 logical tracerdyn 166 166 … … 214 214 REAL sky 215 215 216 SAVE day_ini, icount 216 SAVE day_ini, icount, time_phys 217 217 SAVE aerosol, tsurf,tsoil 218 218 SAVE co2ice,albedo,emis, q2 … … 478 478 #ifndef MESOSCALE 479 479 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 480 485 #endif 481 486 … … 1354 1359 1355 1360 1361 1356 1362 c----------------------------------------------------------------------- 1357 1363 c 10. Write output files … … 1520 1526 c thus we store for time=time+dtvr 1521 1527 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 1530 1544 ENDIF 1531 1545 #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) 2 2 3 3 use netcdf … … 12 12 ! r4 or r8 restarts independently of having compiled 13 13 ! the GCM in r4 or r8) 14 ! June 2013 TN : Possibility to read files with a time axis 15 ! 14 16 ! 15 17 ! This subroutine reads from a NetCDF file (opened by the caller) … … 42 44 integer nsoil ! # of soil layers 43 45 real tsurf(ngrid) ! surface temperature 46 integer indextime ! position on time axis 44 47 ! output: 45 48 real tsoil(ngridmx,nsoilmx) ! soil temperature … … 53 56 integer ndims ! # of dimensions of read <inertiedat> data 54 57 integer ig,iloop ! loop counters 58 59 integer edges(3),corner(3) ! to read a specific time 55 60 56 61 logical :: olddepthdef=.false. ! flag … … 298 303 endif 299 304 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) 300 312 ierr=nf90_get_var(nid,nvarid,tsoil) 301 313 if (ierr.ne.nf90_noerr) then -
trunk/LMDZ.MARS/libf/phymars/testphys1d.F
r899 r999 641 641 c It is needed to transfert physics variables to "physiq"... 642 642 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) 647 649 648 650 c======================================================================= -
trunk/LMDZ.MARS/util/expandstartfi.F90
r803 r999 20 20 integer :: varid ! to store the ID of a variable 21 21 integer :: datashape(4) ! to store dimension IDs of a given dataset 22 integer :: corner(3),edges(3) ! to read data with a time axis 22 23 character(len=90) :: varname ! name of a variable 23 24 character(len=90) :: varatt ! name of attribute of a variable … … 28 29 integer :: nlayer_plus_1_dimid 29 30 integer :: number_of_advected_fields_dimid 31 integer :: time_dimid 30 32 integer :: nbindims ! number of dimensions in input file 31 33 integer :: nbinvars ! number of variables in input file … … 36 38 integer :: nlayer_plus_1 37 39 integer :: number_of_advected_fields 40 integer :: timelen 38 41 real,allocatable :: surf_field(:) ! to store a 1D field of physical_points elements 39 42 real,allocatable :: subsurf_field(:,:) ! to store subsurface (2D field) … … 155 158 endif 156 159 160 status=nf90_inq_dimid(inid,"Time",time_dimid) 161 if (status.ne.nf90_noerr) then 162 write(*,*)"Failed to find Time dimension" 163 write(*,*)trim(nf90_strerror(status)) 164 timelen = 0 165 else 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 174 endif 175 157 176 ! 1.3 Allocate memory for input fields 158 177 allocate(surf_field(physical_points)) … … 361 380 allocate(out_surf_field(lonlen,latlen)) 362 381 382 shape(:) = 0 363 383 do ivar=1,nbinvars ! loop on all input variables 364 384 ! find out what dimensions are linked to this variable 365 385 status=nf90_inquire_variable(inid,ivar,name=varname,ndims=nbdim,& 366 386 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 368 395 369 396 ! skip "longitude" and "latitude" … … 375 402 ! load input data: 376 403 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) 378 405 379 406 ! switch output file to to define mode … … 455 482 status=nf90_inquire_variable(inid,ivar,name=varname,ndims=nbdim,& 456 483 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 459 496 460 497 write(*,*) " processing: ",trim(varname) … … 462 499 ! load input data: 463 500 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) 465 502 466 503 ! switch output file to to define mode
Note: See TracChangeset
for help on using the changeset viewer.