Changeset 4419
- Timestamp:
- Feb 5, 2023, 9:32:11 PM (2 years ago)
- Location:
- LMDZ6/trunk/libf
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ6/trunk/libf/dyn3d/iniacademic.F90
r4379 r4419 22 22 USE ener_mod, ONLY: etot0,ptot0,ztot0,stot0,ang0 23 23 USE readTracFiles_mod, ONLY: addPhase 24 use netcdf, only : NF90_NOWRITE,NF90_OPEN,NF90_NOERR,NF90_INQ_VARID 25 use netcdf, only : NF90_CLOSE, NF90_GET_VAR 26 24 27 25 28 ! Author: Frederic Hourdin original: 15/01/93 … … 63 66 real tetajl(jjp1,llm) 64 67 INTEGER i,j,l,lsup,ij, iq, iName, iPhase, iqParent 68 69 integer :: nid_relief,varid,ierr 70 real, dimension(iip1,jjp1) :: relief 65 71 66 72 REAL teta0,ttp,delt_y,delt_z,eps ! Constantes pour profil de T … … 118 124 CALL inifilr 119 125 126 127 !------------------------------------------------------------------ 120 128 ! Initialize pressure and mass field if read_start=.false. 129 !------------------------------------------------------------------ 130 121 131 IF (.NOT. read_start) THEN 132 133 !------------------------------------------------------------------ 134 ! Lecture eventuelle d'un fichier de relief interpollee sur la grille 135 ! du modele. 136 ! On suppose que le fichier relief_in.nc est stoké sur une grille 137 ! iim*jjp1 138 ! Facile a créer à partir de la commande 139 ! cdo remapcon,fichier_output_phys.nc Relief.nc relief_in.nc 140 !------------------------------------------------------------------ 141 142 relief=0. 143 ierr = NF90_OPEN ('relief_in.nc', NF90_NOWRITE,nid_relief) 144 if (ierr.EQ.NF90_NOERR) THEN 145 ierr=NF90_INQ_VARID(nid_relief,'RELIEF',varid) 146 if (ierr==NF90_NOERR) THEN 147 ierr=NF90_GET_VAR(nid_relief,varid,relief(1:iim,1:jjp1)) 148 relief(iip1,:)=relief(1,:) 149 else 150 CALL abort_gcm ('iniacademic','variable RELIEF pas la',1) 151 endif 152 endif 153 ierr = NF90_CLOSE (nid_relief) 154 155 !------------------------------------------------------------------ 156 ! Initialisation du geopotentiel au sol et de la pression 157 !------------------------------------------------------------------ 158 159 print*,'relief=',minval(relief),maxval(relief),'g=',g 160 do j=1,jjp1 161 do i=1,iip1 162 phis((j-1)*iip1+i)=g*relief(i,j) 163 enddo 164 enddo 165 print*,'phis=',minval(phis),maxval(phis),'g=',g 166 167 ! ground geopotential 168 !phis(:)=0. 122 169 ps(:)=preff 123 124 ! ground geopotential125 phis(:)=0.126 170 CALL pression ( ip1jmp1, ap, bp, ps, p ) 127 171 -
LMDZ6/trunk/libf/dyn3dmem/iniacademic_loc.F90
r4379 r4419 23 23 USE ener_mod, ONLY: etot0,ptot0,ztot0,stot0,ang0 24 24 USE readTracFiles_mod, ONLY: addPhase 25 use netcdf, only : NF90_NOWRITE,NF90_OPEN,NF90_NOERR,NF90_INQ_VARID 26 use netcdf, only : NF90_CLOSE, NF90_GET_VAR 27 25 28 26 29 ! Author: Frederic Hourdin original: 15/01/93 … … 67 70 real tetajl(jjp1,llm) 68 71 INTEGER i,j,l,lsup,ij, iq, iName, iPhase, iqParent 72 73 integer :: nid_relief,varid,ierr 74 real, dimension(iip1,jjp1) :: relief 75 69 76 70 77 REAL teta0,ttp,delt_y,delt_z,eps ! Constantes pour profil de T … … 126 133 ! allocate global fields: 127 134 ! allocate(vcov_glo(ip1jm,llm)) 135 128 136 allocate(ucov_glo(ip1jmp1,llm)) 129 137 allocate(teta_glo(ip1jmp1,llm)) … … 135 143 ps_glo(:)=preff 136 144 137 ! ground geopotential 138 phis_glo(:)=0. 145 !------------------------------------------------------------------ 146 ! Lecture eventuelle d'un fichier de relief interpollee sur la grille 147 ! du modele. 148 ! On suppose que le fichier relief_in.nc est stoké sur une grille 149 ! iim*jjp1 150 ! Facile a créer à partir de la commande 151 ! cdo remapcon,fichier_output_phys.nc Relief.nc relief_in.nc 152 !------------------------------------------------------------------ 153 154 relief=0. 155 ierr = NF90_OPEN ('relief_in.nc', NF90_NOWRITE,nid_relief) 156 if (ierr.EQ.NF90_NOERR) THEN 157 ierr=NF90_INQ_VARID(nid_relief,'RELIEF',varid) 158 if (ierr==NF90_NOERR) THEN 159 ierr=NF90_GET_VAR(nid_relief,varid,relief(1:iim,1:jjp1)) 160 relief(iip1,:)=relief(1,:) 161 else 162 CALL abort_gcm ('iniacademic','variable RELIEF pas la',1) 163 endif 164 endif 165 ierr = NF90_CLOSE (nid_relief) 166 167 168 !------------------------------------------------------------------ 169 ! Initialisation du geopotentiel au sol et de la pression 170 !------------------------------------------------------------------ 171 172 print*,'relief=',minval(relief),maxval(relief),'g=',g 173 do j=1,jjp1 174 do i=1,iip1 175 phis_glo((j-1)*iip1+i)=g*relief(i,j) 176 enddo 177 enddo 178 print*,'phis=',minval(phis),maxval(phis),'g=',g 179 139 180 CALL pression ( ip1jmp1, ap, bp, ps_glo, p ) 140 181 if (pressure_exner) then
Note: See TracChangeset
for help on using the changeset viewer.