1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
use crate::geometry::ParticlesContacts;
use crate::object::{Boundary, Fluid};
use crate::TimestepManager;
use na::RealField;
pub trait NonPressureForce<N: RealField>: Send + Sync {
fn solve(
&mut self,
timestep: &TimestepManager<N>,
kernel_radius: N,
fluid_fluid_contacts: &ParticlesContacts<N>,
fluid_boundaries_contacts: &ParticlesContacts<N>,
fluid: &mut Fluid<N>,
boundaries: &[Boundary<N>],
densities: &[N],
);
fn apply_permutation(&mut self, _permutation: &[usize]) {}
}