Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
Distribution_Parameterized.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2024 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
19// A distribution described by parameters such as the mean value and std-dev
20/****************************************************************************/
21#include <config.h>
22
23#include <cassert>
29
31
32
33// ===========================================================================
34// method definitions
35// ===========================================================================
38 Distribution("") {
39 myParameter = {0., 0.};
40 parse(description, true);
41}
42
43
44Distribution_Parameterized::Distribution_Parameterized(const std::string& id, double mean, double deviation) :
45 Distribution(id) {
46 myParameter.push_back(mean);
47 myParameter.push_back(deviation);
48}
49
50
51Distribution_Parameterized::Distribution_Parameterized(const std::string& id, double mean, double deviation, double min, double max) :
52 Distribution(id) {
53 myParameter.push_back(mean);
54 myParameter.push_back(deviation);
55 myParameter.push_back(min);
56 myParameter.push_back(max);
57}
58
59
61
62
63void
64Distribution_Parameterized::parse(const std::string& description, const bool hardFail) {
65 try {
66 const std::string distName = description.substr(0, description.find('('));
67 if (distName == "norm" || distName == "normc") {
68 const std::vector<std::string> params = StringTokenizer(description.substr(distName.size() + 1, description.size() - distName.size() - 2), ',').getVector();
69 myParameter.resize(params.size());
70 std::transform(params.begin(), params.end(), myParameter.begin(), StringUtils::toDouble);
71 setID(distName);
72 } else {
73 myParameter[0] = StringUtils::toDouble(description);
74 }
75 if (myParameter.size() == 1) {
76 myParameter.push_back(0.);
77 }
78 } catch (...) {
79 // set default distribution parameterized
80 myParameter = {0., 0.};
81 if (hardFail) {
82 throw ProcessError(TL("Invalid format of distribution parameterized"));
83 } else {
84 WRITE_ERROR(TL("Invalid format of distribution parameterized"));
85 }
86 }
87}
88
89
90bool
91Distribution_Parameterized::isValidDescription(const std::string& description) {
92 try {
93 Distribution_Parameterized dummy(description);
94 const std::string error = dummy.isValid();
95 if (error == "") {
96 return true;
97 }
98 WRITE_ERROR(error);
99 } catch (...) {
100 WRITE_ERROR(TL("Invalid format of distribution parameterized"));
101 }
102 return false;
103}
104
105
106double
108 if (myParameter[1] <= 0.) {
109 return myParameter[0];
110 }
111 double val = RandHelper::randNorm(myParameter[0], myParameter[1], which);
112 if (myParameter.size() > 2) {
113 const double min = myParameter[2];
114 const double max = getMax();
115 while (val < min || val > max) {
116 val = RandHelper::randNorm(myParameter[0], myParameter[1], which);
117 }
118 }
119 return val;
120}
121
122
123double
125 if (myParameter[1] <= 0.) {
126 return myParameter[0];
127 }
128 return myParameter.size() > 3 ? myParameter[3] : std::numeric_limits<double>::infinity();
129}
130
131
132double
134 if (myParameter[1] <= 0.) {
135 return myParameter[0];
136 }
137 return myParameter.size() > 2 ? myParameter[2] : -std::numeric_limits<double>::infinity();
138}
139
140
141std::vector<double>&
145
146
147const std::vector<double>&
151
152
153std::string
154Distribution_Parameterized::toStr(std::streamsize accuracy) const {
155 if (myParameter[1] < 0) {
156 // only write simple speedFactor
157 return toString(myParameter[0]);
158 } else {
159 return (myParameter[1] == 0.
160 ? myID + "(" + toString(myParameter[0], accuracy) + "," + toString(myParameter[1], accuracy) + ")"
161 : myID + "(" + joinToString(myParameter, ",", accuracy) + ")");
162 }
163}
164
165
166const std::string
168 if (myParameter[1] > 0.) {
169 if (getMin() > getMax()) {
170 return TLF("minimum value % larger than maximum %", getMin(), getMax());
171 }
172 if (getMin() > myParameter[0] + 3 * myParameter[1]) {
173 return TLF("minimum value % too large for distribution with mean % and deviation %", myParameter[2], myParameter[0], myParameter[1]);
174 }
175 if (getMax() < myParameter[0] - 3 * myParameter[1]) {
176 return TLF("maximum value % too small for distribution with mean % and deviation %", myParameter[3], myParameter[0], myParameter[1]);
177 }
178 if (myParameter.size() > 3 && myParameter[3] - myParameter[2] < NUMERICAL_EPS * myParameter[1]) {
179 return TLF("maximum value % and minimum value % too close for distribution with mean % and deviation %", myParameter[3], myParameter[2], myParameter[0], myParameter[1]);
180 }
181 }
182 return "";
183}
184
185
186/****************************************************************************/
#define WRITE_ERROR(msg)
Definition MsgHandler.h:304
#define TL(string)
Definition MsgHandler.h:315
#define TLF(string,...)
Definition MsgHandler.h:317
std::string joinToString(const std::vector< T > &v, const T_BETWEEN &between, std::streamsize accuracy=gPrecision)
Definition ToString.h:283
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:46
double sample(SumoRNG *which=0) const
Draw a sample of the distribution.
void parse(const std::string &description, const bool hardFail)
Overwrite by parsable distribution description.
virtual ~Distribution_Parameterized()
Destructor.
double getMax() const
Returns the maximum value of this distribution.
double getMin() const
Returns the minimum value of this distribution.
Distribution_Parameterized(const std::string &description)
Constructor for any temporary distribution parsed directly from the description.
std::string toStr(std::streamsize accuracy) const
Returns the string representation of this distribution.
static bool isValidDescription(const std::string &description)
validate input description
std::vector< double > & getParameter()
Returns the parameters of this distribution.
const std::string isValid() const
check whether the distribution is valid
std::vector< double > myParameter
The distribution's parameters.
std::string myID
The name of the object.
Definition Named.h:125
virtual void setID(const std::string &newID)
resets the id
Definition Named.h:82
static double randNorm(double mean, double variance, SumoRNG *rng=nullptr)
Access to a random number from a normal distribution.
std::vector< std::string > getVector()
return vector of strings
static double toDouble(const std::string &sData)
converts a string into the double value described by it by calling the char-type converter