From 42c78060859b9ee38a92f983b7fe507c933d14f8 Mon Sep 17 00:00:00 2001 From: Michael Hardman <29800382+mrhardman@users.noreply.github.com> Date: Wed, 13 Nov 2024 13:41:20 +0000 Subject: [PATCH] Broadcast Maxwellian density, parallel flow and thermal speed information across cores in delta_f_multipole option. --- moment_kinetics/src/fokker_planck_calculus.jl | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/moment_kinetics/src/fokker_planck_calculus.jl b/moment_kinetics/src/fokker_planck_calculus.jl index 5594c8e45..a6122afad 100644 --- a/moment_kinetics/src/fokker_planck_calculus.jl +++ b/moment_kinetics/src/fokker_planck_calculus.jl @@ -1794,6 +1794,7 @@ function calculate_rosenbluth_potential_boundary_data_delta_f_multipole!(rpbd::r calculate_GG=false,calculate_dGdvperp=false) mass = 1.0 + dens, upar, vth = 0.0, 0.0, 0.0 # first, compute the moments and delta f begin_anyv_region() @anyv_serial_region begin @@ -1807,6 +1808,12 @@ function calculate_rosenbluth_potential_boundary_data_delta_f_multipole!(rpbd::r dummy_vpavperp[ivpa,ivperp] = pdf[ivpa,ivperp] - F_Maxwellian(dens,upar,vth,vpa,vperp,ivpa,ivperp) end end + # broadcast this information across cores + param_vec = [dens, upar, vth] + if comm_anyv_subblock[] != MPI.COMM_NULL + MPI.Bcast!(param_vec, 0, comm_anyv_subblock[]) + end + (dens, upar, vth) = param_vec # ensure data is synchronized _anyv_subblock_synchronize() # now pass the delta f to the multipole function