84 static const double recip = 1.0/(
double)(1U <<
NBits);
87 for(dim=0; dim < dimension; dim++) {
88 vector[dim] =
_nextq[dim] * recip;
105 oocoutE(
nullptr,Integration) <<
"RooQuasiRandomGenerator::generate: internal error!" << endl;
110 for(dim=0; dim<dimension; dim++) {
129 for(i_dim=0; i_dim<dimension; i_dim++) {
131 const int poly_index = i_dim + 1;
154 for(k=0; k<=px_degree; k++) {
160 for(j=0; j<
NBits; j++) {
179 if(u == px_degree) u = 0;
188 for(j=0; j<
NBits; j++) {
189 term = 2*term + ci[
r][j];
191 _cj[
r][i_dim] = term;
202 int pb[],
int * pb_degree,
int v[],
int maxv)
204 const int nonzero_element = 1;
205 const int arbitrary_element = 1;
213 int bigm = *pb_degree;
227 polyMultiply(px, px_degree, pb, *pb_degree, pb, pb_degree);
246 for(
r=0;
r<kj;
r++) {
253 for(
r=kj+1;
r<
m;
r++) {
254 v[
r] = arbitrary_element;
260 int term =
sub(0, ph[kj]);
262 for(
r=kj+1;
r<bigm;
r++) {
263 v[
r] = arbitrary_element;
272 v[bigm] =
add(nonzero_element, term);
274 for(
r=bigm+1;
r<
m;
r++) {
275 v[
r] = arbitrary_element;
282 for(
r=0;
r<=maxv-
m;
r++) {
285 term =
sub(term,
mul(pb[k],
v[
r+k]));
296 int pb_degree,
int pc[],
int * pc_degree)
301 int pt_degree = pa_degree + pb_degree;
303 for(k=0; k<=pt_degree; k++) {
305 for(j=0; j<=k; j++) {
306 const int conv_term =
mul(pa[k-j], pb[j]);
307 term =
add(term, conv_term);
312 for(k=0; k<=pt_degree; k++) {
319 *pc_degree = pt_degree;
338 { 1, 0, 0, 0, 0, 0 },
339 { 0, 1, 0, 0, 0, 0 },
340 { 1, 1, 0, 0, 0, 0 },
341 { 1, 1, 1, 0, 0, 0 },
342 { 1, 1, 0, 1, 0, 0 },
343 { 1, 0, 1, 1, 0, 0 },
344 { 1, 1, 0, 0, 1, 0 },
345 { 1, 0, 0, 1, 1, 0 },
346 { 1, 1, 1, 1, 1, 0 },
347 { 1, 0, 1, 0, 0, 1 },
348 { 1, 0, 0, 1, 0, 1 },
349 { 1, 1, 1, 1, 0, 1 },
359 0, 1, 1, 2, 3, 3, 4, 4, 4, 5, 5, 5, 5
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t WindowAttributes_t Float_t r
This class generates the quasi-random (aka "low discrepancy") sequence for dimensions up to 12 using ...
void polyMultiply(const int pa[], int pa_degree, const int pb[], int pb_degree, int pc[], int *pc_degree)
Internal function.
RooQuasiRandomGenerator()
Perform one-time initialization of our static coefficient array if necessary and initialize our works...
void calculateV(const int px[], int px_degree, int pb[], int *pb_degree, int v[], int maxv)
Internal function.
Int_t mul(Int_t x, Int_t y) const
void reset()
Reset the workspace to its initial state.
void calculateCoefs(UInt_t dimension)
Calculate the coefficients for the given number of dimensions.
static Int_t _cj[NBits][MaxDimension]
virtual ~RooQuasiRandomGenerator()
Destructor.
static bool _coefsCalculated
static const Int_t _polyDegree[MaxDimension+1]
static const Int_t _primitivePoly[MaxDimension+1][MaxPrimitiveDegree+1]
bool generate(UInt_t dimension, double vector[])
Generate the next number in the sequence for the specified dimension.
Int_t add(Int_t x, Int_t y) const
Int_t sub(Int_t x, Int_t y) const