Gazebo Math
API Reference
7.5.2
insert_drive_file
Tutorials
library_books
Classes
toc
Namespaces
insert_drive_file
Files
launch
Gazebo Website
Index
List
Hierarchy
Members: All
Members: Functions
Members: Variables
Members: Typedefs
Members: Enumerations
Members: Enumerator
List
Members
Functions
Typedefs
Variables
Enumerations
Enumerator
src
gz-math
include
gz
math
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 =
57
Quaternion<Precision>::Identity
);
58
65
public
:
Cylinder
(
const
Precision _length,
const
Precision _radius,
66
const
Material
&_mat,
67
const
Quaternion<Precision>
&_rotOffset =
68
Quaternion<Precision>::Identity
);
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
91
public
:
Quaternion<Precision>
RotationalOffset
()
const
;
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 =
186
Quaternion<Precision>::Identity
;
187
};
188
191
typedef
Cylinder<int>
Cylinderi
;
192
195
typedef
Cylinder<double>
Cylinderd
;
196
199
typedef
Cylinder<float>
Cylinderf
;
200
}
// namespace GZ_MATH_VERSION_NAMESPACE
201
}
// namespace gz::math
202
#include "gz/math/detail/Cylinder.hh"
203
#endif
// GZ_MATH_CYLINDER_HH_