31 #include "../city/AGCar.h" 72 std::list<AGChild>::const_iterator itC;
74 if (itC->haveASchool()) {
85 std::list<AGAdult>::const_iterator itA;
87 if (itA->isWorking()) {
106 std::list<AGAdult>::iterator it;
134 std::list<AGAdult>::const_iterator itUA;
136 if (! itUA->isWorking()) {
154 std::list<AGAdult>::const_iterator itDriA;
162 if (!itDriA->getWorkPosition().getPosition().getStreet().allows(
SVC_PASSENGER)) {
170 std::list<AGAdult>::iterator itAccA;
176 std::list<AGChild>::iterator itAccC;
201 std::list<AGTrip>::iterator it1, it2;
210 diff1 = it2->getTime() - it1->getRideBackArrTime(this->
timePerKm);
211 diff2 = it1->getTime() - it2->getRideBackArrTime(this->
timePerKm);
213 if (diff1 < 0 || diff2 < 0) {
215 arrTime = it2->getArrTime(this->
timePerKm);
216 it2->addLayOver(*it1);
217 it2->setDepTime(it2->estimateDepTime(arrTime, this->timePerKm));
220 arrTime = it1->getArrTime(this->
timePerKm);
221 it1->addLayOver(*it2);
222 it1->setDepTime(it1->estimateDepTime(arrTime, this->timePerKm));
240 std::list<AGTrip>::iterator itAccT;
241 std::list<AGTrip>::iterator itDriT;
242 std::list<AGAdult>::iterator itA;
245 if (itAccT->getArrTime(this->timePerKm) < itDriT->getArrTime(this->
timePerKm)) {
250 if (!itA->isWorking()) {
252 }
else if (itAccT->getRideBackArrTime(this->timePerKm) < itA->getWorkPosition().getOpening()) {
267 std::list<AGTrip>::iterator itAccT;
268 std::list<AGTrip>::iterator itDriT;
269 std::list<AGAdult>::iterator itA;
279 if (itAccT->getArrTime(this->timePerKm) < itDriT->getArrTime(this->
timePerKm) && !alreadyDone) {
281 if (itAccT->getRideBackArrTime(this->timePerKm) < itDriT->getTime()) {
283 itAccT->setVehicleName(itDriT->getVehicleName());
284 itAccT->addLayOver(itAccT->getArr());
290 arrTime = itDriT->getArrTime(this->
timePerKm);
291 itDriT->addLayOver(*itAccT);
292 itDriT->setDepTime(itDriT->estimateDepTime(arrTime, this->timePerKm));
302 if (!itA->isWorking() && !alreadyDone) {
304 if (nameC.size() != 0) {
306 itAccT->addLayOver(itAccT->getArr());
311 }
else if (itAccT->getRideBackArrTime(this->timePerKm) < itA->getWorkPosition().getOpening() && !alreadyDone) {
313 if (nameC.size() != 0) {
315 itAccT->addLayOver(itAccT->getArr());
336 if (itA->getWorkPosition().getPosition() == itDriT->getArr()) {
337 AGTrip trip(itA->getWorkPosition().getPosition(),
myHousehold->
getPosition(), itDriT->getVehicleName(), itA->getWorkPosition().getClosing());
348 std::string nameCar =
"";
349 std::string nameCarUsed =
"";
352 nameCarUsed =
tempTrip.front().getVehicleName();
357 if (nameCarUsed.size() != 0) {
371 std::list<AGAdult>::const_iterator itUA;
373 if (! itUA->isWorking()) {
int depHour(AGPosition from, AGPosition to, int arrival)
const std::list< AGAdult > & getAdults() const
void makePossibleDriversDrive()
std::list< AGAdult > notNeedingDrivers
std::list< AGTrip > tempAccTrip
const std::list< AGChild > & getChildren() const
const AGStreet & getStreet() const
Provides the street this AGPosition is located on.
std::list< AGAdult > adultNeedingCarAccompaniment
int availableTranspMeans(AGPosition from, AGPosition to)
AGHousehold * myHousehold
std::list< AGAdult > personsDrivingCars
bool checkDriversScheduleMatching()
vehicle is a passenger car (a "normal" car)
bool allows(const SUMOVehicleClass vclass) const
Returns whether the given vehicle class is allowed on this street.
std::list< AGAdult > workingPeoplePossCar
std::list< AGChild > childrenNeedingCarAccompaniment
std::list< AGTrip > tempTrip
int possibleTranspMean(AGPosition destination)
std::list< AGTrip > myPartialActivityTrips
void buildChildrenAccompaniment()
double getPosition() const
Provides the relative position of this AGPosition on the street.
void buildWorkDestinations()
std::string getUnusedCar()
bool checkAndBuildTripConsistancy()
const std::list< AGCar > & getCars() const