![]() |
Eclipse SUMO - Simulation of Urban MObility
|
Builds trigger objects for microsim. More...
#include <NLTriggerBuilder.h>
Public Member Functions | |
void | buildVaporizer (const SUMOSAXAttributes &attrs) |
Builds a vaporization. More... | |
MSStoppingPlace * | getCurrentStop () |
NLTriggerBuilder () | |
Constructor. More... | |
void | setHandler (NLHandler *handler) |
Sets the parent handler to use for nested parsing. More... | |
virtual | ~NLTriggerBuilder () |
Destructor. More... | |
parsing methods | |
These methods parse the attributes for each of the described trigger and call the according methods to build the trigger | |
void | parseAndBuildLaneSpeedTrigger (MSNet &net, const SUMOSAXAttributes &attrs, const std::string &base) |
Parses his values and builds a lane speed trigger. More... | |
void | parseAndBuildRerouter (MSNet &net, const SUMOSAXAttributes &attrs, const std::string &base) |
Parses his values and builds a rerouter. More... | |
void | parseAndBuildStoppingPlace (MSNet &net, const SUMOSAXAttributes &attrs, const SumoXMLTag element) |
Parses the values and builds a stopping places for busses, trains or container vehicles. More... | |
virtual void | beginParkingArea (MSNet &net, const std::string &id, const std::vector< std::string > &lines, MSLane *lane, double frompos, double topos, unsigned int capacity, double width, double length, double angle, const std::string &name, bool onRoad) |
Begin a parking area. More... | |
void | addLotEntry (double x, double y, double z, double width, double length, double angle) |
Add a lot entry to current parking area. More... | |
void | addAccess (MSNet &net, const SUMOSAXAttributes &attrs) |
Parses the values and adds an access point to the currently parsed stopping place. More... | |
void | parseAndBeginParkingArea (MSNet &net, const SUMOSAXAttributes &attrs) |
Parses his values and builds a parking area. More... | |
void | parseAndAddLotEntry (const SUMOSAXAttributes &attrs) |
Parses his values and adds a lot entry to current parking area. More... | |
virtual void | endParkingArea () |
End a parking area. More... | |
virtual void | endStoppingPlace () |
End a stopping place. More... | |
void | parseAndBuildChargingStation (MSNet &net, const SUMOSAXAttributes &attrs) |
Parses his values and builds a charging station. More... | |
void | parseAndBuildCalibrator (MSNet &net, const SUMOSAXAttributes &attrs, const std::string &base) |
Parses his values and builds a mesoscopic or microscopic calibrator. More... | |
Protected Member Functions | |
building methods | |
Called with parsed values, these methods build the trigger. These methods should be overriden for the gui loader in order to build visualizable versions of the triggers. In most cases, these methods only call the constructor. | |
virtual MSLaneSpeedTrigger * | buildLaneSpeedTrigger (MSNet &net, const std::string &id, const std::vector< MSLane *> &destLanes, const std::string &file) |
Builds a lane speed trigger. More... | |
virtual void | buildStoppingPlace (MSNet &net, std::string id, std::vector< std::string > lines, MSLane *lane, double frompos, double topos, const SumoXMLTag element, std::string string, int personCapacity) |
Builds a stopping place. More... | |
virtual void | buildChargingStation (MSNet &net, const std::string &id, MSLane *lane, double frompos, double topos, const std::string &name, double chargingPower, double efficiency, bool chargeInTransit, double chargeDelay) |
Builds a charging station. More... | |
virtual MSCalibrator * | buildCalibrator (MSNet &net, const std::string &id, MSEdge *edge, MSLane *lane, double pos, const std::string &file, const std::string &outfile, const SUMOTime freq, const MSRouteProbe *probe, const std::string &vTypes) |
builds a microscopic calibrator More... | |
virtual METriggeredCalibrator * | buildMECalibrator (MSNet &net, const std::string &id, const MSEdge *edge, double pos, const std::string &file, const std::string &outfile, const SUMOTime freq, MSRouteProbe *probe, const std::string &vTypes) |
builds a mesoscopic calibrator More... | |
virtual MSTriggeredRerouter * | buildRerouter (MSNet &net, const std::string &id, MSEdgeVector &edges, double prob, const std::string &file, bool off, SUMOTime timeThreshold, const std::string &vTypes) |
builds an rerouter More... | |
helper method for obtaining and checking values | |
std::string | getFileName (const SUMOSAXAttributes &attrs, const std::string &base, const bool allowEmpty=false) |
Helper method to obtain the filename. More... | |
MSLane * | getLane (const SUMOSAXAttributes &attrs, const std::string &tt, const std::string &tid) |
Returns the lane defined by attribute "lane". More... | |
double | getPosition (const SUMOSAXAttributes &attrs, MSLane *lane, const std::string &tt, const std::string &tid, MSEdge *edge=0) |
returns the position on the lane checking it More... | |
Protected Attributes | |
MSStoppingPlace * | myCurrentStop |
The currently parsed stop to add access points to. More... | |
NLHandler * | myHandler |
The parent handler to set for subhandlers. More... | |
MSParkingArea * | myParkingArea |
definition of the currently parsed parking area More... | |
Builds trigger objects for microsim.
The building methods may be overridden, to build guisim-instances of the triggers, for example.
Definition at line 62 of file NLTriggerBuilder.h.
NLTriggerBuilder::NLTriggerBuilder | ( | ) |
Constructor.
Definition at line 60 of file NLTriggerBuilder.cpp.
|
virtual |
Destructor.
Definition at line 64 of file NLTriggerBuilder.cpp.
void NLTriggerBuilder::addAccess | ( | MSNet & | net, |
const SUMOSAXAttributes & | attrs | ||
) |
Parses the values and adds an access point to the currently parsed stopping place.
[in] | net | The network the stop belongs to |
[in] | attrs | SAX-attributes which define the access |
InvalidArgument | If a parameter (lane/position) is not valid |
Definition at line 203 of file NLTriggerBuilder.cpp.
References MSStoppingPlace::addAccess(), MSLane::allowsVehicleClass(), SUMORouteHandler::checkStopPos(), Named::getID(), getLane(), MSLane::getLength(), SUMOSAXAttributes::getOpt(), myCurrentStop, myHandler, SUMO_ATTR_FRIENDLY_POS, SUMO_ATTR_LENGTH, SUMO_ATTR_POSITION, SVC_PEDESTRIAN, toString(), and WRITE_WARNING.
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::addLotEntry | ( | double | x, |
double | y, | ||
double | z, | ||
double | width, | ||
double | length, | ||
double | angle | ||
) |
Add a lot entry to current parking area.
Simply calls the addLotEntry method for current parking area.
[in] | x | X position of the lot center |
[in] | y | Y position of the lot center |
[in] | z | Z position of the lot center |
[in] | width | Width of the lot rectangle |
[in] | length | Length of the lot rectangle |
[in] | angle | Angle of the lot rectangle |
InvalidArgument | If the current parking area is 0 |
Definition at line 465 of file NLTriggerBuilder.cpp.
References MSParkingArea::addLotEntry(), myParkingArea, and MSParkingArea::parkOnRoad().
Referenced by parseAndAddLotEntry().
|
virtual |
Begin a parking area.
Simply calls the MSParkingArea constructor.
[in] | net | The net the parking area belongs to |
[in] | id | The id of the parking area |
[in] | lines | Names of the lines that halt on this parking area |
[in] | lane | The lane the parking area is placed on |
[in] | frompos | Begin position of the parking area on the lane |
[in] | topos | End position of the parking area on the lane |
[in] | capacity | Capacity of the parking area |
[in] | width | Width of the default lot rectangle |
[in] | length | Length of the default lot rectangle |
[in] | angle | Angle of the default lot rectangle |
InvalidArgument | If the parking area can not be added to the net (is duplicate) |
Reimplemented in GUITriggerBuilder.
Definition at line 447 of file NLTriggerBuilder.cpp.
References MSNet::addStoppingPlace(), myParkingArea, and SUMO_TAG_PARKING_AREA.
Referenced by parseAndBeginParkingArea().
|
protectedvirtual |
builds a microscopic calibrator
Simply calls the MSCalibrator constructor.
[in] | net | The net the calibrator belongs to |
[in] | id | The id of the calibrator |
[in] | edge | The edge the calibrator is placed at |
[in] | pos | The position on the edge the calibrator lies at |
[in] | file | The file to read the flows from |
Reimplemented in GUITriggerBuilder.
Definition at line 411 of file NLTriggerBuilder.cpp.
References MSEdge::getLength().
Referenced by parseAndBuildCalibrator().
|
protectedvirtual |
Builds a charging station.
Simply calls the MSChargingStation constructor and adds the result to the network.
[in] | net | The net the charging station belongs to |
[in] | id | The id of the charging station |
[in] | lane | The lane the charging station is placed on |
[in] | frompos | Begin position of the charging station on the lane |
[in] | topos | End position of the charging station on the lane |
[in] | chargingPower | energy charged in every timeStep |
[in] | efficiency | efficiency of the charge |
[in] | chargeInTransit | enable or disable charge in transit |
[in] | chargeDelay | delay in the charge |
InvalidArgument | If the charging station can not be added to the net (is duplicate) |
Reimplemented in GUITriggerBuilder.
Definition at line 500 of file NLTriggerBuilder.cpp.
References MSNet::addStoppingPlace(), myCurrentStop, and SUMO_TAG_CHARGING_STATION.
Referenced by parseAndBuildChargingStation().
|
protectedvirtual |
Builds a lane speed trigger.
Simply calls the MSLaneSpeedTrigger constructor.
[in] | net | The net the lane speed trigger belongs to |
[in] | id | The id of the lane speed trigger |
[in] | destLanes | List of lanes affected by this speed trigger |
[in] | file | Name of the file to read the speeds to set from |
ProcessError | If the XML definition file is errornous |
Reimplemented in GUITriggerBuilder.
Definition at line 390 of file NLTriggerBuilder.cpp.
Referenced by parseAndBuildLaneSpeedTrigger().
|
protectedvirtual |
builds a mesoscopic calibrator
Simply calls the METriggeredCalibrator constructor.
[in] | net | The net the calibrator belongs to |
[in] | id | The id of the calibrator |
[in] | edge | The edge the calibrator is placed at |
[in] | pos | The position on the edge the calibrator lies at |
[in] | file | The file to read the flows from |
Definition at line 398 of file NLTriggerBuilder.cpp.
References MSGlobals::gMesoNet.
Referenced by parseAndBuildCalibrator().
|
protectedvirtual |
builds an rerouter
Simply calls the MSTriggeredRerouter constructor.
[in] | net | The net the rerouter belongs to |
[in] | id | The id of the rerouter |
[in] | edges | The edges the rerouter is placed at |
[in] | prob | The probability the rerouter reoutes vehicles with |
[in] | file | The file to read the reroute definitions from |
Reimplemented in GUITriggerBuilder.
Definition at line 425 of file NLTriggerBuilder.cpp.
Referenced by parseAndBuildRerouter().
|
protectedvirtual |
Builds a stopping place.
Simply calls the MSStoppingPlace constructor.
[in] | net | The net the stop belongs to |
[in] | id | The id of the stop |
[in] | lines | Names of the lines that halt on this bus stop |
[in] | lane | The lane the stop is placed on |
[in] | frompos | Begin position of the stop on the lane |
[in] | topos | End position of the stop on the lane |
[in] | element | which kind of stop is to be built |
InvalidArgument | If the stop can not be added to the net (is duplicate) |
Reimplemented in GUITriggerBuilder.
Definition at line 435 of file NLTriggerBuilder.cpp.
References MSNet::addStoppingPlace(), myCurrentStop, and toString().
Referenced by parseAndBuildStoppingPlace().
void NLTriggerBuilder::buildVaporizer | ( | const SUMOSAXAttributes & | attrs | ) |
Builds a vaporization.
Parses the attributes, reporting errors if the time values are false or the edge is not known. Instatiates events for enabling and disabling the vaporization otherwise.
[in] | attrs | SAX-attributes which define the vaporizer |
Definition at line 73 of file NLTriggerBuilder.cpp.
References MSEventControl::addEvent(), MSEdge::decVaporization(), MSEdge::dictionary(), SUMOSAXAttributes::get(), MSNet::getBeginOfTimestepEvents(), MSNet::getInstance(), OptionsCont::getOptions(), SUMOSAXAttributes::getSUMOTimeReporting(), MSEdge::incVaporization(), string2time(), SUMO_ATTR_BEGIN, SUMO_ATTR_END, SUMO_ATTR_ID, WRITE_ERROR, and WRITE_WARNING.
Referenced by NLHandler::myStartElement().
|
virtual |
End a parking area.
InvalidArgument | If the current parking area is 0 |
Reimplemented in GUITriggerBuilder.
Definition at line 480 of file NLTriggerBuilder.cpp.
References myParkingArea.
Referenced by NLHandler::myEndElement().
|
virtual |
End a stopping place.
InvalidArgument | If the current stopping place is 0 |
Reimplemented in GUITriggerBuilder.
Definition at line 490 of file NLTriggerBuilder.cpp.
References myCurrentStop.
Referenced by NLHandler::myEndElement().
MSStoppingPlace * NLTriggerBuilder::getCurrentStop | ( | ) |
Definition at line 576 of file NLTriggerBuilder.cpp.
References myCurrentStop, and myParkingArea.
Referenced by NLHandler::myStartElement().
|
protected |
Helper method to obtain the filename.
Retrieves "file" from attributes, checks whether it is absolute and extends it by the given base path if not. Returns this information.
[in] | attrs | The attributes to obtain the file name from |
[in] | base | The base path (the path the loaded additional file lies in) |
Definition at line 511 of file NLTriggerBuilder.cpp.
References FileHelpers::getConfigurationRelative(), SUMOSAXAttributes::getOpt(), FileHelpers::isAbsolute(), and SUMO_ATTR_FILE.
Referenced by parseAndBuildCalibrator(), parseAndBuildLaneSpeedTrigger(), and parseAndBuildRerouter().
|
protected |
Returns the lane defined by attribute "lane".
Retrieves the lane id from the given attrs. Tries to retrieve the lane, throws an InvalidArgument if it does not exist.
[in] | attrs | The attributes to obtain the lane id from |
[in] | tt | The trigger type (for user output) |
[in] | tid | The trigger id (for user output) |
InvalidArgument | If the named lane does not exist or a lane is not named |
Definition at line 532 of file NLTriggerBuilder.cpp.
References MSLane::dictionary(), SUMOSAXAttributes::get(), and SUMO_ATTR_LANE.
Referenced by addAccess(), parseAndBeginParkingArea(), parseAndBuildCalibrator(), parseAndBuildChargingStation(), and parseAndBuildStoppingPlace().
|
protected |
returns the position on the lane checking it
This method extracts the position, checks whether it shall be mirrored and checks whether it is within the lane. If not, an error is reported and a InvalidArgument is thrown.
[in] | attrs | The attributes to obtain the position from |
[in] | lane | The lane the position shall be valid for |
[in] | tt | The trigger type (for user output) |
[in] | tid | The trigger id (for user output) |
InvalidArgument | If the position is beyond the lane |
Definition at line 546 of file NLTriggerBuilder.cpp.
References SUMOSAXAttributes::get(), Named::getID(), MSLane::getLength(), MSEdge::getLength(), SUMOSAXAttributes::getOpt(), SUMO_ATTR_FRIENDLY_POS, and SUMO_ATTR_POSITION.
Referenced by parseAndBuildCalibrator().
void NLTriggerBuilder::parseAndAddLotEntry | ( | const SUMOSAXAttributes & | attrs | ) |
Parses his values and adds a lot entry to current parking area.
[in] | attrs | SAX-attributes which define the lot entry |
Definition at line 259 of file NLTriggerBuilder.cpp.
References addLotEntry(), SUMOSAXAttributes::get(), MSParkingArea::getAngle(), MSParkingArea::getLength(), SUMOSAXAttributes::getOpt(), MSParkingArea::getWidth(), myParkingArea, SUMO_ATTR_ANGLE, SUMO_ATTR_LENGTH, SUMO_ATTR_WIDTH, SUMO_ATTR_X, SUMO_ATTR_Y, and SUMO_ATTR_Z.
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::parseAndBeginParkingArea | ( | MSNet & | net, |
const SUMOSAXAttributes & | attrs | ||
) |
Parses his values and builds a parking area.
[in] | net | The network the parking area belongs to |
[in] | attrs | SAX-attributes which define the trigger |
InvalidArgument | If a parameter (lane/position) is not valid |
Definition at line 229 of file NLTriggerBuilder.cpp.
References beginParkingArea(), SUMORouteHandler::checkStopPos(), SUMOSAXAttributes::get(), getLane(), MSLane::getLength(), SUMOSAXAttributes::getOpt(), SUMOSAXAttributes::getOptStringVector(), myHandler, POSITION_EPS, SUMO_ATTR_ANGLE, SUMO_ATTR_ENDPOS, SUMO_ATTR_FRIENDLY_POS, SUMO_ATTR_ID, SUMO_ATTR_LENGTH, SUMO_ATTR_LINES, SUMO_ATTR_NAME, SUMO_ATTR_ONROAD, SUMO_ATTR_ROADSIDE_CAPACITY, SUMO_ATTR_STARTPOS, and SUMO_ATTR_WIDTH.
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::parseAndBuildCalibrator | ( | MSNet & | net, |
const SUMOSAXAttributes & | attrs, | ||
const std::string & | base | ||
) |
Parses his values and builds a mesoscopic or microscopic calibrator.
[in] | net | The network the calibrator belongs to |
[in] | attrs | SAX-attributes which define the trigger |
[in] | base | The base path |
InvalidArgument | If a parameter (edge/position) is not valid |
Definition at line 284 of file NLTriggerBuilder.cpp.
References buildCalibrator(), buildMECalibrator(), DELTA_T, MSEdge::dictionary(), SUMOSAXAttributes::get(), NamedObjectCont< T >::get(), MSNet::getDetectorControl(), MSLane::getEdge(), getFileName(), Named::getID(), getLane(), MSEdge::getLanes(), SUMOSAXAttributes::getOpt(), SUMOSAXAttributes::getOptSUMOTimeReporting(), getPosition(), MSDetectorControl::getTypedDetectors(), MSGlobals::gUseMesoSim, SUMOSAXAttributes::hasAttribute(), myHandler, GenericSAXHandler::registerParent(), SUMO_ATTR_EDGE, SUMO_ATTR_FREQUENCY, SUMO_ATTR_ID, SUMO_ATTR_LANE, SUMO_ATTR_OUTPUT, SUMO_ATTR_ROUTEPROBE, SUMO_ATTR_VTYPES, SUMO_TAG_CALIBRATOR, SUMO_TAG_ROUTEPROBE, and WRITE_WARNING.
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::parseAndBuildChargingStation | ( | MSNet & | net, |
const SUMOSAXAttributes & | attrs | ||
) |
Parses his values and builds a charging station.
[in] | net | The network the charging station belongs to |
[in] | attrs | SAXattributes which define the trigger |
InvalidArgument | If a parameter (lane/position) is not valid |
Definition at line 147 of file NLTriggerBuilder.cpp.
References buildChargingStation(), SUMORouteHandler::checkStopPos(), SUMOSAXAttributes::get(), getLane(), MSLane::getLength(), SUMOSAXAttributes::getOpt(), myHandler, POSITION_EPS, SUMO_ATTR_CHARGEDELAY, SUMO_ATTR_CHARGEINTRANSIT, SUMO_ATTR_CHARGINGPOWER, SUMO_ATTR_EFFICIENCY, SUMO_ATTR_ENDPOS, SUMO_ATTR_FRIENDLY_POS, SUMO_ATTR_ID, SUMO_ATTR_NAME, and SUMO_ATTR_STARTPOS.
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::parseAndBuildLaneSpeedTrigger | ( | MSNet & | net, |
const SUMOSAXAttributes & | attrs, | ||
const std::string & | base | ||
) |
Parses his values and builds a lane speed trigger.
If one of the declaration values is errornous, an InvalidArgument is thrown.
If the XML-file parsed during initialisation is errornous, and the MSLaneSpeedTrigger-constructor throws a ProcessError due to this, this exception is catched and an InvalidArgument with the message given in the ProcessError is thrown.
[in] | net | The network the lane speed trigger belongs to |
[in] | attrs | SAX-attributes which define the trigger |
[in] | base | The base path |
InvalidArgument | If a parameter (lane/position) is not valid or the read definition is errornous |
Definition at line 110 of file NLTriggerBuilder.cpp.
References buildLaneSpeedTrigger(), MSLane::dictionary(), SUMOSAXAttributes::get(), getFileName(), myHandler, GenericSAXHandler::registerParent(), SUMO_ATTR_ID, SUMO_ATTR_LANES, and SUMO_TAG_VSS.
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::parseAndBuildRerouter | ( | MSNet & | net, |
const SUMOSAXAttributes & | attrs, | ||
const std::string & | base | ||
) |
Parses his values and builds a rerouter.
[in] | net | The network the rerouter belongs to |
[in] | attrs | SAX-attributes which define the trigger |
[in] | base | The base path |
InvalidArgument | If a parameter (edge) is not valid |
Definition at line 345 of file NLTriggerBuilder.cpp.
References buildRerouter(), MSEdge::dictionary(), SUMOSAXAttributes::get(), getFileName(), SUMOSAXAttributes::getOpt(), myHandler, GenericSAXHandler::registerParent(), XMLSubSys::runParser(), SUMO_ATTR_EDGES, SUMO_ATTR_HALTING_TIME_THRESHOLD, SUMO_ATTR_ID, SUMO_ATTR_OFF, SUMO_ATTR_PROB, SUMO_ATTR_VTYPES, SUMO_TAG_REROUTER, and TIME2STEPS.
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::parseAndBuildStoppingPlace | ( | MSNet & | net, |
const SUMOSAXAttributes & | attrs, | ||
const SumoXMLTag | element | ||
) |
Parses the values and builds a stopping places for busses, trains or container vehicles.
[in] | net | The network the stop belongs to |
[in] | attrs | SAX-attributes which define the stop |
[in] | element | which kind of stop is to be built |
InvalidArgument | If a parameter (lane/position) is not valid |
Definition at line 175 of file NLTriggerBuilder.cpp.
References buildStoppingPlace(), SUMORouteHandler::checkStopPos(), SUMOSAXAttributes::get(), getLane(), SUMOSAXAttributes::getOpt(), SUMOSAXAttributes::getOptStringVector(), MSStoppingPlace::getPersonsAbreast(), MAX2(), myHandler, POSITION_EPS, SUMO_ATTR_ENDPOS, SUMO_ATTR_FRIENDLY_POS, SUMO_ATTR_ID, SUMO_ATTR_LINES, SUMO_ATTR_NAME, SUMO_ATTR_PERSON_CAPACITY, SUMO_ATTR_STARTPOS, and toString().
Referenced by NLHandler::myStartElement().
void NLTriggerBuilder::setHandler | ( | NLHandler * | handler | ) |
Sets the parent handler to use for nested parsing.
[in] | handler | The netload handler to set |
Definition at line 67 of file NLTriggerBuilder.cpp.
References myHandler.
Referenced by NLBuilder::init(), and GUILoadThread::run().
|
protected |
The currently parsed stop to add access points to.
Definition at line 413 of file NLTriggerBuilder.h.
Referenced by addAccess(), GUITriggerBuilder::buildChargingStation(), buildChargingStation(), GUITriggerBuilder::buildStoppingPlace(), buildStoppingPlace(), GUITriggerBuilder::endStoppingPlace(), endStoppingPlace(), and getCurrentStop().
|
protected |
The parent handler to set for subhandlers.
Definition at line 409 of file NLTriggerBuilder.h.
Referenced by addAccess(), parseAndBeginParkingArea(), parseAndBuildCalibrator(), parseAndBuildChargingStation(), parseAndBuildLaneSpeedTrigger(), parseAndBuildRerouter(), parseAndBuildStoppingPlace(), and setHandler().
|
protected |
definition of the currently parsed parking area
Definition at line 411 of file NLTriggerBuilder.h.
Referenced by addLotEntry(), GUITriggerBuilder::beginParkingArea(), beginParkingArea(), GUITriggerBuilder::endParkingArea(), endParkingArea(), getCurrentStop(), and parseAndAddLotEntry().