Eclipse SUMO - Simulation of Urban MObility
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
GNEDataSet.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2025 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
18// A abstract class for data sets
19/****************************************************************************/
20
21#include <netedit/GNENet.h>
26
27#include "GNEDataSet.h"
28#include "GNEDataInterval.h"
29
30// ===========================================================================
31// member method definitions
32// ===========================================================================
33
34// ---------------------------------------------------------------------------
35// GNEDataSet::AttributeColors - methods
36// ---------------------------------------------------------------------------
37
40
41
42void
43GNEDataSet::AttributeColors::updateValues(const std::string& attribute, const double value) {
44 // check if exist
45 if (myMinMaxValue.count(attribute) == 0) {
46 myMinMaxValue[attribute] = std::make_pair(value, value);
47 } else {
48 // update min value
49 if (value < myMinMaxValue.at(attribute).first) {
50 myMinMaxValue.at(attribute).first = value;
51 }
52 // update max value
53 if (value > myMinMaxValue.at(attribute).second) {
54 myMinMaxValue.at(attribute).second = value;
55 }
56 }
57}
58
59
60void
62 // iterate over map
63 for (const auto& attributeColor : attributeColors.myMinMaxValue) {
64 if (myMinMaxValue.count(attributeColor.first) == 0) {
65 myMinMaxValue[attributeColor.first] = attributeColor.second;
66 } else {
67 // update min value
68 if (attributeColor.second.first < myMinMaxValue.at(attributeColor.first).first) {
69 myMinMaxValue.at(attributeColor.first).first = attributeColor.second.first;
70 }
71 // update max value
72 if (attributeColor.second.second > myMinMaxValue.at(attributeColor.first).second) {
73 myMinMaxValue.at(attributeColor.first).second = attributeColor.second.second;
74 }
75 }
76 }
77}
78
79
80bool
81GNEDataSet::AttributeColors::exist(const std::string& attribute) const {
82 return (myMinMaxValue.count(attribute) > 0);
83}
84
85
86double
87GNEDataSet::AttributeColors::getMinValue(const std::string& attribute) const {
88 return myMinMaxValue.at(attribute).first;
89}
90
91
92double
93GNEDataSet::AttributeColors::getMaxValue(const std::string& attribute) const {
94 return myMinMaxValue.at(attribute).second;
95}
96
97
98void
100 myMinMaxValue.clear();
101}
102
103// ---------------------------------------------------------------------------
104// GNEDataSet - methods
105// ---------------------------------------------------------------------------
106
107GNEDataSet::GNEDataSet(const std::string& dataSetID, GNENet* net, const std::string& filename) :
108 GNEAttributeCarrier(SUMO_TAG_DATASET, net, filename, false),
109 myDataSetID(dataSetID) {
110}
111
112
114
115
118 return this;
119}
120
121
124 return nullptr;
125}
126
127
128const GUIGlObject*
130 return nullptr;
131}
132
133
134void
136 // first update attribute colors in data interval childrens
137 for (const auto& interval : myDataIntervalChildren) {
138 interval.second->updateAttributeColors();
139 }
140 // continue with data sets containers
143 // iterate over all data interval children
144 for (const auto& interval : myDataIntervalChildren) {
145 myAllAttributeColors.updateAllValues(interval.second->getAllAttributeColors());
146 }
147 // iterate over specificdata interval children
148 for (const auto& interval : myDataIntervalChildren) {
149 for (const auto& specificAttributeColor : interval.second->getSpecificAttributeColors()) {
150 mySpecificAttributeColors[specificAttributeColor.first].updateAllValues(specificAttributeColor.second);
151 }
152 }
153}
154
155
160
161
162const std::map<SumoXMLTag, GNEDataSet::AttributeColors>&
166
167
168void
170 // nothing to update
171}
172
173
176 return Position(0, 0);
177}
178
179
180void
182 // iterate over intervals
183 for (const auto& interval : myDataIntervalChildren) {
184 // open device
186 // write ID
187 device.writeAttr(SUMO_ATTR_ID, getID());
188 // write begin
189 device.writeAttr(SUMO_ATTR_BEGIN, interval.second->getAttribute(SUMO_ATTR_BEGIN));
190 // write end
191 device.writeAttr(SUMO_ATTR_END, interval.second->getAttribute(SUMO_ATTR_END));
192 // iterate over interval generic datas
193 for (const auto& genericData : interval.second->getGenericDataChildren()) {
194 // write generic data
195 genericData->writeGenericData(device);
196 }
197 // close device
198 device.closeTag();
199 }
200}
201
202
203bool
205 return false;
206}
207
208
209bool
211 return false;
212}
213
214
215bool
217 return false;
218}
219
220
221bool
223 return false;
224}
225
226
227bool
229 return false;
230}
231
232
233bool
235 return false;
236}
237
238
239bool
241 return false;
242}
243
244
245bool
247 return false;
248}
249
250
251void
253 // check that dataInterval wasn't previously inserted
254 if (myDataIntervalChildren.count(dataInterval->getAttributeDouble(SUMO_ATTR_BEGIN)) == 0) {
255 // add data interval child
256 myDataIntervalChildren[dataInterval->getAttributeDouble(SUMO_ATTR_BEGIN)] = dataInterval;
257 // add reference in attributeCarriers
258 myNet->getAttributeCarriers()->insertDataInterval(dataInterval, dataInterval);
259 } else {
260 throw ProcessError(TL("DataInterval was already inserted"));
261 }
262}
263
264
265void
267 // check that dataInterval was previously inserted
268 if (myDataIntervalChildren.count(dataInterval->getAttributeDouble(SUMO_ATTR_BEGIN)) == 1) {
269 // remove data interval child
271 // remove it from inspected elements and GNEElementTree
274 // remove reference from attributeCarriers
276 } else {
277 throw ProcessError(TL("DataInterval wasn't previously inserted"));
278 }
279}
280
281
282bool
284 for (const auto& interval : myDataIntervalChildren) {
285 if (interval.second == dataInterval) {
286 return true;
287 }
288 }
289 return false;
290}
291
292void
294 // check that dataInterval was previously inserted
295 if (myDataIntervalChildren.count(oldBegin) == 1) {
296 // get data interval
297 GNEDataInterval* dataInterval = myDataIntervalChildren.at(oldBegin);
298 // insert again using new begin
299 myDataIntervalChildren[dataInterval->getAttributeDouble(SUMO_ATTR_BEGIN)] = dataInterval;
300 } else {
301 throw ProcessError(TL("DataInterval wasn't previously inserted"));
302 }
303}
304
305
306bool
307GNEDataSet::checkNewInterval(const double newBegin, const double newEnd) {
308 return checkNewInterval(myDataIntervalChildren, newBegin, newEnd);
309}
310
311
312bool
313GNEDataSet::checkNewBeginEnd(const GNEDataInterval* dataInterval, const double newBegin, const double newEnd) {
314 // make a copy of myDataIntervalChildren without dataInterval, and check checkNewInterval
315 std::map<const double, GNEDataInterval*> copyOfDataIntervalMap;
316 for (const auto& element : myDataIntervalChildren) {
317 if (element.second != dataInterval) {
318 copyOfDataIntervalMap.insert(element);
319 }
320 }
321 return checkNewInterval(copyOfDataIntervalMap, newBegin, newEnd);
322}
323
324
326GNEDataSet::retrieveInterval(const double begin, const double end) const {
327 if (myDataIntervalChildren.count(begin) == 0) {
328 return nullptr;
329 } else if (myDataIntervalChildren.at(begin)->getAttributeDouble(SUMO_ATTR_END) != end) {
330 return nullptr;
331 } else {
332 return myDataIntervalChildren.at(begin);
333 }
334}
335
336
337const std::map<const double, GNEDataInterval*>&
341
342
343std::string
345 switch (key) {
346 case SUMO_ATTR_ID:
347 return myDataSetID;
348 default:
349 return getCommonAttribute(this, key);
350 }
351}
352
353
354double
356 throw InvalidArgument(getTagStr() + " doesn't have a double attribute of type '" + toString(key) + "'");
357}
358
359
360void
361GNEDataSet::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
362 switch (key) {
363 case SUMO_ATTR_ID:
364 GNEChange_Attribute::changeAttribute(this, key, value, undoList);
365 break;
366 default:
367 setCommonAttribute(key, value, undoList);
368 break;
369 }
370}
371
372
373bool
374GNEDataSet::isValid(SumoXMLAttr key, const std::string& value) {
375 switch (key) {
376 case SUMO_ATTR_ID:
377 if (SUMOXMLDefinitions::isValidNetID(value) && (myNet->getAttributeCarriers()->retrieveDataSet(value, false) == nullptr)) {
378 return true;
379 } else {
380 return false;
381 }
382 default:
383 return isCommonValid(key, value);
384 }
385}
386
387
388std::string
390 return getTagStr();
391}
392
393
394std::string
396 return getTagStr() + ": " + myDataSetID;
397}
398
399
404
405
406void
407GNEDataSet::setAttribute(SumoXMLAttr key, const std::string& value) {
408 switch (key) {
409 case SUMO_ATTR_ID:
410 myDataSetID = value;
411 // update all intervals
412 for (const auto& interval : myDataIntervalChildren) {
413 interval.second->updateGenericDataIDs();
414 }
415 break;
416 default:
417 setCommonAttribute(this, key, value);
418 break;
419 }
420 // mark interval toolbar for update
422}
423
424
425bool
426GNEDataSet::checkNewInterval(const std::map<const double, GNEDataInterval*>& dataIntervalMap, const double newBegin, const double newEnd) {
427 if (dataIntervalMap.empty()) {
428 return true;
429 } else {
430 // declare first and last element
431 const auto itFirstElement = dataIntervalMap.begin();
432 const auto itLastElement = dataIntervalMap.rbegin();
433 if (newBegin > newEnd) {
434 return false;
435 } else if (dataIntervalMap.count(newBegin) == 1) {
436 return false;
437 } else if (newBegin < itFirstElement->first) {
438 return (newEnd <= itFirstElement->first);
439 } else if (newBegin > itLastElement->first) {
440 return (newBegin >= itLastElement->second->getAttributeDouble(SUMO_ATTR_END));
441 } else {
442 // iterate over myDataIntervalChildren
443 for (auto it = itFirstElement; it != dataIntervalMap.end(); it++) {
444 if (newBegin < it->first) {
445 // obtain previous edge
446 auto itPrevious = it;
447 itPrevious--;
448 // check overlapping with end
449 if (itPrevious->second->getAttributeDouble(SUMO_ATTR_END) < newBegin) {
450 return true;
451 }
452 }
453 }
454 }
455 return false;
456 }
457}
458
459/****************************************************************************/
#define TL(string)
Definition MsgHandler.h:301
@ SUMO_TAG_INTERVAL
an aggreagated-output interval
@ SUMO_TAG_DATASET
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
@ SUMO_ATTR_BEGIN
weights: time range begin
@ SUMO_ATTR_END
weights: time range end
@ SUMO_ATTR_ID
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:46
const std::string getID() const
get ID (all Attribute Carriers have one)
std::string getCommonAttribute(const Parameterised *parameterised, SumoXMLAttr key) const
void setCommonAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
const std::string & getTagStr() const
get tag assigned to this object in string format
GNENet * myNet
pointer to net
bool isCommonValid(SumoXMLAttr key, const std::string &value) const
static void changeAttribute(GNEAttributeCarrier *AC, SumoXMLAttr key, const std::string &value, GNEUndoList *undoList, const bool force=false)
change attribute
double getAttributeDouble(SumoXMLAttr key) const
std::map< std::string, std::pair< double, double > > myMinMaxValue
map with the minimum and maximum value
Definition GNEDataSet.h:68
void updateAllValues(const AttributeColors &attributeColors)
update value for all attributes
bool exist(const std::string &attribute) const
check if given attribute exist (needed for non-double attributes)
double getMaxValue(const std::string &attribute) const
get maximum value
AttributeColors()
default constructor
double getMinValue(const std::string &attribute) const
get minimum value
void clear()
clear AttributeColors
void updateValues(const std::string &attribute, const double value)
update value for an specific attribute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform data element changes
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Position getPositionInView() const
Returns element position in view.
GUIGlObject * getGUIGlObject()
get GUIGlObject associated with this AttributeCarrier
void writeDataSet(OutputDevice &device) const
write data set
std::string myDataSetID
dataSet ID
Definition GNEDataSet.h:209
bool dataIntervalChildrenExist(GNEDataInterval *dataInterval) const
check if given data interval exist
std::string getAttribute(SumoXMLAttr key) const
std::map< const double, GNEDataInterval * > myDataIntervalChildren
map with dataIntervals children sorted by begin
Definition GNEDataSet.h:212
void removeDataIntervalChild(GNEDataInterval *dataInterval)
add data interval child
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
GNEDataInterval * retrieveInterval(const double begin, const double end) const
return interval
GNEHierarchicalElement * getHierarchicalElement()
get GNEHierarchicalElement associated with this AttributeCarrier
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
bool checkDrawDeleteContourSmall() const
check if draw delete contour small (pink/white)
bool checkDrawMoveContour() const
check if draw move contour (red)
bool checkDrawOverContour() const
check if draw over contour (orange)
bool checkDrawFromContour() const
check if draw from contour (green)
~GNEDataSet()
Destructor.
const Parameterised::Map & getACParametersMap() const
get parameters map
const GNEDataSet::AttributeColors & getAllAttributeColors() const
all attribute colors
void updateAttributeColors()
update attribute colors deprecated
double getAttributeDouble(SumoXMLAttr key) const
bool checkDrawRelatedContour() const
check if draw related contour (cyan)
std::map< SumoXMLTag, GNEDataSet::AttributeColors > mySpecificAttributeColors
specific attribute colors
Definition GNEDataSet.h:218
bool checkDrawSelectContour() const
check if draw select contour (blue)
bool checkNewBeginEnd(const GNEDataInterval *dataInterval, const double newBegin, const double newEnd)
check if new begin or end for given GNEDataInterval is given
GNEDataSet::AttributeColors myAllAttributeColors
all attribute colors
Definition GNEDataSet.h:215
const std::map< SumoXMLTag, GNEDataSet::AttributeColors > & getSpecificAttributeColors() const
specific attribute colors
bool checkDrawToContour() const
check if draw from contour (magenta)
bool checkDrawDeleteContour() const
check if draw delete contour (pink/white)
const std::map< const double, GNEDataInterval * > & getDataIntervalChildren() const
get data interval children
bool checkNewInterval(const double newBegin, const double newEnd)
check if a new GNEDataInterval with the given begin and end can be inserted in current GNEDataSet
void updateGeometry()
update pre-computed geometry information
void addDataIntervalChild(GNEDataInterval *dataInterval)
add data interval child
GNEDataSet(const std::string &dataSetID, GNENet *net, const std::string &filename)
Constructor.
void updateDataIntervalBegin(const double oldBegin)
update data interval begin
void removeCurrentEditedAttributeCarrier(const GNEAttributeCarrier *HE)
if given AttributeCarrier is the same of myHE, set it as nullptr
GNEElementTree * getHierarchicalElementTree() const
get GNEElementTree modul
void insertDataInterval(const GNEAttributeCarrier *AC, GNEDataInterval *dataInterval)
insert data interval in container
GNEDataSet * retrieveDataSet(const std::string &id, bool hardFail=true) const
Returns the named data set.
void deleteDataInterval(GNEDataInterval *dataInterval)
delete data interval of container
A NBNetBuilder extended by visualisation and editing capabilities.
Definition GNENet.h:42
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
Definition GNENet.cpp:146
GNEViewNet * getViewNet() const
get view net
Definition GNENet.cpp:2184
void uninspectAC(GNEAttributeCarrier *AC)
uninspect AC
GNEViewNetHelper::InspectedElements & getInspectedElements()
get inspected elements
GNEViewNetHelper::IntervalBar & getIntervalBar()
get interval bar
GNEViewParent * getViewParent() const
get the net object
GNEInspectorFrame * getInspectorFrame() const
get frame for inspect elements
Static storage of an output device and its base (abstract) implementation.
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
bool closeTag(const std::string &comment="")
Closes the most recently opened tag and optionally adds a comment.
std::map< std::string, std::string > Map
parameters map
const Parameterised::Map & getParametersMap() const
Returns the inner key/value map.
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
static bool isValidNetID(const std::string &value)
whether the given string is a valid id for a network element