13 #define TRG_SHORT_NAMES 
   14 #define TRGCDC_SHORT_NAMES 
   17 #define PROGRAM_NAME    "TRGCDCTrackSegmentSimulator" 
   18 #define PROGRAM_VERSION "version 0.00" 
   19 #define ENV_PATH        "BELLE2_LOCAL_DIR" 
   21 #define CONFIG          "TRGCDCConfig_0_20101111_1051_2013beamtest.dat" 
   26 #include "trg/trg/Debug.h" 
   27 #include "trg/trg/Utilities.h" 
   28 #include "trg/trg/State.h" 
   29 #include "trg/trg/Channel.h" 
   30 #include "trg/cdc/TRGCDC.h" 
   31 #include "trg/cdc/Wire.h" 
   32 #include "trg/cdc/Segment.h" 
   33 #include "trg/cdc/TrackSegmentFinder.h" 
   34 #include "framework/gearbox/Gearbox.h" 
   37 #include "trg/cdc/DisplayRphi.h" 
   38 #include "trg/cdc/DisplayHough.h" 
   39 namespace Belle2_TRGCDC {
 
   40   Belle2::TRGCDCDisplayRphi* D = 0;
 
   47 using namespace Belle2_TRGCDC;
 
   50 void readFile(
const string& filename,
 
   56 main(
int argc, 
char* argv[])
 
   59   cout << PROGRAM_NAME << 
" ... " << PROGRAM_VERSION << endl;
 
   64     cout << PROGRAM_NAME << 
" needs 3 arguments" << endl;
 
   67   const unsigned dl = stoi(
string(argv[1]));
 
   68   const unsigned sl = stoi(
string(argv[2]));
 
   69   const string fn = string(argv[3]);
 
   74   const string path = getenv(ENV_PATH);
 
   75   const string patht = path + 
"/data/trg/cdc/";
 
   76   vector<std::string> backends;
 
   77   backends.push_back(
"file:");
 
   78   string filename = 
"geometry/Belle2.xml";
 
   79   Gearbox& gearbox = Gearbox::getInstance();
 
   80   gearbox.setBackends(backends);
 
   81   gearbox.open(filename);
 
   84   const string configFile = patht + CONFIG;
 
   85   const unsigned simulationMode = 3; 
 
   86   const unsigned fastSimulationMode = 0;
 
   87   const unsigned firmwareSimulationMode = 0;
 
   88   const int firmwareSimulationStart = 0;
 
   89   const int firmwareSimulationStop = 32 * 32 - 1;
 
   90   const unsigned makeRootFile = 0;
 
   91   const bool perfect2DFinder = 
false;
 
   92   const bool perfect3DFinder = 
false;
 
   93   const string innerTSLUTFile = patht + 
"innerLUT_v2.2.coe";
 
   94   const string outerTSLUTFile = patht + 
"outerLUT_v2.2.coe";
 
   95   const string rootTRGCDCFile = 
"TRGCDC.root";
 
   96   const string rootFitter3DFile = 
"Fitter3D.root";
 
   97   const unsigned houghFinderPeakMin = 5;
 
   98   const string houghMappingFilePlus = patht + 
"HoughMappingPlus20140807.dat";
 
   99   const string houghMappingFileMinus = patht +
 
  100                                        "HoughMappingMinus20140808.dat";
 
  101   const unsigned houghDoit = 2;
 
  102   const unsigned fLogicLUTTSF = 0;
 
  103   const unsigned fLRLUT = 1;
 
  104   const unsigned fevtTime = 1;
 
  105   const unsigned fmclr = 0;
 
  106   const double inefficiency = 0;
 
  107   const unsigned fileTSF = 0;
 
  108   const unsigned fileETF = 0;
 
  109   const unsigned fverETF = 0;
 
  110   const unsigned fprintFirmETF = 0;
 
  111   const unsigned fileHough3D = 0;
 
  112   const unsigned finder3DMode = 2;
 
  113   const unsigned fileFitter3D = 0;
 
  114   const unsigned trgCDCDataInputMode = 0;
 
  117   TRGCDC* cdc = TRGCDC::getTRGCDC(configFile,
 
  120                                   firmwareSimulationMode,
 
  121                                   firmwareSimulationStart,
 
  122                                   firmwareSimulationStop,
 
  131                                   houghMappingFilePlus,
 
  132                                   houghMappingFileMinus,
 
  146                                   trgCDCDataInputMode);
 
  152   const TRGClock& dc = TRGCDC::getTRGCDC()->dataClock();
 
  156   readFile(fn, isb, osbe, osbt);
 
  162   isbd.push_back(& dummy);
 
  163   for (
unsigned i = 1; i < tsfb.
nInput(); i++)
 
  174 #ifdef TRGCDC_DISPLAY 
  181   cout << PROGRAM_NAME << 
" ... terminated" << endl;
 
  185 readFile(
const string& fn,
 
  192   ifstream ifile(fn.c_str(), ios::in);
 
  194     cout << PROGRAM_NAME << 
" !!! can not open file" << endl
 
  195          << 
"    " << fn << endl;
 
  200   const TRGClock& dc = TRGCDC::getTRGCDC()->dataClock();
 
  201   const unsigned eSize = 625;
 
  202   const unsigned tSize = 1054 - 625;
 
  203   const unsigned mSize = 1309 - 1053 - 9;
 
  210   while (! ifile.eof()) {
 
  211     ifile.getline(b, 10000);
 
  214     if (l.size() == 0) 
continue;
 
  215     if (b[0] == 
'#') 
continue;
 
  216     if (b[0] == 
'S') 
continue;
 
  219     l = TRGUtil::cdrstring(l);
 
  221     l = TRGUtil::cdrstring(l);
 
  222     const string dat = TRGUtil::carstring(l);
 
  223     l = TRGUtil::cdrstring(l);
 
  228     TRGState t = a.subset(eSize, tSize);
 
  230     TRGState c = a.subset(1054 + mSize, 9);
 
  231     unsigned cMgr = unsigned(c);
 
  243   osbe.push_back(eOut);
 
  244   osbt.push_back(tOut);
 
Singleton class responsible for loading detector parameters from an XML file.
a class of TrackSegmentFinder in TRGCDC
The instance of TRGCDC is a singleton.
A class to represent a serial link between trigger hardware modules.
A class to represent a digitized signal. Unit is nano second.
A class to represent a bundle of SignalVectors.
A class to represent a bundle of digitized signals.
A class to represent a state of multi bits.
const TRGSignalVector & set(const TRGState &, int clockPosition)
sets state at given clock.
const TRGChannel * input(unsigned i) const
returns input channel i.
unsigned nInput(void) const
returns input channels.
TRGSignalBundle * signal(void) const
returns signal.
void simulate2(void)
Firmware simulation. Unified version of inner and outer : yi.
TRGChannel * output(unsigned i) const
returns output channel i.
void dump(const std::string &message="", const std::string &pre="") const
dumps contents.
Abstract base class for different kinds of events.
int main(int argc, char **argv)
Run all tests.