 |
Eclipse SUMO - Simulation of Urban MObility
|
Go to the documentation of this file.
60 const std::string& name,
61 const std::vector<int>& districts,
const std::vector<double>& percentages,
62 int edgeid,
double position,
63 const std::vector<std::pair<int, int> >& assignedVehicles)
64 : myID(id), myName(name), myDistricts(districts),
65 myEdgeID(edgeid), myPosition(position),
66 myAssignedVehicles(assignedVehicles) {
68 std::vector<double>::const_iterator j = percentages.begin();
83 const std::vector<int>& districts,
const std::vector<double>& percentages,
84 int edgeid,
double position,
85 const std::vector<std::pair<int, int> >& assignedVehicles) {
88 edgeid, position, assignedVehicles);
99 DictType::iterator i =
myDict.find(
id);
110 DictType::iterator i =
myDict.find(
id);
120 for (DictType::iterator i =
myDict.begin(); i !=
myDict.end(); i++) {
122 const std::vector<int>& districts = c->
myDistricts;
123 for (std::vector<int>::const_iterator j = districts.begin(); j != districts.end(); j++) {
134 const std::vector<int>& connections = (*k).second;
135 for (std::vector<int>::const_iterator j = connections.begin(); j != connections.end(); j++) {
156 const std::vector<int>& connections = (*k).second;
158 std::string dsid = toString<int>((*k).first);
163 for (std::vector<int>::const_iterator j = connections.begin(); j != connections.end(); j++) {
168 if (connections.size() == 1) {
169 distCenter.
add(10, 10);
173 std::string
id =
"District" + district->
getID();
176 if (!nc.
insert(districtNode)) {
192 const std::vector<int>& connections = (*k).second;
195 dc.
retrieve(toString<int>((*k).first));
197 assert(district != 0 && districtNode != 0);
199 for (std::vector<int>::const_iterator l = connections.begin(); l != connections.end(); l++) {
207 WRITE_WARNING(
"Could not build district '" + toString<int>((*k).first) +
"' - edge '" + toString<int>(c->
myEdgeID) +
"' is missing.");
210 std::string
id =
"ParkingPlace" + toString<int>(*l);
212 if (parkingPlace ==
nullptr) {
214 if (pos < e->getLength() - pos) {
229 id =
"VissimFromParkingplace" + toString<int>((*k).first) +
"-" + toString<int>(c->
myID);
231 new NBEdge(
id, districtNode, parkingPlace,
239 if (!district->
addSource(source, percNormed)) {
246 id =
"VissimToParkingplace" + toString<int>((*k).first) +
"-" + toString<int>(c->
myID);
248 new NBEdge(
id, parkingPlace, districtNode,
249 "Connection", (
double) 100 / (
double) 3.6, 2, -1,
251 if (!ec.
insert(destination)) {
256 if (!district->
addSink(destination, percNormed2)) {
340 for (DictType::iterator i =
myDict.begin(); i !=
myDict.end(); i++) {
341 if ((*i).second->myEdgeID == edgeid) {
351 for (DictType::iterator i =
myDict.begin(); i !=
myDict.end(); i++) {
363 return (
double) 200 / (double) 3.6;
366 std::vector<std::pair<int, int> >::const_iterator i;
376 std::string
id = toString<int>(distNo);
378 if (dist ==
nullptr) {
379 WRITE_WARNING(
"The referenced speed distribution '" +
id +
"' is not known.");
384 double speed = dist->
getMax();
385 if (speed < 0 || speed > 1000) {
double getPosition() const
Returns the position of the connection at the edge.
std::vector< std::pair< int, int > > myAssignedVehicles
The vehicles using this connection.
static void dict_BuildDistrictNodes(NBDistrictCont &dc, NBNodeCont &nc)
Builds the nodes that belong to a district.
static const double UNSPECIFIED_OFFSET
unspecified lane offset
Position getPolygonCenter() const
Returns the arithmetic of all corner points.
NBEdge * retrieve(const std::string &id, bool retrieveExtracted=false) const
Returns the edge that has the given id.
#define WRITE_WARNING(msg)
static bool dictionary(const std::string &type, const std::string &id, Distribution *d)
Adds a distribution of the given type and name to the container.
Storage for edges, including some functionality operating on multiple edges.
A temporary storage for edges imported from Vissim.
double getRealSpeed(int distNo) const
int myID
The id of the connections.
static DictType myDict
District connection dictionary.
const Position & getPosition() const
Returns the position of this district's center.
bool insert(const std::string &id, const Position &position, NBDistrict *district=0)
Inserts a node into the map.
static void dict_BuildDistrictConnections()
static bool dictionary(int id, const std::string &name, const std::vector< int > &districts, const std::vector< double > &percentages, int edgeid, double position, const std::vector< std::pair< int, int > > &assignedVehicles)
Inserts the connection into the dictionary after building it.
static OptionsCont & getOptions()
Retrieves the options.
bool insert(NBEdge *edge, bool ignorePrunning=false)
Adds an edge to the dictionary.
virtual double getMax() const =0
Returns the maximum value of this distribution.
static void dict_BuildDistricts(NBDistrictCont &dc, NBEdgeCont &ec, NBNodeCont &nc)
Builds the districts.
void checkDistrictConnectionExistanceAt(double pos)
static std::map< int, std::vector< int > > myDistrictsConnections
Map from ditricts to connections.
NBDistrict * retrieve(const std::string &id) const
Returns the districts with the given id.
A container for districts.
Container for nodes during the netbuilding process.
The representation of a single edge during network building.
static bool dictionary(int id, const std::string &name, const std::string &type, int noLanes, double zuschlag1, double zuschlag2, double length, const PositionVector &geom, const NIVissimClosedLanesVector &clv)
Adds the described item to the dictionary Builds the edge first.
int myEdgeID
The id of the connected edge.
NBNode * getToNode() const
Returns the destination node of the edge.
void invalidateIncomingConnections()
invalidate incoming connections
static void clearDict()
Clears the dictionary.
std::map< int, NIVissimDistrictConnection * > DictType
Definition of a dictionary of district connections.
NBEdge * retrievePossiblySplit(const std::string &id, bool downstream) const
Tries to retrieve an edge, even if it is splitted.
A point in 2D or 3D with translation and scaling methods.
void invalidateOutgoingConnections()
invalidate outgoing connections
static NIVissimDistrictConnection * dict_findForEdge(int edgeid)
Returns the connection to a district placed at the given node Yep, there onyl should be one,...
static void dict_CheckEdgeEnds()
NIVissimDistrictConnection(int id, const std::string &name, const std::vector< int > &districts, const std::vector< double > &percentages, int edgeid, double position, const std::vector< std::pair< int, int > > &assignedVehicles)
Contructor.
NBNode * retrieve(const std::string &id) const
Returns the node with the given name.
Position geomPosition() const
Returns the position The position yields from the edge geometry and the place the connection is plaed...
double getFloat(const std::string &name) const
Returns the double-value of the named option (only for Option_Float)
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Position getGeomPosition(double pos) const
std::vector< int > myDistricts
The connected districts.
DistrictPercentages myPercentages
A map how many vehicles (key, amount) should leave to a district (key)
bool insert(NBDistrict *const district)
Adds a district to the dictionary.
static const double UNSPECIFIED_WIDTH
unspecified lane width
bool addSink(NBEdge *const sink, double weight)
Adds a sink.
void add(const Position &pos)
Adds the given position to this one.
void setCenter(const Position &pos)
Sets the center coordinates.
Represents a single node (junction) during network building.
double getMeanSpeed() const
double myPosition
The position on the edge.
~NIVissimDistrictConnection()
bool addSource(NBEdge *const source, double weight)
Adds a source.
const std::string & getID() const
Returns the id.
A class representing a single district.
NBNode * getFromNode() const
Returns the origin node of the edge.