35 GO4TRACE((15,
"TGo4MbsRandom::TGo4MbsRandom()",__LINE__, __FILE__));
45 GO4TRACE((15,
"TGo4MbsRandom::TGo4MbsRandom(TGo4MbsRandomParameter*)",__LINE__, __FILE__));
58 GO4TRACE((15,
"TGo4MbsRandom::TGo4MbsRandom(const char *)",__LINE__, __FILE__));
67 GO4TRACE((15,
"TGo4MbsRandom::~TGo4MbsRandom()",__LINE__, __FILE__));
73 GO4TRACE((12,
"TGo4MbsRandom::NextEvent()",__LINE__, __FILE__));
75 void *clearfield = (
void *) (
fxEvent+1);
76 size_t clearlen =
fiDLen*2 - 8;
77 memset(clearfield, 0, clearlen);
82 for (Int_t i = 0; i <
fiNumSub; ++i) {
83 int l_val_num = (int)(
get_int(1., 7.)+0.5);
92 subevt->
l_dlen=l_val_num*2+2;
93 fxEvent->l_dlen+=(l_val_num*
sizeof(Int_t)) / 2 ;
95 Int_t *subdata = (Int_t *) (subevt+1);
96 for (Int_t j = 0; j < l_val_num; ++j) {
109 GO4TRACE((12,
"TGo4MbsRandom::Open()",__LINE__, __FILE__));
134 GO4TRACE((12,
"TGo4MbsRandom::Close()",__LINE__, __FILE__));
162 double v1, v2, s, u1;
165 v1 = gRandom->Rndm();
166 return (log(1 - v1) / sigma + mean);
173 v1 = 2. * gRandom->Rndm() - 1.;
174 v2 = 2. * gRandom->Rndm() - 1.;
176 s = v1 * v1 + v2 * v2;
177 }
while (s >= 1.0 || s == 0.0);
179 u1 = sigma * v1 * (sqrt(-2. * log(s) / s)) + mean;
183 return (sigma * v2 * (sqrt(-2. * log(s) / s)) + mean);
194 return ((high-low)*gRandom->Rndm()+low);
200 static double fgdPeak[] = { 200., 302., 653., 1024., 2800.};
201 static double fgdSigma[] = { 10., 22., 153., 104., 38.};
202 static double fgdPeak2[] = { 300., 402., 853., 2000., 3024.};
203 static double fgdSigma2[] = { 22., 153., 104., 100., 20.};
209 return ((
long)(
gauss_rnd(fgdPeak[cnt], fgdSigma[cnt])));
static void Debug(const char *text,...) GO4_PRINTF_ARGS
User shortcut for message with prio 0.
Short_t * fxEventMem
Memory allocated for the current random event.
Int_t NextEvent() override
Requests the next event from mbs source.
Int_t Open() override
Open the file or connection.
double get_int(double low, double high)
s_bufhe * GetBufferHeader() override
User access to current event buffer header.
Int_t fiNumSub
Number of subevents per event.
Int_t fiNumDat
Number of data longwords per subevent.
void get_rand_seed()
obtains seed for generator
double gauss_rnd(double mean, double sigma)
long rand_event(long choice)
Int_t Close() override
Close the file or connection.
Int_t fiDLen
total length of current random event in words (Short_t)
TGo4MbsSource()
default for streamer
double p_dUniform(unsigned *seed)
double p_dNormal(double mean, double sigma, unsigned int *seed)
double p_dExponential(double lambda, unsigned int *seed)