SUBROUTINE defrun_new( tapedef, etatinit ) #ifndef CPP_PARA c c----------------------------------------------------------------------- c Auteurs : L. Fairhead , P. Le Van . c Modif C. Hourdin F. Forget VERSION MARTIENNE c c c ------------------------------------------------------------------- c c MODIF JUIN 2000 (zoom) c ......... Version du 29/04/97 .......... c c Nouveaux parametres nitergdiv,nitergrot,niterh,tetagdiv,tetagrot, c tetatemp ajoutes pour la dissipation . c c Autre parametre ajoute en fin de liste : ** fxyhypb ** c c Si fxyhypb = .TRUE. , choix de la fonction a derivee tangente hyperb. c Sinon , choix de fxynew , a derivee sinusoidale .. c c ...... etatinit = . TRUE. si defrun_new est appele dans NEWSTART c ETAT0_LMD ou LIMIT_LMD pour l'initialisation de start.dat (dic) et c de limit.dat (dic) ........... c Sinon etatinit = . FALSE . c c Donc etatinit = .F. si on veut comparer les valeurs de alphax , c alphay,clon,clat, fxyhypb lues sur le fichier start avec c celles passees par run.def , au debut du gcm, apres l'appel a c lectba . c Ces parametres definissant entre autres la grille et doivent etre c pareils et coherents , sinon il y aura divergence du gcm . c c c----------------------------------------------------------------------- c Declarations : c -------------- ! to use 'getin' use ioipsl_getincom, only: getin use control_mod, only: ndynstep, day_step, iperiod, iconser, & idissip, iphysiq, anneeref, ecritphy, & ecritstart, timestart, nday_r IMPLICIT NONE #include "dimensions.h" #include "paramet.h" !#include "control.h" #include "logic.h" #include "serre.h" #include "comdissnew.h" #include "sponge.h" #include "iniprint.h" c c arguments: c --------- LOGICAL etatinit ! should be .false. for a call from gcm.F ! and .true. for a call from newstart.F INTEGER tapedef ! unit number to assign to 'run.def' file c c local variables: c --------------- CHARACTER ch1*72,ch2*72,ch3*72,ch4*8 ! to store various strings integer tapeerr ! unit number for error message parameter (tapeerr=0) c REAL clonn,clatt,alphaxx,alphayy c LOGICAL fxyhypbb INTEGER ierr REAL clonn,clatt,grossismxx,grossismyy REAL dzoomxx,dzoomyy,tauxx,tauyy,temp LOGICAL fxyhypbb, ysinuss c initialisations: c ---------------- ! lunout=6 c----------------------------------------------------------------------- c Parametres de controle du run: c----------------------------------------------------------------------- !Initialisation des parametres "terrestres", qui ne concernent pas !le modele martien et ne sont donc plus lues dans "run.def" anneeref=0 OPEN(tapedef,file='run.def',status='old',form='formatted' . ,iostat=ierr) CLOSE(tapedef) ! first call to getin will open the file !lunout: default unit for the text outputs lunout=6 CALL getin('lunout', lunout) IF (lunout /= 5 .and. lunout /= 6) THEN OPEN(UNIT=lunout,FILE='lmdz.out',ACTION='write', & STATUS='unknown',FORM='formatted') ENDIF IF(ierr.EQ.0) THEN ! if file run.def is found WRITE(lunout,*) "DEFRUN_NEW: reading file run.def" WRITE(lunout,*) "" WRITE(lunout,*) "Number of days to run:" nday_r=1 ! default value call getin("nday",nday_r) WRITE(lunout,*)" nday = ",nday_r ndynstep=-9999 ! default value call getin("ndynstep",ndynstep) if (ndynstep .gt. 0) then WRITE(lunout,*) "" WRITE(lunout,*) "Number of dynamical steps to run:" WRITE(lunout,*) " ndynstep = ",ndynstep WRITE(lunout,*) " nday value is now discarded " endif WRITE(lunout,*) "" WRITE(lunout,*) "Number of dynamical steps per day:", & "(should be a multiple of iperiod)" day_step=960 ! default value call getin("day_step",day_step) WRITE(lunout,*)" day_step = ",day_step WRITE(lunout,*) "" WRITE(lunout,*) "periode pour le pas Matsuno (en pas)" iperiod=5 ! default value call getin("iperiod",iperiod) ! verify that day_step is a multiple of iperiod if (((1.*day_step)/iperiod).ne.(day_step/iperiod)) then write(lunout,*)" Error! iperiod must be such that", & " day_step is a multiple of iperiod, but iperiod=", & iperiod," and day_step=",day_step else WRITE(lunout,*)" iperiod = ",iperiod endif WRITE(lunout,*) "" WRITE(lunout,*) "periode de sortie des variables de ", & "controle (en pas)" iconser=120 ! default value call getin("iconser",iconser) WRITE(lunout,*)" iconser = ",iconser WRITE(lunout,*) "" WRITE(lunout,*) "periode de la dissipation (en pas)" idissip=5 ! default value call getin("idissip",idissip) WRITE(lunout,*)" idissip = ",idissip ccc .... P. Le Van , modif le 29/04/97 .pour la dissipation ... ccc WRITE(lunout,*) "" WRITE(lunout,*) "choix de l'operateur de dissipation ", & "(star ou non star )" lstardis=.true. ! default value call getin("lstardis",lstardis) WRITE(lunout,*)" lstardis = ",lstardis WRITE(lunout,*) "" WRITE(lunout,*) "avec ou sans coordonnee hybrides" hybrid=.true. ! default value call getin("hybrid",hybrid) WRITE(lunout,*)" hybrid = ",hybrid WRITE(lunout,*) "" WRITE(lunout,*) "nombre d'iterations de l'operateur de ", & "dissipation gradiv " nitergdiv=1 ! default value call getin("nitergdiv",nitergdiv) WRITE(lunout,*)" nitergdiv = ",nitergdiv WRITE(lunout,*) "" WRITE(lunout,*) "nombre d'iterations de l'operateur de ", & "dissipation nxgradrot" nitergrot=2 ! default value call getin("nitergrot",nitergrot) WRITE(lunout,*)" nitergrot = ",nitergrot WRITE(lunout,*) "" WRITE(lunout,*) "nombre d'iterations de l'operateur de ", & "dissipation divgrad" niterh=2 ! default value call getin("niterh",niterh) WRITE(lunout,*)" niterh = ",niterh WRITE(lunout,*) "" WRITE(lunout,*) "temps de dissipation des plus petites ", & "long.d ondes pour u,v (gradiv)" tetagdiv=4000. ! default value call getin("tetagdiv",tetagdiv) WRITE(lunout,*)" tetagdiv = ",tetagdiv WRITE(lunout,*) "" WRITE(lunout,*) "temps de dissipation des plus petites ", & "long.d ondes pour u,v(nxgradrot)" tetagrot=5000. ! default value call getin("tetagrot",tetagrot) WRITE(lunout,*)" tetagrot = ",tetagrot WRITE(lunout,*) "" WRITE(lunout,*) "temps de dissipation des plus petites ", & "long.d ondes pour h ( divgrad)" tetatemp=5000. ! default value call getin("tetatemp",tetatemp) WRITE(lunout,*)" tetatemp = ",tetatemp WRITE(lunout,*) "" WRITE(lunout,*) "coefficient pour gamdissip" coefdis=0. ! default value call getin("coefdis",coefdis) WRITE(lunout,*)" coefdis = ",coefdis c c ............................................................... WRITE(lunout,*) "" WRITE(lunout,*) "choix du shema d'integration temporelle ", & "(true==Matsuno ou false==Matsuno-leapfrog)" purmats=.false. ! default value call getin("purmats",purmats) WRITE(lunout,*)" purmats = ",purmats WRITE(lunout,*) "" WRITE(lunout,*) "avec ou sans physique" physic=.true. ! default value call getin("physic",physic) WRITE(lunout,*)" physic = ",physic WRITE(lunout,*) "" WRITE(lunout,*) "periode de la physique (en pas)" iphysiq=20 ! default value call getin("iphysiq",iphysiq) ! verify that day_step is a multiple of iphysiq if (((1.*day_step)/iphysiq).ne.(day_step/iphysiq)) then write(lunout,*)" Error! iphysiq must be such that", & " day_step is a multiple of iphysiq, but iphysiq=", & iphysiq," and day_step=",day_step else WRITE(lunout,*)" iphysiq = ",iphysiq endif WRITE(lunout,*) "" WRITE(lunout,*) "choix d'une grille reguliere" grireg=.true. call getin("grireg",grireg) WRITE(lunout,*)" grireg = ",grireg ccc .... P.Le Van, ajout le 03/01/96 pour l'ecriture phys ... c WRITE(lunout,*) "" WRITE(lunout,*) "frequence (en pas) de l'ecriture ", & "du fichier diagfi.nc" ecritphy=240 call getin("ecritphy",ecritphy) ! verify that ecriphy is indeed a multiple of iphysiq if (((1.*ecritphy)/iphysiq).ne.(ecritphy/iphysiq)) then write(lunout,*)" Error! ecritphy must be a multiple", & " of iphysiq, but ecritphy=",ecritphy," and iphysiq=", & iphysiq else WRITE(lunout,*)" ecritphy = ",ecritphy endif ccc .... T.Navarro, read start time (06/2013) ... c WRITE(lunout,*) "" WRITE(lunout,*) "date de debut dans le fichier start.nc" timestart=-9999 call getin("timestart",timestart) WRITE(lunout,*)" timestart = ",timestart ccc .... T.Navarro, start output (01/2013) ... c WRITE(lunout,*) "" WRITE(lunout,*) "frequence (en pas) de l'ecriture ", & "du fichier start.nc" ecritstart=0 call getin("ecritstart",ecritstart) ! verify that ecritstart is indeed a multiple of iphysiq if ( ((real(ecritstart))/iphysiq) & .ne.(real(ecritstart)/iphysiq) ) then write(lunout,*)" Error! ecritstart must be a multiple", & " of iphysiq, but ecritstart=",ecritstart," and iphysiq=", & iphysiq else WRITE(lunout,*)" ecritstart = ",ecritstart endif ccc .... P. Le Van , ajout le 7/03/95 .pour le zoom ... c ......... ( modif le 17/04/96 ) ......... c if (.not.etatinit ) then clonn=63. call getin("clon",clonn) IF( ABS(clon - clonn).GE. 0.001 ) THEN PRINT *,' La valeur de clon passee par run.def est ' * ,'differente de celle lue sur le fichier start ' STOP ENDIF c c clatt=0. call getin("clat",clatt) IF( ABS(clat - clatt).GE. 0.001 ) THEN PRINT *,' La valeur de clat passee par run.def est ' * ,'differente de celle lue sur le fichier start ' STOP ENDIF grossismxx=1.0 call getin("grossismx",grossismxx) if(grossismxx.eq.0) then write(*,*) write(*,*)'ERREUR : dans run.def, grossismx =0' write(*,*)'Attention a ne pas utiliser une version de' write(*,*)'run.def avant le nouveau zoom LMDZ2.3 (06/2000)' write(*,*)'(Il faut ajouter grossismx,dzoomx,etc... a la' write(*,*)'place de alphax, alphay. cf. dyn3d). ' write(*,*) stop end if IF( ABS(grossismx - grossismxx).GE. 0.001 ) THEN PRINT *,' La valeur de grossismx passee par run.def est ' * ,'differente de celle lue sur le fichier start =', * grossismx if (grossismx.eq.0) then write(*,*) 'OK,Normal : c est un vieux start' * , 'd avant le nouveau zoom LMDZ2.3 (06/2000)' grossismx=grossismxx else STOP endif ENDIF grossismyy=1.0 call getin("grossismy",grossismyy) IF( ABS(grossismy - grossismyy).GE. 0.001 ) THEN PRINT *,' La valeur de grossismy passee par run.def est ' * ,'differente de celle lue sur le fichier start =', * grossismy if (grossismy.eq.0) then write(*,*) 'OK,Normal : c est un vieux start' * , 'd avant le nouveau zoom LMDZ2.3 (06/2000)' grossismy=grossismyy else STOP endif ENDIF IF( grossismx.LT.1. ) THEN PRINT *,' *** ATTENTION !! grossismx < 1 . *** ' STOP ELSE alphax = 1. - 1./ grossismx ENDIF IF( grossismy.LT.1. ) THEN PRINT *,' *** ATTENTION !! grossismy < 1 . *** ' STOP ELSE alphay = 1. - 1./ grossismy ENDIF PRINT *,' ' PRINT *,' --> In defrun: alphax alphay ',alphax,alphay PRINT *,' ' c fxyhypbb=.false. call getin("fxyhypbb",fxyhypbb) IF( .NOT.fxyhypb ) THEN IF( fxyhypbb ) THEN PRINT *,' ******** PBS DANS DEFRUN ******** ' PRINT *,' *** fxyhypb lu sur le fichier start est F ', * 'alors qu il est T sur run.def ***' STOP ENDIF ELSE IF( .NOT.fxyhypbb ) THEN PRINT *,' ******** PBS DANS DEFRUN ******** ' PRINT *,' *** fxyhypb lu sur le fichier start est T ', * 'alors qu il est F sur run.def **** ' STOP ENDIF ENDIF dzoomxx=0.0 call getin("dzoomx",dzoomxx) IF( fxyhypb ) THEN IF( ABS(dzoomx - dzoomxx).GE. 0.001 ) THEN PRINT *,' La valeur de dzoomx passee par run.def est ' * ,'differente de celle lue sur le fichier start ' STOP ENDIF ENDIF dzoomyy=0.0 call getin("dzoomy",dzoomyy) IF( fxyhypb ) THEN IF( ABS(dzoomy - dzoomyy).GE. 0.001 ) THEN PRINT *,' La valeur de dzoomy passee par run.def est ' * ,'differente de celle lue sur le fichier start ' STOP ENDIF ENDIF tauxx=2.0 call getin("taux",tauxx) tauyy=2.0 call getin("tauy",tauyy) IF( fxyhypb ) THEN IF( ABS(taux - tauxx).GE. 0.001 ) THEN WRITE(6,*)' La valeur de taux passee par run.def est', * 'differente de celle lue sur le fichier start ' CALL ABORT ENDIF IF( ABS(tauy - tauyy).GE. 0.001 ) THEN WRITE(6,*)' La valeur de tauy passee par run.def est', * 'differente de celle lue sur le fichier start ' CALL ABORT ENDIF ENDIF ELSE ! Below, case when etainit=.true. WRITE(lunout,*) "" WRITE(lunout,*) "longitude en degres du centre du zoom" clon=63. ! default value call getin("clon",clon) WRITE(lunout,*)" clon = ",clon c WRITE(lunout,*) "" WRITE(lunout,*) "latitude en degres du centre du zoom " clat=0. ! default value call getin("clat",clat) WRITE(lunout,*)" clat = ",clat WRITE(lunout,*) "" WRITE(lunout,*) "facteur de grossissement du zoom,", & " selon longitude" grossismx=1.0 ! default value call getin("grossismx",grossismx) WRITE(lunout,*)" grossismx = ",grossismx WRITE(lunout,*) "" WRITE(lunout,*) "facteur de grossissement du zoom ,", & " selon latitude" grossismy=1.0 ! default value call getin("grossismy",grossismy) WRITE(lunout,*)" grossismy = ",grossismy IF( grossismx.LT.1. ) THEN PRINT *,' *** ATTENTION !! grossismx < 1 . *** ' STOP ELSE alphax = 1. - 1./ grossismx ENDIF IF( grossismy.LT.1. ) THEN PRINT *,' *** ATTENTION !! grossismy < 1 . *** ' STOP ELSE alphay = 1. - 1./ grossismy ENDIF PRINT *,' Defrun alphax alphay ',alphax,alphay c WRITE(lunout,*) "" WRITE(lunout,*) "Fonction f(y) hyperbolique si = .true.", & ", sinon sinusoidale" fxyhypb=.false. ! default value call getin("fxyhypb",fxyhypb) WRITE(lunout,*)" fxyhypb = ",fxyhypb WRITE(lunout,*) "" WRITE(lunout,*) "extension en longitude de la zone du zoom", & " (fraction de la zone totale)" dzoomx=0. ! default value call getin("dzoomx",dzoomx) WRITE(lunout,*)" dzoomx = ",dzoomx WRITE(lunout,*) "" WRITE(lunout,*) "extension en latitude de la zone du zoom", & " (fraction de la zone totale)" dzoomy=0. ! default value call getin("dzoomy",dzoomy) WRITE(lunout,*)" dzoomy = ",dzoomy WRITE(lunout,*) "" WRITE(lunout,*) "raideur du zoom en X" taux=2. ! default value call getin("taux",taux) WRITE(lunout,*)" taux = ",taux WRITE(lunout,*) "" WRITE(lunout,*) "raideur du zoom en Y" tauy=2.0 ! default value call getin("tauy",tauy) WRITE(lunout,*)" tauy = ",tauy END IF ! of if (.not.etatinit ) WRITE(lunout,*) "" WRITE(lunout,*) "Avec sponge layer" callsponge=.true. ! default value call getin("callsponge",callsponge) WRITE(lunout,*)" callsponge = ",callsponge WRITE(lunout,*) "" WRITE(lunout,*) "Sponge: number of layers over which", & " sponge extends" nsponge=3 ! default value call getin("nsponge",nsponge) WRITE(lunout,*)" nsponge = ",nsponge WRITE(lunout,*)"" WRITE(lunout,*)"Sponge mode: (forcing is towards ..." WRITE(lunout,*)" over upper nsponge layers)" WRITE(lunout,*)" 0: (h=hmean,u=v=0)" WRITE(lunout,*)" 1: (h=hmean,u=umean,v=0)" WRITE(lunout,*)" 2: (h=hmean,u=umean,v=vmean)" mode_sponge=2 ! default value call getin("mode_sponge",mode_sponge) WRITE(lunout,*)" mode_sponge = ",mode_sponge WRITE(lunout,*) "" WRITE(lunout,*) "Sponge: characteristice time scale tetasponge" WRITE(lunout,*) "(seconds) at topmost layer (time scale then " WRITE(lunout,*) " doubles with decreasing layer index)." tetasponge=30000.0 call getin("tetasponge",tetasponge) WRITE(lunout,*)" tetasponge = ",tetasponge WRITE(lunout,*) '-----------------------------------------------' WRITE(lunout,*) ' ' WRITE(lunout,*) ' ' c c Unlike on Earth (cf LMDZ2.2) , always a regular grid on Mars : ysinus = .false. !Mars Mettre a jour WRITE(lunout,*) '-----------------------------------------------' WRITE(lunout,*) ' ' WRITE(lunout,*) ' ' cc ELSE write(tapeerr,*) ' WHERE IS run.def ? WE NEED IT !!!!!!!!!!!!!!' stop ENDIF ! of IF(ierr.eq.0) c Test sur le zoom if((grossismx.eq.1).and.(grossismy.eq.1)) then c Pas de zoom : write(lunout,*) 'No zoom ? -> fxyhypb set to False' & ,' (It runs better that way)' fxyhypb = .false. else c Avec Zoom if (.not.fxyhypb) stop 'With zoom, fxyhypb should be set to T &in run.def for this version... -> STOP ! ' end if #else write(*,*) "defrun_new should not be used in parallel mode!" stop #endif ! of #ifndef CPP_PARA END