Gazebo Math

API Reference

7.5.2
gz/math/Cylinder.hh
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2018 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 #ifndef GZ_MATH_CYLINDER_HH_
18 #define GZ_MATH_CYLINDER_HH_
19 
20 #include <optional>
21 #include "gz/math/MassMatrix3.hh"
22 #include "gz/math/Material.hh"
23 #include "gz/math/Plane.hh"
24 #include "gz/math/Quaternion.hh"
25 
26 namespace gz::math
27 {
28  // Foward declarations
29  class CylinderPrivate;
30 
31  // Inline bracket to help doxygen filtering.
32  inline namespace GZ_MATH_VERSION_NAMESPACE {
33  //
42  template<typename Precision>
43  class Cylinder
44  {
48  public: Cylinder() = default;
49 
55  public: Cylinder(const Precision _length, const Precision _radius,
56  const Quaternion<Precision> &_rotOffset =
58 
65  public: Cylinder(const Precision _length, const Precision _radius,
66  const Material &_mat,
67  const Quaternion<Precision> &_rotOffset =
69 
72  public: Precision Radius() const;
73 
76  public: void SetRadius(const Precision _radius);
77 
80  public: Precision Length() const;
81 
84  public: void SetLength(const Precision _length);
85 
92 
97  public: void SetRotationalOffset(
98  const Quaternion<Precision> &_rotOffset);
99 
102  public: const Material &Mat() const;
103 
106  public: void SetMat(const Material &_mat);
107 
116  public: bool MassMatrix(MassMatrix3d &_massMat) const;
117 
124  public: std::optional< MassMatrix3<Precision> > MassMatrix() const;
125 
128  public: bool operator==(const Cylinder &_cylinder) const;
129 
132  public: Precision Volume() const;
133 
139  public: Precision VolumeBelow(const Plane<Precision> &_plane) const;
140 
148  public: std::optional<Vector3<Precision>>
149  CenterOfVolumeBelow(const Plane<Precision> &_plane) const;
150 
159  public: Precision DensityFromMass(const Precision _mass) const;
160 
173  public: bool SetDensityFromMass(const Precision _mass);
174 
176  private: Precision radius = 0.0;
177 
179  private: Precision length = 0.0;
180 
182  private: Material material;
183 
185  private: Quaternion<Precision> rotOffset =
187  };
188 
192 
196 
200  } // namespace GZ_MATH_VERSION_NAMESPACE
201 } // namespace gz::math
202 #include "gz/math/detail/Cylinder.hh"
203 #endif // GZ_MATH_CYLINDER_HH_