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 <array>
9#include <cstddef>
10#include <cstdint>
11#include "fsb_body.h"
12#include "fsb_body_tree.h"
13#include "fsb_configuration.h"
14#include "fsb_motion.h"
15#include "fsb_joint.h"
16#include "fsb_types.h"
17#include "fsb_jacobian.h"
18
19namespace fsb
20{
21
37
38enum class InverseKinematicsInfo : uint8_t
39{
40 INVALID_INPUT = 0,
41 SUCCESS = 1,
42 WITHIN_FTOL = 2,
43 WITHIN_XTOL = 3,
47};
48
59
60inline OptimParameters default_optim_parameters()
61{
62 return {
63 100U, // max iterations
64 1.0e-12, // objective tolerance
65 1.0e-12, // f tolerance
66 0.001,
67 {
68 {1.0, 1.0, 1.0},
69 {1.0, 1.0, 1.0}
70 }
71 };
72}
73
85InverseKinematicsResult compute_inverse_kinematics(
86 const BodyTree& body_tree, const OptimParameters& params, const JointSpacePosition& initial_config, size_t body_index,
87 const Transform& target_pose, const Transform& base_pose = transform_identity());
88
93}
94
95#endif //FSB_INVERSE_KINEMATICS_H
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:185
InverseKinematicsInfo
Definition fsb_inverse_kinematics.h:39
@ WITHIN_XTOL
relative error between two consecutive iterates is at most xtol
@ WITHIN_FTOL_XTOL
conditions for WITHIN_FTOL and WITHIN_XTOL both hold
@ WITHIN_FTOL
both actual and predicted relative reductions in the sum of squares are at most ftol
@ MAXIMUM_EVALUATIONS_REACHED
number of calls to fcn with iflag = 1 has reached maxfev
@ SINGULAR_UPDATE_MATRIX
singular matrix encountered
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:79
Definition fsb_inverse_kinematics.h:50
BodyCartesianPva body_poses
Body poses.
Definition fsb_inverse_kinematics.h:53
MotionVector error_pose
Error between computed and desired pose.
Definition fsb_inverse_kinematics.h:56
Transform computed_pose
Computed end-effector pose.
Definition fsb_inverse_kinematics.h:55
size_t iterations
Number of iterations.
Definition fsb_inverse_kinematics.h:57
JointSpacePosition joint_position
Joint position.
Definition fsb_inverse_kinematics.h:52
InverseKinematicsInfo info
Convergence information.
Definition fsb_inverse_kinematics.h:51
Jacobian jacobian
Jacobian matrix.
Definition fsb_inverse_kinematics.h:54
Jacobian matrix.
Definition fsb_jacobian.h:28
Joint space position in generalized coordinates.
Definition fsb_joint.h:55
Motion vector.
Definition fsb_motion.h:37
Definition fsb_inverse_kinematics.h:30
real_t state_tol
State vector error tolerance for convergence.
Definition fsb_inverse_kinematics.h:33
real_t damping_factor
Damping factor for Levenberg-Marquardt algorithm.
Definition fsb_inverse_kinematics.h:34
size_t max_iterations
Maximum number of iterations.
Definition fsb_inverse_kinematics.h:31
MotionVector objective_weights
Cartesian weights for objective function.
Definition fsb_inverse_kinematics.h:35
real_t objective_tol
Objective function error tolerance for convergence.
Definition fsb_inverse_kinematics.h:32
Coordinate transform.
Definition fsb_motion.h:22