Changeset 4286 for palm/trunk/SOURCE
- Timestamp:
- Oct 30, 2019 4:01:14 PM (5 years ago)
- Location:
- palm/trunk
- Files:
-
- 10 edited
Legend:
- Unmodified
- Added
- Removed
-
palm/trunk
- Property svn:mergeinfo changed
/palm/branches/resler merged: 4248,4252-4253,4263,4283-4285
- Property svn:mergeinfo changed
-
palm/trunk/SOURCE
- Property svn:mergeinfo changed
/palm/branches/resler/SOURCE merged: 4248,4252-4253,4263,4283-4285
- Property svn:mergeinfo changed
-
palm/trunk/SOURCE/Makefile
- Property svn:mergeinfo changed
/palm/branches/resler/SOURCE/Makefile merged: 4248,4263,4283
- Property svn:mergeinfo changed
-
palm/trunk/SOURCE/biometeorology_mod.f90
- Property svn:mergeinfo changed
/palm/branches/resler/SOURCE/biometeorology_mod.f90 merged: 4248
- Property svn:mergeinfo changed
-
palm/trunk/SOURCE/check_parameters.f90
- Property svn:mergeinfo changed
/palm/branches/resler/SOURCE/check_parameters.f90 merged: 4248
- Property svn:mergeinfo changed
-
palm/trunk/SOURCE/init_3d_model.f90
- Property svn:mergeinfo changed
/palm/branches/resler/SOURCE/init_3d_model.f90 merged: 4248
- Property svn:mergeinfo changed
-
palm/trunk/SOURCE/nesting_offl_mod.f90
r4273 r4286 25 25 ! ----------------- 26 26 ! $Id$ 27 ! Fix wrong checks of time from dynamic driver in nesting_offl_mod 28 ! 29 ! 4273 2019-10-24 13:40:54Z monakurppa 27 30 ! Add a logical switch nesting_offline_chem 28 31 ! … … 2032 2035 !-- not for the soil/wall spinup. However, as the spinup time is added 2033 2036 !-- to the end_time, this must be considered here. 2034 IF ( end_time - spinup_time > & 2035 nest_offl%time(nest_offl%nt-1) - time_utc_init ) THEN 2037 IF ( end_time - spinup_time > nest_offl%time(nest_offl%nt-1) ) THEN 2036 2038 message_string = 'end_time of the simulation exceeds the ' // & 2037 2039 'time dimension in the dynamic input file.' 2038 2040 CALL message( 'nesting_offl_init', 'PA0183', 1, 2, 0, 6, 0 ) 2039 ENDIF2040 2041 IF ( nest_offl%time(0) /= time_utc_init ) THEN2042 message_string = 'Offline nesting: time dimension must start at ' // &2043 ' time_utc_init.'2044 CALL message( 'nesting_offl_init', 'PA0676', 1, 2, 0, 6, 0 )2045 2041 ENDIF 2046 2042 ! -
palm/trunk/SOURCE/radiation_model_mod.f90
- Property svn:mergeinfo changed
/palm/branches/resler/SOURCE/radiation_model_mod.f90 merged: 4248,4253,4283-4285
r4271 r4286 28 28 ! ----------------- 29 29 ! $Id$ 30 ! - Fix wrong treating of time_rad during interpolation in radiation_model_mod 31 ! - Fix wrong checks of time_rad from dynamic driver in radiation_model_mod 32 ! - Add new directional model of human body for MRT: ellipsoid 33 ! 34 ! 4271 2019-10-23 10:46:41Z maronga 30 35 ! Bugfix: missing parentheses in calculation of snow albedo 31 36 ! … … 670 675 LOGICAL :: mrt_skip_roof = .TRUE. !< do not calculate MRT above roof surfaces 671 676 LOGICAL :: mrt_include_sw = .TRUE. !< should MRT calculation include SW radiation as well? 672 LOGICAL :: mrt_geom_human = .TRUE. !< MRT direction weights simulate human body instead of a sphere 677 INTEGER(wp) :: mrt_geom = 1 !< method for MRT direction weights simulating a sphere or a human body 678 REAL(wp), DIMENSION(2) :: mrt_geom_params = (/ .12_wp, .88_wp /) !< parameters for the selected method 673 679 INTEGER(iwp) :: nrefsteps = 3 !< number of reflection steps to perform 674 680 REAL(wp), PARAMETER :: ext_coef = 0.6_wp !< extinction coefficient (a.k.a. alpha) … … 967 973 !-- Public variables and constants / NEEDS SORTING 968 974 PUBLIC albedo, albedo_type, decl_1, decl_2, decl_3, dots_rad, dt_radiation,& 969 emissivity, force_radiation_call, lat, lon, mrt_geom_human, & 975 emissivity, force_radiation_call, lat, lon, mrt_geom, & 976 mrt_geom_params, & 970 977 mrt_include_sw, mrt_nlevels, mrtbl, mrtinsw, mrtinlw, nmrtbl, & 971 978 rad_net_av, radiation, radiation_scheme, rad_lw_in, & … … 2949 2956 CALL get_date_time( 0.0_wp, second_of_day=second_of_day ) 2950 2957 2951 IF ( ABS( time_rad_f%var1d(0) - second_of_day ) > 1E-6_wp ) THEN 2952 message_string = 'External radiation forcing: first point in ' // & 2953 'time is /= origin_date_time.' 2954 CALL message( 'radiation_init', 'PA0313', 1, 2, 0, 6, 0 ) 2955 ENDIF 2956 2957 IF ( end_time - spinup_time > time_rad_f%var1d(ntime-1) & 2958 - second_of_day ) THEN 2958 IF ( end_time - spinup_time > time_rad_f%var1d(ntime-1) ) THEN 2959 2959 message_string = 'External radiation forcing does not cover ' // & 2960 2960 'the entire simulation time.' … … 3147 3147 CALL get_date_time( 0.0_wp, second_of_day=second_of_day_init ) 3148 3148 t = 0 3149 DO WHILE ( time_rad_f%var1d(t) <= & 3150 time_since_reference_point + second_of_day_init ) 3149 DO WHILE ( time_rad_f%var1d(t) <= time_since_reference_point ) 3151 3150 t = t + 1 3152 3151 ENDDO … … 3154 3153 tm = MAX( t-1, 0 ) 3155 3154 3156 fac_dt = ( time_since_reference_point + second_of_day_init&3155 fac_dt = ( time_since_reference_point & 3157 3156 - time_rad_f%var1d(tm) + dt_3d ) & 3158 3157 / ( time_rad_f%var1d(t) - time_rad_f%var1d(tm) ) … … 3844 3843 constant_albedo, dt_radiation, emissivity, & 3845 3844 lw_radiation, max_raytracing_dist, & 3846 min_irrf_value, mrt_geom _human,&3845 min_irrf_value, mrt_geom, mrt_geom_params, & 3847 3846 mrt_include_sw, mrt_nlevels, & 3848 3847 mrt_skip_roof, net_radiation, nrefsteps, & … … 3860 3859 constant_albedo, dt_radiation, emissivity, & 3861 3860 lw_radiation, max_raytracing_dist, & 3862 min_irrf_value, mrt_geom _human,&3861 min_irrf_value, mrt_geom, mrt_geom_params, & 3863 3862 mrt_include_sw, mrt_nlevels, & 3864 3863 mrt_skip_roof, net_radiation, nrefsteps, & … … 7720 7719 zbdry(:) = (/( zn0+REAL(izn,wp)*zns, izn=0, nzn )/) 7721 7720 vffrac0(:) = (COS(zbdry(0:nzn-1)) - COS(zbdry(1:nzn))) / 2._wp / REAL(naz, wp) 7722 ! 7723 !--Modify direction weights to simulate human body (lower weight for top-down) 7724 IF ( mrt_geom_human ) THEN 7725 vffrac0(:) = vffrac0(:) * MAX(0._wp, SIN(zcent(:))*0.88_wp + COS(zcent(:))*0.12_wp) 7721 ! 7722 !-- Modify direction weights to simulate human body (lower weight for 7723 !-- irradiance from zenith, higher from sides) depending on selection. 7724 !-- For mrt_geom=0, no weighting is done (simulates spherical globe 7725 !-- thermometer). 7726 SELECT CASE ( mrt_geom ) 7727 7728 CASE ( 1 ) 7729 vffrac0(:) = vffrac0(:) * MAX(0._wp, SIN(zcent(:))*mrt_geom_params(2) & 7730 + COS(zcent(:))*mrt_geom_params(1)) 7726 7731 vffrac0(:) = vffrac0(:) / (SUM(vffrac0) * REAL(naz, wp)) 7727 ENDIF 7732 7733 CASE ( 2 ) 7734 vffrac0(:) = vffrac0(:) & 7735 * SQRT( ( mrt_geom_params(1) * COS(zcent(:)) ) ** 2 & 7736 + ( mrt_geom_params(2) * SIN(zcent(:)) ) ** 2 ) 7737 vffrac0(:) = vffrac0(:) / (SUM(vffrac0) * REAL(naz, wp)) 7738 7739 END SELECT 7728 7740 7729 7741 DO imrt = 1, nmrtbl - Property svn:mergeinfo changed
-
palm/trunk/SOURCE/salsa_mod.f90
r4280 r4286 26 26 ! ----------------- 27 27 ! $Id$ 28 ! 29 ! 30 ! 4280 2019-10-29 14:34:15Z monakurppa 28 31 ! Corrected a bug in boundary conditions and fac_dt in offline nesting 29 32 ! -
palm/trunk/SOURCE/surface_data_output_mod.f90
r4205 r4286 25 25 ! ----------------- 26 26 ! $Id$ 27 ! Fix wrongly declared nc_stat variable in surface_data_output_mod 28 ! 29 ! 4205 2019-08-30 13:25:00Z suehring 27 30 ! - Correct x,y-coordinates of vertical surfaces in netcdf output 28 31 ! - Change definition of azimuth angle, reference is north 0 degree … … 119 122 120 123 USE netcdf_interface, & 121 ONLY: n etcdf_create_att, netcdf_create_dim, netcdf_create_file,&122 netcdf_create_ global_atts, netcdf_create_var, netcdf_data_format,&123 netcdf_ handle_error124 ONLY: nc_stat, netcdf_create_att, netcdf_create_dim, & 125 netcdf_create_file, netcdf_create_global_atts, & 126 netcdf_create_var, netcdf_data_format, netcdf_handle_error 124 127 125 128 USE pegrid … … 163 166 INTEGER(iwp) :: dosurf_no(0:1) = 0 !< number of surface output quantities 164 167 #if defined( __netcdf4_parallel ) 165 INTEGER(iwp) :: nc_stat !< error code for netcdf routines166 168 INTEGER(iwp) :: oldmode !< save old set-fill-mode of netcdf file (not needed, but required for routine call) 167 169
Note: See TracChangeset
for help on using the changeset viewer.