FancySafeBot 0.0.1
A safe robotics library
Loading...
Searching...
No Matches
fsb_inverse_kinematics.h
1//
2// Created by Kyle Chisholm on 2025-05-16.
3//
4
5#ifndef FSB_INVERSE_KINEMATICS_H
6#define FSB_INVERSE_KINEMATICS_H
7
8#include <cstddef>
9#include <cstdint>
10#include "fsb_body.h"
11#include "fsb_body_tree.h"
12#include "fsb_motion.h"
13#include "fsb_joint.h"
14#include "fsb_types.h"
15#include "fsb_jacobian.h"
16#include "fsb_linalg.h"
17
18namespace fsb
19{
20
29{
30 size_t max_iterations = 100U;
31 Real objective_tol = 1.0e-12;
32 Real state_tol = 1.0e-12;
33 Real damping_factor = 0.001;
35 {1.0, 1.0, 1.0},
36 {1.0, 1.0, 1.0}
37 };
38};
39
40enum class InverseKinematicsInfo : uint8_t
41{
42 INVALID_INPUT = 0,
43 SUCCESS = 1,
44 WITHIN_FTOL = 2,
46 WITHIN_XTOL = 3,
50};
51
62
75 const BodyTree& body_tree, const OptimParameters& params,
76 const JointSpacePosition& initial_config, size_t body_index, const Transform& target_pose,
77 const Transform& base_pose = transform_identity());
78
91FsbLinalgErrorType inverse_velocity_kinematics(
92 const Jacobian& jacobian, const MotionVector& cart_velocity, size_t dofs,
93 JointSpace& joint_velocity);
94
109FsbLinalgErrorType inverse_acceleration_kinematics(
110 const Jacobian& jacobian, const Jacobian& jacobian_derivative,
111 const MotionVector& cart_acceleration, const JointSpace& joint_velocity, size_t dofs,
112 JointSpace& joint_acceleration);
113
118} // namespace fsb
119
120#endif // FSB_INVERSE_KINEMATICS_H
Body tree description of a kinematic chain.
Definition fsb_body_tree.h:99
@ SUCCESS
Successful operation.
BodyCartesianPva body_poses
Body poses.
Definition fsb_inverse_kinematics.h:56
InverseKinematicsResult compute_inverse_kinematics(const BodyTree &body_tree, const OptimParameters &params, const JointSpacePosition &initial_config, size_t body_index, const Transform &target_pose, const Transform &base_pose=transform_identity())
Compute inverse kinematics for a given end-effector pose.
Definition fsb_inverse_kinematics.cpp:173
Real state_tol
State vector error tolerance for convergence.
Definition fsb_inverse_kinematics.h:32
InverseKinematicsInfo
Definition fsb_inverse_kinematics.h:41
MotionVector error_pose
Error between computed and desired pose.
Definition fsb_inverse_kinematics.h:59
Real damping_factor
Damping factor for Levenberg-Marquardt algorithm.
Definition fsb_inverse_kinematics.h:33
Transform computed_pose
Computed end-effector pose.
Definition fsb_inverse_kinematics.h:58
size_t max_iterations
Maximum number of iterations.
Definition fsb_inverse_kinematics.h:30
Real objective_tol
Objective function error tolerance for convergence.
Definition fsb_inverse_kinematics.h:31
MotionVector objective_weights
Cartesian weights for objective function.
Definition fsb_inverse_kinematics.h:34
size_t iterations
Number of iterations.
Definition fsb_inverse_kinematics.h:60
JointSpacePosition joint_position
Joint position.
Definition fsb_inverse_kinematics.h:55
InverseKinematicsInfo info
Convergence information.
Definition fsb_inverse_kinematics.h:54
Jacobian jacobian
Jacobian matrix.
Definition fsb_inverse_kinematics.h:57
@ WITHIN_XTOL
relative error between two consecutive iterates is at most xtol
@ WITHIN_FTOL_XTOL
conditions for WITHIN_FTOL and WITHIN_XTOL both hold
@ MAXIMUM_EVALUATIONS_REACHED
number of calls to fcn with iflag = 1 has reached maxfev
@ SINGULAR_UPDATE_MATRIX
singular matrix encountered
enum FsbLapackErrorType FsbLinalgErrorType
Error codes for linear algebra functions.
Transform transform_identity()
Identity transform.
Definition fsb_motion.cpp:12
Container of Cartesian pose, velocity, and acceleration for a list of bodies.
Definition fsb_body.h:78
Definition fsb_inverse_kinematics.h:53
Jacobian matrix.
Definition fsb_jacobian.h:47
Joint space position in generalized coordinates.
Definition fsb_joint.h:55
Joint space differential of generalized coordinates.
Definition fsb_joint.h:66
Motion vector.
Definition fsb_motion.h:37
Definition fsb_inverse_kinematics.h:29
Coordinate transform.
Definition fsb_motion.h:22