aboutsummaryrefslogtreecommitdiff
path: root/src/dynamics/solver/delta_vel.rs
diff options
context:
space:
mode:
authorSébastien Crozet <developer@crozet.re>2022-01-16 08:20:22 -0800
committerGitHub <noreply@github.com>2022-01-16 08:20:22 -0800
commit1880619d29029c99985ffae9ed12a1c8d2cc796b (patch)
tree806e7d950015875ebfcca5520784aea6e7c5ae10 /src/dynamics/solver/delta_vel.rs
parent4454a845e98b990abf3929ca46b59d0fca5a18ec (diff)
parent0703e5527fd95d86bb6621e61dbcb1a6e7f9329a (diff)
downloadrapier-1880619d29029c99985ffae9ed12a1c8d2cc796b.tar.gz
rapier-1880619d29029c99985ffae9ed12a1c8d2cc796b.tar.bz2
rapier-1880619d29029c99985ffae9ed12a1c8d2cc796b.zip
Merge pull request #277 from dimforge/solver-fixes
Fix some solver issues
Diffstat (limited to 'src/dynamics/solver/delta_vel.rs')
-rw-r--r--src/dynamics/solver/delta_vel.rs13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/dynamics/solver/delta_vel.rs b/src/dynamics/solver/delta_vel.rs
index 9160f2e..697fd24 100644
--- a/src/dynamics/solver/delta_vel.rs
+++ b/src/dynamics/solver/delta_vel.rs
@@ -1,7 +1,7 @@
use crate::math::{AngVector, Vector, SPATIAL_DIM};
use na::{DVectorSlice, DVectorSliceMut};
use na::{Scalar, SimdRealField};
-use std::ops::AddAssign;
+use std::ops::{AddAssign, Sub};
#[derive(Copy, Clone, Debug)]
#[repr(C)]
@@ -44,3 +44,14 @@ impl<N: SimdRealField + Copy> AddAssign for DeltaVel<N> {
self.angular += rhs.angular;
}
}
+
+impl<N: SimdRealField + Copy> Sub for DeltaVel<N> {
+ type Output = Self;
+
+ fn sub(self, rhs: Self) -> Self {
+ DeltaVel {
+ linear: self.linear - rhs.linear,
+ angular: self.angular - rhs.angular,
+ }
+ }
+}