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-2018 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 /****************************************************************************/
20 // Parent object for all activities. Derived classes generate trips for each
21 // household.
22 /****************************************************************************/
23 #ifndef AGACTIVITY_H
24 #define AGACTIVITY_H
25 
26 
27 // ===========================================================================
28 // included modules
29 // ===========================================================================
30 #include <config.h>
31 
32 #include "AGTrip.h"
33 #include "../city/AGHousehold.h"
34 #include "../city/AGDataAndStatistics.h"
35 
36 
37 // ===========================================================================
38 // class definitions
39 // ===========================================================================
40 class AGActivity {
41 public:
42  AGActivity(AGHousehold* hh, AGDataAndStatistics* das, std::list<AGTrip>* prevTrips, int prio) :
43  myHousehold(hh),
44  myStatData(das),
45  myPreviousTrips(prevTrips),
46  activityPriority(prio),
47  genDone(false),
48  timePerKm(das->speedTimePerKm),
50 
54  bool isGenerated();
55 
60  virtual bool generateTrips() = 0;
61 
70  int possibleTranspMean(AGPosition destination);
71 
82 
86  int timeToDrive(AGPosition from, AGPosition to);
87 
92  int depHour(AGPosition from, AGPosition to, int arrival);
93  int arrHour(AGPosition from, AGPosition to, int departure);
94 
98  int randomTimeBetween(int begin, int end);
99 
100  std::list<AGTrip>& getPartialActivityTrips();
101 
102 protected:
104 
106 
107  std::list<AGTrip>* myPreviousTrips;
108  std::list<AGTrip> myPartialActivityTrips;
110  bool genDone;
111  double timePerKm;
116 
117 };
118 
119 #endif
120 
121 /****************************************************************************/
int depHour(AGPosition from, AGPosition to, int arrival)
Definition: AGActivity.cpp:108
int timeToDrive(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:102
virtual bool generateTrips()=0
Definition: AGActivity.cpp:43
bool isGenerated()
Definition: AGActivity.cpp:38
A location in the 2D plane freely positioned on a street.
Definition: AGPosition.h:56
double carPreference
Definition: AGActivity.h:115
AGDataAndStatistics * myStatData
Definition: AGActivity.h:105
double timePerKm
Definition: AGActivity.h:111
int activityPriority
Definition: AGActivity.h:109
std::list< AGTrip > * myPreviousTrips
Definition: AGActivity.h:107
std::list< AGTrip > & getPartialActivityTrips()
Definition: AGActivity.cpp:132
int availableTranspMeans(AGPosition from, AGPosition to)
Definition: AGActivity.cpp:85
int randomTimeBetween(int begin, int end)
Definition: AGActivity.cpp:120
AGHousehold * myHousehold
Definition: AGActivity.h:103
int arrHour(AGPosition from, AGPosition to, int departure)
Definition: AGActivity.cpp:115
int possibleTranspMean(AGPosition destination)
Definition: AGActivity.cpp:48
std::list< AGTrip > myPartialActivityTrips
Definition: AGActivity.h:108
AGActivity(AGHousehold *hh, AGDataAndStatistics *das, std::list< AGTrip > *prevTrips, int prio)
Definition: AGActivity.h:42
bool genDone
Definition: AGActivity.h:110