/usr/include/kido/dynamics/PlanarJoint.hpp is in libkido-dev 0.1.0+dfsg-2build9.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 | /*
* Copyright (c) 2014-2015, Georgia Tech Research Corporation
* All rights reserved.
*
* Author(s): Jeongseok Lee <jslee02@gmail.com>
*
* Georgia Tech Graphics Lab and Humanoid Robotics Lab
*
* Directed by Prof. C. Karen Liu and Prof. Mike Stilman
* <karenliu@cc.gatech.edu> <mstilman@cc.gatech.edu>
*
* This file is provided under the following "BSD-style" License:
* Redistribution and use in source and binary forms, with or
* without modification, are permitted provided that the following
* conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef KIDO_DYNAMICS_PLANARRJOINT_HPP_
#define KIDO_DYNAMICS_PLANARRJOINT_HPP_
#include <string>
#include "kido/dynamics/MultiDofJoint.hpp"
namespace kido {
namespace dynamics {
/// PlanarJoint represents a 3-dof joint, which has two orthogonal translational
/// axes and one rotational axis.
///
/// First and second coordiantes represent translation along first and second
/// translational axese, respectively. Third coordinate represents rotation
/// along rotational axis.
class PlanarJoint : public MultiDofJoint<3>
{
public:
friend class Skeleton;
/// Plane type
enum PlaneType
{
PT_XY,
PT_YZ,
PT_ZX,
PT_ARBITRARY
};
/// Properties that are unique to PlanarJoints. Note that the mPlaneType
/// member has greater authority than the mTransAxis1 and mTransAxis2 members.
/// When copying properties into a PlanarJoint, it will first defer to
/// mPlaneType. If mPlaneType is PT_ARBITRARY, then and only then will it use
/// mTransAxis1 and mTransAxis2. mRotAxis has no authority; it will always be
/// recomputed from mTransAxis1 and mTransAxis2 when copying it into a
/// PlanarJoint
struct UniqueProperties
{
/// Plane type
PlaneType mPlaneType;
/// First translational axis
Eigen::Vector3d mTransAxis1;
/// Second translational axis
Eigen::Vector3d mTransAxis2;
/// Rotational axis
Eigen::Vector3d mRotAxis;
/// Constructor for pre-defined plane types. Defaults to the XY plane if
/// PT_ARBITRARY is specified.
UniqueProperties(PlaneType _planeType = PT_XY);
/// Constructor for arbitrary plane types. mPlaneType will be set to
/// PT_ARBITRARY
UniqueProperties(const Eigen::Vector3d& _transAxis1,
const Eigen::Vector3d& _transAxis2);
virtual ~UniqueProperties() = default;
/// Set plane type as XY-plane
void setXYPlane();
/// Set plane type as YZ-plane
void setYZPlane();
/// Set plane type as ZX-plane
void setZXPlane();
/// Set plane type as arbitrary plane with two orthogonal translational axes
void setArbitraryPlane(const Eigen::Vector3d& _transAxis1,
const Eigen::Vector3d& _transAxis2);
};
struct Properties : MultiDofJoint<3>::Properties, PlanarJoint::UniqueProperties
{
Properties(const MultiDofJoint<3>::Properties& _multiDofProperties =
MultiDofJoint<3>::Properties(),
const PlanarJoint::UniqueProperties& _planarProperties =
PlanarJoint::UniqueProperties());
virtual ~Properties() = default;
};
PlanarJoint(const PlanarJoint&) = delete;
/// Destructor
virtual ~PlanarJoint();
/// Set the Properties of this PlanarJoint
void setProperties(const Properties& _properties);
/// Set the Properties of this PlanarJoint
void setProperties(const UniqueProperties& _properties);
/// Get the Properties of this PlanarJoint
Properties getPlanarJointProperties() const;
/// Copy the Properties of another PlanarJoint
void copy(const PlanarJoint& _otherJoint);
/// Copy the Properties of another PlanarJoint
void copy(const PlanarJoint* _otherJoint);
/// Same as copy(const PlanarJoint&)
PlanarJoint& operator=(const PlanarJoint& _otherJoint);
// Documentation inherited
virtual const std::string& getType() const override;
/// Get joint type for this class
static const std::string& getStaticType();
// Documentation inherited
virtual bool isCyclic(size_t _index) const override;
/// \brief Set plane type as XY-plane
/// \param[in] _renameDofs If true, the names of dofs in this joint will be
/// renmaed according to the plane type.
void setXYPlane(bool _renameDofs = true);
/// \brief Set plane type as YZ-plane
/// \param[in] _renameDofs If true, the names of dofs in this joint will be
/// renmaed according to the plane type.
void setYZPlane(bool _renameDofs = true);
/// \brief Set plane type as ZX-plane
/// \param[in] _renameDofs If true, the names of dofs in this joint will be
/// renmaed according to the plane type.
void setZXPlane(bool _renameDofs = true);
/// \brief Set plane type as arbitrary plane with two orthogonal translational
/// axes
/// \param[in] _renameDofs If true, the names of dofs in this joint will be
/// renmaed according to the plane type.
void setArbitraryPlane(const Eigen::Vector3d& _transAxis1,
const Eigen::Vector3d& _transAxis2,
bool _renameDofs = true);
/// Return plane type
PlaneType getPlaneType() const;
/// Return rotational axis
const Eigen::Vector3d& getRotationalAxis() const;
/// Return first translational axis
const Eigen::Vector3d& getTranslationalAxis1() const;
/// Return second translational axis
const Eigen::Vector3d& getTranslationalAxis2() const;
// Documentation inherited
Eigen::Matrix<double, 6, 3> getLocalJacobianStatic(
const Eigen::Vector3d& _positions) const override;
protected:
/// Constructor called by Skeleton class
PlanarJoint(const Properties& _properties);
// Documentation inherited
virtual Joint* clone() const override;
using MultiDofJoint::getLocalJacobianStatic;
/// Set the names of this joint's DegreesOfFreedom. Used during construction
/// and when the Plane type is changed.
virtual void updateDegreeOfFreedomNames() override;
// Documentation inherited
virtual void updateLocalTransform() const override;
// Documentation inherited
virtual void updateLocalJacobian(bool =true) const override;
// Documentation inherited
virtual void updateLocalJacobianTimeDeriv() const override;
protected:
/// PlanarJoint Properties
UniqueProperties mPlanarP;
public:
// To get byte-aligned Eigen vectors
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
};
} // namespace dynamics
} // namespace kido
#endif // KIDO_DYNAMICS_PLANARRJOINT_HPP_
|