Eclipse SUMO - Simulation of Urban MObility
AGActivity.h
Go to the documentation of this file.
1 /****************************************************************************/
2 // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.org/sumo
3 // Copyright (C) 2010-2019 German Aerospace Center (DLR) and others.
4 // activitygen module
5 // Copyright 2010 TUM (Technische Universitaet Muenchen, http://www.tum.de/)
6 // This program and the accompanying materials
7 // are made available under the terms of the Eclipse Public License v2.0
8 // which accompanies this distribution, and is available at
9 // http://www.eclipse.org/legal/epl-v20.html
10 // SPDX-License-Identifier: EPL-2.0
11 /****************************************************************************/
19 // Parent object for all activities. Derived classes generate trips for each
20 // household.
21 /****************************************************************************/
22 #ifndef AGACTIVITY_H
23 #define AGACTIVITY_H
24 
25 
26 // ===========================================================================
27 // included modules
28 // ===========================================================================
29 #include <config.h>
30 
31 #include "AGTrip.h"
33 
34 
35 // ===========================================================================
36 // class declarations
37 // ===========================================================================
38 class AGHousehold;
39 
40 
41 // ===========================================================================
42 // class definitions
43 // ===========================================================================
44 class AGActivity {
45 public:
46  AGActivity(AGHousehold* hh, AGDataAndStatistics* das, std::list<AGTrip>* prevTrips, int prio) :
47  myHousehold(hh),
48  myStatData(das),
49  myPreviousTrips(prevTrips),
50  activityPriority(prio),
51  genDone(false),
52  timePerKm(das->speedTimePerKm),
54 
58  bool isGenerated();
59 
64  virtual bool generateTrips() = 0;
65 
74  int possibleTranspMean(AGPosition destination);
75 
86 
90  int timeToDrive(AGPosition from, AGPosition to);
91 
96  int depHour(AGPosition from, AGPosition to, int arrival);
97  int arrHour(AGPosition from, AGPosition to, int departure);
98 
102  int randomTimeBetween(int begin, int end);
103 
104  std::list<AGTrip>& getPartialActivityTrips();
105 
106 protected:
108 
110 
111  std::list<AGTrip>* myPreviousTrips;
112  std::list<AGTrip> myPartialActivityTrips;
114  bool genDone;
115  double timePerKm;
120 
121 };
122 
123 #endif
124 
125 /****************************************************************************/
AGActivity::isGenerated
bool isGenerated()
Definition: AGActivity.cpp:38
AGHousehold
Definition: AGHousehold.h:51
AGActivity::myPreviousTrips
std::list< AGTrip > * myPreviousTrips
Definition: AGActivity.h:111
AGActivity::arrHour
int arrHour(AGPosition from, AGPosition to, int departure)
Definition: AGActivity.cpp:119
AGActivity::possibleTranspMean
int possibleTranspMean(AGPosition destination)
Definition: AGActivity.cpp:49
AGActivity::myHousehold
AGHousehold * myHousehold
Definition: AGActivity.h:107
AGDataAndStatistics
Definition: AGDataAndStatistics.h:40
AGActivity::AGActivity
AGActivity(AGHousehold *hh, AGDataAndStatistics *das, std::list< AGTrip > *prevTrips, int prio)
Definition: AGActivity.h:46
AGActivity::carPreference
double carPreference
Definition: AGActivity.h:119
AGActivity::availableTranspMeans
int availableTranspMeans(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:86
AGActivity::timeToDrive
int timeToDrive(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:104
AGActivity
Definition: AGActivity.h:44
AGActivity::randomTimeBetween
int randomTimeBetween(int begin, int end)
Definition: AGActivity.cpp:125
AGPosition
A location in the 2D plane freely positioned on a street.
Definition: AGPosition.h:55
AGActivity::activityPriority
int activityPriority
Definition: AGActivity.h:113
AGActivity::generateTrips
virtual bool generateTrips()=0
Definition: AGActivity.cpp:44
config.h
AGActivity::depHour
int depHour(AGPosition from, AGPosition to, int arrival)
Definition: AGActivity.cpp:111
AGActivity::myStatData
AGDataAndStatistics * myStatData
Definition: AGActivity.h:109
AGTrip.h
AGActivity::myPartialActivityTrips
std::list< AGTrip > myPartialActivityTrips
Definition: AGActivity.h:112
AGActivity::timePerKm
double timePerKm
Definition: AGActivity.h:115
AGActivity::getPartialActivityTrips
std::list< AGTrip > & getPartialActivityTrips()
Definition: AGActivity.cpp:138
AGDataAndStatistics.h
AGActivity::genDone
bool genDone
Definition: AGActivity.h:114