1#ifndef ROBOT_MODEL_PINOCCHIO_HPP
2#define ROBOT_MODEL_PINOCCHIO_HPP
5#include <pinocchio/multibody/fwd.hpp>
6#include <pinocchio/parsers/urdf.hpp>
16 typedef std::shared_ptr<pinocchio::Data>
DataPtr;
38 const base::samples::RigidBodyStateSE3&
floating_base_state = base::samples::RigidBodyStateSE3());
41 virtual void systemState(base::VectorXd &
q, base::VectorXd &
qd, base::VectorXd &
qdd);
44 virtual const base::samples::RigidBodyStateSE3 &
rigidBodyState(
const std::string &root_frame,
const std::string &tip_frame);
52 virtual const base::MatrixXd &
spaceJacobian(
const std::string &root_frame,
const std::string &tip_frame);
60 virtual const base::MatrixXd &
bodyJacobian(
const std::string &root_frame,
const std::string &tip_frame);
74 virtual const base::Acceleration &
spatialAccelerationBias(
const std::string &root_frame,
const std::string &tip_frame);
83 virtual const base::MatrixXd &
jacobianDot(
const std::string &root_frame,
const std::string &tip_frame);
92 virtual const base::samples::RigidBodyStateSE3&
centerOfMass();
static RobotModelRegistry< RobotModelPinocchio > reg
Definition RobotModelPinocchio.hpp:12
virtual void update(const base::samples::Joints &joint_state, const base::samples::RigidBodyStateSE3 &floating_base_state=base::samples::RigidBodyStateSE3())
Update the robot configuration.
Definition RobotModelPinocchio.cpp:133
virtual const base::MatrixXd & bodyJacobian(const std::string &root_frame, const std::string &tip_frame)
Returns the Body Jacobian for the kinematic chain between root and the tip frame as full body Jacobia...
Definition RobotModelPinocchio.cpp:290
virtual const base::MatrixXd & jointSpaceInertiaMatrix()
Compute and return the joint space mass-inertia matrix, which is nj x nj, where nj is the number of j...
Definition RobotModelPinocchio.cpp:365
Eigen::VectorXd q
Definition RobotModelPinocchio.hpp:14
virtual const base::samples::RigidBodyStateSE3 & rigidBodyState(const std::string &root_frame, const std::string &tip_frame)
Definition RobotModelPinocchio.cpp:223
pinocchio::Model model
Definition RobotModelPinocchio.hpp:15
virtual const base::MatrixXd & jacobianDot(const std::string &root_frame, const std::string &tip_frame)
Returns the derivative of the Jacobian for the kinematic chain between root and the tip frame as full...
Definition RobotModelPinocchio.cpp:360
RobotModelPinocchio()
Definition RobotModelPinocchio.cpp:16
Eigen::VectorXd qdd
Definition RobotModelPinocchio.hpp:14
virtual const base::MatrixXd & comJacobian()
Returns the CoM Jacobian for the entire robot, which maps the robot joint velocities to linear spatia...
Definition RobotModelPinocchio.cpp:320
DataPtr data
Definition RobotModelPinocchio.hpp:17
virtual void computeInverseDynamics(base::commands::Joints &solver_output)
Compute and return the inverse dynamics solution.
Definition RobotModelPinocchio.cpp:410
Eigen::VectorXd qd
Definition RobotModelPinocchio.hpp:14
std::shared_ptr< pinocchio::Data > DataPtr
Definition RobotModelPinocchio.hpp:16
~RobotModelPinocchio()
Definition RobotModelPinocchio.cpp:20
virtual void systemState(base::VectorXd &q, base::VectorXd &qd, base::VectorXd &qdd)
Definition RobotModelPinocchio.cpp:217
virtual const base::VectorXd & biasForces()
Compute and return the bias force vector, which is nj x 1, where nj is the number of joints of the sy...
Definition RobotModelPinocchio.cpp:379
void clear()
Definition RobotModelPinocchio.cpp:23
virtual const base::Acceleration & spatialAccelerationBias(const std::string &root_frame, const std::string &tip_frame)
Returns the spatial acceleration bias, i.e. the term Jdot*qdot.
Definition RobotModelPinocchio.cpp:333
virtual bool configure(const RobotModelConfig &cfg)
Load and configure the robot model.
Definition RobotModelPinocchio.cpp:30
virtual const base::samples::RigidBodyStateSE3 & centerOfMass()
Compute and return center of mass expressed in base frame.
Definition RobotModelPinocchio.cpp:391
virtual const base::MatrixXd & spaceJacobian(const std::string &root_frame, const std::string &tip_frame)
Returns the Space Jacobian for the kinematic chain between root and the tip frame as full body Jacobi...
Definition RobotModelPinocchio.cpp:260
RobotModel()
Definition RobotModel.cpp:15
base::samples::RigidBodyStateSE3 floating_base_state
Definition RobotModel.hpp:31
base::samples::Joints joint_state
Definition RobotModel.hpp:42
Definition ContactsAccelerationConstraint.cpp:3
Robot Model configuration class.
Definition RobotModelConfig.hpp:40
Definition RobotModel.hpp:239