Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 1 | // Copyright (c) 2014 The Chromium OS Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
Gilad Arnold | 48415f1 | 2014-06-27 07:10:58 -0700 | [diff] [blame^] | 5 | #ifndef UPDATE_ENGINE_UPDATE_MANAGER_PRNG_H_ |
| 6 | #define UPDATE_ENGINE_UPDATE_MANAGER_PRNG_H_ |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 7 | |
Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 8 | #include <random> |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 9 | |
Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 10 | #include <base/logging.h> |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 11 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 12 | namespace chromeos_update_manager { |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 13 | |
Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 14 | // A thread-safe, unsecure, 32-bit pseudo-random number generator based on |
| 15 | // std::mt19937. |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 16 | class PRNG { |
| 17 | public: |
Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 18 | // Initializes the generator with the passed |seed| value. |
| 19 | explicit PRNG(uint32_t seed) : gen_(seed) {} |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 20 | |
Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 21 | // Returns a random unsigned 32-bit integer. |
| 22 | uint32_t Rand() { return gen_(); } |
| 23 | |
| 24 | // Returns a random integer uniformly distributed in the range [min, max]. |
| 25 | int RandMinMax(int min, int max) { |
| 26 | DCHECK_LE(min, max); |
| 27 | return std::uniform_int_distribution<>(min, max)(gen_); |
| 28 | } |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 29 | |
| 30 | private: |
Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 31 | // A pseudo-random number generator. |
| 32 | std::mt19937 gen_; |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 33 | |
| 34 | DISALLOW_COPY_AND_ASSIGN(PRNG); |
| 35 | }; |
| 36 | |
Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 37 | } // namespace chromeos_update_manager |
Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 38 | |
Gilad Arnold | 48415f1 | 2014-06-27 07:10:58 -0700 | [diff] [blame^] | 39 | #endif // UPDATE_ENGINE_UPDATE_MANAGER_PRNG_H_ |