Robotics-focused geometry and quantities library with support for reference frame checking.
Authored by Christian Dreher and Rainer Kartmann.
[[TOC]]
- State ≠ Operation: Explicit differentiation between state (e.g., a position, an orientation, or a pose) and an operation (e.g., a translation, a rotation or a transform).
- Units: It must be clear what units are used if it is relevant (e.g., during construction or initialization), it should not interfere if it is not relevant (e.g., when calculating).
- Frames of Reference: Vectors, quaternions, matrices and even scalar values are usually in a frame of reference. Transforming a vector in a certain frame using a matrix can be ensured if information about the frames is given to avoid logic errors.
There are dedicated types for states and operations. Specifically, if two states are subtracted, the result will be a difference type. See the following tables. For some geometric concepts, special names are given.
In the following, if we refer to a base quantity, we mean a geometric object describing a state, whereas when we refer to a quantity, it may refer to a state or an operation.
Geometric Concept | Position | Orientation | Pose | Translation | Rotation | Transform |
---|---|---|---|---|---|---|
Position | Position | Orientation | Pose | Linear Displacement (Position Difference) |
Angular Displacement (Orientation Difference) |
Spatial Displacement (Pose Difference) |
Velocity | Linear Velocity | Angular Velocity | Twist | Linear Velocity Difference | Angular Velocity Difference | Twist Difference (Spatial Velocity Difference) |
Acceleration | Linear Acceleration | Angular Acceleration | Spatial Acceleration | Linear Acceleration Difference | Angular Acceleration Difference | Spatial Acceleration Difference |
Jerk | Linear Jerk | Angular Jerk | Spatial Jerk | Linear Jerk Difference | Angular Jerk Difference | Spatial Jerk Difference |
Momentum | Linear Momentum | Angular Momentum | Spatial Momentum | Linear Momentum Difference | Angular Momentum Difference | Spatial Momentum Difference |
Force | Force | Torque | Wrench | Force Difference | Torque Difference | Wrench Difference |
Geometric Concept | Position | Translation |
---|---|---|
Angle | Angle | Angle Difference |
Angular Speed | Angular Speed | Angular Speed Difference |
Angular Acceleration | Angular Acceleration | Angular Acceleration Difference |
Time | Time Point | Duration |
Length | Length (Magniute of Position) | Distance (Magnitude of Linear Displacement) |
Speed | Speed (Magnitude of Linear Velocity) | Speed Difference (Magnitude of Linear velocity |
Acceleration Magnitude | Acceleration Magnitude | Acceleration Magnitude Difference |
Mass | Mass | Mass Difference |
Force Magnitude | Force Magnitude | Force Magnitude Difference |
Torque Magnitude | Torque Magnitude | Torque Magnitude Difference |
Each quantity is stored as a normalized unit (e.g., Millimeters for Position). Constructing a quantity from any other non-normalized form will result in a run-time conversion (e.g., a construction from Meters will result in a conversion to Millimeters). This allows for flexibility and easier to read and write code at the cost of run-time conversions if non-normalized units are provided.
It is not possible to construct any quantity in this framework without explicitly specifying the unit. For example, for Position:
using namespace quant;
Position p1_good; // Ok, will be [0, 0, 0] mm.
Position p2_good == Position::zero(); // Ok, will be [0, 0, 0] mm.
Position p3_good == Position::millimeters(100, 200, 300); // Ok, will be [100, 200, 300] mm.
Position p4_good == Position::meters(0.1, 0.2, 0.3); // Ok, will be [100, 200, 300] mm.
Position p5_good == Position::meters({.y = 0.2}); // Ok, will be [0, 200, 0] mm.
Position p6_good == Position::meters(Vector::from_eigen(e)); // Ok, will be the Eigen vector e converted to mm.
Position p1_bad{0, 0, 0}; // Error, forbidden: Unit unclear.
This applies to all quantities. There will be static constructor-like functions specifying the unit of the passed numbers.
Usually a quantity (e.g., a position or a velocity) is in a base frame. For example, the position of the tool center point of a robot might be given in the frame of the robot model's root.
Especially in robotics, where several frames of reference have to be taken into account, logic errors can quickly occur and are usually just mitigated by specific naming conventions.
This library provides the concept of "Framed" states and "Frame" operations.