29
Numerics library
[numerics]
29.5
Random number generation
[rand]
29.5.9
Random number distribution class templates
[rand.dist]
29.5.9.3
Bernoulli distributions
[rand.dist.bern]
29.5.9.3.3
Class template
geometric_
distribution
[rand.dist.bern.geo]
1
#
A
geometric_
distribution
random number distribution produces integer values
i
≥ 0
distributed according to the discrete probability function in Formula
29.6
.
P
(
i
|
p
)
=
p
⋅
(
1
−
p
)
i
(29.6)
🔗
namespace
std
{
template
<
class
IntType
=
int
>
class
geometric_distribution
{
public
:
// types
using
result_type
=
IntType;
using
param_type
=
unspecified
;
// constructors and reset functions
geometric_distribution
(
)
:
geometric_distribution
(
0.5
)
{
}
explicit
geometric_distribution
(
double
p
)
;
explicit
geometric_distribution
(
const
param_type
&
parm
)
;
void
reset
(
)
;
// equality operators
friend
bool
operator
=
=
(
const
geometric_distribution
&
x,
const
geometric_distribution
&
y
)
;
// generating functions
template
<
class
URBG
>
result_type
operator
(
)
(
URBG
&
g
)
;
template
<
class
URBG
>
result_type
operator
(
)
(
URBG
&
g,
const
param_type
&
parm
)
;
// property functions
double
p
(
)
const
; param_type param
(
)
const
;
void
param
(
const
param_type
&
parm
)
; result_type min
(
)
const
; result_type max
(
)
const
;
// inserters and extractors
template
<
class
charT,
class
traits
>
friend
basic_ostream
<
charT, traits
>
&
operator
<
<
(
basic_ostream
<
charT, traits
>
&
os,
const
geometric_distribution
&
x
)
;
template
<
class
charT,
class
traits
>
friend
basic_istream
<
charT, traits
>
&
operator
>
>
(
basic_istream
<
charT, traits
>
&
is, geometric_distribution
&
x
)
;
}
;
}
🔗
explicit
geometric_distribution
(
double
p
)
;
2
#
Preconditions
:
0
<
p
<
1
.
3
#
Remarks
:
p
corresponds to the parameter of the distribution
.
🔗
double
p
(
)
const
;
4
#
Returns
: The value of the
p
parameter with which the object was constructed
.