ForceTorqueHelper.cpp
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 Simon Ottenhaus (simon dot ottenhaus at kit dot edu)
20
* @copyright http://www.gnu.org/licenses/gpl-2.0.txt
21
* GNU General Public License
22
*/
23
24
#include "
ForceTorqueHelper.h
"
25
26
#include <
ArmarXCore/observers/variant/DatafieldRef.h
>
27
28
#include <
RobotAPI/libraries/core/FramedPose.h
>
29
30
namespace
armarx
31
{
32
ForceTorqueHelper::ForceTorqueHelper
(
33
const
ForceTorqueUnitObserverInterfacePrx& forceTorqueObserver,
34
const
std::string& FTDatefieldName)
35
{
36
forceDf
=
37
DatafieldRefPtr::dynamicCast(forceTorqueObserver->getForceDatafield(FTDatefieldName));
38
torqueDf
=
39
DatafieldRefPtr::dynamicCast(forceTorqueObserver->getTorqueDatafield(FTDatefieldName));
40
setZero
();
41
}
42
43
Eigen::Vector3f
44
ForceTorqueHelper::getForce
()
45
{
46
return
forceDf
->getDataField()->get<
FramedDirection
>()->
toEigen
() -
initialForce
;
47
}
48
49
FramedDirection
50
ForceTorqueHelper::getFramedForce
()
51
{
52
const
auto
force =
forceDf
->getDataField()->get<
FramedDirection
>();
53
54
return
FramedDirection
(force->toEigen() -
initialForce
, force->getFrame(), force->agent);
55
}
56
57
Eigen::Vector3f
58
ForceTorqueHelper::getTorque
()
59
{
60
return
torqueDf
->getDataField()->get<
FramedDirection
>()->
toEigen
() -
initialTorque
;
61
}
62
63
void
64
ForceTorqueHelper::setZero
()
65
{
66
initialForce
=
forceDf
->getDataField()->get<
FramedDirection
>()->
toEigen
();
67
initialTorque
=
torqueDf
->getDataField()->get<
FramedDirection
>()->
toEigen
();
68
}
69
}
// namespace armarx
armarx::ForceTorqueHelper::setZero
void setZero()
Definition:
ForceTorqueHelper.cpp:64
armarx::viz::toEigen
Eigen::Matrix4f toEigen(data::GlobalPose const &pose)
Definition:
Interaction.h:48
armarx::ForceTorqueHelper::initialTorque
Eigen::Vector3f initialTorque
Definition:
ForceTorqueHelper.h:57
armarx::ForceTorqueHelper::getForce
Eigen::Vector3f getForce()
Definition:
ForceTorqueHelper.cpp:44
ForceTorqueHelper.h
armarx::ForceTorqueHelper::initialForce
Eigen::Vector3f initialForce
Definition:
ForceTorqueHelper.h:56
DatafieldRef.h
FramedPose.h
armarx::ForceTorqueHelper::ForceTorqueHelper
ForceTorqueHelper(const ForceTorqueUnitObserverInterfacePrx &forceTorqueObserver, const std::string &FTDatefieldName)
Definition:
ForceTorqueHelper.cpp:32
armarx::ForceTorqueHelper::getFramedForce
FramedDirection getFramedForce()
Definition:
ForceTorqueHelper.cpp:50
armarx::ForceTorqueHelper::getTorque
Eigen::Vector3f getTorque()
Definition:
ForceTorqueHelper.cpp:58
armarx::FramedDirection
FramedDirection is a 3 dimensional direction vector with a reference frame. The reference frame can b...
Definition:
FramedPose.h:86
armarx::VariantType::FramedDirection
const VariantTypeId FramedDirection
Definition:
FramedPose.h:37
armarx::ForceTorqueHelper::torqueDf
DatafieldRefPtr torqueDf
Definition:
ForceTorqueHelper.h:55
armarx::ForceTorqueHelper::forceDf
DatafieldRefPtr forceDf
Definition:
ForceTorqueHelper.h:54
armarx
This file offers overloads of toIce() and fromIce() functions for STL container types.
Definition:
ArmarXTimeserver.cpp:27
RobotAPI
libraries
RobotStatechartHelpers
ForceTorqueHelper.cpp
Generated on Sat Mar 29 2025 09:17:31 for armarx_documentation by
1.8.17