void Person::appendWalkingStage(const std::string& personID, const std::vector<std::string>& edgeIDs, double arrivalPos, double duration, double speed, const std::string& stopID) { MSTransportable* p = getPerson(personID); ConstMSEdgeVector edges; try { MSEdge::parseEdgesList(edgeIDs, edges, "<unknown>"); } catch (ProcessError& e) { throw TraCIException(e.what()); } if (edges.empty()) { throw TraCIException("Empty edge list for walking stage of person '" + personID + "'."); } if (fabs(arrivalPos) > edges.back()->getLength()) { throw TraCIException("Invalid arrivalPos for walking stage of person '" + personID + "'."); } if (arrivalPos < 0) { arrivalPos += edges.back()->getLength(); } if (speed < 0) { speed = p->getVehicleType().getMaxSpeed(); } MSStoppingPlace* bs = nullptr; if (stopID != "") { bs = MSNet::getInstance()->getStoppingPlace(stopID, SUMO_TAG_BUS_STOP); if (bs == nullptr) { throw TraCIException("Invalid stopping place id '" + stopID + "' for person: '" + personID + "'"); } } p->appendStage(new MSPerson::MSPersonStage_Walking(p->getID(), edges, bs, TIME2STEPS(duration), speed, p->getArrivalPos(), arrivalPos, 0)); }
bool MSDevice_Container::notifyLeave(SUMOVehicle& veh, SUMOReal /*lastPos*/, MSMoveReminder::Notification reason) { if (reason >= MSMoveReminder::NOTIFICATION_ARRIVED) { for (std::vector<MSTransportable*>::iterator i = myContainers.begin(); i != myContainers.end(); ++i) { MSTransportable* container = *i; if (&(container->getDestination()) != veh.getEdge()) { WRITE_WARNING("Teleporting container '" + container->getID() + "' from vehicle destination edge '" + veh.getEdge()->getID() + "' to intended destination edge '" + container->getDestination().getID() + "'"); } if (!container->proceed(MSNet::getInstance(), MSNet::getInstance()->getCurrentTimeStep())) { MSNet::getInstance()->getContainerControl().erase(container); }; } } return true; }
void MSPerson::MSPersonStage_Waiting::endEventOutput(const MSTransportable& p, SUMOTime t, OutputDevice& os) const { os.openTag("event").writeAttr("time", time2string(t)).writeAttr("type", "actend " + myActType).writeAttr("agent", p.getID()) .writeAttr("link", getEdge()->getID()).closeTag(); }
void MSPerson::MSPersonStage_Driving::beginEventOutput(const MSTransportable& p, SUMOTime t, OutputDevice& os) const { os.openTag("event").writeAttr("time", time2string(t)).writeAttr("type", "arrival").writeAttr("agent", p.getID()).writeAttr("link", getEdge()->getID()).closeTag(); }
void MSPerson::MSPersonStage_Walking::endEventOutput(const MSTransportable& p, SUMOTime t, OutputDevice& os) const { os.openTag("event").writeAttr("time", time2string(t)).writeAttr("type", "arrival") .writeAttr("agent", p.getID()).writeAttr("link", myRoute.back()->getID()).closeTag(); }
void MSContainer::MSContainerStage_Tranship::endEventOutput(const MSTransportable& c, SUMOTime t, OutputDevice& os) const { os.openTag("event").writeAttr("time", time2string(t)).writeAttr("type", "arrival") .writeAttr("agent", c.getID()).writeAttr("link", myRoute.back()->getID()).closeTag(); }