SUMO - Simulation of Urban MObility
NIVissimTL.h
Go to the documentation of this file.
1 /****************************************************************************/
8 // -------------------
9 /****************************************************************************/
10 // SUMO, Simulation of Urban MObility; see http://sumo.dlr.de/
11 // Copyright (C) 2001-2015 DLR (http://www.dlr.de/) and contributors
12 /****************************************************************************/
13 //
14 // This file is part of SUMO.
15 // SUMO is free software: you can redistribute it and/or modify
16 // it under the terms of the GNU General Public License as published by
17 // the Free Software Foundation, either version 3 of the License, or
18 // (at your option) any later version.
19 //
20 /****************************************************************************/
21 #ifndef NIVissimTL_h
22 #define NIVissimTL_h
23 
24 
25 // ===========================================================================
26 // included modules
27 // ===========================================================================
28 #ifdef _MSC_VER
29 #include <windows_config.h>
30 #else
31 #include <config.h>
32 #endif
33 
34 
35 #include <map>
36 #include <string>
37 #include <vector>
40 #include <utils/common/SUMOTime.h>
41 
42 
43 // ===========================================================================
44 // class declarations
45 // ===========================================================================
47 class NBLoadedTLDef;
48 class NBEdgeCont;
49 
50 
51 // ===========================================================================
52 // class definitions
53 // ===========================================================================
57 class NIVissimTL {
58 public:
59  NIVissimTL(int id, const std::string& type, const std::string& name,
60  SUMOTime absdur, SUMOTime offset);
61  ~NIVissimTL();
62 // void computeBounding();
63  std::string getType() const;
64  int getID() const;
65 
66 public:
67  static bool dictionary(int id, const std::string& type,
68  const std::string& name, SUMOTime absdur, SUMOTime offset);
69  static bool dictionary(int id, NIVissimTL* o);
70  static NIVissimTL* dictionary(int id);
71 // static std::vector<int> getWithin(const AbstractPoly &poly, SUMOReal offset);
72  static void clearDict();
74  NBEdgeCont& ec);
75 
76 public:
77  class NIVissimTLSignal;
79  typedef std::map<int, NIVissimTLSignal*> SSignalDictType;
80  typedef std::map<int, NIVissimTLSignalGroup*> SGroupDictType;
81  typedef std::map<int, SSignalDictType> SignalDictType;
82  typedef std::map<int, SGroupDictType> GroupDictType;
83 
88  public:
89  NIVissimTLSignal(int id, const std::string& name,
90  const std::vector<int>& groupids, int edgeid, int laneno,
91  SUMOReal position, const std::vector<int>& assignedVehicleTypes);
93  bool isWithin(const PositionVector& poly) const;
94  Position getPosition() const;
95  bool addTo(NBEdgeCont& ec, NBLoadedTLDef* node) const;
96 
97  public:
98  static bool dictionary(int lsaid, int id, NIVissimTLSignal* o);
99  static NIVissimTLSignal* dictionary(int lsaid, int id);
100  static void clearDict();
101  static SSignalDictType getSignalsFor(int tlid);
102 
103  protected:
104  int myID;
105  std::string myName;
106  std::vector<int> myGroupIDs;
107  int myEdgeID;
108  int myLane;
110  std::vector<int> myVehicleTypes;
111  static SignalDictType myDict;
112  };
113 
115  public:
116  NIVissimTLSignalGroup(int id, const std::string& name,
117  bool isGreenBegin, const std::vector<SUMOReal>& times,
118  SUMOTime tredyellow, SUMOTime tyellow);
120  bool addTo(NBLoadedTLDef* node) const;
121  public:
122  static bool dictionary(int lsaid, int id, NIVissimTLSignalGroup* o);
123  static NIVissimTLSignalGroup* dictionary(int lsaid, int id);
124  static void clearDict();
125  static SGroupDictType getGroupsFor(int tlid);
126 
127  private:
128  int myID;
129  std::string myName;
130  std::vector<SUMOReal> myTimes;
133  static GroupDictType myDict;
134  };
135 
136 protected:
137  int myID;
138  std::string myName;
142  std::string myType;
143 private:
144  typedef std::map<int, NIVissimTL*> DictType;
145  static DictType myDict;
146 };
147 
148 
149 #endif
150 
151 /****************************************************************************/
152 
NIVissimTL(int id, const std::string &type, const std::string &name, SUMOTime absdur, SUMOTime offset)
Definition: NIVissimTL.cpp:316
std::string getType() const
Definition: NIVissimTL.cpp:435
std::map< int, NIVissimTL * > DictType
Definition: NIVissimTL.h:144
static SSignalDictType getSignalsFor(int tlid)
Definition: NIVissimTL.cpp:134
A container for traffic light definitions and built programs.
A loaded (complete) traffic light logic.
Definition: NBLoadedTLDef.h:49
SUMOTime myOffset
Definition: NIVissimTL.h:140
NIVissimTLSignal(int id, const std::string &name, const std::vector< int > &groupids, int edgeid, int laneno, SUMOReal position, const std::vector< int > &assignedVehicleTypes)
Definition: NIVissimTL.cpp:65
NIVissimTLSignalGroup * myCurrentGroup
Definition: NIVissimTL.h:141
int getID() const
Definition: NIVissimTL.cpp:441
std::map< int, SSignalDictType > SignalDictType
Definition: NIVissimTL.h:81
static bool dictionary(int lsaid, int id, NIVissimTLSignal *o)
Definition: NIVissimTL.cpp:92
bool addTo(NBLoadedTLDef *node) const
Definition: NIVissimTL.cpp:285
std::map< int, SGroupDictType > GroupDictType
Definition: NIVissimTL.h:82
std::string myName
Definition: NIVissimTL.h:138
std::map< int, NIVissimTLSignal * > SSignalDictType
Definition: NIVissimTL.h:78
SUMOTime myAbsDuration
Definition: NIVissimTL.h:139
static DictType myDict
Definition: NIVissimTL.h:145
A point in 2D or 3D with translation and scaling methods.
Definition: Position.h:46
A list of positions.
static bool dictionary(int id, const std::string &type, const std::string &name, SUMOTime absdur, SUMOTime offset)
Definition: NIVissimTL.cpp:332
static bool dictionary(int lsaid, int id, NIVissimTLSignalGroup *o)
Definition: NIVissimTL.cpp:226
static bool dict_SetSignals(NBTrafficLightLogicCont &tlc, NBEdgeCont &ec)
Definition: NIVissimTL.cpp:377
Storage for edges, including some functionality operating on multiple edges.
Definition: NBEdgeCont.h:66
NIVissimTLSignalGroup(int id, const std::string &name, bool isGreenBegin, const std::vector< SUMOReal > &times, SUMOTime tredyellow, SUMOTime tyellow)
Definition: NIVissimTL.cpp:212
std::map< int, NIVissimTLSignalGroup * > SGroupDictType
Definition: NIVissimTL.h:80
std::vector< int > myGroupIDs
Definition: NIVissimTL.h:106
bool isWithin(const PositionVector &poly) const
Definition: NIVissimTL.cpp:80
static GroupDictType myDict
Definition: NIVissimTL.h:133
static SignalDictType myDict
Definition: NIVissimTL.h:111
std::string myType
Definition: NIVissimTL.h:142
static void clearDict()
Definition: NIVissimTL.cpp:365
int SUMOTime
Definition: SUMOTime.h:43
Position getPosition() const
Definition: NIVissimTL.cpp:86
std::vector< int > myVehicleTypes
Definition: NIVissimTL.h:110
std::vector< SUMOReal > myTimes
Definition: NIVissimTL.h:130
static SGroupDictType getGroupsFor(int tlid)
Definition: NIVissimTL.cpp:275
#define SUMOReal
Definition: config.h:218
bool addTo(NBEdgeCont &ec, NBLoadedTLDef *node) const
Definition: NIVissimTL.cpp:144