Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(80)

Side by Side Diff: webrtc/test/random.h

Issue 1413053002: Change to use local Random object instead of global rand() in the RtcEventLog unit test. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Updated WebRTC unit tests to use the new functions in Random Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #ifndef WEBRTC_TEST_RANDOM_H_ 11 #ifndef WEBRTC_TEST_RANDOM_H_
12 #define WEBRTC_TEST_RANDOM_H_ 12 #define WEBRTC_TEST_RANDOM_H_
13 13
14 #include <limits>
15
14 #include "webrtc/typedefs.h" 16 #include "webrtc/typedefs.h"
15 #include "webrtc/base/constructormagic.h" 17 #include "webrtc/base/constructormagic.h"
16 18
17 namespace webrtc { 19 namespace webrtc {
18 20
19 namespace test { 21 namespace test {
20 22
21 class Random { 23 class Random {
22 public: 24 public:
23 explicit Random(uint32_t seed); 25 explicit Random(uint32_t seed);
24 26
25 // Return pseudo-random number in the interval [0.0, 1.0). 27 // Return pseudo-random number in the interval [0.0, 1.0).
26 float Rand(); 28 float Rand();
27 29
28 // Return pseudo-random number mapped to the interval [low, high]. 30 template <typename T>
29 int Rand(int low, int high); 31 T Rand() {
the sun 2015/10/22 12:30:38 This is very pretty! Why are some functions calle
terelius 2015/10/26 18:18:41 I considered both ideas, but couldn't make up my m
the sun 2015/10/27 09:03:12 Ok, I understand your argument. I think we should
terelius 2015/10/29 12:54:04 But isn't it a bit weird (and error prone) to over
32 static_assert(std::numeric_limits<T>::is_integer &&
33 std::numeric_limits<T>::radix == 2 &&
34 std::numeric_limits<T>::digits <= 32,
35 "Rand is only supported for built-in integer types that are "
36 "32 bits or smaller.");
37 return static_cast<T>(Uniform(std::numeric_limits<uint32_t>::max()));
38 }
39
40 template <bool>
41 bool Rand() {
42 return Uniform(0, 1) == 1;
43 }
44
45 // Uniformly distributed pseudo-random number in the interval [0, t].
46 uint32_t Uniform(uint32_t t);
47
48 // Uniformly distributed pseudo-random number in the interval [low, high].
49 uint32_t Uniform(uint32_t low, uint32_t high);
30 50
31 // Normal Distribution. 51 // Normal Distribution.
32 int Gaussian(int mean, int standard_deviation); 52 int Gaussian(int mean, int standard_deviation);
33 53
34 // Exponential Distribution. 54 // Exponential Distribution.
35 int Exponential(float lambda); 55 int Exponential(float lambda);
36 56
37 // TODO(solenberg): Random from histogram. 57 // TODO(solenberg): Random from histogram.
38 // template<typename T> int Distribution(const std::vector<T> histogram) { 58 // template<typename T> int Distribution(const std::vector<T> histogram) {
39 59
40 private: 60 private:
41 uint32_t a_; 61 uint32_t a_;
42 uint32_t b_; 62 uint32_t b_;
43 63
44 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(Random); 64 RTC_DISALLOW_IMPLICIT_CONSTRUCTORS(Random);
45 }; 65 };
46 } // namespace test 66 } // namespace test
47 } // namespace webrtc 67 } // namespace webrtc
48 68
49 #endif // WEBRTC_TEST_RANDOM_H_ 69 #endif // WEBRTC_TEST_RANDOM_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698