Line data Source code
1 : /****************************************************************************/
2 : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 : // Copyright (C) 2010-2024 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 AGStreet.cpp
17 : /// @author Piotr Woznica
18 : /// @author Walter Bamberger
19 : /// @author Daniel Krajzewicz
20 : /// @author Michael Behrisch
21 : /// @date July 2010
22 : ///
23 : // Represents a SUMO edge and contains people and work densities
24 : /****************************************************************************/
25 : #include <config.h>
26 :
27 : #include "AGStreet.h"
28 : #include "router/ROEdge.h"
29 : #include <iostream>
30 :
31 :
32 : // ===========================================================================
33 : // method definitions
34 : // ===========================================================================
35 2660 : AGStreet::AGStreet(const std::string& id, RONode* from, RONode* to, int index, const int priority) :
36 2660 : ROEdge(id, from, to, index, priority), myPopulation(0.), myNumWorkplaces(0.) {
37 2660 : }
38 :
39 :
40 : void
41 0 : AGStreet::print() const {
42 0 : std::cout << "- AGStreet: Name=" << getID() << " Length=" << getLength() << " pop=" << myPopulation << " work=" << myNumWorkplaces << std::endl;
43 0 : }
44 :
45 :
46 : double
47 696 : AGStreet::getPopulation() const {
48 696 : return myPopulation;
49 : }
50 :
51 :
52 : void
53 228 : AGStreet::setPopulation(const double population) {
54 228 : myPopulation = population;
55 228 : }
56 :
57 :
58 : double
59 3866 : AGStreet::getWorkplaceNumber() const {
60 3866 : return myNumWorkplaces;
61 : }
62 :
63 :
64 : void
65 228 : AGStreet::setWorkplaceNumber(const double workPositions) {
66 228 : myNumWorkplaces = workPositions;
67 228 : }
68 :
69 :
70 : bool
71 1114 : AGStreet::allows(const SUMOVehicleClass vclass) const {
72 1114 : return (getPermissions() & vclass) == vclass;
73 : }
74 :
75 :
76 : /****************************************************************************/
|