arci/traits/move_base.rs
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 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
use auto_impl::auto_impl;
use crate::error::Error;
#[derive(Clone, Debug, Default, Copy)]
pub struct BaseVelocity {
pub x: f64,
pub y: f64,
pub theta: f64,
}
impl BaseVelocity {
pub fn new(x: f64, y: f64, theta: f64) -> Self {
Self { x, y, theta }
}
}
/// Multiply scalar value for velocity
///
/// # Example
///
/// ```
/// use assert_approx_eq::assert_approx_eq;
/// use arci::BaseVelocity;
///
/// let vel = BaseVelocity::new(0.1, -0.2, 1.0);
/// let twice = vel * 2.0;
/// assert_approx_eq!(twice.x, 0.2);
/// assert_approx_eq!(twice.y, -0.4);
/// assert_approx_eq!(twice.theta, 2.0);
/// ```
impl std::ops::Mul<f64> for BaseVelocity {
type Output = Self;
fn mul(self, rhs: f64) -> Self::Output {
Self {
x: self.x * rhs,
y: self.y * rhs,
theta: self.theta * rhs,
}
}
}
/// Multiply scalar value for velocity
///
/// # Example
///
/// ```
/// use assert_approx_eq::assert_approx_eq;
/// use arci::BaseVelocity;
///
/// let mut vel = BaseVelocity::new(0.1, -0.2, 1.0);
/// vel *= 2.0;
/// assert_approx_eq!(vel.x, 0.2);
/// assert_approx_eq!(vel.y, -0.4);
/// assert_approx_eq!(vel.theta, 2.0);
/// ```
impl std::ops::MulAssign<f64> for BaseVelocity {
fn mul_assign(&mut self, rhs: f64) {
self.x *= rhs;
self.y *= rhs;
self.theta *= rhs;
}
}
#[auto_impl(Box, Arc)]
pub trait MoveBase: Send + Sync {
fn send_velocity(&self, velocity: &BaseVelocity) -> Result<(), Error>;
fn current_velocity(&self) -> Result<BaseVelocity, Error>;
}