Visual Servoing Platform
version 3.1.0
vpUniRand.h
1
/****************************************************************************
2
*
3
* This file is part of the ViSP software.
4
* Copyright (C) 2005 - 2017 by Inria. All rights reserved.
5
*
6
* This software is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; either version 2 of the License, or
9
* (at your option) any later version.
10
* See the file LICENSE.txt at the root directory of this source
11
* distribution for additional information about the GNU GPL.
12
*
13
* For using ViSP with software that can not be combined with the GNU
14
* GPL, please contact Inria about acquiring a ViSP Professional
15
* Edition License.
16
*
17
* See http://visp.inria.fr for more information.
18
*
19
* This software was developed at:
20
* Inria Rennes - Bretagne Atlantique
21
* Campus Universitaire de Beaulieu
22
* 35042 Rennes Cedex
23
* France
24
*
25
* If you have questions regarding the use of this file, please contact
26
* Inria at visp@inria.fr
27
*
28
* This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
29
* WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
30
*
31
* Description:
32
* Generation of random number with uniform and normal probability density.
33
*
34
* Authors:
35
* Eric Marchand
36
*
37
*****************************************************************************/
38
39
#ifndef vpUniRand_hh
40
#define vpUniRand_hh
41
42
#include <visp3/core/vpConfig.h>
43
65
class
VISP_EXPORT
vpUniRand
66
{
67
long
a;
68
long
m;
// 2^31-1
69
long
q;
// integer part of m/a
70
long
r;
// r=m mod a
71
double
normalizer;
// we use a normalizer > m to ensure ans will never be 1
72
// (it is the case if x = 739806647)
73
74
private
:
75
void
draw0();
76
77
protected
:
78
long
x
;
79
double
draw1();
80
81
public
:
83
explicit
vpUniRand
(
const
long
seed = 0)
84
: a(16807), m(2147483647), q(127773), r(2836), normalizer(2147484721.0), x((seed) ? seed : 739806647)
85
{
86
}
87
89
virtual
~vpUniRand
(){};
90
92
double
operator()
() {
return
draw1(); }
93
};
94
95
#endif
vpUniRand::~vpUniRand
virtual ~vpUniRand()
Default destructor.
Definition:
vpUniRand.h:89
vpUniRand::vpUniRand
vpUniRand(const long seed=0)
Default constructor.
Definition:
vpUniRand.h:83
vpUniRand::operator()
double operator()()
Operator that allows to get a random value.
Definition:
vpUniRand.h:92
vpUniRand::x
long x
Definition:
vpUniRand.h:78
vpUniRand
Class for generating random numbers with uniform probability density.
Definition:
vpUniRand.h:65
visp
modules
core
include
visp3
core
vpUniRand.h
Generated by
1.8.13