LinearizeAngularTrajectory.h
Go to the documentation of this file.
1
/*
2
* This file is part of ArmarX.
3
*
4
* Copyright (C) 2012-2016, High Performance Humanoid Technologies (H2T),
5
* Karlsruhe Institute of Technology (KIT), all rights reserved.
6
*
7
* ArmarX is free software; you can redistribute it and/or modify
8
* it under the terms of the GNU General Public License version 2 as
9
* published by the Free Software Foundation.
10
*
11
* ArmarX is distributed in the hope that it will be useful, but
12
* WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
15
*
16
* You should have received a copy of the GNU General Public License
17
* along with this program. If not, see <http://www.gnu.org/licenses/>.
18
*
19
* @author ()
20
* @copyright http://www.gnu.org/licenses/gpl-2.0.txt
21
* GNU General Public License
22
*/
23
24
#pragma once
25
26
#include <vector>
27
#include <memory>
28
29
namespace
armarx::math
30
{
31
class
LinearizeAngularTrajectory;
32
using
LinearizedAngularTrajectoryPtr
= std::shared_ptr<LinearizeAngularTrajectory>;
33
34
class
LinearizeAngularTrajectory
35
{
36
public
:
37
LinearizeAngularTrajectory
(
float
initialLinearValue);
38
39
float
update
(
float
angle
);
40
float
getLinearValue
();
41
42
static
std::vector<float>
Linearize
(
const
std::vector<float>&
data
);
43
static
void
LinearizeRef
(std::vector<float>&
data
);
44
static
std::vector<float>
Angularize
(
const
std::vector<float>&
data
,
float
center = 0);
45
static
void
AngularizeRef
(std::vector<float>&
data
,
float
center = 0);
46
47
private
:
48
float
linearValue;
49
};
50
}
armarx::math::LinearizeAngularTrajectory::Angularize
static std::vector< float > Angularize(const std::vector< float > &data, float center=0)
Definition:
LinearizeAngularTrajectory.cpp:74
armarx::math::LinearizeAngularTrajectory::update
float update(float angle)
Definition:
LinearizeAngularTrajectory.cpp:34
armarx::math::LinearizeAngularTrajectory::LinearizeAngularTrajectory
LinearizeAngularTrajectory(float initialLinearValue)
Definition:
LinearizeAngularTrajectory.cpp:29
armarx::math::LinearizedAngularTrajectoryPtr
std::shared_ptr< LinearizeAngularTrajectory > LinearizedAngularTrajectoryPtr
Definition:
LinearizeAngularTrajectory.h:32
data
uint8_t data[1]
Definition:
EtherCATFrame.h:68
armarx::math::LinearizeAngularTrajectory
Definition:
LinearizeAngularTrajectory.h:34
armarx::math::LinearizeAngularTrajectory::LinearizeRef
static void LinearizeRef(std::vector< float > &data)
Definition:
LinearizeAngularTrajectory.cpp:61
armarx::math
Definition:
LinearizeAngularTrajectory.cpp:27
armarx::math::LinearizeAngularTrajectory::getLinearValue
float getLinearValue()
Definition:
LinearizeAngularTrajectory.cpp:40
angle
double angle(const Point &a, const Point &b, const Point &c)
Definition:
point.hpp:100
armarx::math::LinearizeAngularTrajectory::AngularizeRef
static void AngularizeRef(std::vector< float > &data, float center=0)
Definition:
LinearizeAngularTrajectory.cpp:85
armarx::math::LinearizeAngularTrajectory::Linearize
static std::vector< float > Linearize(const std::vector< float > &data)
Definition:
LinearizeAngularTrajectory.cpp:45
RobotAPI
libraries
core
math
LinearizeAngularTrajectory.h
Generated on Sat Oct 12 2024 09:14:10 for armarx_documentation by
1.8.17