13 #define TRG_SHORT_NAMES
14 #define TRGCDC_SHORT_NAMES
19 #include <framework/dataobjects/EventMetaData.h>
20 #include "framework/datastore/StoreArray.h"
21 #include "framework/datastore/RelationArray.h"
22 #include "cdc/dataobjects/CDCHit.h"
23 #include "cdc/dataobjects/CDCSimHit.h"
24 #include "cdc/geometry/CDCGeometryPar.h"
25 #include "trg/trg/Debug.h"
26 #include "trg/trg/Utilities.h"
27 #include "trg/cdc/TRGCDC.h"
28 #include "trg/cdc/Layer.h"
29 #include "trg/cdc/Cell.h"
30 #include "trg/cdc/Wire.h"
31 #include "trg/cdc/WireHit.h"
32 #include "trg/cdc/Hough3DFinder.h"
33 #include "trg/cdc/Segment.h"
34 #include "trg/cdc/SegmentHit.h"
35 #include "trg/cdc/Circle.h"
36 #include "trg/cdc/TRGCDCTrack.h"
37 #include "trg/cdc/Link.h"
38 #include "trg/cdc/Relation.h"
39 #include "trg/cdc/Fitter3DUtility.h"
40 #include "trg/cdc/Fitter3D.h"
41 #include "trg/cdc/HandleRoot.h"
51 TRGCDCHough3DFinder::TRGCDCHough3DFinder(
const TRGCDC&
TRGCDC,
bool makeRootFile,
int finderMode)
52 : _cdc(
TRGCDC), m_makeRootFile(makeRootFile), m_finderMode(finderMode)
62 m_mBool[
"fIsIntegerEffect"] = 1;
78 for (
unsigned iSL = 0; iSL < 9; iSL++) {
85 for (
unsigned iAx = 0; iAx < 5; iAx++) {
89 m_mConstV[
"zToStraw"] = vector<double> (4);
90 m_mConstV[
"zToOppositeStraw"] = vector<double> (4);
91 m_mConstV[
"angleSt"] = vector<double> (4);
93 for (
int iSt = 0; iSt < 4; iSt++) {
104 for (
int iSt = 0; iSt < 4; iSt++)
m_mConstV[
"rr3D"][iSt] =
m_mConstV[
"rr"][iSt * 2 + 1];
105 m_mConstV[
"wirePhi2DError"] = vector<double> (5);
106 m_mConstV[
"driftPhi2DError"] = vector<double> (5);
120 m_mConstV[
"wirePhi2DError"][0] = 0.00085106;
121 m_mConstV[
"wirePhi2DError"][1] = 0.00039841;
122 m_mConstV[
"wirePhi2DError"][2] = 0.00025806;
123 m_mConstV[
"wirePhi2DError"][3] = 0.00019084;
124 m_mConstV[
"wirePhi2DError"][4] = 0.0001514;
125 m_mConstV[
"driftPhi2DError"][0] = 0.00085106;
126 m_mConstV[
"driftPhi2DError"][1] = 0.00039841;
127 m_mConstV[
"driftPhi2DError"][2] = 0.00025806;
128 m_mConstV[
"driftPhi2DError"][3] = 0.00019084;
129 m_mConstV[
"driftPhi2DError"][4] = 0.0001514;
148 m_mConstV[
"driftZError"] = vector<double> ({0.7676, 0.9753, 1.029, 1.372});
149 m_mConstV[
"wireZError"] = vector<double> ({0.7676, 0.9753, 1.029, 1.372});
153 for (
unsigned iSl = 0; iSl < 9; iSl++) {
154 string tableName =
"driftLengthTableSL" + to_string(iSl);
155 unsigned tableSize = 512;
156 m_mConstV[tableName] = vector<double> (tableSize);
158 for (
unsigned iTick = 0; iTick < tableSize; iTick++) {
160 double avgDriftLength = 0;
161 if (
m_mBool[
"fXtSimple"] == 1) {
164 double driftLength_0 = cdcp.
getDriftLength(t_driftTime, t_layer, 0);
165 double driftLength_1 = cdcp.
getDriftLength(t_driftTime, t_layer, 1);
166 avgDriftLength = (driftLength_0 + driftLength_1) / 2;
168 m_mConstV[tableName][iTick] = avgDriftLength;
173 TVectorD geometryHough3D(16);
174 for (
int i = 0; i < 4; i++) {
175 geometryHough3D[i] =
m_mConstV[
"rr"][2 * i + 1] / 100;
176 geometryHough3D[i + 4] =
m_mConstV[
"angleSt"][i];
177 geometryHough3D[i + 8] =
m_mConstV[
"zToStraw"][i] / 100;
178 geometryHough3D[i + 12] =
m_mConstV[
"nWires"][2 * i + 1];
190 float tempInitVariables[] = { -3, 3, -2, 2, 1001, 1001};
191 vector<float > initVariables(tempInitVariables, tempInitVariables +
sizeof(tempInitVariables) /
sizeof(tempInitVariables[0]));
196 m_mConstV[
"initVariablesHough3D"] = vector<double> (6);
197 m_mConstV[
"initVariablesHough3D"][0] = tempInitVariables[0];
198 m_mConstV[
"initVariablesHough3D"][1] = tempInitVariables[1];
199 m_mConstV[
"initVariablesHough3D"][2] = tempInitVariables[2];
200 m_mConstV[
"initVariablesHough3D"][3] = tempInitVariables[3];
201 m_mConstV[
"initVariablesHough3D"][4] = tempInitVariables[4];
202 m_mConstV[
"initVariablesHough3D"][5] = tempInitVariables[5];
223 for (
unsigned int iTrack = 0; iTrack < trackList2D.size(); iTrack++) {
224 TCTrack& aTrack = *
new TCTrack(* trackList2D[iTrack]);
225 trackList3D.push_back(& aTrack);
234 for (
unsigned iTrack = 0; iTrack < trackList.size(); iTrack++) {
235 TCTrack& aTrack = *trackList[iTrack];
236 aTrack.setTrackID(iTrack + 1);
257 m_mDouble[
"eventNumber"] = eventMetaDataPtr->getEvent();;
260 vector<vector<double> > stTSs(4);
261 vector<vector<int> > stTSDrift(4);
262 vector<vector<const TCSHit*> > p_stTSs(4);
263 for (
unsigned iSL = 0; iSL < 4; iSL++) {
266 string slName =
"st" + to_string(iSL);
267 m_mEventV[slName +
"_hit"] = vector<double> ();
268 m_mEventV[slName +
"_driftHit"] = vector<double> ();
269 stTSs[iSL] = vector<double> ();
270 stTSDrift[iSL] = vector<int> ();
271 p_stTSs[iSL] = vector<const TCSHit*> ();
273 for (
unsigned iHit = 0; iHit < hits.size(); iHit++) {
274 if (hits[iHit] == 0)
continue;
280 double t_wirePhi = ((double)hits[iHit]->cell().localId()) /
m_mConstV[
"nWires"][2 * iSL + 1] * 4 *
m_mConstD[
"Trg_PI"];
281 m_mEventV[slName +
"_hit"].push_back(t_wirePhi);
283 int t_tdc = hits[iHit]->segment().priorityTime();
284 int t_lr = hits[iHit]->segment().LUT()->getValue(hits[iHit]->segment().lutPattern());;
285 int t_priorityPosition = hits[iHit]->segment().priorityPosition();
286 int t_driftInfo = (t_tdc << 4) + (t_lr << 2) + t_priorityPosition;
287 stTSs[iSL].push_back(t_wirePhi);
288 p_stTSs[iSL].push_back(hits[iHit]);
289 stTSDrift[iSL].push_back(t_driftInfo);
296 map<unsigned, unsigned> numberTSsForParticle;
301 for (
unsigned iTrack = 0; iTrack <
m_mEventD[
"nTracks"]; iTrack++) {
303 TCTrack& aTrack = * trackList[iTrack];
309 m_mDouble[
"trackId"] = aTrack.getTrackID();
313 if (fit2DResult != 0)
continue;
324 const TCSHit* p_bestTS[4] = {0, 0, 0, 0};
325 for (
int iSt = 0; iSt < 4; iSt++) {
326 if (
m_mVector[
"bestTSIndex"][iSt] == 999) p_bestTS[iSt] = 0;
327 else p_bestTS[iSt] = p_stTSs[iSt][(int)
m_mVector[
"bestTSIndex"][iSt]];
331 for (
unsigned iSt = 0; iSt < 4; iSt++) {
332 if (
m_mVector[
"bestTS"][iSt] != 999) aTrack.append(
new TCLink(0, p_bestTS[iSt], p_bestTS[iSt]->cell().xyPosition()));
362 const TCRelation& trackRelation3D = aTrack.relation3D();
363 m_mDouble[
"purity"] = trackRelation3D.purity3D(aTrack.relation2D().contributor(0));
364 m_mDouble[
"efficiency"] = trackRelation3D.efficiency3D(aTrack.relation2D().contributor(0), numberTSsForParticle);
366 m_mVector[
"mcTSs"] = vector<double> (4, 999);
367 vector<const TCSHit*> mcTSList;
369 for (
unsigned iTS = 0; iTS < mcTSList.size(); iTS++) {
370 int iSuperLayer = (int)(
double(mcTSList[iTS]->cell().superLayerId()) - 1) / 2;
371 m_mVector[
"mcTSs"][iSuperLayer] = (double)mcTSList[iTS]->cell().localId() /
m_mConstV[
"nWires"][2 * iSuperLayer + 1] * 4 *
375 m_mVector[
"mcTSsX"] = vector<double> (4);
376 m_mVector[
"mcTSsY"] = vector<double> (4);
377 for (
unsigned iTS = 0; iTS < mcTSList.size(); iTS++) {
378 unsigned iCDCSimHit = mcTSList[iTS]->iCDCSimHit();
379 CDCSimHit* aCDCSimHit = SimHits[iCDCSimHit];
385 m_mVector[
"perfectWireDiff"] = vector<double> (4);
386 m_mVector[
"perfectCalZ"] = vector<double> (4);
387 for (
unsigned iSt = 0; iSt < 4; iSt++) {
401 unsigned int mcParticleId = aTrack.relation2D().contributor(0);
402 for (
unsigned iSt = 0; iSt < 4; iSt++) {
403 string mcTsName =
"mcTsSt" + to_string(iSt);
407 for (
unsigned iTS = 0; iTS < hits.size(); iTS++) {
408 if (hits[iTS]->iMCParticle() == mcParticleId)
m_mVector[mcTsName].push_back((
double)hits[iTS]->cell().localId() /
435 HandleRoot::saveTrackValues(
"hough3D",
444 HandleRoot::saveEventValues(
"hough3D",
452 if (
m_mBool[
"debugEfficiency"]) {
454 for (
unsigned iTrack = 0; iTrack < trackList.size(); iTrack++) {
456 TCTrack& aTrack = * trackList[iTrack];
458 int nPriorityHitSL = 0;
459 for (
unsigned iSt = 0; iSt < 4; iSt++) {
460 int priorityHitSL = 0;
461 for (
unsigned iTS = 0; iTS < stTSDrift[iSt].size(); iTS++) {
462 int t_priorityPosition = (stTSDrift[iSt][iTS] & 3);
463 if (t_priorityPosition == 3) priorityHitSL = 1;
466 if (priorityHitSL) nPriorityHitSL++;
471 if (
m_mDouble[
"efficiency"] != nPriorityHitSL * 1. / 4) {
472 aTrack.setDebugValue(TRGCDCTrack::EDebugValueType::find3D, 1);
479 for (
unsigned iTrack = 0; iTrack < trackList.size(); iTrack++) {
480 unsigned nHitStSl = 0;
481 for (
unsigned iSt = 0; iSt < 4; iSt++) {
482 if (trackList[iTrack]->links(2 * iSt + 1).size() != 0) nHitStSl++;
484 if (nHitStSl < 2) trackList[iTrack]->setDebugValue(TRGCDCTrack::EDebugValueType::find3D, 1);
501 unsigned id = trackList[j]->relation().contributor(0);
502 vector<const TCSHit*> tsList[9];
507 for (
unsigned i = 0; i < hits.size(); i++) {
508 const TCSHit& ts = * hits[i];
509 if (ts.segment().axial())
continue;
510 if (! ts.signal().active())
continue;
511 const TCWHit* wh = ts.segment().center().hit();
513 const unsigned trackId = wh->iMCParticle();
524 tsList[wh->wire().superLayerId()].push_back(& ts);
528 for (
unsigned k = 0; k < 9; k++) {
531 for (
unsigned l = 0; l < tsList[k].size(); l++) {
534 cout << tsList[k][l]->cell().name();
542 for (
unsigned i = 0; i < 9; i++) {
543 const TCSHit* best = 0;
544 if (tsList[i].size() == 0) {
546 }
else if (tsList[i].size() == 1) {
550 for (
unsigned k = 0; k < tsList[i].size(); k++) {
551 const TRGSignal& timing = tsList[i][k]->signal();
552 const TRGTime& t = * timing[0];
553 if (t.time() < timeMin) {
559 mcTSList.push_back(best);
570 cout <<
TRGDebug::tab() <<
"givenTrk#=" << trackList.size() << endl;
574 for (
unsigned j = 0; j < trackList.size(); j++) {
576 TCTrack* trk = trackList[j];
578 vector<const TCSHit*> mcTSList;
580 for (
unsigned iTS = 0; iTS < mcTSList.size(); iTS++) {
581 trk->append(
new TCLink(0, mcTSList[iTS], mcTSList[iTS]->cell().xyPosition()));
594 map<unsigned, unsigned>& numberTSsForParticle)
596 vector<unsigned> mcParticleList;
597 for (
unsigned iLayer = 0; iLayer < 4; iLayer++) {
599 mcParticleList.clear();
600 for (
unsigned iTS = 0; iTS < p_stTSs[iLayer].size(); iTS++) {
601 unsigned iMCParticle = p_stTSs[iLayer][iTS]->iMCParticle();
602 if (find(mcParticleList.begin(), mcParticleList.end(), iMCParticle) == mcParticleList.end()) {
603 mcParticleList.push_back(iMCParticle);
607 for (
unsigned iMCPart = 0; iMCPart < mcParticleList.size(); iMCPart++) {
608 map<unsigned, unsigned>::iterator it = numberTSsForParticle.find(mcParticleList[iMCPart]);
609 if (it != numberTSsForParticle.end()) ++it->second;
610 else numberTSsForParticle[mcParticleList[iMCPart]] = 1;
DataType X() const
access variable X (= .at(0) without boundary check)
DataType Y() const
access variable Y (= .at(1) without boundary check)
B2Vector3D getPosWire() const
The method to get position on wire.
The Class for CDC Geometry Parameters.
int nShifts(int layerId) const
Returns number shift.
double getTdcBinWidth() const
Return TDC bin width (nsec).
double senseWireBZ(int layerId) const
Returns backward z position of sense wire in each layer.
unsigned nWiresInLayer(int layerId) const
Returns wire numbers in a layer.
double senseWireFZ(int layerId) const
Returns forward z position of sense wire in each layer.
double getNominalDriftV() const
Return the nominal drift velocity of He-ethane gas (default: 4.0x10^-3 cm/nsec).
double getDriftLength(double dt, unsigned short layer, unsigned short lr, double alpha=0., double theta=0.5 *M_PI, bool calculateMinTime=true, double minTime=0.) const
Return the drift dength to the sense wire.
static CDCGeometryPar & Instance(const CDCGeometry *=nullptr)
Static method to get a reference to the CDCGeometryPar instance.
double senseWireR(int layerId) const
Returns radius of sense wire in each layer.
Low-level class to create/modify relations between StoreArrays.
Accessor to arrays stored in the data store.
Type-safe access to single objects in the data store.
std::map< std::string, std::vector< double > > m_mVector
Map to hold track vector values for Fitter3D.
std::map< std::string, TVectorD * > m_mEventTVectorD
TVectorD map for saving event values to root file.
std::map< std::string, bool > m_mBool
Map to hold input options.
std::map< std::string, double > m_mConstD
Map to hold run values for Fitter3D.
bool m_makeRootFile
Choose whether to save root file.
const TRGCDC & _cdc
Members.
std::map< std::string, std::vector< double > > m_mConstV
Map to hold run vectcors for Fitter3D.
std::map< std::string, double > m_mDouble
Map to hold track double values for Fitter3D.
std::map< std::string, double > m_mEventD
Map to hold event values for Fitter3D.
std::map< std::string, TClonesArray * > m_mTClonesArray
TClonesArray map for saving track values to root file.
TTree * m_treeConstantsFinder3D
TTree for constants of Hough3D.
int m_finderMode
0: perfect finder, 1: Hough3DFinder, 2: GeoFinder, 3: VHDL GeoFinder Choose what finder to use.
Hough3DFinder * m_Hough3DFinder
Hough Variables.
TFile * m_fileFinder3D
Tfile for Hough3D root file.
TTree * m_treeTrackFinder3D
TTree for tracks of Hough3D.
std::map< std::string, std::vector< double > > m_mEventV
Map to hold event vectcors for Fitter3D.
std::map< std::string, TVectorD * > m_mRunTVectorD
TVectorD map for saving run values to root file.
The instance of TRGCDC is a singleton.
A class to represent a digitized signal. Unit is nano second.
A class to represent a signal timing in the trigger system.
static double calZ(int charge, double anglest, double ztostraw, double rr, double phi, double rho, double phi0)
Calculates z.
static double calDeltaPhi(int charge, double anglest, double ztostraw, double rr, double phi, double rho, double phi0)
Calculates the phi difference between fitted axial phi and stereo phi.
A class to finded stereo TS hits related to 2D tracks.
void initialize(const TVectorD &geometryVariables, std::vector< float > &initVariables)
Geometry variables.
void setInputFileName(const std::string &inputFileName)
Sets the config file for the GeoFinder.
int getMode(void)
Gets which 3D finder is used.
void setMode(int mode)
Sets which 3D finder to use.
void runFinder(const std::vector< double > &trackVariables, std::vector< std::vector< double > > &stTSs, const std::vector< std::vector< int > > &stTSDrift)
Track variables.
void getValues(const std::string &input, std::vector< double > &result)
Gets results from the 3D finder.
void destruct(void)
Destructs the 3D finder.
std::vector< const TRGCDCSegmentHit * > segmentHits(void) const
returns a list of TRGCDCSegmentHit.
static std::string tab(void)
returns tab spaces.
const TRGCDCWire & center(void) const
returns a center wire.
static double calPhi(TRGCDCSegmentHit const *segmentHit, double eventTime)
Utility functions.
std::vector< const TRGCDCSegmentHit * > stereoSegmentHits(unsigned) const
returns a list of TRGCDCSegmentHit in a stereo super layer N.
unsigned layerId(void) const
returns layer id.
const TRGCDCSegment & stereoSegment(unsigned lyrId, unsigned id) const
returns a track segment in stereo layers. (lyrId is stereo #)
void terminate(void)
Termination method.
static void enterStage(const std::string &stageName)
Declare that you enter new stage.
~TRGCDCHough3DFinder()
Destructor.
void findNumberOfHitSuperlayersForMcParticles(std::vector< std::vector< const TRGCDCSegmentHit * > > &p_stTSs, std::map< unsigned, unsigned > &numberTSsForParticle)
Finds number of hit superlayers for each mc particle.
void perfectFinder(std::vector< TRGCDCTrack * > &trackList, unsigned j, std::vector< const TRGCDCSegmentHit * > &mcTSList)
Perfect 3D finder for a track.
const TRGCDCSegment & segment(unsigned id) const
returns a track segment.
int getEventTime(void) const
returns bad hits(finding invalid hits).
void doitPerfectly(std::vector< TRGCDCTrack * > &trackList)
Perfect 3D finder for a tracklist.
static int do2DFit(TRGCDCTrack &aTrack, const std::map< std::string, bool > &m_mBool_in, const std::map< std::string, double > &m_mConstD_in, std::map< std::string, std::vector< double > > &m_mConstV_in, std::map< std::string, double > &m_mDouble_in, std::map< std::string, std::vector< double > > &m_mVector_in)
Does 2D fit. Returns 0 if fit is done successfully. m_mBool should have fIsPrintError,...
static int level(void)
returns the debug level.
static void leaveStage(const std::string &stageName)
Declare that you leave a stage.
void doitFind(std::vector< TRGCDCTrack * > &trackList)
Finds tracks using tracklist.
static void getMCValues(const TRGCDC &m_cdc_in, TRGCDCTrack *aTrack, const std::map< std::string, double > &m_mConstD_in, std::map< std::string, double > &m_mDouble_in, std::map< std::string, std::vector< double > > &m_mVector_in)
Function for mc debugging.
void doit(std::vector< TRGCDCTrack * > const &trackList2D, std::vector< TRGCDCTrack * > &trackList3D)
Member functions.
Abstract base class for different kinds of events.