Develop Biology
The language of life
Random.cpp
Go to the documentation of this file.
1/*
2 * This file is a part of the Biology project by eons LLC.
3 * Biology (aka Develop Biology) is a framework for approaching software
4 * development from a natural sciences perspective.
5 *
6 * Copyright (C) 2021 Séon O'Shannon & eons LLC
7 *
8 * This program is free software: you can redistribute it and/or modify
9 * it under the terms of the GNU Affero General Public License as
10 * published by the Free Software Foundation, either version 3 of the
11 * License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU Affero General Public License for more details.
17 *
18 * You should have received a copy of the GNU Affero General Public License
19 * along with this program. If not, see <https://www.gnu.org/licenses/>.
20 */
21
22#include "bio/common/Random.h"
23
24#if BIO_CPP_VERSION >= 11
25 #include <random>
26#endif
27
28namespace bio {
29
30#if BIO_CPP_VERSION >= 11
31static std::random_device rd;
32static std::mt19937 gen(rd());
33#endif
34
36 float mean,
37 float standardDeviation
38)
39{
40 #if BIO_CPP_VERSION >= 11
41 std::normal_distribution<float> dist
42 {
43 mean,
44 standardDeviation
45 };
46 return dist(gen);
47 #else
48 return 0;
49 #endif
50}
51
53 float min,
54 float max
55)
56{
57 #if BIO_CPP_VERSION >= 11
58 std::uniform_real_distribution<float> dist(
59 min,
60 max
61 );
62 return dist(gen);
63 #else
64 return 0;
65 #endif
66}
67
68} //bio namespace
float NormalFloat(float mean, float standardDeviation)
Definition: Random.cpp:35
float UniformFloat(float min, float max)
Definition: Random.cpp:52
Definition: Cell.h:31