Skip to main content

DynamicURDFChain

Enum DynamicURDFChain 

Source
pub enum DynamicURDFChain {
    J1(URDFChain<1>),
    J2(URDFChain<2>),
    J3(URDFChain<3>),
    J4(URDFChain<4>),
    J5(URDFChain<5>),
    J6(URDFChain<6>),
    J7(URDFChain<7>),
    J8(URDFChain<8>),
}

Variants§

Implementations§

Source§

impl DynamicURDFChain

Source

pub fn try_new(joints: Vec<URDFJoint>) -> DekeResult<Self>

Source

pub fn dof(&self) -> usize

Source

pub fn fk_dyn(&self, q: &[f32]) -> DekeResult<Vec<Affine3A>>

Source

pub fn fk_end_dyn(&self, q: &[f32]) -> DekeResult<Affine3A>

Source§

impl DynamicURDFChain

Source

pub fn from_chain(chain: impl Into<Self>) -> Self

Trait Implementations§

Source§

impl Clone for DynamicURDFChain

Source§

fn clone(&self) -> DynamicURDFChain

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DynamicURDFChain

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl FKChain<1> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<1>) -> Result<[Affine3A; 1], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<1>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<1>, ) -> Result<([Vec3A; 1], [Vec3A; 1], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl FKChain<2> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<2>) -> Result<[Affine3A; 2], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<2>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<2>, ) -> Result<([Vec3A; 2], [Vec3A; 2], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl FKChain<3> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<3>) -> Result<[Affine3A; 3], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<3>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<3>, ) -> Result<([Vec3A; 3], [Vec3A; 3], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl FKChain<4> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<4>) -> Result<[Affine3A; 4], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<4>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<4>, ) -> Result<([Vec3A; 4], [Vec3A; 4], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl FKChain<5> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<5>) -> Result<[Affine3A; 5], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<5>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<5>, ) -> Result<([Vec3A; 5], [Vec3A; 5], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl FKChain<6> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<6>) -> Result<[Affine3A; 6], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<6>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<6>, ) -> Result<([Vec3A; 6], [Vec3A; 6], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl FKChain<7> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<7>) -> Result<[Affine3A; 7], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<7>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<7>, ) -> Result<([Vec3A; 7], [Vec3A; 7], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl FKChain<8> for DynamicURDFChain

Source§

type Error = DekeError

Source§

fn fk(&self, q: &SRobotQ<8>) -> Result<[Affine3A; 8], Self::Error>

Source§

fn fk_end(&self, q: &SRobotQ<8>) -> Result<Affine3A, Self::Error>

Source§

fn joint_axes_positions( &self, q: &SRobotQ<8>, ) -> Result<([Vec3A; 8], [Vec3A; 8], Vec3A), Self::Error>

Returns joint rotation axes and axis-origin positions in world frame at configuration q, plus the end-effector position.
Source§

fn dof(&self) -> usize

Source§

fn max_reach(&self) -> Result<f32, Self::Error>

Theoretical maximum reach: sum of link lengths (upper bound, ignores joint limits).
Source§

fn jacobian(&self, q: &SRobotQ<N>) -> Result<[[f32; N]; 6], Self::Error>

Geometric Jacobian (6×N) at configuration q. Rows 0–2: linear velocity, rows 3–5: angular velocity.
Source§

fn jacobian_dot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

First time-derivative of the geometric Jacobian.
Source§

fn jacobian_ddot( &self, q: &SRobotQ<N>, qdot: &SRobotQ<N>, qddot: &SRobotQ<N>, ) -> Result<[[f32; N]; 6], Self::Error>

Second time-derivative of the geometric Jacobian.
Source§

impl From<URDFChain<1>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<1>) -> Self

Converts to this type from the input type.
Source§

impl From<URDFChain<2>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<2>) -> Self

Converts to this type from the input type.
Source§

impl From<URDFChain<3>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<3>) -> Self

Converts to this type from the input type.
Source§

impl From<URDFChain<4>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<4>) -> Self

Converts to this type from the input type.
Source§

impl From<URDFChain<5>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<5>) -> Self

Converts to this type from the input type.
Source§

impl From<URDFChain<6>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<6>) -> Self

Converts to this type from the input type.
Source§

impl From<URDFChain<7>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<7>) -> Self

Converts to this type from the input type.
Source§

impl From<URDFChain<8>> for DynamicURDFChain

Source§

fn from(chain: URDFChain<8>) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.