diff --git a/Python/boundary_layer/boundary_layer.py b/Python/boundary_layer/boundary_layer.py index 6f6c64bc072d3afbb8aa5febbec209c26af2deee..a58d52651599b963a90cd1ec4d5cb966f140a9d9 100644 --- a/Python/boundary_layer/boundary_layer.py +++ b/Python/boundary_layer/boundary_layer.py @@ -119,7 +119,7 @@ logger.vf_log_info(f"viscosity [10^8 dx^2/dt] = {viscosity_LB*1e8}") logger.vf_log_info(f"u* /(dx/dt) = {u_star*dt/dx}") logger.vf_log_info(f"dpdx = {pressure_gradient}") logger.vf_log_info(f"dpdx /(dx/dt^2) = {pressure_gradient_LB}") - + #%% #%% @@ -139,6 +139,8 @@ para.set_timestep_start_out(int(t_start_out/dt)) para.set_timestep_out(int(t_out/dt)) para.set_timestep_end(int(t_end/dt)) para.set_is_body_force(config.get_bool_value("bodyForce")) +para.set_devices(np.arange(10)) +para.set_max_dev(communicator.get_number_of_process()) #%% tm_factory = gpu.TurbulenceModelFactory(para) tm_factory.read_config_file(config) @@ -164,13 +166,7 @@ bc_factory.set_pressure_boundary_condition(gpu.PressureBC.OutflowNonReflective) bc_factory.set_precursor_boundary_condition(gpu.PrecursorBC.DistributionsPrecursor if use_distributions else gpu.PrecursorBC.VelocityPrecursor) para.set_outflow_pressure_correction_factor(0.0); #%% -def init_func(coord_x, coord_y, coord_z): - return [ - 0.0, - (u_star/0.4 * np.log(np.maximum(coord_z,z0)/z0) + 2.0*np.sin(np.pi*16*coord_x/length[0])*np.sin(np.pi*8*coord_z/boundary_layer_height)/(np.square(coord_z/boundary_layer_height)+1)) * dt / dx, - 2.0*np.sin(np.pi*16.*coord_x/length[0])*np.sin(np.pi*8.*coord_z/boundary_layer_height)/(np.square(coord_z/boundary_layer_height)+1.) * dt / dx, - 8.0*u_star/0.4*(np.sin(np.pi*8.0*coord_y/boundary_layer_height)*np.sin(np.pi*8.0*coord_z/boundary_layer_height)+np.sin(np.pi*8.0*coord_x/length[0]))/(np.square(length[2]/2.0-coord_z)+1.) * dt / dx] -para.set_initial_condition(init_func) +para.set_initial_condition_perturbed_log_law(u_star, z0, length[0], length[2], boundary_layer_height, dx/dx) #%% planar_average_probe = gpu.probes.PlanarAverageProbe("horizontalPlanes", para.get_output_path(), 0, int(t_start_tmp_averaging/dt), int(t_averaging/dt) , int(t_start_out_probe/dt), int(t_out_probe/dt), 'z') diff --git a/apps/gpu/LBM/BoundaryLayer/configBoundaryLayer.txt b/apps/gpu/LBM/BoundaryLayer/configBoundaryLayer.txt index 83e7861a5fb85ea800d187699f1c6c1409422f0a..1b415aa6ce14109c2d93a17ae78463786a7b7608 100644 --- a/apps/gpu/LBM/BoundaryLayer/configBoundaryLayer.txt +++ b/apps/gpu/LBM/BoundaryLayer/configBoundaryLayer.txt @@ -23,8 +23,7 @@ Ma = 0.1 nz = 96 bodyForce = true -UseAMD = true -SGSconstant = 0.2 +TurbulenceModel = QR QuadricLimiterP = 100000.0 QuadricLimiterM = 100000.0 QuadricLimiterD = 100000.0