linbox  1
Public Member Functions
ModularBalancedRandIter< Element > Class Template Reference

#include <modular-balanced.h>

List of all members.

Public Member Functions

 ModularBalancedRandIter (const ModularBalanced< Element > &F, const integer &size=0, const integer &seed=0)
 ModularBalancedRandIter (const ModularBalancedRandIter< Element > &R)
 ~ModularBalancedRandIter ()
ModularBalancedRandIter
< Element > & 
operator= (const ModularBalancedRandIter< Element > &R)
Element & random (Element &a) const
ElementAbstractrandom (ElementAbstract &a) const

Detailed Description

template<class Element>
class LinBox::ModularBalancedRandIter< Element >

Random field base element generator. This encapsulated class is a generator of random field base elements for the encapsulating field. It is required to contain constructors from a field object and two integers. The first integer being a cardinality of a set to draw the random elements from, and the second being a seed for the random number generator. It is also required to contain a copy constructor, a destructor, and an operator () which acts on a reference to a field base element. In this operator (), the random element is placed into the input field base element and also returned as a reference.


Constructor & Destructor Documentation

ModularBalancedRandIter ( const ModularBalanced< Element > &  F,
const integer size = 0,
const integer seed = 0 
) [inline]

Constructor from field, sampling size, and seed. The random field element iterator works in the field F, is seeded by seed, and it returns any one element with probability no more than 1/min (size, F.cardinality (c)). A sampling size of zero means to sample from the entire field. A seed of zero means to use some arbitrary seed for the generator. Purely virtual.

Parameters:
FLinBox field archetype object in which to do arithmetic
sizeconstant integer reference of sample size from which to sample (default = modulus of field)
seedconstant integer reference from which to seed random number generator (default = 0)
ModularBalancedRandIter ( const ModularBalancedRandIter< Element > &  R) [inline]

Copy constructor. Constructs ModularBalancedRandIter object by copying the random field element generator. This is required to allow generator objects to be passed by value into functions.

Parameters:
RModularBalancedRandIter object.
~ModularBalancedRandIter ( ) [inline]

Destructor. This destructs the random field element generator object.


Member Function Documentation

ModularBalancedRandIter<Element>& operator= ( const ModularBalancedRandIter< Element > &  R) [inline]

Assignment operator. Assigns ModularBalancedRandIter object R to generator.

Parameters:
RModularBalancedRandIter object.
Element& random ( Element &  a) const [inline]

Random field element creator. This returns a random field element from the information supplied at the creation of the generator. Required by abstract base class.

Returns:
reference to random field element
ElementAbstract& random ( ElementAbstract a) const [inline]

Random field element creator. This returns a random field element from the information supplied at the creation of the generator. Required by abstract base class.

Returns:
reference to random field element

The documentation for this class was generated from the following file: