VTK  9.1.0
vtkBoxMuellerRandomSequence.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkBoxMuellerRandomSequence.h
5
6 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7 All rights reserved.
8 See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9
10 This software is distributed WITHOUT ANY WARRANTY; without even
11 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12 PURPOSE. See the above copyright notice for more information.
13=========================================================================*/
35#ifndef vtkBoxMuellerRandomSequence_h
36#define vtkBoxMuellerRandomSequence_h
37
38#include "vtkCommonCoreModule.h" // For export macro
40
41class VTKCOMMONCORE_EXPORT vtkBoxMuellerRandomSequence : public vtkGaussianRandomSequence
42{
43public:
45
50 void PrintSelf(ostream& os, vtkIndent indent) override;
52
57 void Initialize(vtkTypeUInt32 vtkNotUsed(seed)) override {}
58
62 double GetValue() override;
63
67 void Next() override;
68
73
78 void SetUniformSequence(vtkRandomSequence* uniformSequence);
79
80protected:
83
85 double Value;
86
87private:
89 void operator=(const vtkBoxMuellerRandomSequence&) = delete;
90};
91
92#endif // #ifndef vtkBoxMuellerRandomSequence_h
Gaussian sequence of pseudo random numbers implemented with the Box-Mueller transform.
void SetUniformSequence(vtkRandomSequence *uniformSequence)
Set the uniformly distributed sequence of random numbers.
static vtkBoxMuellerRandomSequence * New()
Standard methods for instantiation, type information, and printing.
~vtkBoxMuellerRandomSequence() override
void Next() override
Move to the next number in the random sequence.
vtkRandomSequence * GetUniformSequence()
Return the uniformly distributed sequence of random numbers.
double GetValue() override
Current value.
void PrintSelf(ostream &os, vtkIndent indent) override
Standard methods for instantiation, type information, and printing.
void Initialize(vtkTypeUInt32 vtkNotUsed(seed)) override
Satisfy general API of vtkRandomSequence superclass.
Gaussian sequence of pseudo random numbers.
a simple class to control print indentation
Definition: vtkIndent.h:43
Generate a sequence of random numbers.