diff options
| author | Crozet Sébastien <developer@crozet.re> | 2021-02-21 17:15:00 +0100 |
|---|---|---|
| committer | Crozet Sébastien <developer@crozet.re> | 2021-02-21 17:15:00 +0100 |
| commit | 01496d43e5a39a7348578faa4e6c2fcf1793785b (patch) | |
| tree | 0969fd6568be669929e27c8a8a24640327e570ff /src/dynamics/joint | |
| parent | f5515c39736aced54f65879a42b2a74a68609ee7 (diff) | |
| download | rapier-01496d43e5a39a7348578faa4e6c2fcf1793785b.tar.gz rapier-01496d43e5a39a7348578faa4e6c2fcf1793785b.tar.bz2 rapier-01496d43e5a39a7348578faa4e6c2fcf1793785b.zip | |
Add motors to ball joints.
Diffstat (limited to 'src/dynamics/joint')
| -rw-r--r-- | src/dynamics/joint/ball_joint.rs | 92 | ||||
| -rw-r--r-- | src/dynamics/joint/joint.rs | 3 |
2 files changed, 92 insertions, 3 deletions
diff --git a/src/dynamics/joint/ball_joint.rs b/src/dynamics/joint/ball_joint.rs index f1e8fdf..47c90ab 100644 --- a/src/dynamics/joint/ball_joint.rs +++ b/src/dynamics/joint/ball_joint.rs @@ -1,4 +1,5 @@ -use crate::math::{Point, Real, Vector}; +use crate::dynamics::SpringModel; +use crate::math::{Point, Real, Rotation, Vector}; #[derive(Copy, Clone)] #[cfg_attr(feature = "serde-serialize", derive(Serialize, Deserialize))] @@ -12,6 +13,33 @@ pub struct BallJoint { /// /// The impulse applied to the second body is given by `-impulse`. pub impulse: Vector<Real>, + + /// The target relative angular velocity the motor will attempt to reach. + #[cfg(feature = "dim2")] + pub motor_target_vel: Real, + /// The target relative angular velocity the motor will attempt to reach. + #[cfg(feature = "dim3")] + pub motor_target_vel: Vector<Real>, + /// The target angular position of this joint, expressed as an axis-angle. + pub motor_target_pos: Rotation<Real>, + /// The motor's stiffness. + /// See the documentation of `SpringModel` for more information on this parameter. + pub motor_stiffness: Real, + /// The motor's damping. + /// See the documentation of `SpringModel` for more information on this parameter. + pub motor_damping: Real, + /// The maximal impulse the motor is able to deliver. + pub motor_max_impulse: Real, + /// The angular impulse applied by the motor. + #[cfg(feature = "dim2")] + pub motor_impulse: Real, + /// The angular impulse applied by the motor. + #[cfg(feature = "dim3")] + pub motor_impulse: Vector<Real>, + /// The spring-like model used by the motor to reach the target velocity and . + pub motor_model: SpringModel, + // Used to handle cases where the position target ends up being more than pi radians away. + pub(crate) motor_last_angle: Real, } impl BallJoint { @@ -29,11 +57,71 @@ impl BallJoint { local_anchor1, local_anchor2, impulse, + motor_target_vel: na::zero(), + motor_target_pos: Rotation::identity(), + motor_stiffness: 0.0, + motor_damping: 0.0, + motor_impulse: na::zero(), + motor_max_impulse: Real::MAX, + motor_model: SpringModel::default(), + motor_last_angle: 0.0, } } /// Can a SIMD constraint be used for resolving this joint? pub fn supports_simd_constraints(&self) -> bool { - true + // SIMD ball constraints don't support motors right now. + self.motor_max_impulse == 0.0 || (self.motor_stiffness == 0.0 && self.motor_damping == 0.0) + } + + pub fn configure_motor_model(&mut self, model: SpringModel) { + self.motor_model = model; + } + + #[cfg(feature = "dim2")] + pub fn configure_motor_velocity(&mut self, target_vel: Real, factor: Real) { + self.configure_motor(self.motor_target_pos, target_vel, 0.0, factor) + } + + #[cfg(feature = "dim3")] + pub fn configure_motor_velocity(&mut self, target_vel: Vector<Real>, factor: Real) { + self.configure_motor(self.motor_target_pos, target_vel, 0.0, factor) + } + + pub fn configure_motor_position( + &mut self, + target_pos: Rotation<Real>, + stiffness: Real, + damping: Real, + ) { + self.configure_motor(target_pos, na::zero(), stiffness, damping) + } + + #[cfg(feature = "dim2")] + pub fn configure_motor( + &mut self, + target_pos: Rotation<Real>, + target_vel: Real, + stiffness: Real, + damping: Real, + ) { + self.motor_target_vel = target_vel; + self.motor_target_pos = target_pos; + self.motor_stiffness = stiffness; + self.motor_damping = damping; + } + + #[cfg(feature = "dim3")] + pub fn configure_motor( + &mut self, + target_pos: Rotation<Real>, + target_vel: Vector<Real>, + stiffness: Real, + damping: Real, + ) { + self.motor_target_vel = target_vel; + self.motor_target_pos = target_pos; + self.motor_stiffness = stiffness; + self.motor_damping = damping; } } diff --git a/src/dynamics/joint/joint.rs b/src/dynamics/joint/joint.rs index b4089ae..290c34c 100644 --- a/src/dynamics/joint/joint.rs +++ b/src/dynamics/joint/joint.rs @@ -132,10 +132,11 @@ pub struct Joint { impl Joint { pub fn supports_simd_constraints(&self) -> bool { match &self.params { - JointParams::RevoluteJoint(joint) => joint.supports_simd_constraints(), JointParams::PrismaticJoint(joint) => joint.supports_simd_constraints(), JointParams::FixedJoint(joint) => joint.supports_simd_constraints(), JointParams::BallJoint(joint) => joint.supports_simd_constraints(), + #[cfg(feature = "dim3")] + JointParams::RevoluteJoint(joint) => joint.supports_simd_constraints(), } } } |
