37 #include "../city/AGCar.h" 78 std::list<AGChild>::const_iterator itC;
80 if (itC->haveASchool()) {
91 std::list<AGAdult>::const_iterator itA;
93 if (itA->isWorking()) {
112 std::list<AGAdult>::iterator it;
140 std::list<AGAdult>::const_iterator itUA;
142 if (! itUA->isWorking()) {
160 std::list<AGAdult>::const_iterator itDriA;
168 if (!itDriA->getWorkPosition().getPosition().getStreet().allows(
SVC_PASSENGER)) {
176 std::list<AGAdult>::iterator itAccA;
182 std::list<AGChild>::iterator itAccC;
207 std::list<AGTrip>::iterator it1, it2;
216 diff1 = it2->getTime() - it1->getRideBackArrTime(this->
timePerKm);
217 diff2 = it1->getTime() - it2->getRideBackArrTime(this->
timePerKm);
219 if (diff1 < 0 || diff2 < 0) {
221 arrTime = it2->getArrTime(this->
timePerKm);
222 it2->addLayOver(*it1);
223 it2->setDepTime(it2->estimateDepTime(arrTime, this->timePerKm));
226 arrTime = it1->getArrTime(this->
timePerKm);
227 it1->addLayOver(*it2);
228 it1->setDepTime(it1->estimateDepTime(arrTime, this->timePerKm));
246 std::list<AGTrip>::iterator itAccT;
247 std::list<AGTrip>::iterator itDriT;
248 std::list<AGAdult>::iterator itA;
251 if (itAccT->getArrTime(this->timePerKm) < itDriT->getArrTime(this->
timePerKm)) {
256 if (!itA->isWorking()) {
258 }
else if (itAccT->getRideBackArrTime(this->timePerKm) < itA->getWorkPosition().getOpening()) {
273 std::list<AGTrip>::iterator itAccT;
274 std::list<AGTrip>::iterator itDriT;
275 std::list<AGAdult>::iterator itA;
285 if (itAccT->getArrTime(this->timePerKm) < itDriT->getArrTime(this->
timePerKm) && !alreadyDone) {
287 if (itAccT->getRideBackArrTime(this->timePerKm) < itDriT->getTime()) {
289 itAccT->setVehicleName(itDriT->getVehicleName());
290 itAccT->addLayOver(itAccT->getArr());
296 arrTime = itDriT->getArrTime(this->
timePerKm);
297 itDriT->addLayOver(*itAccT);
298 itDriT->setDepTime(itDriT->estimateDepTime(arrTime, this->timePerKm));
308 if (!itA->isWorking() && !alreadyDone) {
310 if (nameC.size() != 0) {
312 itAccT->addLayOver(itAccT->getArr());
317 }
else if (itAccT->getRideBackArrTime(this->timePerKm) < itA->getWorkPosition().getOpening() && !alreadyDone) {
319 if (nameC.size() != 0) {
321 itAccT->addLayOver(itAccT->getArr());
342 if (itA->getWorkPosition().getPosition() == itDriT->getArr()) {
343 AGTrip trip(itA->getWorkPosition().getPosition(),
myHousehold->
getPosition(), itDriT->getVehicleName(), itA->getWorkPosition().getClosing());
354 std::string nameCar =
"";
355 std::string nameCarUsed =
"";
358 nameCarUsed =
tempTrip.front().getVehicleName();
363 if (nameCarUsed.size() != 0) {
377 std::list<AGAdult>::const_iterator itUA;
379 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