ROOT logo
// @(#)root/mathcore:$Id: TRandom3.h 39600 2011-06-08 13:04:37Z moneta $
// Author: Peter Malzacher   31/08/99

 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *

#ifndef ROOT_TRandom3
#define ROOT_TRandom3

//                                                                      //
// TRandom3                                                             //
//                                                                      //
// random number generator class: Mersenne Twistor                      //
//                                                                      //

#ifndef ROOT_TRandom
#include "TRandom.h"

class TRandom3 : public TRandom {

   UInt_t   fMt[624];
   Int_t    fCount624;

   TRandom3(UInt_t seed=4357);
   virtual ~TRandom3();
   // get the current seed (only first element of the seed table)
   virtual  UInt_t    GetSeed() const { return fMt[0];}
   virtual  Double_t  Rndm(Int_t i=0);
   virtual  void      RndmArray(Int_t n, Float_t *array);
   virtual  void      RndmArray(Int_t n, Double_t *array);
   virtual  void      SetSeed(UInt_t seed=0);

   ClassDef(TRandom3,2)  //Random number generator: Mersenne Twistor

R__EXTERN TRandom *gRandom;