Remove non-global Threadpool
This commit is contained in:
parent
7aadda3de9
commit
ff9a477b67
|
@ -9,7 +9,7 @@ edition = "2018"
|
||||||
sbp = { path = "../sbp", features = ["serde1", "fast-float"] }
|
sbp = { path = "../sbp", features = ["serde1", "fast-float"] }
|
||||||
euler = { path = "../euler", features = ["serde1"] }
|
euler = { path = "../euler", features = ["serde1"] }
|
||||||
hdf5 = "0.7.0"
|
hdf5 = "0.7.0"
|
||||||
integrate = { path = "../utils/integrate", features = ["rayon"] }
|
integrate = { path = "../utils/integrate" }
|
||||||
rayon = "1.3.0"
|
rayon = "1.3.0"
|
||||||
indicatif = "0.15.0"
|
indicatif = "0.15.0"
|
||||||
structopt = "0.3.14"
|
structopt = "0.3.14"
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
use rayon::prelude::*;
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
|
|
||||||
use sbp::operators::SbpOperator2d;
|
use sbp::operators::SbpOperator2d;
|
||||||
|
@ -20,6 +21,21 @@ struct System {
|
||||||
operators: Vec<Box<dyn SbpOperator2d>>,
|
operators: Vec<Box<dyn SbpOperator2d>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl integrate::Integrable for System {
|
||||||
|
type State = Vec<euler::Field>;
|
||||||
|
type Diff = Vec<euler::Field>;
|
||||||
|
fn assign(s: &mut Self::State, o: &Self::State) {
|
||||||
|
s.par_iter_mut()
|
||||||
|
.zip(o.par_iter())
|
||||||
|
.for_each(|(s, o)| euler::Field::assign(s, o))
|
||||||
|
}
|
||||||
|
fn scaled_add(s: &mut Self::State, o: &Self::Diff, scale: Float) {
|
||||||
|
s.par_iter_mut()
|
||||||
|
.zip(o.par_iter())
|
||||||
|
.for_each(|(s, o)| euler::Field::scaled_add(s, o, scale))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl System {
|
impl System {
|
||||||
fn new(
|
fn new(
|
||||||
grids: Vec<grid::Grid>,
|
grids: Vec<grid::Grid>,
|
||||||
|
@ -68,7 +84,7 @@ impl System {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn advance(&mut self, dt: Float, pool: &rayon::ThreadPool) {
|
fn advance(&mut self, dt: Float) {
|
||||||
let metrics = &self.metrics;
|
let metrics = &self.metrics;
|
||||||
let grids = &self.grids;
|
let grids = &self.grids;
|
||||||
let bt = &self.bt;
|
let bt = &self.bt;
|
||||||
|
@ -76,9 +92,9 @@ impl System {
|
||||||
let eb = &mut self.eb;
|
let eb = &mut self.eb;
|
||||||
let operators = &self.operators;
|
let operators = &self.operators;
|
||||||
|
|
||||||
let rhs = move |fut: &mut [euler::Field], prev: &[euler::Field], time: Float| {
|
let rhs = move |fut: &mut Vec<euler::Field>, prev: &Vec<euler::Field>, time: Float| {
|
||||||
let prev_all = &prev;
|
let prev_all = &prev;
|
||||||
pool.scope(|s| {
|
rayon::scope(|s| {
|
||||||
for (((((((fut, prev), wb), grid), metrics), op), bt), eb) in fut
|
for (((((((fut, prev), wb), grid), metrics), op), bt), eb) in fut
|
||||||
.iter_mut()
|
.iter_mut()
|
||||||
.zip(prev.iter())
|
.zip(prev.iter())
|
||||||
|
@ -101,19 +117,13 @@ impl System {
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut k = self
|
integrate::integrate::<integrate::Rk4, System, _>(
|
||||||
.k
|
|
||||||
.iter_mut()
|
|
||||||
.map(|k| k.as_mut_slice())
|
|
||||||
.collect::<Vec<_>>();
|
|
||||||
integrate::integrate_multigrid::<integrate::Rk4, euler::Field, _>(
|
|
||||||
rhs,
|
rhs,
|
||||||
&self.fnow,
|
&self.fnow,
|
||||||
&mut self.fnext,
|
&mut self.fnext,
|
||||||
&mut self.time,
|
&mut self.time,
|
||||||
dt,
|
dt,
|
||||||
&mut k,
|
&mut self.k,
|
||||||
pool,
|
|
||||||
);
|
);
|
||||||
|
|
||||||
std::mem::swap(&mut self.fnow, &mut self.fnext);
|
std::mem::swap(&mut self.fnow, &mut self.fnext);
|
||||||
|
@ -178,7 +188,7 @@ struct Options {
|
||||||
no_progressbar: bool,
|
no_progressbar: bool,
|
||||||
/// Number of simultaneous threads
|
/// Number of simultaneous threads
|
||||||
#[structopt(short, long)]
|
#[structopt(short, long)]
|
||||||
jobs: Option<Option<usize>>,
|
jobs: Option<usize>,
|
||||||
/// Name of output file
|
/// Name of output file
|
||||||
#[structopt(default_value = "output.hdf", long, short)]
|
#[structopt(default_value = "output.hdf", long, short)]
|
||||||
output: std::path::PathBuf,
|
output: std::path::PathBuf,
|
||||||
|
@ -241,20 +251,13 @@ fn main() {
|
||||||
|
|
||||||
let ntime = (integration_time / dt).round() as u64;
|
let ntime = (integration_time / dt).round() as u64;
|
||||||
|
|
||||||
let pool = {
|
{
|
||||||
let builder = rayon::ThreadPoolBuilder::new();
|
let nthreads = opt.jobs.unwrap_or(1);
|
||||||
if let Some(j) = opt.jobs {
|
rayon::ThreadPoolBuilder::new()
|
||||||
if let Some(j) = j {
|
.num_threads(nthreads)
|
||||||
builder.num_threads(j)
|
.build_global()
|
||||||
} else {
|
.unwrap();
|
||||||
builder
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
builder.num_threads(1)
|
|
||||||
}
|
|
||||||
.build()
|
|
||||||
.unwrap()
|
|
||||||
};
|
|
||||||
|
|
||||||
let should_output = |itime| {
|
let should_output = |itime| {
|
||||||
opt.number_of_outputs.map_or(false, |num_out| {
|
opt.number_of_outputs.map_or(false, |num_out| {
|
||||||
|
@ -282,7 +285,7 @@ fn main() {
|
||||||
output.add_timestep(itime, &sys.fnow);
|
output.add_timestep(itime, &sys.fnow);
|
||||||
}
|
}
|
||||||
progressbar.inc(1);
|
progressbar.inc(1);
|
||||||
sys.advance(dt, &pool);
|
sys.advance(dt);
|
||||||
}
|
}
|
||||||
progressbar.finish_and_clear();
|
progressbar.finish_and_clear();
|
||||||
|
|
||||||
|
|
|
@ -6,4 +6,3 @@ edition = "2018"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
float = { path = "../float/" }
|
float = { path = "../float/" }
|
||||||
rayon = { version = "1.5.0", optional = true }
|
|
||||||
|
|
|
@ -243,90 +243,6 @@ pub fn integrate_embedded_rk<BTableau: EmbeddedButcherTableau, F: Integrable, RH
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(feature = "rayon")]
|
|
||||||
#[allow(clippy::too_many_arguments)]
|
|
||||||
/// Integrates a multigrid problem, much the same as [`integrate`],
|
|
||||||
/// using a `rayon` threadpool for parallelisation.
|
|
||||||
///
|
|
||||||
/// note that `rhs` accepts the full system state, and is responsible
|
|
||||||
/// for computing the full state difference.
|
|
||||||
/// `rhs` can be a mutable closure, so buffers can be used
|
|
||||||
/// and mutated inside the closure.
|
|
||||||
///
|
|
||||||
/// This function requires the `rayon` feature, and is not callable in
|
|
||||||
/// a `wasm` context.
|
|
||||||
pub fn integrate_multigrid<BTableau: ButcherTableau, F: Integrable, RHS>(
|
|
||||||
mut rhs: RHS,
|
|
||||||
prev: &[F::State],
|
|
||||||
fut: &mut [F::State],
|
|
||||||
time: &mut Float,
|
|
||||||
dt: Float,
|
|
||||||
k: &mut [&mut [F::Diff]],
|
|
||||||
|
|
||||||
pool: &rayon::ThreadPool,
|
|
||||||
) where
|
|
||||||
RHS: FnMut(&mut [F::Diff], &[F::State], Float),
|
|
||||||
F::State: Send + Sync,
|
|
||||||
F::Diff: Send + Sync,
|
|
||||||
{
|
|
||||||
for i in 0.. {
|
|
||||||
let simtime;
|
|
||||||
match i {
|
|
||||||
0 => {
|
|
||||||
pool.scope(|s| {
|
|
||||||
assert!(k.len() >= BTableau::S);
|
|
||||||
for (prev, fut) in prev.iter().zip(fut.iter_mut()) {
|
|
||||||
s.spawn(move |_| {
|
|
||||||
F::assign(fut, prev);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
simtime = *time;
|
|
||||||
}
|
|
||||||
i if i < BTableau::S => {
|
|
||||||
pool.scope(|s| {
|
|
||||||
for (ig, (prev, fut)) in prev.iter().zip(fut.iter_mut()).enumerate() {
|
|
||||||
let k = &k;
|
|
||||||
s.spawn(move |_| {
|
|
||||||
F::assign(fut, prev);
|
|
||||||
for (ik, &a) in BTableau::A[i - 1].iter().enumerate() {
|
|
||||||
if a == 0.0 {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
F::scaled_add(fut, &k[ik][ig], a * dt);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
simtime = *time + dt * BTableau::C[i - 1];
|
|
||||||
}
|
|
||||||
_ if i == BTableau::S => {
|
|
||||||
pool.scope(|s| {
|
|
||||||
for (ig, (prev, fut)) in prev.iter().zip(fut.iter_mut()).enumerate() {
|
|
||||||
let k = &k;
|
|
||||||
s.spawn(move |_| {
|
|
||||||
F::assign(fut, prev);
|
|
||||||
for (ik, &b) in BTableau::B.iter().enumerate() {
|
|
||||||
if b == 0.0 {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
F::scaled_add(fut, &k[ik][ig], b * dt);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
*time += dt;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
_ => {
|
|
||||||
unreachable!();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
rhs(&mut k[i], &fut, simtime);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
/// Solving a second order PDE
|
/// Solving a second order PDE
|
||||||
fn ballistic() {
|
fn ballistic() {
|
||||||
|
|
Loading…
Reference in New Issue