Changeset 2422 for LMDZ5/trunk/libf/phylmd
- Timestamp:
- Jan 6, 2016, 12:37:41 PM (9 years ago)
- Location:
- LMDZ5/trunk/libf/phylmd
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
LMDZ5/trunk/libf/phylmd/dyn1d/lmdz1d.F90
r2421 r2422 934 934 935 935 call physiq(ngrid,llm, & 936 firstcall,lastcall, day,time,timestep, &936 firstcall,lastcall,timestep, & 937 937 plev,play,phi,phis,presnivs, & 938 938 u,v, rot, temp,q,omega2, & -
LMDZ5/trunk/libf/phylmd/phys_cal_mod.F90
r2358 r2422 52 52 END SUBROUTINE phys_cal_init 53 53 54 SUBROUTINE phys_cal_update(j D_cur, jH_cur)54 SUBROUTINE phys_cal_update(julian_date) 55 55 ! This subroutine updates the module saved variables. 56 56 57 57 USE IOIPSL, only: ju2ymds, ymds2ju, ioget_mon_len, ioget_year_len 58 59 REAL, INTENT(IN) :: jD_cur ! jour courant a l'appel de la physique (jour julien) 60 REAL, INTENT(IN) :: jH_cur ! heure courante a l'appel de la physique (jour julien) 58 IMPLICIT NONE 59 REAL, INTENT(IN) :: julian_date 60 61 jD_cur=INT(julian_date) 62 jH_cur=julian_date-jD_cur 61 63 62 64 CALL ju2ymds(jD_cur+jH_cur, year_cur, mth_cur, day_cur, hour) … … 68 70 days_elapsed = jD_cur - jD_1jan 69 71 70 ! Get lenght of acutualmonth72 ! Get lenght of current month 71 73 mth_len = ioget_mon_len(year_cur,mth_cur) 72 74 75 ! Get length of current year 73 76 year_len = ioget_year_len(year_cur) 74 77 -
LMDZ5/trunk/libf/phylmd/physiq_mod.F90
r2421 r2422 10 10 11 11 SUBROUTINE physiq (nlon,nlev, & 12 debut,lafin, jD_cur_,jH_cur_,pdtphys_, &12 debut,lafin,pdtphys_, & 13 13 paprs,pplay,pphi,pphis,presnivs, & 14 14 u,v,rot,t,qx, & … … 20 20 USE geometry_mod, ONLY: cell_area, latitude_deg, longitude_deg 21 21 USE phys_cal_mod, only: year_len, mth_len, days_elapsed, jh_1jan, year_cur, & 22 mth_cur,jD_cur, jH_cur, jD_ref , phys_cal_update22 mth_cur,jD_cur, jH_cur, jD_ref 23 23 USE write_field_phy 24 24 USE dimphy … … 29 29 USE print_control_mod, ONLY: mydebug=>debug , lunout, prt_level 30 30 USE phystokenc_mod, ONLY: offline, phystokenc 31 USE time_phylmdz_mod, only: raz_date, day_step_phy 31 USE time_phylmdz_mod, only: raz_date, day_step_phy, update_time 32 32 USE vampir 33 33 USE pbl_surface_mod, ONLY : pbl_surface … … 226 226 INTEGER nlon 227 227 INTEGER nlev 228 REAL, intent(in):: jD_cur_, jH_cur_229 ! JD_cur and JH_cur to be used in physics are in phys_cal_mod230 228 REAL,INTENT(IN) :: pdtphys_ 231 229 ! NB: pdtphys to be used in physics is in time_phylmdz_mod … … 915 913 ! Gestion calendrier : mise a jour du module phys_cal_mod 916 914 ! 917 JD_cur=JD_cur_918 JH_cur=JH_cur_919 915 pdtphys=pdtphys_ 920 CALL phys_cal_update(jD_cur,jH_cur)916 CALL update_time(pdtphys) 921 917 922 918 !====================================================================== -
LMDZ5/trunk/libf/phylmd/time_phylmdz_mod.F90
r2344 r2422 77 77 END SUBROUTINE init_iteration 78 78 79 SUBROUTINE update_time(pdtphys_) 80 ! This subroutine updates the module saved variables. 81 USE ioipsl, ONLY : ymds2ju 82 USE phys_cal_mod, ONLY: phys_cal_update 83 USE print_control_mod, ONLY: lunout 84 IMPLICIT NONE 85 REAL,INTENT(IN) :: pdtphys_ 86 REAL :: julian_date 87 88 ! Check if the physics timestep has changed 89 IF ( ABS( (pdtphys-pdtphys_) / ((pdtphys+pdtphys_)/2))> 10.*EPSILON(pdtphys_)) THEN 90 WRITE(lunout,*) "WARNING ! Physics time step changes from a call to the next",pdtphys_,pdtphys 91 WRITE(lunout,*) "Not sure the physics parametrizations can handle this..." 92 ENDIF 93 pdtphys=pdtphys_ 94 95 ! Update elapsed time since begining of run: 96 current_time=current_time+pdtphys 97 98 ! Compute corresponding Julian date and update calendar 99 CALL ymds2ju(annee_ref,1,day_ini,start_time+current_time,julian_date) 100 CALL phys_cal_update(julian_date) 101 102 END SUBROUTINE update_time 103 79 104 END MODULE time_phylmdz_mod 80 105
Note: See TracChangeset
for help on using the changeset viewer.