70 InterpolationType(IntType)
72 prepareTable(aProbFunc);
76 const double* aProbFunc,
82 InterpolationType(IntType)
84 prepareTable(aProbFunc);
88 const double* aProbFunc,
92 localEngine(anEngine),
94 InterpolationType(IntType)
96 prepareTable(aProbFunc);
99 void RandGeneral::prepareTable(
const double* aProbFunc) {
105 "RandGeneral constructed with no bins - will use flat distribution\n";
106 useFlatDistribution();
110 theIntegralPdf.resize(nBins+1);
111 theIntegralPdf[0] = 0;
115 for ( ptn = 0; ptn<nBins; ++ptn ) {
116 weight = aProbFunc[ptn];
121 "RandGeneral constructed with negative-weight bin " << ptn <<
122 " = " << weight <<
" \n -- will substitute 0 weight \n";
126 theIntegralPdf[ptn+1] = theIntegralPdf[ptn] + weight;
129 if ( theIntegralPdf[nBins] <= 0 ) {
131 "RandGeneral constructed nothing in bins - will use flat distribution\n";
132 useFlatDistribution();
136 for ( ptn = 0; ptn < nBins+1; ++ptn ) {
137 theIntegralPdf[ptn] /= theIntegralPdf[nBins];
142 oneOverNbins = 1.0 / nBins;
146 if ( (InterpolationType != 0) && (InterpolationType != 1) ) {
148 "RandGeneral does not recognize IntType " << InterpolationType
149 <<
"\n Will use type 0 (continuous linear interpolation \n";
150 InterpolationType = 0;
155 void RandGeneral::useFlatDistribution() {
160 theIntegralPdf.resize(2);
161 theIntegralPdf[0] = 0;
162 theIntegralPdf[1] = 1;
180 double RandGeneral::mapRandom(
double rand)
const {
190 while (nabove > nbelow+1) {
191 middle = (nabove + nbelow+1)>>1;
192 if (rand >= theIntegralPdf[middle]) {
198 assert ( nabove == nbelow+1 );
199 assert ( theIntegralPdf[nbelow] <= rand );
200 assert ( theIntegralPdf[nabove] >= rand );
204 if ( InterpolationType == 1 ) {
206 return nbelow * oneOverNbins;
210 double binMeasure = theIntegralPdf[nabove] - theIntegralPdf[nbelow];
214 if ( binMeasure == 0 ) {
218 return (nbelow + .5) * oneOverNbins;
221 double binFraction = (rand - theIntegralPdf[nbelow]) / binMeasure;
223 return (nbelow + binFraction) * oneOverNbins;
229 const int size,
double* vect )
233 for (i=0; i<size; ++i) {
234 vect[i] =
shoot(anEngine);
242 for (i=0; i<size; ++i) {
248 int pr=os.precision(20);
249 std::vector<unsigned long> t(2);
250 os <<
" " <<
name() <<
"\n";
251 os <<
"Uvec" <<
"\n";
252 os << nBins <<
" " << oneOverNbins <<
" " << InterpolationType <<
"\n";
254 os << t[0] <<
" " << t[1] <<
"\n";
255 assert (static_cast<int>(theIntegralPdf.size())==nBins+1);
256 for (
unsigned int i=0; i<theIntegralPdf.size(); ++i) {
258 os << theIntegralPdf[i] <<
" " << t[0] <<
" " << t[1] <<
"\n";
267 if (inName !=
name()) {
268 is.clear(std::ios::badbit | is.rdstate());
269 std::cerr <<
"Mismatch when expecting to read state of a "
270 <<
name() <<
" distribution\n"
271 <<
"Name found was " << inName
272 <<
"\nistream is left in the badbit state\n";
276 std::vector<unsigned long> t(2);
277 is >> nBins >> oneOverNbins >> InterpolationType;
279 theIntegralPdf.resize(nBins+1);
280 for (
unsigned int i=0; i<theIntegralPdf.size(); ++i) {
281 is >> theIntegralPdf[i] >> t[0] >> t[1];
287 is >> oneOverNbins >> InterpolationType;
288 theIntegralPdf.resize(nBins+1);
289 for (
unsigned int i=0; i<theIntegralPdf.size(); ++i) is >> theIntegralPdf[i];
void shootArray(const int size, double *vect)
HepRandomEngine & engine()
RandGeneral(const double *aProbFunc, int theProbSize, int IntType=0)
bool possibleKeywordInput(IS &is, const std::string &key, T &t)
std::ostream & put(std::ostream &os) const
std::istream & get(std::istream &is)
static std::vector< unsigned long > dto2longs(double d)
void fireArray(const int size, double *vect)
static double longs2double(const std::vector< unsigned long > &v)