NAME
Math::Random::Cauchy - Random numbers following a Cauchy PDF
SYNOPSIS
use Math::Random::Cauchy;
my $cauchy = Math::Random::Cauchy->new(
fwhm => 1, # the width (full width, half maximum), default==1
middle => 5, # the expectation value, default==0
random => 'rand', # use Perl's builtin (default)
);
foreach (1..100) {
my $rnd = $cauchy->rand();
# ...
}
# Use Math::Random::MT instead of bultin rand()
use Math::Random::MT;
my $mt = Math::Random::Mt->new($seed);
$cauchy = Math::Random::Cauchy->new(
random => sub { $mt->rand() };
);
DESCRIPTION
This module transforms uniformly spaced random numbers into random numbers that follow the Cauchy Probability Density Function (PDF).
A more general transformation method is implemented in Math::Random::AcceptReject.
The algorithm is from Blobel et al as quoted in the SEE ALSO section below.
METHODS
new
Creates a new random number generator. Takes named arguments.
Optional parameters:
random: The random number generator. Defaults to using Perl's
rand() function. May be set to either 'rand' for the
default or a subroutine reference for custom random
number generators. Expected to return one or more(!)
random numbers per call.
fwhm: Full width, half maximum. Defaults to 1.
middle: Expectation value for x. Defaults to 0.
rand
Returns the next random number of Cauchy PDF.
SEE ALSO
Math::Random::MT, Math::Random, Math::Random::OO, Math::TrulyRandom, Math::Random::AcceptReject
The examples in the examples/ subdirectory of this distribution.
The algorithm was taken from: (German)
Blobel, V., and Lohrmann, E. Statistische und numerische Methoden der Datenanalyse. Stuttgart, Leipzig: Teubner, 1998
AUTHOR
Steffen Mueller, <smueller@cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2007 by Steffen Mueller
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.6 or, at your option, any later version of Perl 5 you may have available.