ConditionCheckChanged.h
Go to the documentation of this file.
1/*
2* This file is part of ArmarX.
3*
4* Copyright (C) 2011-2016, High Performance Humanoid Technologies (H2T), Karlsruhe Institute of Technology (KIT), all rights reserved.
5*
6* ArmarX is free software; you can redistribute it and/or modify
7* it under the terms of the GNU General Public License version 2 as
8* published by the Free Software Foundation.
9*
10* ArmarX is distributed in the hope that it will be useful, but
11* WITHOUT ANY WARRANTY; without even the implied warranty of
12* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13* GNU General Public License for more details.
14*
15* You should have received a copy of the GNU General Public License
16* along with this program. If not, see <http://www.gnu.org/licenses/>.
17*
18* @package ArmarX::Core
19* @author Kai Welke (welke _at_ kit _dot_ edu)
20* @date 2012
21* @copyright http://www.gnu.org/licenses/gpl-2.0.txt
22* GNU General Public License
23*/
24
25#pragma once
26
29
30namespace armarx
31{
32 /**
33 * \ingroup ConditionChecks
34 *
35 * Checks if the relevant data fields have been updated since the installation
36 * of this condition.
37 *
38 * Parameters: None
39 * Supported types: String, Int, Bool, Float, Double
40 */
42 {
43 public:
54
56 clone() override
57 {
58 return new ConditionCheckChanged(*this);
59 }
60
61 bool
62 evaluate(const StringVariantMap& dataFields) override
63 {
64 if (dataFields.size() != 1)
65 {
66 ARMARX_INFO_S << "Size of dataFields: " << dataFields.size();
67 throw InvalidConditionException(
68 "Wrong number of datafields for condition changed ");
69 }
70 const Variant& value = dataFields.begin()->second;
71
72 // on initial check this condition should not return true
73 if (!lastValue)
74 {
75 lastValue = value.clone();
76 return false;
77 }
78 VariantTypeId type = value.getType();
79
80 bool result = false;
81 if (!lastValue->getInitialized() && !value.getInitialized())
82 {
83 return false;
84 }
85
86 if (lastValue->getInitialized() != value.getInitialized())
87 {
88 result = true;
89 }
90
91 else if (type == VariantType::String)
92 {
93 result = value.getString() != lastValue->getString();
94 }
95
96 else if (type == VariantType::Bool)
97 {
98 result = value.getBool() != lastValue->getBool();
99 }
100
101 else if (type == VariantType::Int)
102 {
103 result = value.getInt() != lastValue->getInt();
104 }
105
106 else if (type == VariantType::Long)
107 {
108 result = value.getLong() != lastValue->getLong();
109 }
110
111 else if (type == VariantType::Float)
112 {
113 result = value.getFloat() != lastValue->getFloat();
114 }
115
116 else if (type == VariantType::Double)
117 {
118 result = value.getDouble() != lastValue->getDouble();
119 }
120 lastValue = value.clone();
121
122 return result;
123 }
124
125 private:
126 VariantPtr lastValue;
127 };
128} // namespace armarx
#define ARMARXCORE_IMPORT_EXPORT
ConditionCheck * clone() override
Clones the current check.
bool evaluate(const StringVariantMap &dataFields) override
Evaluate the condition based on the current data field values.
A ConditionCheck implements a check on the sensor data stream of a Sensor-Actor Unit.
static ParameterTypeList createParameterTypeList(int numberTypes,...)
void setNumberParameters(int numberParameters)
Sets the number of paramaters required for this check.
ConditionCheck()
Creates and initializes a ConditionCheck instance.
void addSupportedType(VariantTypeId dataFieldType=0, ParameterTypeList parameterTypes=ParameterTypeList())
Add a supported type for elementary condition check marks pairs of (dataFieldType,...
The Variant class is described here: Variants.
Definition Variant.h:224
#define ARMARX_INFO_S
Definition Logging.h:202
const VariantTypeId String
Definition Variant.h:921
const VariantTypeId Int
Definition Variant.h:917
const VariantTypeId Long
Definition Variant.h:918
const VariantTypeId Bool
Definition Variant.h:916
const VariantTypeId Double
Definition Variant.h:920
const VariantTypeId Float
Definition Variant.h:919
This file offers overloads of toIce() and fromIce() functions for STL container types.
IceInternal::Handle< Variant > VariantPtr
Definition Variant.h:41
Ice::Int VariantTypeId
Definition Variant.h:43
std::map< std::string, Variant > StringVariantMap
Definition Variant.h:748