5#ifndef FSB_INVERSE_KINEMATICS_H
6#define FSB_INVERSE_KINEMATICS_H
12#include "fsb_body_tree.h"
13#include "fsb_configuration.h"
14#include "fsb_motion.h"
17#include "fsb_jacobian.h"
18#include "fsb_linalg.h"
69 {{1.0, 1.0, 1.0}, {1.0, 1.0, 1.0}}
85 const BodyTree& body_tree,
const OptimParameters& params,
86 const JointSpacePosition& initial_config,
size_t body_index,
const Transform& target_pose,
102 const Jacobian& jacobian,
const MotionVector& cart_velocity,
size_t dofs,
103 JointSpace& joint_velocity);
116 const MotionVector& cart_acceleration,
const JointSpace& joint_velocity,
size_t dofs,
117 JointSpace& joint_acceleration);
BodyCartesianPva body_poses
Body poses.
Definition fsb_inverse_kinematics.h:55
InverseKinematicsResult compute_inverse_kinematics(const BodyTree &body_tree, const OptimParameters ¶ms, 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:162
real_t state_tol
State vector error tolerance for convergence.
Definition fsb_inverse_kinematics.h:34
InverseKinematicsInfo
Definition fsb_inverse_kinematics.h:40
real_t damping_factor
Damping factor for Levenberg-Marquardt algorithm.
Definition fsb_inverse_kinematics.h:35
MotionVector error_pose
Error between computed and desired pose.
Definition fsb_inverse_kinematics.h:58
Transform computed_pose
Computed end-effector pose.
Definition fsb_inverse_kinematics.h:57
size_t max_iterations
Maximum number of iterations.
Definition fsb_inverse_kinematics.h:32
MotionVector objective_weights
Cartesian weights for objective function.
Definition fsb_inverse_kinematics.h:36
size_t iterations
Number of iterations.
Definition fsb_inverse_kinematics.h:59
JointSpacePosition joint_position
Joint position.
Definition fsb_inverse_kinematics.h:54
real_t objective_tol
Objective function error tolerance for convergence.
Definition fsb_inverse_kinematics.h:33
InverseKinematicsInfo info
Convergence information.
Definition fsb_inverse_kinematics.h:53
Jacobian jacobian
Jacobian matrix.
Definition fsb_inverse_kinematics.h:56
@ 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
Jacobian jacobian_derivative(const Hessian &hessian, const JointSpace &joint_velocity, size_t dofs=MaxSize::dofs)
Compute derivative of Jacobian matrix.
Definition fsb_jacobian.cpp:370
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:79
Definition fsb_inverse_kinematics.h:52
Jacobian matrix.
Definition fsb_jacobian.h:43
Joint space position in generalized coordinates.
Definition fsb_joint.h:55
Motion vector.
Definition fsb_motion.h:37
Definition fsb_inverse_kinematics.h:31