MotionsΒΆ

class jacobi.LinearSectionΒΆ

Bases: pybind11_object

Represents a linear Cartesian section for either the approach to the goal or the retraction from the start.

class ApproximationΒΆ

Bases: pybind11_object

Whether to approximate the Cartesian linear motion in joint space for singularity-free calculation.

Members:

Always :

Never :

__init__(self: Approximation, value: int) NoneΒΆ
property nameΒΆ
__init__(self: jacobi.LinearSection, offset: jacobi.Frame, speed: float = 1.0, approximation: jacobi.LinearSection.Approximation = <Approximation.Never: 0>, smooth_transition: bool = True) NoneΒΆ
property offsetΒΆ

Relative linear cartesian offset from the reference pose.

property smooth_transitionΒΆ

Whether to use a smooth transition between this and the next or previous section. If false, the robot will come to a complete stop at the transition point.

property speedΒΆ

Speed of the sub-motion, relative to the overall motion’s speed.

class jacobi.MotionΒΆ

Bases: pybind11_object

Represents a request for a collision-free point-to-point motion.

The Motion class provides an interface for general point-to-point motion planning with arbitrary waypoints, linear approach and retraction, and task constraints. It includes parameters for the motion name, robot, start and goal points, and additional settings for motion planning, such as collision checking and soft failure handling.

__init__(*args, **kwargs)ΒΆ

Overloaded function.

  1. __init__(self: jacobi.Motion, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion]) -> None

Construct a Motion with a given start and goal point.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.Motion, robot: jacobi.Robot, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion]) -> None

Construct a Motion with a name, start and goal point.

Parameter name:

The unique name of the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.Motion, name: str, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion]) -> None

Construct a Motion with a name, start and goal point.

Parameter name:

The unique name of the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.Motion, name: str, robot: jacobi.Robot, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint, jacobi.Region, jacobi.CartesianRegion]) -> None

Construct a Motion with a name, robot, start and goal point.

Parameter name:

The unique name of the motion.

Parameter robot:

The robot for the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

property cartesian_tcp_speed_cutoffΒΆ

Optional Cartesian TCP speed (translation-only) cutoff. This is a post-processing step.

property goalΒΆ

Goal point of the motion

property ignore_collisionsΒΆ

Whether to ignore collisions

property initial_waypointsΒΆ

Optional initial waypoints to start the optimization with (don’t use with intermediate waypoints).

property linear_approachΒΆ

Optional relative linear cartesian motion for approaching the goal pose.

property linear_retractionΒΆ

Optional relative linear cartesian motion for retracting from the start pose.

property nameΒΆ

The unique name of the motion.

property orientation_loss_weightΒΆ

Weight of the loss minimizing the maximizing deviation of the end- effector orientation to the target value.

property orientation_targetΒΆ

Target vector pointing in the direction of the end-effector (TCP) orientation in the global coordinate system.

property path_length_loss_weightΒΆ

Weight of the loss minimizing the path length of the trajectory.

property robotΒΆ

The robot for the motion (e.g. defines the kinematics and the joint limits).

property startΒΆ

Start point of the motion

property waypointsΒΆ

Intermediate waypoints that the motion passes through exactly. The list of waypoints is limited to less than four, otherwise please take a look at LowLevelMotion.

class jacobi.LinearMotionΒΆ

Bases: pybind11_object

Represents a request for a linear Cartesian-space motion.

The LinearMotion struct represents a request for a linear motion in Cartesian space. It consists of a start and goal point, as well as a robot to perform the motion. It provides an interface for planning singularity-free linear motion in Cartesian space between any two waypoints.

__init__(*args, **kwargs)ΒΆ

Overloaded function.

  1. __init__(self: jacobi.LinearMotion, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint]) -> None

Construct a linear motion with a given start, and goal.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.LinearMotion, robot: jacobi.Robot, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint]) -> None

Construct a linear motion with a given robot, start, and goal.

Parameter robot:

The robot for the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.LinearMotion, name: str, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint]) -> None

Construct a linear motion with a given name, start, and goal.

Parameter name:

The unique name of the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.LinearMotion, name: str, robot: jacobi.Robot, start: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint], goal: Union[list[float], jacobi.Waypoint, jacobi.CartesianWaypoint, jacobi.MultiRobotPoint]) -> None

Construct a linear motion with a given name, robot, start, and goal.

Parameter name:

The unique name of the motion.

Parameter robot:

The robot for the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

property goalΒΆ

Goal point of the motion.

property ignore_collisionsΒΆ

Whether to ignore collisions

property nameΒΆ

The unique name of the motion.

property robotΒΆ

The robot for the motion (e.g. defines the kinematics and the joint limits).

property startΒΆ

Start point of the motion

class jacobi.LowLevelMotionΒΆ

Bases: pybind11_object

Represents a request for a low-level motion.

The LinearMotion class provides an interface for very efficient planning of motion between joint-space waypoints. While low level motions are not checked for collisions, they are much faster to compute and allow for more flexible constraints such as a minimum duration parameter. This motion type is suitable for visual servoing task or other real-time control.

class ControlInterfaceΒΆ

Bases: pybind11_object

The control interface for the motion, specifying either position or velocity control.

Members:

Position : Position-control: Full control over the entire kinematic state

(Default)

Velocity : Velocity-control: Ignores the current position, target position, and

velocity limits

__init__(self: ControlInterface, value: int) NoneΒΆ
property nameΒΆ
class DurationDiscretizationΒΆ

Bases: pybind11_object

The duration discretization strategy for the motion, specifying either continuous or discrete durations.

Members:

Continuous : Every trajectory synchronization duration is allowed (Default)

Discrete : The trajectory synchronization duration must be a multiple of the

control cycle

__init__(self: DurationDiscretization, value: int) NoneΒΆ
property nameΒΆ
class SynchronizationΒΆ

Bases: pybind11_object

The synchronization strategy for the motion, specifying either phase, time, time if necessary, or no synchronization.

Members:

Phase : Phase synchronize the DoFs when possible, else fallback to β€œTime”

strategy (Default)

Time : Always synchronize the DoFs to reach the target at the same time

TimeIfNecessary : Synchronize only when necessary (e.g. for non-zero target velocity or

acceleration)

None : Calculate every DoF independently

__init__(self: Synchronization, value: int) NoneΒΆ
property nameΒΆ
__init__(*args, **kwargs)ΒΆ

Overloaded function.

  1. __init__(self: jacobi.LowLevelMotion, robot: jacobi.Robot) -> None

Construct a low-level motion with a given robot.

Parameter robot:

The robot for the motion.

  1. __init__(self: jacobi.LowLevelMotion, name: str) -> None

Construct a low-level motion with a given name.

Parameter name:

The unique name of the motion.

  1. __init__(self: jacobi.LowLevelMotion, name: str, robot: jacobi.Robot) -> None

Construct a low-level motion with a given name, robot, start, and goal.

Parameter name:

The unique name of the motion.

Parameter robot:

The robot for the motion.

  1. __init__(self: jacobi.LowLevelMotion) -> None

Default constructor.

property control_interfaceΒΆ

The control interface for the motion.

property duration_discretizationΒΆ

The duration discretization strategy for the motion.

property goalΒΆ

Goal waypoint of the motion.

property intermediate_positionsΒΆ

List of intermediate positions.

For a small number of waypoints (less than 16), the trajectory goes exactly through the intermediate waypoints. For a larger number of waypoints, first a filtering algorithm is used to keep the resulting trajectory close to the original waypoints.

property minimum_durationΒΆ

A minimum duration of the motion.

property nameΒΆ

The unique name of the motion.

property robotΒΆ

The robot for the motion (e.g. defines the kinematics and the joint limits).

property startΒΆ

Start waypoint of the motion.

property synchronizationΒΆ

The synchronization strategy for the motion.

class jacobi.LinearPathΒΆ

Bases: pybind11_object

__init__(self: LinearPath, start: Frame, goal: Frame) NoneΒΆ

Construct a LinearPath with a given start and goal pose.

Parameter start:

The starting pose of the linear path.

Parameter goal:

The ending pose of the linear path.

property goalΒΆ

The goal pose of the linear path.

property startΒΆ

The start pose of the linear path.

class jacobi.CircularPathΒΆ

Bases: pybind11_object

__init__(*args, **kwargs)ΒΆ

Overloaded function.

  1. __init__(self: jacobi.CircularPath, start: jacobi.Frame, theta: float, center: Annotated[list[float], FixedSize(3)], normal: Annotated[list[float], FixedSize(3)], keep_tool_to_surface_orientation: bool = True) -> None

  2. __init__(self: jacobi.CircularPath, start: jacobi.Frame, goal: jacobi.Frame, center: Annotated[list[float], FixedSize(3)], keep_tool_to_surface_orientation: bool = True) -> None

property centerΒΆ

The center of the circle.

property keep_tool_to_surface_orientationΒΆ

Whether to maintain the tool-to-surface orientation.

property normalΒΆ

The normal of the plane in which to create a circular path.

property startΒΆ

The start pose of the circular path.

property thetaΒΆ

The rotation angle of the circular path [rad].

class jacobi.PathΒΆ

Bases: pybind11_object

Abstract base class representing a type of path.

The PathType class provides an abstract interface for different types of paths.

__init__(*args, **kwargs)ΒΆ

Overloaded function.

  1. __init__(self: jacobi.Path) -> None

Default constructor

  1. __init__(self: jacobi.Path, arg0: jacobi.LinearPath) -> None

  2. __init__(self: jacobi.Path, arg0: jacobi.CircularPath) -> None

static from_waypoints(waypoints: list[Frame], blend_radius: float | None = None, keep_tool_to_surface_orientation: bool = True) PathΒΆ

Construct a path from a list of waypoints and a blend radius

Parameter waypoints:

The Cartesian waypoints defining the path.

Parameter blend_radius:

The radius for the circular blend between waypoints.

Parameter keep_tool_to_surface_orientation:

Whether to maintain tool-to-surface orientation.

position(self: Path, s: float) FrameΒΆ

Calculate the position at the path parameter s

Parameter s:

The path parameter (0.0 to length).

sample_positions(self: Path, velocity: float, delta_time: float) list[Frame]ΒΆ

Sample positions along the path with a given constant velocity and time step

Parameter velocity:

The constant velocity of the end-effector [m/s].

Parameter delta_time:

The time step for sampling the path [s].

Returns:

std::vector<Frame> The sampled positions along the path.

property lengthΒΆ

Get the overall length of the path

property segmentsΒΆ

Get the individual segments of the path

class jacobi.PathFollowingMotionΒΆ

Bases: pybind11_object

Represents a request for a Cartesian-space motion to be followed by the end-effector.

The PathFollowingMotion class provides an interface for Cartesian- space paths to be accurately followed by the robot end-effector with a constant velocity. There are currently three different path types that are supported: linear, circular and blended. The path-following motion is suitable for use cases such as welding, painting, dispensing and deburring, where constant end-effector velocity is required for successful task execution. It includes parameters for the motion name, robot, path type, velocity, and additional settings for motion planning, such as collision checking and soft failure handling.

__init__(*args, **kwargs)ΒΆ

Overloaded function.

  1. __init__(self: jacobi.PathFollowingMotion, path: jacobi.Path, velocity: float = 50.0) -> None

Construct a PathFollowingMotion with a given path type and optional velocity.

Parameter path:

The Cartesian path type to follow.

Parameter velocity:

The desired velocity of the end-effector [m/s]. If not provided, the robot will move as fast as possible while respecting velocity limits.

  1. __init__(self: jacobi.PathFollowingMotion, name: str, path: jacobi.Path, velocity: float = 50.0) -> None

Construct a PathFollowingMotion with a name, path type, and optional velocity.

Parameter name:

The unique name of the motion.

Parameter path:

The Cartesian path type to follow.

Parameter velocity:

The desired velocity of the end-effector [m/s]. If not provided, the robot will move as fast as possible while respecting velocity limits.

  1. __init__(self: jacobi.PathFollowingMotion, robot: jacobi.Robot, path: jacobi.Path, velocity: float = 50.0) -> None

Construct a PathFollowingMotion with a robot, path type, and optional velocity.

Parameter robot:

The robot for the motion.

Parameter path:

The Cartesian path type to follow.

Parameter velocity:

The desired velocity of the end-effector [m/s]. If not provided, the robot will move as fast as possible while respecting velocity limits.

  1. __init__(self: jacobi.PathFollowingMotion, name: str, robot: jacobi.Robot, path: jacobi.Path, velocity: float = 50.0) -> None

Construct a PathFollowingMotion with a name, robot, path type, and optional velocity.

Parameter name:

The unique name of the motion.

Parameter robot:

The robot for the motion.

Parameter path_type:

The Cartesian path type to follow.

Parameter velocity:

The desired velocity of the end-effector [m/s]. If not provided, the robot will move as fast as possible while respecting velocity limits.

robot_arm(self: PathFollowingMotion) RobotArmΒΆ
property check_collisionΒΆ

If true, the planner will check for collisions during the motion.

property feasible_velocityΒΆ

The feasible velocity of the end-effector achieved after planning [m/s] (only used if soft_failure is true).

property nameΒΆ

The unique name of the motion.

property pathΒΆ

The Cartesian path to follow.

property reference_configΒΆ

Optional reference configuration for the start state of the motion.

property robotΒΆ

The robot for the motion (e.g. defines the kinematics and the joint limits).

property soft_failureΒΆ

If true, the planner will adjust path velocity until a solution until velocity limits are satisfied.

property velocityΒΆ

The desired velocity of the end-effector [m/s].

class jacobi.BimanualMotionΒΆ

Bases: pybind11_object

Represents a request for a collision-free point-to-point bimanual motion for dual-arm robots.

The BimanualMotion class provides an interface for general point-to- point motion planning for dual-arm robots with arbitrary waypoints, linear approach and retraction, and task constraints. It includes parameters for the motion name, robot, start and goal points, and additional settings for motion planning, such as intermediate waypoints, setting if the bimanual motion should be coordinated, and soft failure handling.

__init__(*args, **kwargs)ΒΆ

Overloaded function.

  1. __init__(self: jacobi.BimanualMotion, arm_left: jacobi.RobotArm, arm_right: jacobi.RobotArm, start: jacobi.MultiRobotPoint, goal: jacobi.MultiRobotPoint) -> None

Construct a BimanualMotion with left and right robot arms, start and goal point.

Parameter arm_left:

The left robot arm for the motion.

Parameter arm_right:

The right robot arm for the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.BimanualMotion, name: str, arm_left: jacobi.RobotArm, arm_right: jacobi.RobotArm, start: jacobi.MultiRobotPoint, goal: jacobi.MultiRobotPoint) -> None

Construct a BimanualMotion with a name, left and right robot arms, start and goal point.

Parameter name:

The unique name of the motion.

Parameter arm_left:

The left robot arm for the motion.

Parameter arm_right:

The right robot arm for the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.BimanualMotion, robot: jacobi::robots::DualArm, start: jacobi.MultiRobotPoint, goal: jacobi.MultiRobotPoint) -> None

Construct a BimanualMotion with a robot, start and goal point.

Parameter robot:

The dual-arm robot for the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

  1. __init__(self: jacobi.BimanualMotion, name: str, robot: jacobi::robots::DualArm, start: jacobi.MultiRobotPoint, goal: jacobi.MultiRobotPoint) -> None

Construct a BimanualMotion with a name, robot, start and goal point.

Parameter name:

The unique name of the motion.

Parameter robot:

The dual-arm robot for the motion.

Parameter start:

The start point of the motion.

Parameter goal:

The goal point of the motion.

property goalΒΆ

Goal point of the motion for both arms.

property is_coordinatedΒΆ

Flag to indicate if the motion is coordinated, in which case the follower arm moves with a constant offset to the leader arm.

property leader_armΒΆ

The leader arm for the coordinated motion. Left arm is used by default if this variable is not set.

property linear_approachΒΆ

Optional relative linear cartesian motion for approaching the goal pose, specified for one or both arms.

property linear_retractionΒΆ

Optional relative linear cartesian motion for retracting from the start pose, specified for one or both arms.

property nameΒΆ

The unique name of the bimanual motion.

property path_length_loss_weightΒΆ

Weight of the loss minimizing the path length of the trajectory.

property robotΒΆ

The dual-arm robot for the bimanual motion (e.g. defines the kinematics and the joint limits).

property startΒΆ

Start point of the motion for both arms.

property waypointsΒΆ

Intermediate waypoints for both arms that the motion passes through exactly. The list of waypoints is limited to less than four.