KDL 1.5.3
Loading...
Searching...
No Matches
rigidbodyinertia.hpp
Go to the documentation of this file.
1// Copyright (C) 2009 Ruben Smits <ruben dot smits at mech dot kuleuven dot be>
2
3// Version: 1.0
4// Author: Ruben Smits <ruben dot smits at mech dot kuleuven dot be>
5// Maintainer: Ruben Smits <ruben dot smits at mech dot kuleuven dot be>
6// URL: http://www.orocos.org/kdl
7
8// This library is free software; you can redistribute it and/or
9// modify it under the terms of the GNU Lesser General Public
10// License as published by the Free Software Foundation; either
11// version 2.1 of the License, or (at your option) any later version.
12
13// This library is distributed in the hope that it will be useful,
14// but WITHOUT ANY WARRANTY; without even the implied warranty of
15// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16// Lesser General Public License for more details.
17
18// You should have received a copy of the GNU Lesser General Public
19// License along with this library; if not, write to the Free Software
20// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21
22#ifndef KDL_RIGIDBODYINERTIA_HPP
23#define KDL_RIGIDBODYINERTIA_HPP
24
25#include "frames.hpp"
26
27#include "rotationalinertia.hpp"
28
29namespace KDL {
30
38 public:
39
44 explicit RigidBodyInertia(double m=0, const Vector& oc=Vector::Zero(), const RotationalInertia& Ic=RotationalInertia::Zero());
45
52
53
55
56 friend RigidBodyInertia operator*(double a,const RigidBodyInertia& I);
58 friend Wrench operator*(const RigidBodyInertia& I,const Twist& t);
59 friend RigidBodyInertia operator*(const Frame& T,const RigidBodyInertia& I);
61
67
71 double getMass() const{
72 return m;
73 };
74
79 {
80 return h;
81 }
82
86 Vector getCOG() const{
87 if(m==0) return Vector::Zero();
88 else return h/m;
89 };
90
95 return I;
96 };
97
98 private:
99 RigidBodyInertia(double m,const Vector& h,const RotationalInertia& I,bool mhi);
100 double m;
103
105
106 };
107
118
123 Wrench operator*(const RigidBodyInertia& I,const Twist& t);
124
134
135
136
137}//namespace
138
139
140#endif
Definition frames.hpp:572
6D Inertia of a rigid body
Definition rigidbodyinertia.hpp:37
friend RigidBodyInertia operator*(double a, const RigidBodyInertia &I)
Scalar product: I_new = double * I_old.
Definition rigidbodyinertia.cpp:42
RotationalInertia getRotationalInertia() const
Get the rotational inertia expressed in the reference frame (not the cog)
Definition rigidbodyinertia.hpp:94
RigidBodyInertia(double m=0, const Vector &oc=Vector::Zero(), const RotationalInertia &Ic=RotationalInertia::Zero())
This constructor creates a cartesian space inertia matrix, the arguments are the mass,...
Definition rigidbodyinertia.cpp:35
friend class ArticulatedBodyInertia
Definition rigidbodyinertia.hpp:104
RigidBodyInertia RefPoint(const Vector &p)
Reference point change with v the vector from the old to the new point expressed in the current refer...
Definition rigidbodyinertia.cpp:83
const Vector & getSpatialMomentum() const
Get the spatial momentum of the rigid body.
Definition rigidbodyinertia.hpp:78
static RigidBodyInertia Zero()
Creates an inertia with zero mass, and zero RotationalInertia.
Definition rigidbodyinertia.hpp:49
~RigidBodyInertia()
Definition rigidbodyinertia.hpp:54
friend RigidBodyInertia operator+(const RigidBodyInertia &Ia, const RigidBodyInertia &Ib)
addition I: I_new = I_old1 + I_old2, make sure that I_old1 and I_old2 are expressed in the same refer...
Definition rigidbodyinertia.cpp:46
Vector getCOG() const
Get the center of gravity of the rigid body.
Definition rigidbodyinertia.hpp:86
Vector h
Definition rigidbodyinertia.hpp:101
double m
Definition rigidbodyinertia.hpp:100
RotationalInertia I
Definition rigidbodyinertia.hpp:102
double getMass() const
Get the mass of the rigid body.
Definition rigidbodyinertia.hpp:71
represents rotations in 3 dimensional space.
Definition frames.hpp:304
Definition rotationalinertia.hpp:34
static RotationalInertia Zero()
Definition rotationalinertia.hpp:39
represents both translational and rotational velocities.
Definition frames.hpp:723
A concrete implementation of a 3 dimensional vector class.
Definition frames.hpp:163
static Vector Zero()
Definition frames.hpp:139
represents both translational and rotational acceleration.
Definition frames.hpp:882
Definition articulatedbodyinertia.cpp:26
ArticulatedBodyInertia operator+(const ArticulatedBodyInertia &Ia, const ArticulatedBodyInertia &Ib)
addition I: I_new = I_old1 + I_old2, make sure that I_old1 and I_old2 are expressed in the same refer...
Definition articulatedbodyinertia.cpp:53
static const bool mhi
Definition rigidbodyinertia.cpp:28
ArticulatedBodyInertia operator*(double a, const ArticulatedBodyInertia &I)
Scalar product: I_new = double * I_old.
Definition articulatedbodyinertia.cpp:49