Changeset 2269 for trunk/LMDZ.GENERIC
- Timestamp:
- Mar 27, 2020, 5:44:49 PM (5 years ago)
- Location:
- trunk/LMDZ.GENERIC
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/LMDZ.GENERIC/README
r2245 r2269 1517 1517 H2H2 dimer from Fletcher et al. 2018, useful for giant planets. 1518 1518 Retrocompatibility is ok, default value to 2011. 1519 1520 == 27/03/2020 == EM 1521 - Cleanup OpenMP statements in callcorrk.F90 and also use "call abort_physic" 1522 instead of "stop" or "call abort" -
trunk/LMDZ.GENERIC/libf/phystd/callcorrk.F90
r2254 r2269 135 135 REAL*8,allocatable,save :: wbari(:,:,:) 136 136 REAL*8,allocatable,save :: wbarv(:,:,:) 137 !$OMP THREADPRIVATE(dtaui,dtauv,cosbv,cosbi,wbari,wbarv) 137 138 REAL*8,allocatable,save :: tauv(:,:,:) 138 139 REAL*8,allocatable,save :: taucumv(:,:,:) 139 140 REAL*8,allocatable,save :: taucumi(:,:,:) 140 141 !$OMP THREADPRIVATE(tauv,taucumv,taucumi) 141 142 REAL*8 tauaero(L_LEVELS,naerkind) 142 143 REAL*8 nfluxtopv,nfluxtopi,nfluxtop,fluxtopvdn … … 158 159 real*8,allocatable,save :: taugsurf(:,:) 159 160 real*8,allocatable,save :: taugsurfi(:,:) 161 !$OMP THREADPRIVATE(taugsurf,taugsurfi) 160 162 real*8 qvar(L_LEVELS) ! Mixing ratio of variable component (mol/mol). 161 163 … … 167 169 real*8,save,allocatable :: QSIAER(:,:,:) 168 170 real*8,save,allocatable :: GIAER(:,:,:) 169 171 !$OMP THREADPRIVATE(QXVAER,QSVAER,GVAER,QXIAER,QSIAER,GIAER) 170 172 real, dimension(:,:,:), save, allocatable :: QREFvis3d 171 173 real, dimension(:,:,:), save, allocatable :: QREFir3d 172 !$OMP THREADPRIVATE(Q XVAER,QSVAER,GVAER,QXIAER,QSIAER,GIAER,QREFvis3d,QREFir3d)174 !$OMP THREADPRIVATE(QREFvis3d,QREFir3d) 173 175 174 176 … … 177 179 character(len=10) :: tmp1 178 180 character(len=10) :: tmp2 181 character(len=100) :: message 182 character(len=10),parameter :: subname="callcorrk" 179 183 180 184 ! For fixed water vapour profiles. … … 224 228 225 229 if(naerkind.gt.4)then 226 print*,'Code not general enough to deal with naerkind > 4 yet.'227 call abort 230 message='Code not general enough to deal with naerkind > 4 yet.' 231 call abort_physic(subname,message,1) 228 232 endif 229 233 call su_aer_radii(ngrid,nlayer,reffrad,nueffrad) … … 264 268 265 269 if((igcm_h2o_vap.eq.0) .and. varactive)then 266 print*,'varactive in callcorrk but no h2o_vap tracer.'267 stop270 message='varactive in callcorrk but no h2o_vap tracer.' 271 call abort_physic(subname,message,1) 268 272 endif 269 273 … … 279 283 ! Test of incompatibility : if global1d is true, there should not be any diurnal cycle. 280 284 if (global1d.and.diurnal) then 281 print*,'if global1d is true, diurnal must be set to false'282 stop285 message='if global1d is true, diurnal must be set to false' 286 call abort_physic(subname,message,1) 283 287 endif 284 288 … … 476 480 do nw=1,L_NSPECTV 477 481 if(qsvaer(k,nw,iaer).gt.1.05*qxvaer(k,nw,iaer))then 478 print*,'Serious problems with qsvaer values' 479 print*,'in callcorrk' 480 call abort 482 message='Serious problems with qsvaer values' 483 call abort_physic(subname,message,1) 481 484 endif 482 485 if(qsvaer(k,nw,iaer).gt.qxvaer(k,nw,iaer))then … … 487 490 do nw=1,L_NSPECTI 488 491 if(qsiaer(k,nw,iaer).gt.1.05*qxiaer(k,nw,iaer))then 489 print*,'Serious problems with qsiaer values' 490 print*,'in callcorrk' 491 call abort 492 message='Serious problems with qsvaer values' 493 call abort_physic(subname,message,1) 492 494 endif 493 495 if(qsiaer(k,nw,iaer).gt.qxiaer(k,nw,iaer))then … … 602 604 603 605 if(.not.global1d)then ! garde-fou/safeguard added by MT (to be removed in the future) 604 write(*,*) 'You have to fix mu0, ' 605 write(*,*) 'the cosinus of the solar angle' 606 stop 606 message='You have to fix mu0, the cosinus of the solar angle' 607 call abort_physic(subname,message,1) 607 608 endif 608 609 … … 632 633 633 634 if(nq.gt.1)then 634 print*,'Need 1 tracer only to run kcm1d.e'635 stop635 message='Need 1 tracer only to run kcm1d.e' 636 call abort_physic(subname,message,1) 636 637 endif 637 638 … … 648 649 qvar(1)=qvar(2) 649 650 650 print*,'Warning: reducing qvar in callcorrk.'651 print*,'Temperature profile no longer consistent ', &651 write(*,*)trim(subname),' :Warning: reducing qvar in callcorrk.' 652 write(*,*)trim(subname),' :Temperature profile no longer consistent ', & 652 653 'with saturated H2O. qsat=',satval 653 654 … … 728 729 print*,'Minimum pressure is outside the radiative' 729 730 print*,'transfer kmatrix bounds, exiting.' 730 call abort 731 message="Minimum pressure outside of kmatrix bounds" 732 call abort_physic(subname,message,1) 731 733 elseif(plevrad(L_LEVELS).gt.pgasmax)then 732 734 print*,'Maximum pressure is outside the radiative' 733 735 print*,'transfer kmatrix bounds, exiting.' 734 call abort 736 message="Minimum pressure outside of kmatrix bounds" 737 call abort_physic(subname,message,1) 735 738 endif 736 739 … … 743 746 print*,"tgasmin=",tgasmin 744 747 if (strictboundcorrk) then 745 call abort 748 message="Minimum temperature outside of kmatrix bounds" 749 call abort_physic(subname,message,1) 746 750 else 747 751 print*,'***********************************************' … … 758 762 print*,"tgasmax=",tgasmax 759 763 if (strictboundcorrk) then 760 call abort 764 message="Maximum temperature outside of kmatrix bounds" 765 call abort_physic(subname,message,1) 761 766 else 762 767 print*,'***********************************************' … … 776 781 print*,"tgasmin=",tgasmin 777 782 if (strictboundcorrk) then 778 call abort 783 message="Minimum temperature outside of kmatrix bounds" 784 call abort_physic(subname,message,1) 779 785 else 780 786 print*,'***********************************************' … … 791 797 print*,"tgasmax=",tgasmax 792 798 if (strictboundcorrk) then 793 call abort 799 message="Maximum temperature outside of kmatrix bounds" 800 call abort_physic(subname,message,1) 794 801 else 795 802 print*,'***********************************************' … … 899 906 print*,'temp= ',pt(ig,:) 900 907 print*,'pplay= ',pplay(ig,:) 901 call abort 908 message="Achtung! fluxtop_dn has lost the plot!" 909 call abort_physic(subname,message,1) 902 910 endif 903 911
Note: See TracChangeset
for help on using the changeset viewer.