Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/clhep/src/EngineFactory.cc

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /externals/clhep/src/EngineFactory.cc (Version 11.3.0) and /externals/clhep/src/EngineFactory.cc (Version 11.0)


  1 // -*- C++ -*-                                      1 // -*- C++ -*-
  2 //                                                  2 //
  3 // -------------------------------------------      3 // -----------------------------------------------------------------------
  4 //                             HEP Random           4 //                             HEP Random
  5 //                      --- EngineFactory ---       5 //                      --- EngineFactory ---
  6 //                      class implementation f      6 //                      class implementation file
  7 // -------------------------------------------      7 // -----------------------------------------------------------------------
  8 //                                                  8 //
  9 // ===========================================      9 // =======================================================================
 10 // Mark Fischler  - Created: Dec. 21, 2004         10 // Mark Fischler  - Created: Dec. 21, 2004
 11 // ===========================================     11 // =======================================================================
 12                                                    12 
 13 #include "CLHEP/Random/EngineFactory.h"            13 #include "CLHEP/Random/EngineFactory.h"
 14 #include "CLHEP/Random/DualRand.h"                 14 #include "CLHEP/Random/DualRand.h"
 15 #include "CLHEP/Random/JamesRandom.h"              15 #include "CLHEP/Random/JamesRandom.h"
 16 #include "CLHEP/Random/MixMaxRng.h"                16 #include "CLHEP/Random/MixMaxRng.h"
 17 #include "CLHEP/Random/MTwistEngine.h"             17 #include "CLHEP/Random/MTwistEngine.h"
 18 #include "CLHEP/Random/RanecuEngine.h"             18 #include "CLHEP/Random/RanecuEngine.h"
 19 #include "CLHEP/Random/Ranlux64Engine.h"           19 #include "CLHEP/Random/Ranlux64Engine.h"
 20 #include "CLHEP/Random/RanluxppEngine.h"           20 #include "CLHEP/Random/RanluxppEngine.h"
 21 #include "CLHEP/Random/RanluxEngine.h"             21 #include "CLHEP/Random/RanluxEngine.h"
 22 #include "CLHEP/Random/RanshiEngine.h"             22 #include "CLHEP/Random/RanshiEngine.h"
 23 #include "CLHEP/Random/NonRandomEngine.h"          23 #include "CLHEP/Random/NonRandomEngine.h"
 24 #include "CLHEP/Random/engineIDulong.h"            24 #include "CLHEP/Random/engineIDulong.h"
 25 #include <iostream>                                25 #include <iostream>
 26 #include <string>                                  26 #include <string>
 27 #include <vector>                                  27 #include <vector>
 28                                                    28 
 29 namespace CLHEP {                                  29 namespace CLHEP {
 30                                                    30 
 31 template<class E>                                  31 template<class E>
 32 static HepRandomEngine*                            32 static HepRandomEngine* 
 33 makeAnEngine (const std::string & tag,             33 makeAnEngine (const std::string & tag, 
 34               std::istream & is) {                 34               std::istream & is) {
 35   if ( tag != E::beginTag() ) return 0;            35   if ( tag != E::beginTag() ) return 0;
 36   HepRandomEngine* eptr = new E;                   36   HepRandomEngine* eptr = new E;
 37   eptr->getState(is);                              37   eptr->getState(is);
 38   if (!is) return 0;                               38   if (!is) return 0;
 39   return eptr;                                     39   return eptr;        
 40 }                                                  40 }       
 41                                                    41 
 42 template<class E>                                  42 template<class E>
 43 static HepRandomEngine*                            43 static HepRandomEngine* 
 44 makeAnEngine (const std::vector<unsigned long>     44 makeAnEngine (const std::vector<unsigned long> & v) {
 45   if ( (v[0] & 0xffffffffUL) != engineIDulong<     45   if ( (v[0] & 0xffffffffUL) != engineIDulong<E>() ) return 0;
 46   HepRandomEngine* eptr = new E;                   46   HepRandomEngine* eptr = new E;
 47   bool success = eptr->getState(v);                47   bool success = eptr->getState(v);
 48   if (!success) return 0;                          48   if (!success) return 0;
 49   // std::cerr << "makeAnEngine made " << E::e     49   // std::cerr << "makeAnEngine made " << E::engineName() << "\n"; 
 50   return eptr;                                     50   return eptr;        
 51 }                                                  51 }       
 52                                                    52 
 53 HepRandomEngine* EngineFactory::newEngine(std:     53 HepRandomEngine* EngineFactory::newEngine(std::istream& is) {
 54   HepRandomEngine* eptr;                           54   HepRandomEngine* eptr; 
 55   std::string tag;                                 55   std::string tag;
 56   is >> tag;                                       56   is >> tag;
 57   eptr = makeAnEngine <HepJamesRandom>  (tag,      57   eptr = makeAnEngine <HepJamesRandom>  (tag, is); if (eptr) return eptr;
 58   eptr = makeAnEngine <RanecuEngine>    (tag,      58   eptr = makeAnEngine <RanecuEngine>    (tag, is); if (eptr) return eptr;
 59   eptr = makeAnEngine <Ranlux64Engine>  (tag,      59   eptr = makeAnEngine <Ranlux64Engine>  (tag, is); if (eptr) return eptr;
 60   eptr = makeAnEngine <RanluxppEngine>  (tag,      60   eptr = makeAnEngine <RanluxppEngine>  (tag, is); if (eptr) return eptr;
 61   eptr = makeAnEngine <MixMaxRng>       (tag,      61   eptr = makeAnEngine <MixMaxRng>       (tag, is); if (eptr) return eptr;
 62   eptr = makeAnEngine <MTwistEngine>    (tag,      62   eptr = makeAnEngine <MTwistEngine>    (tag, is); if (eptr) return eptr;
 63   eptr = makeAnEngine <DualRand>        (tag,      63   eptr = makeAnEngine <DualRand>        (tag, is); if (eptr) return eptr;
 64   eptr = makeAnEngine <RanluxEngine>    (tag,      64   eptr = makeAnEngine <RanluxEngine>    (tag, is); if (eptr) return eptr;
 65   eptr = makeAnEngine <RanshiEngine>    (tag,      65   eptr = makeAnEngine <RanshiEngine>    (tag, is); if (eptr) return eptr;
 66   eptr = makeAnEngine <NonRandomEngine> (tag,      66   eptr = makeAnEngine <NonRandomEngine> (tag, is); if (eptr) return eptr;
 67   is.clear(std::ios::badbit | is.rdstate());       67   is.clear(std::ios::badbit | is.rdstate());
 68   std::cerr <<                                     68   std::cerr << 
 69     "Input mispositioned or bad in reading ano     69     "Input mispositioned or bad in reading anonymous engine\n"
 70       << "\nBegin-tag read was: " << tag           70       << "\nBegin-tag read was: " << tag 
 71       << "\nInput stream is probably fouled up     71       << "\nInput stream is probably fouled up\n";
 72   return eptr;                                     72   return eptr;
 73 }                                                  73 }
 74                                                    74 
 75 HepRandomEngine*                                   75 HepRandomEngine* 
 76 EngineFactory::newEngine(std::vector<unsigned      76 EngineFactory::newEngine(std::vector<unsigned long> const & v) {
 77   HepRandomEngine* eptr;                           77   HepRandomEngine* eptr; 
 78   eptr = makeAnEngine <HepJamesRandom>  (v); i     78   eptr = makeAnEngine <HepJamesRandom>  (v); if (eptr) return eptr;
 79   eptr = makeAnEngine <RanecuEngine>    (v); i     79   eptr = makeAnEngine <RanecuEngine>    (v); if (eptr) return eptr;
 80   eptr = makeAnEngine <Ranlux64Engine>  (v); i     80   eptr = makeAnEngine <Ranlux64Engine>  (v); if (eptr) return eptr;
 81   eptr = makeAnEngine <RanluxppEngine>  (v); i     81   eptr = makeAnEngine <RanluxppEngine>  (v); if (eptr) return eptr;
 82   eptr = makeAnEngine <MixMaxRng>       (v); i     82   eptr = makeAnEngine <MixMaxRng>       (v); if (eptr) return eptr;
 83   eptr = makeAnEngine <MTwistEngine>    (v); i     83   eptr = makeAnEngine <MTwistEngine>    (v); if (eptr) return eptr;
 84   eptr = makeAnEngine <DualRand>        (v); i     84   eptr = makeAnEngine <DualRand>        (v); if (eptr) return eptr;
 85   eptr = makeAnEngine <RanluxEngine>    (v); i     85   eptr = makeAnEngine <RanluxEngine>    (v); if (eptr) return eptr;
 86   eptr = makeAnEngine <RanshiEngine>    (v); i     86   eptr = makeAnEngine <RanshiEngine>    (v); if (eptr) return eptr;
 87   eptr = makeAnEngine <NonRandomEngine> (v); i     87   eptr = makeAnEngine <NonRandomEngine> (v); if (eptr) return eptr;
 88   std::cerr <<                                     88   std::cerr << 
 89     "Cannot correctly get anonymous engine fro     89     "Cannot correctly get anonymous engine from vector\n"
 90       << "First unsigned long was: " << v[0]       90       << "First unsigned long was: " << v[0] 
 91       << " Vector size was: " << v.size() <<"\     91       << " Vector size was: " << v.size() <<"\n";
 92   return eptr;                                     92   return eptr;
 93 }                                                  93 }
 94                                                    94 
 95 }  // namespace CLHEP                              95 }  // namespace CLHEP
 96                                                    96 
 97                                                    97