Changeset 1492 for LMDZ5/trunk/libf
- Timestamp:
- Mar 8, 2011, 9:10:25 AM (14 years ago)
- Location:
- LMDZ5/trunk
- Files:
-
- 9 deleted
- 22 edited
- 15 copied
Legend:
- Unmodified
- Added
- Removed
-
LMDZ5/trunk
- Property svn:mergeinfo changed
/LMDZ5/branches/LMDZ5V2.0-dev (added) merged: 1456-1457,1460-1463,1466-1467,1470,1472-1475,1478,1480,1482,1484-1491
- Property svn:mergeinfo changed
-
LMDZ5/trunk/libf/dyn3d/ce0l.F90
r1425 r1492 91 91 END IF 92 92 93 IF (grilles_gcm_netcdf) THEN 94 WRITE(lunout,'(//)') 95 WRITE(lunout,*) ' *************************** ' 96 WRITE(lunout,*) ' *** grilles_gcm_netcdf *** ' 97 WRITE(lunout,*) ' *************************** ' 98 WRITE(lunout,'(//)') 99 CALL grilles_gcm_netcdf_sub() 100 END IF 93 101 #endif 94 102 ! of #ifndef CPP_EARTH #else -
LMDZ5/trunk/libf/dyn3d/comdissipn.h
r524 r1492 2 2 ! $Header$ 3 3 ! 4 c----------------------------------------------------------------------- 5 c INCLUDE comdissipn.h 4 ! Attention : ce fichier include est compatible format fixe/format libre 5 ! veillez à n'utiliser que des ! pour les commentaires 6 ! et à bien positionner les & des lignes de continuation 7 ! (les placer en colonne 6 et en colonne 73) 8 !----------------------------------------------------------------------- 9 ! INCLUDE comdissipn.h 6 10 7 11 REAL tetaudiv, tetaurot, tetah, cdivu, crot, cdivh 8 c 9 COMMON/comdissipn/ tetaudiv(llm),tetaurot(llm),tetah(llm) , 10 1cdivu, crot, cdivh12 ! 13 COMMON/comdissipn/ tetaudiv(llm),tetaurot(llm),tetah(llm) , & 14 & cdivu, crot, cdivh 11 15 12 c 13 cLes parametres de ce common proviennent des calculs effectues dans14 cInidissip .15 c 16 c-----------------------------------------------------------------------16 ! 17 ! Les parametres de ce common proviennent des calculs effectues dans 18 ! Inidissip . 19 ! 20 !----------------------------------------------------------------------- -
LMDZ5/trunk/libf/dyn3d/conf_gcm.F
r1418 r1492 841 841 ok_etat0 = .TRUE. 842 842 CALL getin('ok_etat0',ok_etat0) 843 844 !Config Key = grilles_gcm_netcdf 845 !Config Desc = creation de fichier grilles_gcm.nc dans create_etat0_limit 846 !Config Def = n 847 grilles_gcm_netcdf = .FALSE. 848 CALL getin('grilles_gcm_netcdf',grilles_gcm_netcdf) 843 849 844 850 write(lunout,*)' #########################################' … … 887 893 write(lunout,*)' ok_limit = ', ok_limit 888 894 write(lunout,*)' ok_etat0 = ', ok_etat0 895 write(lunout,*)' grilles_gcm_netcdf = ', grilles_gcm_netcdf 889 896 c 890 897 RETURN -
LMDZ5/trunk/libf/dyn3d/etat0_netcdf.F90
r1425 r1492 98 98 REAL :: dummy 99 99 LOGICAL :: ok_newmicro, ok_journe, ok_mensuel, ok_instan, ok_hf 100 LOGICAL :: ok_LES, ok_ade, ok_aie, aerosol_couple, new_aod 100 LOGICAL :: ok_LES, ok_ade, ok_aie, aerosol_couple, new_aod, callstats 101 101 INTEGER :: iflag_radia, flag_aerosol 102 102 REAL :: bl95_b0, bl95_b1, fact_cldcon, facttemps, ratqsbas, ratqshaut … … 130 130 !--- CONSTRUCT A GRID 131 131 CALL conf_phys( ok_journe, ok_mensuel, ok_instan, ok_hf, ok_LES, & 132 callstats, & 132 133 solarlong0,seuil_inversion, & 133 134 fact_cldcon, facttemps,ok_newmicro,iflag_radia, & -
LMDZ5/trunk/libf/dyn3d/logic.h
r1319 r1492 10 10 & statcl,conser,apdiss,apdelq,saison,ecripar,fxyhypb,ysinus & 11 11 & ,read_start,ok_guide,ok_strato,ok_gradsfile & 12 & ,ok_limit,ok_etat0 12 & ,ok_limit,ok_etat0,grilles_gcm_netcdf 13 13 14 14 LOGICAL purmats,forward,leapf,apphys,statcl,conser, & 15 15 & apdiss,apdelq,saison,ecripar,fxyhypb,ysinus & 16 16 & ,read_start,ok_guide,ok_strato,ok_gradsfile & 17 & ,ok_limit,ok_etat0 17 & ,ok_limit,ok_etat0,grilles_gcm_netcdf 18 18 19 19 INTEGER iflag_phys -
LMDZ5/trunk/libf/dyn3dpar/abort_gcm.F
r1425 r1492 45 45 if (ierr .eq. 0) then 46 46 write(lunout,*) 'Everything is cool' 47 stop48 47 else 49 48 write(lunout,*) 'Houston, we have a problem ', ierr -
LMDZ5/trunk/libf/dyn3dpar/ce0l.F90
r1425 r1492 22 22 USE mod_const_mpi 23 23 USE infotrac 24 USE parallel, ONLY: finalize_parallel 24 25 25 26 #ifdef CPP_IOIPSL … … 55 56 CALL abort_gcm('ce0l','In parallel mode, & 56 57 & ce0l must be called only & 57 & for 1 process and 1 task' )58 & for 1 process and 1 task',1) 58 59 ENDIF 59 60 … … 101 102 END IF 102 103 104 IF (grilles_gcm_netcdf) THEN 105 WRITE(lunout,'(//)') 106 WRITE(lunout,*) ' *************************** ' 107 WRITE(lunout,*) ' *** grilles_gcm_netcdf *** ' 108 WRITE(lunout,*) ' *************************** ' 109 WRITE(lunout,'(//)') 110 CALL grilles_gcm_netcdf_sub() 111 END IF 112 113 !$OMP MASTER 114 CALL finalize_parallel 115 !$OMP END MASTER 116 103 117 #endif 104 118 ! of #ifndef CPP_EARTH #else -
LMDZ5/trunk/libf/dyn3dpar/comdissipn.h
r774 r1492 2 2 ! $Header$ 3 3 ! 4 c----------------------------------------------------------------------- 5 c INCLUDE comdissipn.h 4 ! Attention : ce fichier include est compatible format fixe/format libre 5 ! veillez à n'utiliser que des ! pour les commentaires 6 ! et à bien positionner les & des lignes de continuation 7 ! (les placer en colonne 6 et en colonne 73) 8 !----------------------------------------------------------------------- 9 ! INCLUDE comdissipn.h 6 10 7 11 REAL tetaudiv, tetaurot, tetah, cdivu, crot, cdivh 8 c 9 COMMON/comdissipn/ tetaudiv(llm),tetaurot(llm),tetah(llm) , 10 1cdivu, crot, cdivh12 ! 13 COMMON/comdissipn/ tetaudiv(llm),tetaurot(llm),tetah(llm) , & 14 & cdivu, crot, cdivh 11 15 12 c 13 cLes parametres de ce common proviennent des calculs effectues dans14 cInidissip .15 c 16 c-----------------------------------------------------------------------16 ! 17 ! Les parametres de ce common proviennent des calculs effectues dans 18 ! Inidissip . 19 ! 20 !----------------------------------------------------------------------- -
LMDZ5/trunk/libf/dyn3dpar/conf_gcm.F
r1454 r1492 888 888 ok_etat0 = .TRUE. 889 889 CALL getin('ok_etat0',ok_etat0) 890 891 !Config Key = grilles_gcm_netcdf 892 !Config Desc = creation de fichier grilles_gcm.nc dans create_etat0_limit 893 !Config Def = n 894 grilles_gcm_netcdf = .FALSE. 895 CALL getin('grilles_gcm_netcdf',grilles_gcm_netcdf) 890 896 891 897 write(lunout,*)' #########################################' … … 937 943 write(lunout,*)' ok_limit = ', ok_limit 938 944 write(lunout,*)' ok_etat0 = ', ok_etat0 945 write(lunout,*)' grilles_gcm_netcdf = ', grilles_gcm_netcdf 939 946 c 940 947 RETURN -
LMDZ5/trunk/libf/dyn3dpar/etat0_netcdf.F90
r1425 r1492 98 98 REAL :: dummy 99 99 LOGICAL :: ok_newmicro, ok_journe, ok_mensuel, ok_instan, ok_hf 100 LOGICAL :: ok_LES, ok_ade, ok_aie, aerosol_couple, new_aod 100 LOGICAL :: ok_LES, ok_ade, ok_aie, aerosol_couple, new_aod, callstats 101 101 INTEGER :: iflag_radia, flag_aerosol 102 102 REAL :: bl95_b0, bl95_b1, fact_cldcon, facttemps, ratqsbas, ratqshaut … … 130 130 !--- CONSTRUCT A GRID 131 131 CALL conf_phys( ok_journe, ok_mensuel, ok_instan, ok_hf, ok_LES, & 132 callstats, & 132 133 solarlong0,seuil_inversion, & 133 134 fact_cldcon, facttemps,ok_newmicro,iflag_radia, & -
LMDZ5/trunk/libf/dyn3dpar/friction_p.F
r1454 r1492 34 34 35 35 ! arguments: 36 REAL,INTENT( out) :: ucov( iip1,jjp1,llm )37 REAL,INTENT( out) :: vcov( iip1,jjm,llm )36 REAL,INTENT(inout) :: ucov( iip1,jjp1,llm ) 37 REAL,INTENT(inout) :: vcov( iip1,jjm,llm ) 38 38 REAL,INTENT(in) :: pdt ! time step 39 39 -
LMDZ5/trunk/libf/dyn3dpar/leapfrog_p.F
r1454 r1492 996 996 enddo 997 997 !$OMP END DO 998 !$OMP SINGLE998 !$OMP MASTER 999 999 dpfi(ijb:ije)=0 1000 !$OMP END SINGLE1000 !$OMP END MASTER 1001 1001 ijb=ij_begin 1002 1002 ije=ij_end -
LMDZ5/trunk/libf/dyn3dpar/logic.h
r1319 r1492 10 10 & statcl,conser,apdiss,apdelq,saison,ecripar,fxyhypb,ysinus & 11 11 & ,read_start,ok_guide,ok_strato,ok_gradsfile & 12 & ,ok_limit,ok_etat0 12 & ,ok_limit,ok_etat0,grilles_gcm_netcdf 13 13 14 14 LOGICAL purmats,forward,leapf,apphys,statcl,conser, & 15 15 & apdiss,apdelq,saison,ecripar,fxyhypb,ysinus & 16 16 & ,read_start,ok_guide,ok_strato,ok_gradsfile & 17 & ,ok_limit,ok_etat0 17 & ,ok_limit,ok_etat0,grilles_gcm_netcdf 18 18 19 19 INTEGER iflag_phys -
LMDZ5/trunk/libf/dyn3dpar/parallel.F90
r1279 r1492 5 5 USE mod_const_mpi 6 6 7 LOGICAL,SAVE :: using_mpi 7 LOGICAL,SAVE :: using_mpi=.TRUE. 8 8 LOGICAL,SAVE :: using_omp 9 9 … … 208 208 integer :: ierr 209 209 integer :: i 210 deallocate(jj_begin_para) 211 deallocate(jj_end_para) 212 deallocate(jj_nb_para) 210 211 if (allocated(jj_begin_para)) deallocate(jj_begin_para) 212 if (allocated(jj_end_para)) deallocate(jj_end_para) 213 if (allocated(jj_nb_para)) deallocate(jj_nb_para) 213 214 214 215 if (type_ocean == 'couple') then … … 549 550 550 551 551 /* 552 Subroutine verif_hallo(Field,ij,ll,up,down) 553 implicit none 554 #include "dimensions.h" 555 #include "paramet.h" 556 include 'mpif.h' 557 558 INTEGER :: ij,ll 559 REAL, dimension(ij,ll) :: Field 560 INTEGER :: up,down 561 562 REAL,dimension(ij,ll): NewField 563 564 NewField=0 565 566 ijb=ij_begin 567 ije=ij_end 568 if (pole_nord) 569 NewField(ij_be 570 */ 552 ! Subroutine verif_hallo(Field,ij,ll,up,down) 553 ! implicit none 554 !#include "dimensions.h" 555 !#include "paramet.h" 556 ! include 'mpif.h' 557 ! 558 ! INTEGER :: ij,ll 559 ! REAL, dimension(ij,ll) :: Field 560 ! INTEGER :: up,down 561 ! 562 ! REAL,dimension(ij,ll): NewField 563 ! 564 ! NewField=0 565 ! 566 ! ijb=ij_begin 567 ! ije=ij_end 568 ! if (pole_nord) 569 ! NewField(ij_be 570 571 571 end module parallel -
LMDZ5/trunk/libf/phylmd/conf_phys.F90
r1423 r1492 13 13 subroutine conf_phys(ok_journe, ok_mensuel, ok_instan, ok_hf, & 14 14 ok_LES,& 15 callstats,& 15 16 solarlong0,seuil_inversion, & 16 17 fact_cldcon, facttemps,ok_newmicro,iflag_radia,& … … 66 67 logical :: ok_journe, ok_mensuel, ok_instan, ok_hf 67 68 logical :: ok_LES 69 LOGICAL :: callstats 68 70 LOGICAL :: ok_ade, ok_aie, aerosol_couple 69 71 INTEGER :: flag_aerosol … … 79 81 logical,SAVE :: ok_journe_omp, ok_mensuel_omp, ok_instan_omp, ok_hf_omp 80 82 logical,SAVE :: ok_LES_omp 83 LOGICAL,SAVE :: callstats_omp 81 84 LOGICAL,SAVE :: ok_ade_omp, ok_aie_omp, aerosol_couple_omp 82 85 INTEGER, SAVE :: flag_aerosol_omp … … 1418 1421 ok_LES_omp = .false. 1419 1422 call getin('OK_LES', ok_LES_omp) 1423 1424 !Config Key = callstats 1425 !Config Desc = Pour des sorties callstats 1426 !Config Def = .false. 1427 !Config Help = Pour creer le fichier stats contenant les sorties 1428 ! stats 1429 ! 1430 callstats_omp = .false. 1431 call getin('callstats', callstats_omp) 1420 1432 ! 1421 1433 !Config Key = ecrit_LES … … 1581 1593 ok_hines = ok_hines_omp 1582 1594 ok_LES = ok_LES_omp 1595 callstats = callstats_omp 1583 1596 ecrit_LES = ecrit_LES_omp 1584 1597 carbon_cycle_tr = carbon_cycle_tr_omp -
LMDZ5/trunk/libf/phylmd/orografi_strato.F
r1403 r1492 2004 2004 2005 2005 DO 110 JK=1,NLEV 2006 ZPM1R=pplay_glo(klon_glo/2,jk)/paprs_glo(klon_glo/2 ,1)2006 ZPM1R=pplay_glo(klon_glo/2,jk)/paprs_glo(klon_glo/2+1,1) 2007 2007 IF(ZPM1R.GE.ZSIGT)THEN 2008 2008 nktopg=JK 2009 2009 ENDIF 2010 ZPM1R=pplay_glo(klon_glo/2,jk)/paprs_glo(klon_glo/2 ,1)2010 ZPM1R=pplay_glo(klon_glo/2,jk)/paprs_glo(klon_glo/2+1,1) 2011 2011 IF(ZPM1R.GE.ZTOP)THEN 2012 2012 nstra=JK -
LMDZ5/trunk/libf/phylmd/phys_output_mod.F90
r1424 r1492 427 427 type(ctrl_out),save :: o_pres = ctrl_out((/ 2, 3, 10, 10, 1 /),'pres') 428 428 type(ctrl_out),save :: o_paprs = ctrl_out((/ 2, 3, 10, 10, 1 /),'paprs') 429 type(ctrl_out),save :: o_mass = ctrl_out((/ 2, 3, 10, 10, 1 /),'mass') 430 429 431 type(ctrl_out),save :: o_rneb = ctrl_out((/ 2, 5, 10, 10, 1 /),'rneb') 430 432 type(ctrl_out),save :: o_rnebcon = ctrl_out((/ 2, 5, 10, 10, 1 /),'rnebcon') … … 1057 1059 ! Couplage conv-CL 1058 1060 IF (iflag_con.GE.3) THEN 1059 IF (iflag_coupl .EQ.1) THEN1061 IF (iflag_coupl>=1) THEN 1060 1062 CALL histdef2d(iff,o_ale_bl%flag,o_ale_bl%name, "ALE BL", "m2/s2") 1061 1063 CALL histdef2d(iff,o_alp_bl%flag,o_alp_bl%name, "ALP BL", "m2/s2") … … 1108 1110 CALL histdef3d(iff,o_pres%flag,o_pres%name, "Air pressure", "Pa" ) 1109 1111 CALL histdef3d(iff,o_paprs%flag,o_paprs%name, "Air pressure Inter-Couches", "Pa" ) 1112 CALL histdef3d(iff,o_mass%flag,o_mass%name, "Masse Couches", "kg/m2" ) 1110 1113 CALL histdef3d(iff,o_rneb%flag,o_rneb%name, "Cloud fraction", "-") 1111 1114 CALL histdef3d(iff,o_rnebcon%flag,o_rnebcon%name, "Convective Cloud Fraction", "-") -
LMDZ5/trunk/libf/phylmd/phys_output_write.h
r1403 r1492 104 104 s o_psol%name,itau_w,zx_tmp_fi2d) 105 105 ENDIF 106 107 IF (o_mass%flag(iff)<=lev_files(iff)) THEN 108 CALL histwrite_phy(nid_files(iff),o_mass%name,itau_w,zmasse) 109 ENDIF 110 106 111 107 112 IF (o_qsurf%flag(iff)<=lev_files(iff)) THEN … … 691 696 ! Couplage convection-couche limite 692 697 IF (iflag_con.GE.3) THEN 693 IF (iflag_coupl .EQ.1) THEN698 IF (iflag_coupl>=1) THEN 694 699 IF (o_ale_bl%flag(iff)<=lev_files(iff)) THEN 695 700 CALL histwrite_phy(nid_files(iff),o_ale_bl%name,itau_w,ale_bl) … … 698 703 CALL histwrite_phy(nid_files(iff),o_alp_bl%name,itau_w,alp_bl) 699 704 ENDIF 700 ENDIF !iflag_coupl .EQ.1705 ENDIF !iflag_coupl>=1 701 706 ENDIF !(iflag_con.GE.3) 702 707 -
LMDZ5/trunk/libf/phylmd/physiq.F
r1479 r1492 158 158 save ok_LES 159 159 c$OMP THREADPRIVATE(ok_LES) 160 c 161 LOGICAL callstats ! sortir le fichier stats 162 save callstats 163 c$OMP THREADPRIVATE(callstats) 160 164 c 161 165 LOGICAL ok_region ! sortir le fichier regional … … 1150 1154 ! and 360 1151 1155 1156 INTEGER ierr 1152 1157 #include "YOMCST.h" 1153 1158 #include "YOETHF.h" … … 1222 1227 . ok_instan, ok_hf, 1223 1228 . ok_LES, 1229 . callstats, 1224 1230 . solarlong0,seuil_inversion, 1225 1231 . fact_cldcon, facttemps,ok_newmicro,iflag_radia, … … 2459 2465 endif 2460 2466 ! ---------------------------------------------------------------------- 2467 !IM/FH: 2011/02/23 2468 ! Couplage Thermiques/Emanuel seulement si T<0 2469 if (iflag_coupl==2) then 2470 print*,'Couplage Thermiques/Emanuel seulement si T<0' 2471 do i=1,klon 2472 if (t_seri(i,lmax_th(i))>273.) then 2473 Ale_bl(i)=0. 2474 endif 2475 enddo 2476 endif 2461 2477 2462 2478 endif … … 2834 2850 ! de la convection profonde. 2835 2851 2852 !IM/FH: 2011/02/23 2853 ! definition des points sur lesquels ls thermiques sont actifs 2836 2854 if (prt_level>9)write(*,*)'TEST SCHEMA DE NUAGES ' 2855 ptconvth(:,:)=fm_therm(:,:)>0. 2837 2856 do k=1,klev 2838 2857 do i=1,klon … … 3695 3714 c==================================================================== 3696 3715 c 3697 3716 3717 c ----------------------------------------------------------------- 3718 c WSTATS: Saving statistics 3719 c ----------------------------------------------------------------- 3720 c ("stats" stores and accumulates 8 key variables in file "stats.nc" 3721 c which can later be used to make the statistic files of the run: 3722 c "stats") only possible in 3D runs ! 3723 3724 3725 IF (callstats) THEN 3726 3727 call wstats(klon,o_psol%name,"Surface pressure","Pa" 3728 & ,2,paprs(:,1)) 3729 call wstats(klon,o_tsol%name,"Surface temperature","K", 3730 & 2,zxtsol) 3731 zx_tmp_fi2d(:) = rain_fall(:) + snow_fall(:) 3732 call wstats(klon,o_precip%name,"Precip Totale liq+sol", 3733 & "kg/(s*m2)",2,zx_tmp_fi2d) 3734 zx_tmp_fi2d(:) = rain_lsc(:) + snow_lsc(:) 3735 call wstats(klon,o_plul%name,"Large-scale Precip", 3736 & "kg/(s*m2)",2,zx_tmp_fi2d) 3737 zx_tmp_fi2d(:) = rain_con(:) + snow_con(:) 3738 call wstats(klon,o_pluc%name,"Convective Precip", 3739 & "kg/(s*m2)",2,zx_tmp_fi2d) 3740 call wstats(klon,o_sols%name,"Solar rad. at surf.", 3741 & "W/m2",2,solsw) 3742 call wstats(klon,o_soll%name,"IR rad. at surf.", 3743 & "W/m2",2,sollw) 3744 zx_tmp_fi2d(:) = topsw(:)-toplw(:) 3745 call wstats(klon,o_nettop%name,"Net dn radiatif flux at TOA", 3746 & "W/m2",2,zx_tmp_fi2d) 3747 3748 3749 3750 call wstats(klon,o_temp%name,"Air temperature","K", 3751 & 3,t_seri) 3752 call wstats(klon,o_vitu%name,"Zonal wind","m.s-1", 3753 & 3,u_seri) 3754 call wstats(klon,o_vitv%name,"Meridional wind", 3755 & "m.s-1",3,v_seri) 3756 call wstats(klon,o_vitw%name,"Vertical wind", 3757 & "m.s-1",3,omega) 3758 call wstats(klon,o_ovap%name,"Specific humidity", "kg/kg", 3759 & 3,q_seri) 3760 3761 3762 3763 IF(lafin) THEN 3764 write (*,*) "Writing stats..." 3765 call mkstats(ierr) 3766 ENDIF 3767 3768 ENDIF !if callstats 3769 3698 3770 3699 3771 IF (lafin) THEN -
LMDZ5/trunk/libf/phylmd/readaerosol.F90
r1403 r1492 7 7 CONTAINS 8 8 9 SUBROUTINE readaerosol(name_aero, type, iyr_in, klev_src, pt_ap, pt_b, pt_out, psurf, load)9 SUBROUTINE readaerosol(name_aero, type, filename, iyr_in, klev_src, pt_ap, pt_b, pt_out, psurf, load) 10 10 11 11 !**************************************************************************************** … … 27 27 ! Input arguments 28 28 CHARACTER(len=7), INTENT(IN) :: name_aero 29 CHARACTER(len=*), INTENT(IN) :: type ! correspond to aer_type in clesphys.h 29 CHARACTER(len=*), INTENT(IN) :: type ! actuel, annuel, scenario or preind 30 CHARACTER(len=8), INTENT(IN) :: filename 30 31 INTEGER, INTENT(IN) :: iyr_in 31 32 … … 58 59 ! get_aero_fromfile returns pt_out allocated and initialized with data for 12 month 59 60 ! pt_out has dimensions (klon, klev_src, 12) 60 CALL get_aero_fromfile(name_aero, cyear, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load)61 CALL get_aero_fromfile(name_aero, cyear, filename, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load) 61 62 62 63 … … 67 68 ! get_aero_fromfile returns pt_out allocated and initialized with data for 12 month 68 69 ! pt_out has dimensions (klon, klev_src, 12) 69 CALL get_aero_fromfile(name_aero, cyear, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load)70 CALL get_aero_fromfile(name_aero, cyear, filename, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load) 70 71 71 72 ELSE IF (type == 'annuel') THEN … … 76 77 ! get_aero_fromfile returns pt_out allocated and initialized with data for nbr_tsteps month 77 78 ! pt_out has dimensions (klon, klev_src, 12) 78 CALL get_aero_fromfile(name_aero, cyear, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load)79 CALL get_aero_fromfile(name_aero, cyear, filename, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load) 79 80 80 81 ELSE IF (type == 'scenario') THEN … … 86 87 ! get_aero_fromfile returns pt_out allocated and initialized with data for 12 month 87 88 ! pt_out has dimensions (klon, klev_src, 12) 88 CALL get_aero_fromfile(name_aero, cyear, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load)89 CALL get_aero_fromfile(name_aero, cyear, filename, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load) 89 90 90 91 ELSE IF (iyr_in .GE. 2100) THEN … … 93 94 ! get_aero_fromfile returns pt_out allocated and initialized with data for 12 month 94 95 ! pt_out has dimensions (klon, klev_src, 12) 95 CALL get_aero_fromfile(name_aero, cyear, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load)96 CALL get_aero_fromfile(name_aero, cyear, filename, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load) 96 97 97 98 ELSE … … 113 114 ! get_aero_fromfile returns pt_out allocated and initialized with data for 12 month 114 115 ! pt_out has dimensions (klon, klev_src, 12) 115 CALL get_aero_fromfile(name_aero, cyear, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load)116 CALL get_aero_fromfile(name_aero, cyear, filename, klev_src, pt_ap, pt_b, p0, pt_out, psurf, load) 116 117 117 118 ! If to read two decades: … … 125 126 ! get_aero_fromfile returns pt_2 allocated and initialized with data for 12 month 126 127 ! pt_2 has dimensions (klon, klev_src, 12) 127 CALL get_aero_fromfile(name_aero, cyear, klev_src2, pt_ap, pt_b, p0, pt_2, psurf2, load2)128 CALL get_aero_fromfile(name_aero, cyear, filename, klev_src2, pt_ap, pt_b, p0, pt_2, psurf2, load2) 128 129 ! Test for same number of vertical levels 129 130 IF (klev_src /= klev_src2) THEN … … 160 161 161 162 ELSE 162 WRITE(lunout,*)'This option is not implemented : aer_type = ', type 163 WRITE(lunout,*)'This option is not implemented : aer_type = ', type,' name_aero=',name_aero 163 164 CALL abort_gcm('readaerosol','Error : aer_type parameter not accepted',1) 164 165 END IF ! type … … 168 169 169 170 170 SUBROUTINE get_aero_fromfile(varname, cyr, klev_src, pt_ap, pt_b, p0, pt_year, psurf_out, load_out)171 SUBROUTINE get_aero_fromfile(varname, cyr, filename, klev_src, pt_ap, pt_b, p0, pt_year, psurf_out, load_out) 171 172 !**************************************************************************************** 172 173 ! Read 12 month aerosol from file and distribute to local process on physical grid. … … 200 201 CHARACTER(len=7), INTENT(IN) :: varname 201 202 CHARACTER(len=4), INTENT(IN) :: cyr 203 CHARACTER(len=8), INTENT(IN) :: filename 202 204 203 205 ! Output arguments … … 213 215 ! Local variables 214 216 CHARACTER(len=30) :: fname 215 CHARACTER(len=8) :: filename='aerosols'216 217 CHARACTER(len=30) :: cvar 217 218 INTEGER :: ncid, dimid, varid … … 242 243 ! 1) Open file 243 244 !**************************************************************************************** 244 fname = filename//cyr//'.nc' 245 ! Add suffix to filename 246 fname = trim(filename)//cyr//'.nc' 245 247 246 WRITE(lunout,*) 'reading ', TRIM(fname)248 WRITE(lunout,*) 'reading variable ',TRIM(varname),' in file ', TRIM(fname) 247 249 CALL check_err( nf90_open(TRIM(fname), NF90_NOWRITE, ncid) ) 248 250 … … 283 285 CALL abort_gcm('get_aero_fromfile', 'latitudes do not correspond between file and model',1) 284 286 END IF 285 286 ! 1.5) Check number of month in file opened287 !288 !**************************************************************************************************289 ierr = nf90_inq_dimid(ncid, 'TIME',dimid)290 CALL check_err( nf90_inquire_dimension(ncid, dimid, len = nbr_tsteps) )291 ! IF (nbr_tsteps /= 12 .AND. nbr_tsteps /= 14) THEN292 IF (nbr_tsteps /= 12 ) THEN293 CALL abort_gcm('get_aero_fromfile', 'not the right number of months in aerosol file read (should be 12 for the moment)',1)294 ENDIF295 287 296 288 … … 335 327 336 328 IF (new_file) THEN 329 ! ++) Check number of month in file opened 330 !************************************************************************************************** 331 ierr = nf90_inq_dimid(ncid, 'TIME',dimid) 332 CALL check_err( nf90_inquire_dimension(ncid, dimid, len = nbr_tsteps) ) 333 ! IF (nbr_tsteps /= 12 .AND. nbr_tsteps /= 14) THEN 334 IF (nbr_tsteps /= 12 ) THEN 335 CALL abort_gcm('get_aero_fromfile', 'not the right number of months in aerosol file read (should be 12 for the moment)',1) 336 ENDIF 337 337 338 338 ! ++) Read the aerosol concentration month by month and concatenate to total variable varyear -
LMDZ5/trunk/libf/phylmd/readaerosol_interp.F90
r1403 r1492 92 92 LOGICAL,SAVE :: debug=.FALSE.! Debugging in this subroutine 93 93 !$OMP THREADPRIVATE(vert_interp, debug) 94 CHARACTER(len=8) :: type 95 CHARACTER(len=8) :: filename 94 96 95 97 … … 173 175 ! Reading values corresponding to the closest year taking into count the choice of aer_type. 174 176 ! For aer_type=scenario interpolation between 2 data sets is done in readaerosol. 175 CALL readaerosol(name_aero(id_aero), aer_type, iyr, klev_src, pt_ap, pt_b, pt_tmp, & 177 ! If aer_type=mix1 or mix2, the run type and file name depends on the aerosol. 178 IF (aer_type=='preind' .OR. aer_type=='actuel' .OR. aer_type=='annuel' .OR. aer_type=='scenario') THEN 179 ! Standard case 180 filename='aerosols' 181 type=aer_type 182 ELSE IF (aer_type == 'mix1') THEN 183 ! Special case using a mix of decenal sulfate file and annual aerosols(all aerosols except sulfate) 184 IF (name_aero(id_aero) == 'SO4') THEN 185 filename='so4.run ' 186 type='scenario' 187 ELSE 188 filename='aerosols' 189 type='annuel' 190 END IF 191 ELSE IF (aer_type == 'mix2') THEN 192 ! Special case using a mix of decenal sulfate file and natrual aerosols 193 IF (name_aero(id_aero) == 'SO4') THEN 194 filename='so4.run ' 195 type='scenario' 196 ELSE 197 filename='aerosols' 198 type='preind' 199 END IF 200 ELSE 201 CALL abort_gcm('readaerosol_interp', 'this aer_type not supported',1) 202 END IF 203 204 CALL readaerosol(name_aero(id_aero), type, filename, iyr, klev_src, pt_ap, pt_b, pt_tmp, & 176 205 psurf_year(:,:,id_aero), load_year(:,:,id_aero)) 177 206 IF (.NOT. ALLOCATED(var_year)) THEN … … 182 211 183 212 ! Reading values corresponding to the preindustrial concentrations. 184 CALL readaerosol(name_aero(id_aero), 'preind', iyr, pi_klev_src, pt_ap, pt_b, pt_tmp, & 213 type='preind' 214 CALL readaerosol(name_aero(id_aero), type, filename, iyr, pi_klev_src, pt_ap, pt_b, pt_tmp, & 185 215 pi_psurf_year(:,:,id_aero), pi_load_year(:,:,id_aero)) 186 216
Note: See TracChangeset
for help on using the changeset viewer.