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 <
RobotAPI/libraries/core/FramedPose.h
>
27
#include <
ArmarXCore/observers/variant/DatafieldRef.h
>
28
29
namespace
armarx
30
{
31
ForceTorqueHelper::ForceTorqueHelper
(
const
ForceTorqueUnitObserverInterfacePrx& forceTorqueObserver,
const
std::string& FTDatefieldName)
32
{
33
forceDf
= DatafieldRefPtr::dynamicCast(forceTorqueObserver->getForceDatafield(FTDatefieldName));
34
torqueDf
= DatafieldRefPtr::dynamicCast(forceTorqueObserver->getTorqueDatafield(FTDatefieldName));
35
setZero
();
36
}
37
38
Eigen::Vector3f
ForceTorqueHelper::getForce
()
39
{
40
return
forceDf
->getDataField()->get<
FramedDirection
>()->
toEigen
() -
initialForce
;
41
}
42
43
FramedDirection
ForceTorqueHelper::getFramedForce
()
44
{
45
const
auto
force =
forceDf
->getDataField()->get<
FramedDirection
>();
46
47
return
FramedDirection
(force->toEigen() -
initialForce
, force->getFrame(), force->agent);
48
}
49
50
Eigen::Vector3f
ForceTorqueHelper::getTorque
()
51
{
52
return
torqueDf
->getDataField()->get<
FramedDirection
>()->
toEigen
() -
initialTorque
;
53
}
54
55
void
ForceTorqueHelper::setZero
()
56
{
57
initialForce
=
forceDf
->getDataField()->get<
FramedDirection
>()->
toEigen
();
58
initialTorque
=
torqueDf
->getDataField()->get<
FramedDirection
>()->
toEigen
();
59
}
60
}
armarx::ForceTorqueHelper::setZero
void setZero()
Definition:
ForceTorqueHelper.cpp:55
armarx::viz::toEigen
Eigen::Matrix4f toEigen(data::GlobalPose const &pose)
Definition:
Interaction.h:46
armarx::ForceTorqueHelper::initialTorque
Eigen::Vector3f initialTorque
Definition:
ForceTorqueHelper.h:57
armarx::ForceTorqueHelper::getForce
Eigen::Vector3f getForce()
Definition:
ForceTorqueHelper.cpp:38
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:31
armarx::ForceTorqueHelper::getFramedForce
FramedDirection getFramedForce()
Definition:
ForceTorqueHelper.cpp:43
armarx::ForceTorqueHelper::getTorque
Eigen::Vector3f getTorque()
Definition:
ForceTorqueHelper.cpp:50
armarx::FramedDirection
FramedDirection is a 3 dimensional direction vector with a reference frame. The reference frame can b...
Definition:
FramedPose.h:83
armarx::VariantType::FramedDirection
const VariantTypeId FramedDirection
Definition:
FramedPose.h:38
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:28
RobotAPI
libraries
RobotStatechartHelpers
ForceTorqueHelper.cpp
Generated on Sat Oct 12 2024 09:14:11 for armarx_documentation by
1.8.17