SUMO - Simulation of Urban MObility
AGActivity.h
Go to the documentation of this file.
1 /****************************************************************************/
10 // Parent object for all activities. Derived classes generate trips for each
11 // household.
12 /****************************************************************************/
13 // SUMO, Simulation of Urban MObility; see http://sumo.dlr.de/
14 // Copyright (C) 2010-2016 DLR (http://www.dlr.de/) and contributors
15 // activitygen module
16 // Copyright 2010 TUM (Technische Universitaet Muenchen, http://www.tum.de/)
17 /****************************************************************************/
18 //
19 // This file is part of SUMO.
20 // SUMO is free software: you can redistribute it and/or modify
21 // it under the terms of the GNU General Public License as published by
22 // the Free Software Foundation, either version 3 of the License, or
23 // (at your option) any later version.
24 //
25 /****************************************************************************/
26 #ifndef AGACTIVITY_H
27 #define AGACTIVITY_H
28 
29 
30 // ===========================================================================
31 // included modules
32 // ===========================================================================
33 #ifdef _MSC_VER
34 #include <windows_config.h>
35 #else
36 #include <config.h>
37 #endif
38 
39 #include "AGTrip.h"
40 #include "../city/AGHousehold.h"
41 #include "../city/AGDataAndStatistics.h"
42 
43 
44 // ===========================================================================
45 // class definitions
46 // ===========================================================================
47 class AGActivity {
48 public:
49  AGActivity(AGHousehold* hh, AGDataAndStatistics* das, std::list<AGTrip>* prevTrips, int prio) :
50  myHousehold(hh),
51  myStatData(das),
52  myPreviousTrips(prevTrips),
53  activityPriority(prio),
54  genDone(false),
55  timePerKm(das->speedTimePerKm),
57 
61  bool isGenerated();
62 
67  virtual bool generateTrips() = 0;
68 
77  int possibleTranspMean(AGPosition destination);
78 
89 
93  int timeToDrive(AGPosition from, AGPosition to);
94 
99  int depHour(AGPosition from, AGPosition to, int arrival);
100  int arrHour(AGPosition from, AGPosition to, int departure);
101 
105  int randomTimeBetween(int begin, int end);
106 
107  std::list<AGTrip>& getPartialActivityTrips();
108 
109 protected:
111 
113 
114  std::list<AGTrip>* myPreviousTrips;
115  std::list<AGTrip> myPartialActivityTrips;
117  bool genDone;
123 
124 };
125 
126 #endif
127 
128 /****************************************************************************/
int depHour(AGPosition from, AGPosition to, int arrival)
Definition: AGActivity.cpp:115
int timeToDrive(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:109
virtual bool generateTrips()=0
Definition: AGActivity.cpp:50
bool isGenerated()
Definition: AGActivity.cpp:45
A location in the 2D plane freely positioned on a street.
Definition: AGPosition.h:63
AGDataAndStatistics * myStatData
Definition: AGActivity.h:112
SUMOReal carPreference
Definition: AGActivity.h:122
int activityPriority
Definition: AGActivity.h:116
std::list< AGTrip > * myPreviousTrips
Definition: AGActivity.h:114
std::list< AGTrip > & getPartialActivityTrips()
Definition: AGActivity.cpp:139
int availableTranspMeans(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:92
int randomTimeBetween(int begin, int end)
Definition: AGActivity.cpp:127
AGHousehold * myHousehold
Definition: AGActivity.h:110
int arrHour(AGPosition from, AGPosition to, int departure)
Definition: AGActivity.cpp:122
int possibleTranspMean(AGPosition destination)
Definition: AGActivity.cpp:55
std::list< AGTrip > myPartialActivityTrips
Definition: AGActivity.h:115
#define SUMOReal
Definition: config.h:213
SUMOReal timePerKm
Definition: AGActivity.h:118
AGActivity(AGHousehold *hh, AGDataAndStatistics *das, std::list< AGTrip > *prevTrips, int prio)
Definition: AGActivity.h:49
bool genDone
Definition: AGActivity.h:117