All Classes Namespaces Files Functions Variables Typedefs Friends Macros Pages
Rand.hh
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2012-2014 Open Source Robotics Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16 */
17 #ifndef _IGNITION_RAND_HH_
18 #define _IGNITION_RAND_HH_
19 
20 #include <random>
21 #include <cmath>
22 #include <cstdint>
23 #include <ignition/math/Helpers.hh>
24 
25 namespace ignition
26 {
27  namespace math
28  {
31  typedef std::mt19937 GeneratorType;
34  typedef std::uniform_real_distribution<double> UniformRealDist;
37  typedef std::normal_distribution<double> NormalRealDist;
40  typedef std::uniform_int_distribution<int32_t> UniformIntDist;
41 
45  {
49  public: static void Seed(unsigned int _seed);
50 
54  public: static unsigned int Seed();
55 
59  public: static double DblUniform(double _min = 0, double _max = 1);
60 
64  public: static double DblNormal(double _mean = 0, double _sigma = 1);
65 
69  public: static int32_t IntUniform(int _min, int _max);
70 
74  public: static int32_t IntNormal(int _mean, int _sigma);
75 
77  private: static GeneratorType *randGenerator;
78 
80  private: static uint32_t seed;
81  };
82  }
83 }
84 #endif
std::uniform_int_distribution< int32_t > UniformIntDist
Definition: Rand.hh:40
#define IGNITION_VISIBLE
Use to represent "symbol visible" if supported.
Definition: Helpers.hh:346
Random number generator class.
Definition: Rand.hh:44
std::mt19937 GeneratorType
Definition: Rand.hh:31
std::normal_distribution< double > NormalRealDist
Definition: Rand.hh:37
std::uniform_real_distribution< double > UniformRealDist
Definition: Rand.hh:34