Gazebo Physics

API Reference

8.0.0
RelativeQuantity.hh
Go to the documentation of this file.
1/*
2 * Copyright (C) 2017 Open Source Robotics Foundation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 *
16*/
17
18#ifndef GZ_PHYSICS_RELATIVEQUANTITY_HH_
19#define GZ_PHYSICS_RELATIVEQUANTITY_HH_
20
21#include <gz/physics/FrameID.hh>
23
24namespace gz
25{
26 namespace physics
27 {
47 template <typename Q, std::size_t Dim, typename CoordinateSpace>
49 {
52 public: template <typename... Args>
53 explicit RelativeQuantity(const FrameID &_parentID, Args&&... _args);
54
56 public: RelativeQuantity(const Q &_rawValue);
57
74 public: Q &RelativeToParent();
75
77 public: const Q &RelativeToParent() const;
78
95 public: const FrameID &ParentFrame() const;
96
99 public: void MoveToNewParentFrame(const FrameID &_newParentFrame);
100
102 public: using Quantity = Q;
103
106 public: using Space = CoordinateSpace;
107
110 public: enum { Dimension = Dim };
111
114 private: FrameID parentFrame;
115
117 private: Q value;
118 };
119
120 template <typename Q, std::size_t Dim, typename CoordinateSpace>
122 std::ostream& stream,
124 {
125 stream << "Parent Frame ID: " << _fq.ParentFrame().ID()
126 << "\nRelative To Parent:\n" << _fq.RelativeToParent();
127
128 return stream;
129 }
130
131 namespace detail
132 {
134 // Forward delcarations of CoordinateSpaces
135 template <typename, std::size_t> struct SESpace;
136 template <typename, std::size_t, typename> struct SOSpace;
137 template <typename, std::size_t> struct EuclideanSpace;
138 template <typename, std::size_t> struct LinearVelocitySpace;
139 template <typename, std::size_t> struct AngularVelocitySpace;
140 template <typename, std::size_t> struct LinearAccelerationSpace;
141 template <typename, std::size_t> struct AngularAccelerationSpace;
142 template <typename, std::size_t> struct VectorSpace;
143 template <typename, std::size_t> struct FrameSpace;
144 template <typename, std::size_t> struct AABBSpace;
145 template <typename, std::size_t> struct WrenchSpace;
146 // TODO(MXG): We can add more spaces to support other types like Moments
147 // of Inertia, Jacobians, Spatial Velocities/Accelerations, Wrench+Point
148 // pairs, and so on.
149 //
150 // Users can also define Spaces for their own types (see the header
151 // gz/physics/detail/FrameSemantics.hpp for example implementations)
152 // and use them seamlessly in the Frame Semantics infrastructure.
153 }
154
156 template <typename Scalar, std::size_t Dim>
158 Pose<Scalar, Dim>, Dim, detail::SESpace<Scalar, Dim>>;
160
161
162 template <typename Scalar, std::size_t Dim>
164 Eigen::Matrix<Scalar, Dim, Dim>, Dim,
165 detail::SOSpace<Scalar, Dim, Eigen::Matrix<Scalar, Dim, Dim>>>;
167
168
169 template <typename Scalar>
170 using RelativeQuaternion = RelativeQuantity<
171 Eigen::Quaternion<Scalar>, 3, detail::SOSpace<Scalar, 3,
172 Eigen::Quaternion<Scalar>>>;
173 // Note: Eigen only supports quaternions for 3 dimensional space, so we do
174 // not have a dimensionality template argument.
175 using RelativeQuaterniond = RelativeQuaternion<double>;
176 using RelativeQuaternionf = RelativeQuaternion<float>;
177
179 template <typename Scalar, std::size_t Dim>
181 LinearVector<Scalar, Dim>, Dim, detail::EuclideanSpace<Scalar, Dim>>;
183
184
185 template <typename Scalar, std::size_t Dim>
187 LinearVector<Scalar, Dim>, Dim, detail::VectorSpace<Scalar, Dim>>;
189
190
191 template <typename Scalar, std::size_t Dim>
194 detail::VectorSpace<Scalar, (Dim*(Dim-1))/2>>;
196
197
198 template <typename Scalar, std::size_t Dim>
200 AlignedBox<Scalar, Dim>, Dim, detail::AABBSpace<Scalar, Dim>>;
202
203
204 template <typename Scalar, std::size_t Dim>
206 FrameData<Scalar, Dim>, Dim, detail::FrameSpace<Scalar, Dim>>;
208
209
210 template <typename Scalar, std::size_t Dim>
212 Wrench<Scalar, Dim>, Dim, detail::WrenchSpace<Scalar, Dim>>;
214 }
215}
216
217#include <gz/physics/detail/RelativeQuantity.hh>
218
219#endif