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-2017 German Aerospace Center (DLR) and others.
4 // activitygen module
5 // Copyright 2010 TUM (Technische Universitaet Muenchen, http://www.tum.de/)
6 /****************************************************************************/
7 //
8 // This program and the accompanying materials
9 // are made available under the terms of the Eclipse Public License v2.0
10 // which accompanies this distribution, and is available at
11 // http://www.eclipse.org/legal/epl-v20.html
12 //
13 /****************************************************************************/
22 // Parent object for all activities. Derived classes generate trips for each
23 // household.
24 /****************************************************************************/
25 #ifndef AGACTIVITY_H
26 #define AGACTIVITY_H
27 
28 
29 // ===========================================================================
30 // included modules
31 // ===========================================================================
32 #ifdef _MSC_VER
33 #include <windows_config.h>
34 #else
35 #include <config.h>
36 #endif
37 
38 #include "AGTrip.h"
39 #include "../city/AGHousehold.h"
40 #include "../city/AGDataAndStatistics.h"
41 
42 
43 // ===========================================================================
44 // class definitions
45 // ===========================================================================
46 class AGActivity {
47 public:
48  AGActivity(AGHousehold* hh, AGDataAndStatistics* das, std::list<AGTrip>* prevTrips, int prio) :
49  myHousehold(hh),
50  myStatData(das),
51  myPreviousTrips(prevTrips),
52  activityPriority(prio),
53  genDone(false),
54  timePerKm(das->speedTimePerKm),
56 
60  bool isGenerated();
61 
66  virtual bool generateTrips() = 0;
67 
76  int possibleTranspMean(AGPosition destination);
77 
88 
92  int timeToDrive(AGPosition from, AGPosition to);
93 
98  int depHour(AGPosition from, AGPosition to, int arrival);
99  int arrHour(AGPosition from, AGPosition to, int departure);
100 
104  int randomTimeBetween(int begin, int end);
105 
106  std::list<AGTrip>& getPartialActivityTrips();
107 
108 protected:
110 
112 
113  std::list<AGTrip>* myPreviousTrips;
114  std::list<AGTrip> myPartialActivityTrips;
116  bool genDone;
117  double timePerKm;
122 
123 };
124 
125 #endif
126 
127 /****************************************************************************/
int depHour(AGPosition from, AGPosition to, int arrival)
Definition: AGActivity.cpp:114
int timeToDrive(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:108
virtual bool generateTrips()=0
Definition: AGActivity.cpp:49
bool isGenerated()
Definition: AGActivity.cpp:44
A location in the 2D plane freely positioned on a street.
Definition: AGPosition.h:62
double carPreference
Definition: AGActivity.h:121
AGDataAndStatistics * myStatData
Definition: AGActivity.h:111
double timePerKm
Definition: AGActivity.h:117
int activityPriority
Definition: AGActivity.h:115
std::list< AGTrip > * myPreviousTrips
Definition: AGActivity.h:113
std::list< AGTrip > & getPartialActivityTrips()
Definition: AGActivity.cpp:138
int availableTranspMeans(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:91
int randomTimeBetween(int begin, int end)
Definition: AGActivity.cpp:126
AGHousehold * myHousehold
Definition: AGActivity.h:109
int arrHour(AGPosition from, AGPosition to, int departure)
Definition: AGActivity.cpp:121
int possibleTranspMean(AGPosition destination)
Definition: AGActivity.cpp:54
std::list< AGTrip > myPartialActivityTrips
Definition: AGActivity.h:114
AGActivity(AGHousehold *hh, AGDataAndStatistics *das, std::list< AGTrip > *prevTrips, int prio)
Definition: AGActivity.h:48
bool genDone
Definition: AGActivity.h:116