Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/src/activitygen/city/AGHousehold.h
169678 views
1
/****************************************************************************/
2
// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
// Copyright (C) 2010-2025 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 are made available under the
7
// terms of the Eclipse Public License 2.0 which is available at
8
// https://www.eclipse.org/legal/epl-2.0/
9
// This Source Code may also be made available under the following Secondary
10
// Licenses when the conditions for such availability set forth in the Eclipse
11
// Public License 2.0 are satisfied: GNU General Public License, version 2
12
// or later which is available at
13
// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
14
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
15
/****************************************************************************/
16
/// @file AGHousehold.h
17
/// @author Piotr Woznica
18
/// @author Daniel Krajzewicz
19
/// @author Walter Bamberger
20
/// @author Michael Behrisch
21
/// @date July 2010
22
///
23
// A household contains the people and cars of the city: roughly represents
24
// families with their address, cars, adults and possibly children
25
/****************************************************************************/
26
#pragma once
27
#include <config.h>
28
29
#include <iostream>
30
#include <list>
31
#include "AGPerson.h"
32
#include "AGAdult.h"
33
#include "AGChild.h"
34
#include "AGCar.h"
35
#include "AGStreet.h"
36
#include "AGPosition.h"
37
#include "AGCity.h"
38
39
40
// ===========================================================================
41
// class declarations
42
// ===========================================================================
43
class AGCity;
44
45
46
// ===========================================================================
47
// class definitions
48
// ===========================================================================
49
class AGHousehold {
50
public:
51
AGHousehold(AGPosition pos, AGCity* city, int idHouseholds) :
52
myCity(city),
53
myLocation(pos),
54
myId(idHouseholds) {};
55
AGHousehold(AGStreet* str, AGCity* city, int idHouseholds) :
56
myCity(city),
57
myLocation(*str),
58
myId(idHouseholds) {};
59
/**
60
* function generating the given number of adults (1 or 2) and possibly children
61
*/
62
void generatePeople(int numAdults, int numChilds, bool firstRetired);
63
int getPeopleNbr();
64
int getAdultNbr();
65
const std::list<AGAdult>& getAdults() const;
66
const std::list<AGChild>& getChildren() const;
67
const std::list<AGCar>& getCars() const;
68
/**
69
* function returning true if the household is close to the given stations stations
70
*/
71
bool isCloseFromPubTransport(std::list<AGPosition>* pubTransport);
72
bool isCloseFromPubTransport(std::map<int, AGPosition>* pubTransport);
73
/**
74
* function regenerating the household:
75
* --> work positions and schools are resigned
76
* --> cars and people are deleted
77
* --> number of people are MAINTAINED
78
* --> work positions, schools and cars are reallocated
79
*/
80
void regenerate();
81
/**
82
* associates a school to each children.
83
* return false if not done (not enough place at school in the city...
84
*/
85
bool allocateChildrenSchool();
86
/**
87
* associates a work position to every working adult
88
* is taken in account the unemployment and the number of work positions
89
*/
90
bool allocateAdultsWork();
91
/**
92
* function allocating cars to this household in relation to the given rate for each adult
93
*/
94
void generateCars(double rate);
95
int getCarNbr();
96
/**
97
* generates one (more) car in this household
98
*/
99
void addACar();
100
/**
101
* returns the city pointer in which the household is.
102
*/
103
AGCity* getTheCity();
104
/**
105
* returns if adults are retired or in working age
106
*/
107
bool retiredHouseholders();
108
/**
109
* returns the position of the household and other private entities
110
*/
111
AGPosition getPosition();
112
113
private:
114
AGCity* myCity;
115
AGPosition myLocation;
116
int myId;
117
118
private:
119
std::list<AGAdult> myAdults;
120
std::list<AGChild> myChildren;
121
std::list<AGCar> myCars;
122
};
123
124