Monero
Toggle main menu visibility
Loading...
Searching...
No Matches
src
crypto
duration.h
Go to the documentation of this file.
1
// Copyright (c) 2020-2022, The Monero Project
2
3
//
4
// All rights reserved.
5
//
6
// Redistribution and use in source and binary forms, with or without modification, are
7
// permitted provided that the following conditions are met:
8
//
9
// 1. Redistributions of source code must retain the above copyright notice, this list of
10
// conditions and the following disclaimer.
11
//
12
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
13
// of conditions and the following disclaimer in the documentation and/or other
14
// materials provided with the distribution.
15
//
16
// 3. Neither the name of the copyright holder nor the names of its contributors may be
17
// used to endorse or promote products derived from this software without specific
18
// prior written permission.
19
//
20
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
21
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
22
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
23
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
27
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
28
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
30
#pragma once
31
32
#include <chrono>
33
#include "
crypto/crypto.h
"
34
35
namespace
crypto
36
{
38
template
<
typename
D>
39
struct
random_poisson_duration
40
{
41
using
result_type
= D;
42
using
rep
=
typename
result_type::rep;
43
45
explicit
random_poisson_duration
(
result_type
average)
46
:
dist
(average.count() < 0 ? 0 : average.count())
47
{}
48
50
result_type
operator()
()
51
{
52
crypto::random_device
rand
{};
53
return
result_type
{
dist
(
rand
)};
54
}
55
56
private
:
57
std::poisson_distribution<rep>
dist
;
58
};
59
60
/* A custom duration is used for subsecond precision because of the
61
variance. If 5000 milliseconds is given, 95% of the values fall between
62
4859ms-5141ms in 1ms increments (not enough time variance). Providing 1/4
63
seconds would yield 95% of the values between 3s-7.25s in 1/4s
64
increments. */
65
67
using
random_poisson_seconds
=
random_poisson_duration<std::chrono::seconds>
;
69
using
random_poisson_subseconds
=
70
random_poisson_duration<std::chrono::duration<std::chrono::milliseconds::rep, std::ratio<1, 4>
>>;
71
}
crypto.h
crypto
crypto namespace.
Definition
crypto.cpp:60
crypto::random_poisson_subseconds
random_poisson_duration< std::chrono::duration< std::chrono::milliseconds::rep, std::ratio< 1, 4 > > > random_poisson_subseconds
Generate random duration with 1/4 second precision.
Definition
duration.h:69
crypto::rand
void rand(size_t N, uint8_t *bytes)
Definition
crypto.h:167
crypto::random_poisson_seconds
random_poisson_duration< std::chrono::seconds > random_poisson_seconds
Generate random durations with 1 second precision.
Definition
duration.h:67
crypto::random_device
Definition
crypto.h:185
crypto::random_poisson_duration
Generate poisson distributed values in discrete D time units.
Definition
duration.h:40
crypto::random_poisson_duration< std::chrono::seconds >::dist
std::poisson_distribution< rep > dist
Definition
duration.h:57
crypto::random_poisson_duration::rep
typename result_type::rep rep
Type used to represent duration value.
Definition
duration.h:42
crypto::random_poisson_duration::result_type
D result_type
std::chrono::duration time unit precision
Definition
duration.h:41
crypto::random_poisson_duration::random_poisson_duration
random_poisson_duration(result_type average)
Definition
duration.h:45
crypto::random_poisson_duration::operator()
result_type operator()()
Generate a crypto-secure random duration.
Definition
duration.h:50
Generated on
for Monero by
1.17.0