guarded_philox_random.h 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /* Copyright 2015 The TensorFlow Authors. All Rights Reserved.
  2. Licensed under the Apache License, Version 2.0 (the "License");
  3. you may not use this file except in compliance with the License.
  4. You may obtain a copy of the License at
  5. http://www.apache.org/licenses/LICENSE-2.0
  6. Unless required by applicable law or agreed to in writing, software
  7. distributed under the License is distributed on an "AS IS" BASIS,
  8. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. See the License for the specific language governing permissions and
  10. limitations under the License.
  11. ==============================================================================*/
  12. #ifndef TENSORFLOW_CORE_UTIL_GUARDED_PHILOX_RANDOM_H_
  13. #define TENSORFLOW_CORE_UTIL_GUARDED_PHILOX_RANDOM_H_
  14. #include "philox_random.h"
  15. //#include "tensorflow/core/platform/mutex.h"
  16. //#include "tensorflow/core/platform/default/mutex.h"
  17. #include "tensorflow/core/platform/macros.h"
  18. #include "tensorflow/core/platform/types.h"
  19. namespace tensorflow {
  20. // A thread safe wrapper around a Philox generator. Example usage:
  21. //
  22. // GuardedRandomPhilox generator;
  23. // generator.Init(context);
  24. //
  25. // // In thread safe code
  26. // const int samples = ...;
  27. // auto local_generator = generator.ReserveSamples128(samples);
  28. // for (int i = 0; i < samples; i++)
  29. // Array<uint32, 4> sample = local_generator();
  30. // // Use sample
  31. // }
  32. //
  33. class GuardedPhiloxRandom {
  34. public:
  35. // Must call Init to finish initialization
  36. GuardedPhiloxRandom() : initialized_(false) {}
  37. // Initialize the generator from attributes "seed" and "seed2".
  38. // If both seeds are unspecified, use random seeds.
  39. // Must be called exactly once.
  40. // Initialize with given seeds.
  41. void Init(int64 seed, int64 seed2);
  42. void Init(random::PhiloxRandom::ResultType counter, random::PhiloxRandom::Key key);
  43. // Reserve a certain number of 128-bit samples.
  44. // This function is thread safe. The returned generator is valid for the
  45. // given number of samples, and can be used without a lock.
  46. random::PhiloxRandom ReserveSamples128(int64 samples);
  47. // Reserve a certain number of 32-bit samples.
  48. random::PhiloxRandom ReserveSamples32(int64 samples) {
  49. return ReserveSamples128((samples + 3) / 4);
  50. }
  51. // Reserve enough random samples in the generator for the given output count.
  52. random::PhiloxRandom ReserveRandomOutputs(int64 output_count, int multiplier) {
  53. int64 conservative_sample_count = output_count * multiplier;
  54. return ReserveSamples128(conservative_sample_count);
  55. }
  56. private:
  57. // mutex mu_;
  58. random::PhiloxRandom generator_; // GUARDED_BY(mu_);
  59. bool initialized_;
  60. TF_DISALLOW_COPY_AND_ASSIGN(GuardedPhiloxRandom);
  61. };
  62. } // namespace tensorflow
  63. #endif // TENSORFLOW_CORE_UTIL_GUARDED_PHILOX_RANDOM_H_