78 using rng_type = r123::Philox4x64;
79 using ctr_type = rng_type::ctr_type;
80 using key_type = rng_type::key_type;
82 const ctr_type c{{counter, 0u, 0u, 0u}};
84 auto const id1 =
static_cast<uint32_t
>(key1);
85 auto const id2 =
static_cast<uint32_t
>(key2);
89 return rng_type{}(c, k);
113auto noise_uniform(uint64_t counter, uint32_t seed,
int key1,
int key2 = 0) {
115 auto const integers = philox_4_uint64s<salt>(counter, seed, key1, key2);
117 std::ranges::transform(integers | std::ranges::views::take(N), noise.begin(),
118 [](std::size_t v) { return Utils::uniform(v) - 0.5; });
125 auto const integers = philox_4_uint64s<salt>(counter, seed, key1, key2);
153 auto const integers = philox_4_uint64s<salt>(counter, seed, key1, key2);
154 static const double epsilon = std::numeric_limits<double>::min();
156 constexpr std::size_t M = (N <= 2) ? 2 : 4;
158 std::ranges::transform(integers | std::ranges::views::take(M), u.begin(),
159 [](std::size_t value) {
160 auto u = Utils::uniform(value);
161 return (u < epsilon) ? epsilon : u;
170 auto const modulo = sqrt(-2. * log(u[0]));
171 auto const angle = 2. * std::numbers::pi * u[1];
172 noise[0] = modulo * cos(angle);
174 noise[1] = modulo * sin(angle);
178 auto const modulo = sqrt(-2. * log(u[2]));
179 auto const angle = 2. * std::numbers::pi * u[3];
180 noise[2] = modulo * cos(angle);
182 noise[3] = modulo * sin(angle);