00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef RandGaussQ_h
00020 #define RandGaussQ_h 1
00021
00022 #include "CLHEP/Random/RandGauss.h"
00023
00028 class RandGaussQ : public RandGauss {
00029
00030 public:
00031
00032 inline RandGaussQ ( HepRandomEngine& anEngine, double mean=0.0,
00033 double stdDev=1.0 );
00034 inline RandGaussQ ( HepRandomEngine* anEngine, double mean=0.0,
00035 double stdDev=1.0 );
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046 virtual ~RandGaussQ();
00047
00048
00049
00050
00051
00052
00053
00054
00055
00056
00057 static inline double shoot();
00058
00059 static inline double shoot( double mean, double stdDev );
00060
00061 static void shootArray ( const int size, double* vect,
00062 double mean=0.0, double stdDev=1.0 );
00063
00064
00065
00066
00067 static inline double shoot( HepRandomEngine* anotherEngine );
00068
00069 static inline double shoot( HepRandomEngine* anotherEngine,
00070 double mean, double stdDev );
00071
00072
00073 static void shootArray ( HepRandomEngine* anotherEngine,
00074 const int size,
00075 double* vect, double mean=0.0,
00076 double stdDev=1.0 );
00077
00078
00079
00080
00081 inline double fire();
00082
00083 inline double fire ( double mean, double stdDev );
00084
00085 void fireArray ( const int size, double* vect);
00086 void fireArray ( const int size, double* vect,
00087 double mean, double stdDev );
00088
00089 virtual double operator()();
00090 virtual double operator()( double mean, double stdDev );
00091
00092 protected:
00093
00094 static double transformQuick (double r);
00095 static double transformSmall (double r);
00096
00097 private:
00098
00099
00100 RandGaussQ(const RandGaussQ& d);
00101
00102
00103
00104
00105 };
00106
00107 #include "CLHEP/Random/RandGaussQ.icc"
00108
00109 #endif