Visual Servoing Platform
version 3.0.0
Main Page
Related Pages
Modules
Namespaces
Classes
Examples
vpGaussRand.cpp
1
/****************************************************************************
2
*
3
* This file is part of the ViSP software.
4
* Copyright (C) 2005 - 2015 by Inria. All rights reserved.
5
*
6
* This software is free software; you can redistribute it and/or
7
* modify it under the terms of the GNU General Public License
8
* ("GPL") version 2 as published by the Free Software Foundation.
9
* See the file LICENSE.txt at the root directory of this source
10
* distribution for additional information about the GNU GPL.
11
*
12
* For using ViSP with software that can not be combined with the GNU
13
* GPL, please contact Inria about acquiring a ViSP Professional
14
* Edition License.
15
*
16
* See http://visp.inria.fr for more information.
17
*
18
* This software was developed at:
19
* Inria Rennes - Bretagne Atlantique
20
* Campus Universitaire de Beaulieu
21
* 35042 Rennes Cedex
22
* France
23
*
24
* If you have questions regarding the use of this file, please contact
25
* Inria at visp@inria.fr
26
*
27
* This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
28
* WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
29
*
30
* Description:
31
* Generation of random number with uniform and normal probability density.
32
*
33
* Authors:
34
* Eric Marchand
35
*
36
*****************************************************************************/
37
38
#include <math.h>
39
#include <visp3/core/vpGaussRand.h>
40
48
double
49
vpGaussRand::gaussianDraw()
50
{
51
double
v1, v2, rsq;
52
static
bool
AlreadyDone =
false
;
53
static
double
x2;
54
55
if
(AlreadyDone) {
56
AlreadyDone=
false
;
57
return
x2;
58
}
59
60
else
{
61
62
do
{
63
v1=2*
draw1
()-1;
64
v2=2*
draw1
()-1;
65
rsq=v1*v1+v2*v2;
66
}
while
(rsq >= 1);
67
68
double
fac=sqrt(-2*log(rsq)/rsq);
69
x2=v2*fac;
70
AlreadyDone=
true
;
71
return
v1*fac;
72
}
73
}
vpUniRand::draw1
double draw1()
Definition:
vpUniRand.cpp:62
modules
core
src
math
random-generator
vpGaussRand.cpp
Generated by
1.8.9.1