rng.h
Go to the documentation of this file.
1 /*
2  * Software License Agreement (BSD License)
3  *
4  * Copyright (c) 2013-2014, Willow Garage, Inc.
5  * Copyright (c) 2014-2016, Open Source Robotics Foundation
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/or other materials provided
17  * with the distribution.
18  * * Neither the name of Open Source Robotics Foundation nor the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  */
35 
38 #ifndef FCL_MATH_RNG_H
39 #define FCL_MATH_RNG_H
40 
41 #include <cassert>
42 #include <random>
43 #include <iostream>
44 
45 #include "fcl/math/constants.h"
46 #include "fcl/math/detail/seed.h"
47 
48 namespace fcl
49 {
50 
57 template <typename S>
58 class FCL_EXPORT RNG
59 {
60 public:
62  RNG();
63 
65  S uniform01();
66 
69  S uniformReal(S lower_bound, S upper_bound);
70 
73  int uniformInt(int lower_bound, int upper_bound);
74 
76  bool uniformBool();
77 
80  S gaussian01();
81 
84  S gaussian(S mean, S stddev);
85 
93  S halfNormalReal(S r_min, S r_max, S focus = 3.0);
94 
98  int halfNormalInt(int r_min, int r_max, S focus = 3.0);
99 
102  void quaternion(S value[4]);
103 
106  void eulerRPY(S value[3]);
107 
109  void disk(S r_min, S r_max, S& x, S& y);
110 
112  void ball(S r_min, S r_max, S& x, S& y, S& z);
113 
116  static void setSeed(std::uint_fast32_t seed);
117 
121  static std::uint_fast32_t getSeed();
122 
123 private:
124 
125  std::mt19937 generator_;
126  std::uniform_real_distribution<> uniDist_;
127  std::normal_distribution<> normalDist_;
128 
129 };
130 
131 using RNGf = RNG<float>;
133 
134 } // namespace fcl
135 
136 #include "fcl/math/rng-inl.h"
137 
138 #endif
rng-inl.h
fcl::RNG
Random number generation. An instance of this class cannot be used by multiple threads at once (membe...
Definition: rng.h:58
fcl::RNG::normalDist_
std::normal_distribution normalDist_
Definition: rng.h:127
fcl::RNG::uniDist_
std::uniform_real_distribution uniDist_
Definition: rng.h:126
seed.h
constants.h
fcl
Main namespace.
Definition: broadphase_bruteforce-inl.h:45
fcl::RNG::generator_
std::mt19937 generator_
Definition: rng.h:125


fcl
Author(s):
autogenerated on Tue Dec 5 2023 03:40:48