Visual Servoing Platform
version 3.2.0
vpRxyzVector.h
1
/****************************************************************************
2
*
3
* ViSP, open source Visual Servoing Platform software.
4
* Copyright (C) 2005 - 2019 by Inria. All rights reserved.
5
*
6
* This software is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; either version 2 of the License, or
9
* (at your option) any later version.
10
* See the file LICENSE.txt at the root directory of this source
11
* distribution for additional information about the GNU GPL.
12
*
13
* For using ViSP with software that can not be combined with the GNU
14
* GPL, please contact Inria about acquiring a ViSP Professional
15
* Edition License.
16
*
17
* See http://visp.inria.fr for more information.
18
*
19
* This software was developed at:
20
* Inria Rennes - Bretagne Atlantique
21
* Campus Universitaire de Beaulieu
22
* 35042 Rennes Cedex
23
* France
24
*
25
* If you have questions regarding the use of this file, please contact
26
* Inria at visp@inria.fr
27
*
28
* This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
29
* WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
30
*
31
* Description:
32
* Rxyz angle parameterization for the rotation.
33
* Rxyz(phi,theta,psi) = Rot(x,phi)Rot(y,theta)Rot(z,psi).
34
*
35
* Authors:
36
* Eric Marchand
37
* Fabien Spindler
38
*
39
*****************************************************************************/
40
41
#ifndef vpRxyzVECTOR_H
42
#define vpRxyzVECTOR_H
43
53
#include <visp3/core/vpRotationMatrix.h>
54
#include <visp3/core/vpRotationVector.h>
55
56
class
vpRotationVector
;
57
class
vpRotationMatrix
;
58
class
vpThetaUVector
;
59
156
class
VISP_EXPORT
vpRxyzVector
:
public
vpRotationVector
157
{
158
public
:
159
vpRxyzVector
();
160
vpRxyzVector
(
const
vpRxyzVector
&rxyz);
161
vpRxyzVector
(
const
double
phi,
const
double
theta,
const
double
psi);
162
163
// initialize a Rxyz vector from a rotation matrix
164
explicit
vpRxyzVector
(
const
vpRotationMatrix
&R);
165
166
// initialize a Rxyz vector from a ThetaU vector
167
explicit
vpRxyzVector
(
const
vpThetaUVector
&tu);
168
explicit
vpRxyzVector
(
const
vpColVector
&rxyz);
169
explicit
vpRxyzVector
(
const
std::vector<double> &rxyz);
170
172
virtual
~
vpRxyzVector
(){};
173
174
// convert a rotation matrix into Rxyz vector
175
vpRxyzVector
buildFrom(
const
vpRotationMatrix
&R);
176
177
// convert a ThetaU vector into a Rxyz vector
178
vpRxyzVector
buildFrom(
const
vpThetaUVector
&tu);
179
vpRxyzVector
buildFrom(
const
vpColVector
&rxyz);
180
vpRxyzVector
buildFrom(
const
std::vector<double> &rxyz);
181
182
void
buildFrom(
const
double
phi,
const
double
theta,
const
double
psi);
183
184
vpRxyzVector
&
operator=
(
const
vpColVector
&rxyz);
185
vpRxyzVector
&
operator=
(
double
x);
186
};
187
188
#endif
vpThetaUVector
Implementation of a rotation vector as axis-angle minimal representation.
Definition:
vpThetaUVector.h:145
vpColVector
Implementation of column vector and the associated operations.
Definition:
vpColVector.h:71
vpRotationVector::operator=
vpRotationVector & operator=(const vpRotationVector &v)
Definition:
vpRotationVector.h:136
vpRotationVector
Implementation of a generic rotation vector.
Definition:
vpRotationVector.h:99
vpRotationMatrix
Implementation of a rotation matrix and operations on such kind of matrices.
Definition:
vpRotationMatrix.h:70
vpRxyzVector
Implementation of a rotation vector as Euler angle minimal representation.
Definition:
vpRxyzVector.h:155
modules
core
include
visp3
core
vpRxyzVector.h
Generated by
1.8.16