subroutine iniadvtrac(nq,numvanle) !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! ! routine which initializes tracer names and advection schemes ! reads these infos from file 'traceur.def' but uses default values ! if that file is not found. ! Ehouarn Millour. Oct. 2008 (made this LMDZ4-like) for future compatibility !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! IMPLICIT NONE #include "dimensions.h" #include "advtrac.h" #include "control.h" ! routine arguments: INTEGER,INTENT(out) :: nq ! number of tracers INTEGER,INTENT(out) :: numvanle ! local variables: LOGICAL :: first INTEGER :: iq INTEGER :: ierr if (nqmx > 0) then ! Look for file traceur.def OPEN(90,file='traceur.def',form='formatted',status='old', & iostat=ierr) IF (ierr.eq.0) THEN write(*,*) "iniadvtrac: Reading file traceur.def" ! read number of tracers: read(90,*,iostat=ierr) nq if (ierr.ne.0) then write(*,*) "iniadvtrac: error reading number of tracers" write(*,*) " (first line of traceur.def) " stop else ! check that the number of tracers is indeed nqmx if (nq.ne.nqmx) then write(*,*) "iniadvtrac: error, wrong number of tracers:" write(*,*) "nq=",nq," whereas nqmx=",nqmx stop endif endif ! initialize advection schemes to Van-Leer for all tracers do iq=1,nq iadv(iq)=3 ! Van-Leer enddo ! MODIFICATION TO TEST OTHER SCHEMES BY RDW ! do iq=1,nq ! iadv(iq)=1 ! enddo ! print*,'IADV SET TO 1 IN iniadvtrac!!!!' do iq=1,nq ! minimal version, just read in the tracer names, 1 per line read(90,*,iostat=ierr) tnom(iq) if (ierr.ne.0) then write(*,*) 'iniadvtrac: error reading tracer names...' stop endif enddo !of do iq=1,nq ELSE write(*,*) "iniadvtrac: can't find file traceur.def..." stop ENDIF ! of IF (ierr.eq.0) c .... Choix des shemas d'advection pour l'eau et les traceurs ... c ................................................................... c c iadv = 1 shema transport type "humidite specifique LMD" c iadv = 2 shema amont c iadv = 3 shema Van-leer c iadv = 4 schema Van-leer + humidite specifique c Modif F.Codron c c DO iq = 1, nqmx IF( iadv(iq).EQ.1 ) PRINT *,' Choix du shema humidite specifique' * ,' pour le traceur no ', iq IF( iadv(iq).EQ.2 ) PRINT *,' Choix du shema amont',' pour le' * ,' traceur no ', iq IF( iadv(iq).EQ.3 ) PRINT *,' Choix du shema Van-Leer ',' pour' * ,'le traceur no ', iq IF( iadv(iq).EQ.4 ) THEN PRINT *,' Le shema Van-Leer + humidite specifique ', * ' est uniquement pour la vapeur d eau .' PRINT *,' Corriger iadv( ',iq, ') et repasser ! ' CALL ABORT ENDIF IF( iadv(iq).LE.0.OR.iadv(iq).GT.4 ) THEN PRINT *,' Erreur dans le choix de iadv (nqmx).Corriger et ' * ,' repasser car iadv(iq) = ', iadv(iq) CALL ABORT ENDIF ENDDO !!!! AS: compiler complains about iadv(nqmx) when there is nqmx=0 !!!! AS: so I commented those lines and changed nqmx-1 for nqmx above ! IF( iadv(nqmx).EQ.1 ) PRINT *,' Choix du shema humidite ' ! * ,'specifique pour la vapeur d''eau' ! IF( iadv(nqmx).EQ.2 ) PRINT *,' Choix du shema amont',' pour la' ! * ,' vapeur d''eau ' ! IF( iadv(nqmx).EQ.3 ) PRINT *,' Choix du shema Van-Leer ' ! * ,' pour la vapeur d''eau' ! IF( iadv(nqmx).EQ.4 ) PRINT *,' Choix du shema Van-Leer + ' ! * ,' humidite specifique pour la vapeur d''eau' ! !c !! IF( (iadv(nqmx).LE.0).OR.(iadv(nqmx).GT.4) ) THEN !! MODIFICATION TO TEST WITHOUT TRACER ADVECTION BY RDW ! IF( (iadv(nqmx).LT.0).OR.(iadv(nqmx).GT.4) ) THEN ! PRINT *,' Erreur dans le choix de iadv (nqmx).Corriger et ' ! * ,' repasser car iadv(nqmx) = ', iadv(nqmx) ! CALL ABORT ! ENDIF first = .TRUE. numvanle = nqmx + 1 DO iq = 1, nqmx IF(((iadv(iq).EQ.3).OR.(iadv(iq).EQ.4)).AND.first ) THEN numvanle = iq first = .FALSE. ENDIF ENDDO c DO iq = 1, nqmx IF( (iadv(iq).NE.3.AND.iadv(iq).NE.4).AND.iq.GT.numvanle ) THEN PRINT *,' Il y a discontinuite dans le choix du shema de ', * 'Van-leer pour les traceurs . Corriger et repasser . ' CALL ABORT ENDIF ENDDO c endif ! of if nqmx > 0 end