5 #include "KVGeoImport.h"
7 #include "KVFAZIADetector.h"
9 #include "KVFAZIABlock.h"
10 #include "KVDetectorEvent.h"
13 #include "KVDataSet.h"
15 #include "KVFAZIAIDSiPSA.h"
16 #include "KVFAZIAIDCsI.h"
17 #include "KVFAZIAIDSiCsI.h"
18 #include "KVFAZIAIDSiSi.h"
20 #include "TGeoCompositeShape.h"
23 #include <KVFAZIAIDSiSiCsI.h>
24 #include <KVReconstructedNucleus.h>
27 #include "MFMFaziaFrame.h"
31 #include "FzEventSet.pb.h"
32 #include "KVFzDataReader.h"
47 static Char_t
const*
const FzDataType_str[] = {
"QH1",
"I1",
"QL1",
"Q2",
"I2",
"Q3",
"ADC",
"UNK" };
48 static Char_t
const*
const FzDetector_str[] = {
"SI1",
"SI1",
"SI1",
"SI2",
"SI2",
"CSI" };
83 else lval = gEnv->GetValue(parname, 0.0);
145 if (gExpDB->
GetTable(
"FAZIA.Triggers")) {
148 auto links = rundb->
GetLinks(
"FAZIA.Triggers");
149 if (links && links->GetEntries())
150 return links->First()->GetName();
184 KVDetector* csi{
nullptr}, *si2{
nullptr}, *si1{
nullptr};
187 if (d->IsLabelled(
"SI1") && d->IsOK()) si1 = d;
188 else if (d->IsLabelled(
"SI2") && d->IsOK()) si2 = d;
189 else if (d->IsLabelled(
"CSI") && d->IsOK()) csi = d;
202 add_telescope(idt, csi->
GetGroup());
207 add_telescope(idt, csi->
GetGroup());
213 idt->SetName(Form(
"ID_SI_CSI_%d", csi->GetIndex()));
214 add_telescope(idt, csi->
GetGroup());
221 add_telescope(idt, si2->
GetGroup());
227 add_telescope(idt, si2->
GetGroup());
232 add_telescope(idt, si1->
GetGroup());
247 if (gFazia ==
this) gFazia =
nullptr;
275 #ifdef WITH_GNU_INSTALL
286 if (env.GetTable() && env.GetTable()->GetEntries() > 0) {
287 env.
AddCommentLine(Form(
"Automatic generated file by %s::GenerateCorrespondanceFile", ClassName()));
288 env.
AddCommentLine(
"Make link between geometric ROOT objects and detector names");
314 for (Int_t qq = 1; qq <= 4; qq += 1) {
315 for (Int_t tt = 1; tt <= 4; tt += 1) {
320 Form(
"BLOCK_%d_QUARTET_%d_%s-T%d", bb, qq, sdet.Data(), tt),
321 Form(
"%s-%d", sdet.Data(), bb * 100 + qq * 10 + tt)
369 AbstractMethod(
"GetGeometryParameters");
416 if (patterns.Length()) {
418 while (!patterns.
End()) {
419 auto pattern = patterns.
Next(kTRUE);
420 uint16_t val = (uint16_t)
GetDataSetEnv(dataset, Form(
"FAZIA.TriggerPattern.%s", pattern.Data()), 0.);
434 Info(
"BuildFAZIA",
"to be defined in child class ...");
446 new TGeoBBox(
"TARGET_FRAME", 3., 3., 0.1 / 2.);
447 new TGeoEltu(
"TARGET_HOLE", 2., 2., 0.1 / 2.);
448 TGeoCompositeShape* cs =
new TGeoCompositeShape(
"TARGET_FRAME",
"TARGET_FRAME - TARGET_HOLE");
449 TGeoVolume* target_frame =
new TGeoVolume(
"TARGET_FRAME", cs, target_holder_mat.
GetGeoMedium());
450 gGeoManager->GetTopVolume()->AddNode(target_frame, 1);
455 TGeoVolume* target = gGeoManager->MakeEltu(
"TARGET", targMat->
GetGeoMedium(), 2., 2., targMat->
GetThickness() / 2.);
456 gGeoManager->GetTopVolume()->AddNode(target, 1);
479 gGeoManager->CloseGeometry();
517 if (!dets || !dets->GetEntries()) {
523 if (dets && dets->GetEntries()) {
524 TIter next_det(dets);
556 while (!DetNames.
End()) {
576 TString pname = Form(
"%s.%s", det->GetName(), ds->GetName());
615 sname.Form(
"%s-RUTH", FzDataType_str[idsig]);
618 sname.Form(
"%s-%d", FzDataType_str[idsig], 100 * bb + 10 * qq + tt);
623 sname.Form(
"%s-RUTH", FzDataType_str[idsig]);
626 sname.Form(
"%s-%d", FzDataType_str[idsig], 100 * bb + 10 * qq + tt);
630 sname.Form(
"%s-%d", FzDataType_str[idsig], 100 * bb + 10 * qq + tt);
652 Int_t value = (val << 2);
656 case DAQ::FzData_FzDataType_QH1:
657 if (eid == 0) dval = value / (
fQH1risetime * 1e3 / 10.);
659 case DAQ::FzData_FzDataType_I1:
661 case DAQ::FzData_FzDataType_QL1:
663 case DAQ::FzData_FzDataType_Q2:
664 if (eid == 0) dval = value / (
fQ2risetime * 1e3 / 10.);
666 case DAQ::FzData_FzDataType_I2:
668 case DAQ::FzData_FzDataType_Q3:
688 int ts = e.trinfo_size();
691 for (Int_t tr = ts - 1; tr >= 0; tr--) {
692 const DAQ::FzTrigInfo& rdtrinfo = e.trinfo(tr);
693 uint64_t triggervalue = rdtrinfo.value();
699 else if (tr == ts - 8) {
700 dt = triggervalue / (1e6);
716 else if (tr == ts - 19) {
720 else if (tr == ts - 20) {
729 for (
int b = 0; b < e.block_size(); ++b) {
732 if (e.block(b).len_error() || e.block(b).crc_error() || (!good)) {
737 int fIdBlk = e.block(b).blkid();
739 for (
int f = 0; f < e.block(b).fee_size(); ++f) {
741 const DAQ::FzFee& rdfee = e.block(b).fee(f);
743 for (
int h = 0; h < rdfee.hit_size(); ++h) {
745 const DAQ::FzHit& rdhit = rdfee.hit(h);
747 if (rdfee.len_error() || rdfee.crc_error() || (!good)) {
748 Warning(
"treat_event",
"FEE LEN OR CRC ERROR B%03d-FE%d", e.block(b).blkid(), rdfee.feeid());
752 int fIdFee = rdhit.feeid();
753 int fIdTel = rdhit.telid();
755 for (Int_t mm = 0; mm < rdhit.data_size(); mm++) {
756 const DAQ::FzData& rdata = rdhit.data(mm);
757 int fIdSignal = rdata.type();
759 int DetTag = rdhit.dettag();
760 int GTTag = rdhit.gttag();
761 if (DetTag >= 16384 && GTTag < 16384) GTTag += 32768;
764 int fIdQuartet =
fQuartet[fIdFee][fIdTel];
765 int fIdTelescope =
fTelescope[fIdFee][fIdTel];
769 Error(
"treat_event",
"No detector %s-%d found in FAZIA geometry...", FzDetector_str[fIdSignal], 100 * fIdBlk + 10 * fIdQuartet + fIdTelescope);
775 if (!rdata.has_energy() && !rdata.has_waveform()) {
776 if (FzDataType_str[fIdSignal] !=
"I2") Warning(
"treat_event",
"[NO DATA] [%s %s]", det->GetName(), FzDataType_str[fIdSignal]);
780 if (rdata.has_energy()) {
781 const DAQ::Energy& ren = rdata.energy();
782 for (Int_t ee = 0; ee < ren.value_size(); ee++) {
783 Double_t energy =
TreatEnergy(fIdSignal, ee, ren.value(ee));
788 if (rdata.has_baseline()) {
789 Float_t bl = rdata.baseline();
792 if (rdata.has_waveform()) {
793 const DAQ::Waveform& rwf = rdata.waveform();
796 if (fIdSignal <= 5) {
797 TString sname =
GetSignalName(fIdBlk, fIdQuartet, fIdTelescope, fIdSignal);
799 Warning(
"treat_event",
"signal name is empty !!! blk=%d qua=%d tel=%d\n", fIdBlk, fIdQuartet, fIdTelescope);
801 TGraph sig(rwf.sample_size());
803 for (Int_t nn = 0; nn < rwf.sample_size(); nn++) {
804 if (fIdSignal != DAQ::FzData::ADC) {
805 if (rwf.sample(nn) > 8191) {
806 supp = rwf.sample(nn) | 0xFFFFC000;
809 supp = rwf.sample(nn);
813 supp = rwf.sample(nn);
815 sig.SetPoint(nn, nn, supp);
821 Warning(
"treat_event",
"datatype %d>5 - taille = %d\n", fIdSignal, rwf.sample_size());
851 if (f.GetFrameType() != MFM_FAZIA_FRAME_TYPE)
return kFALSE;
855 DAQ::FzEventSet fazia_set;
856 DAQ::FzEvent fazia_event;
858 if (fazia_set.ParseFromArray(f.GetPointUserData(), ((MFMFaziaFrame&)f).GetEventSize())) {
860 if (fazia_set.ev_size() > 1) {
861 Warning(
"handle_raw_data_event_mfmframe",
862 "Got a FzEventSet from data: cannot handle multiple events at once!");
867 else if (fazia_event.ParseFromArray(f.GetPointUserData(), ((MFMFaziaFrame&)f).GetEventSize())) {
887 TString DataFilePath;
889 Error(
"CreateCorrespondence",
"ElecDetLink.env not found");
893 DetLink.ReadFile(DataFilePath, kEnvUser);
894 for (
int t = 1; t <= 4; t++) {
895 for (
int q = 1; q <= 4; q++) {
896 TString elec = DetLink.GetValue(Form(
"T%1d-Q%1d", t, q),
" ");
897 if (!elec.IsWhitespace()) {
899 sscanf(elec.Data(),
"FPGA%d-FE%d", &fpga, &fee);
904 Error(
"CreateCorrespondence",
"Problem reading FAZIA ElecDetLink.env file : T%1d-Q%1d = %s", t, q, elec.Data());
946 Info(
"ReadTriggerPatterns()",
"Reading FAZIA triggers used during runs...");
947 auto trigs = db->
AddTable(
"FAZIA.Triggers",
"Principal triggers used by FAZIA");
952 env.ReadFile(fullpath.Data(), kEnvAll);
953 TIter it(env.GetTable());
955 while ((rec = (TEnvRec*)it.Next())) {
958 dbrec =
new KVDBRecord(rec->GetName(),
"FAZIA Trigger");
959 dbrec->
AddKey(
"Runs",
"List of Runs");
960 trigs->AddRecord(dbrec);
974 if (idt->InheritsFrom(KVFAZIAIDSiPSA::Class())) {
976 else idt->
SetIDCode(IDCodes::ID_SI2_PSA);
978 else if (idt->InheritsFrom(KVFAZIAIDSiSi::Class())) idt->
SetIDCode(IDCodes::ID_SI1_SI2);
979 else if (idt->InheritsFrom(KVFAZIAIDSiCsI::Class())) idt->
SetIDCode(IDCodes::ID_SI2_CSI);
980 else if (idt->InheritsFrom(KVFAZIAIDSiSiCsI::Class())) {
983 if (labsY.Contains(
"SI1") && labsY.Contains(
"SI2"))
985 else if (labsY.Contains(
"SI1"))
987 else if (labsY.Contains(
"SI2"))
990 else if (idt->InheritsFrom(KVFAZIAIDCsI::Class())) idt->
SetIDCode(IDCodes::ID_CSI_PSA);
992 Error(
"SetIDCodeForIDTelescope",
"Request for telescope name=%s of unknown class=%s",
993 idt->GetName(), idt->IsA()->GetName());
static const Char_t * WorkingDirectory()
Bool_t IsLabelled(const Char_t *l) const
static const Char_t * GetDataSetEnv(const Char_t *dataset, const Char_t *type, const Char_t *defval)
static Bool_t SearchKVFile(const Char_t *name, TString &fullpath, const Char_t *kvsubdir="")
Record folder for the database.
virtual Bool_t AddKey(KVDBKey *key, Bool_t check=kTRUE)
virtual KVRList * GetLinks(const Char_t *key) const
Returns the list of records linked to this record in table "key".
virtual KVDBTable * GetTable(const Char_t *table) const
virtual Bool_t AddTable(KVDBTable *table)
const Char_t * GetDataSetDir() const
const Char_t * GetDataSetEnv(const Char_t *type, const Char_t *defval="") const
TString GetFullPathToDataSetFile(const Char_t *filename)
List of hit groups in a multidetector array.
void AddGroup(KVGroup *grp)
Base class for output signal data produced by a detector.
virtual Bool_t IsExpression() const
virtual void SetValue(Double_t x)
virtual Bool_t IsRaw() const
Base class for detector geometry description.
KVGroup * GetGroup() const
const KVSeqCollection & GetListOfDetectorSignals() const
Extension of TEnv to allow the writing of comments in the file.
void AddCommentLine(const Char_t *line)
virtual Int_t WriteFile(const char *fname, EEnvLevel level=kEnvAll)
Base class to describe database of an experiment ,,.
KVDBRun * GetDBRun(Int_t number) const
virtual void LinkRecordToRunRange(KVDBRecord *rec, UInt_t first_run, UInt_t last_run)
Bool_t FindCalibFile(const Char_t *type, TString &fullpath, const TString &array_name="") const
Base class for FAZIA detectors.
void SetSignal(TGraph *signal, const Char_t *signal_name)
KVDetectorSignal * SetBaseLine(int sigid, Float_t baseline)
static const Char_t * GetNewName(KVString oldname)
KVDetectorSignal * SetFPGAEnergy(int sigid, Int_t idx, Double_t energy)
Telescope for FAZIA identification using SI1 and/or SI2 with CSI.
void AddTriggerPattern(const TString &name, uint16_t value)
Description of a FAZIA detector geometry.
Double_t fImport_Xorg
for geometry import
Double_t fImport_ThetaMin
for geometry import
KVGroupReconstructor * GetReconstructorForGroup(const KVGroup *) const
Specialized group reconstructor for FAZIA.
Double_t fQH1risetime
values of trapezoidal filter rise time set in the fpgas defined in .kvrootrc
Double_t TreatEnergy(Int_t sigid, Int_t eid, UInt_t val)
void SetTriggerPatternsForDataSet(const TString &dataset)
void FillDetectorList(KVReconstructedNucleus *rnuc, KVHashList *DetList, const KVString &DetNames)
void SetGeometryImportParameters(Double_t dt=0.25, Double_t dp=1.0, Double_t tmin=2., Double_t pmin=0, Double_t tmax=20., Double_t pmax=360., Double_t xorg=0, Double_t yorg=0, Double_t zorg=0)
int fQuartet[8][2]
quartet number from #FEE and #FPGA
Double_t GetSetupParameter(const Char_t *parname)
Double_t fImport_dTheta
for geometry import
void SetIDCodeForIDTelescope(KVIDTelescope *) const
Set the FAZIA-specific general identification code for the given telescope.
std::string GetTriggerForCurrentRun() const
void AddDetectorLabel(const Char_t *label)
Bool_t handle_raw_data_event_protobuf(KVProtobufDataReader &)
virtual void BuildTarget()
Int_t fStartingBlockNumber
void DeduceIdentificationTelescopesFromGeometry()
TString fCorrespondanceFile
Bool_t fBuildTarget; //kTRUE to include target frame in the geometry.
Double_t fImport_PhiMax
for geometry import
virtual void SetNameOfDetectors(KVEnv &env)
Double_t fImport_Zorg
for geometry import
virtual void BuildFAZIA()
methods to be implemented in child classes
KVFAZIA(const Char_t *title="")
Default constructor.
void ReadTriggerPatterns(KVExpDB *db)
virtual void DefineStructureFormats(KVGeoImport &)
void GenerateCorrespondanceFile()
void PerformClosedROOTGeometryOperations()
Bool_t treat_event(const DAQ::FzEvent &)
Read raw data for an event.
virtual ~KVFAZIA()
Destructor.
Double_t fImport_dPhi
for geometry import
Double_t fImport_ThetaMax
for geometry import
int fTelescope[8][2]
telescope number from #FEE and #FPGA
KVFAZIATrigger fTrigger
trigger pattern read from data for each event
virtual void MakeCalibrationTables(KVExpDB *)
Override base method in order to read FAZIA trigger for each run.
Bool_t handle_raw_data_event_mfmframe(const MFMCommonFrame &)
virtual void GetGeometryParameters()
Called by the Build method.
void SetTriggerPattern(uint16_t fp)
double oldfaziats
dummy ts to control trigger info transmission rate
TString GetSignalName(Int_t bb, Int_t qq, Int_t tt, Int_t idsig)
Double_t fImport_PhiMin
for geometry import
Int_t fNblocks
number of blocks
void GetDetectorEvent(KVDetectorEvent *detev, const TSeqCollection *dets)
virtual void Build(Int_t=-1)
Build the FAZIA array.
Double_t fImport_Yorg
for geometry import
void CreateCorrespondence()
virtual void SetRawDataFromReconEvent(KVNameValueList &)
Overrides base method in order to set the value of the trigger bit pattern for the event.
Handle FAZIA protobuf-format raw data files.
Path taken by particles through multidetector geometry.
KVGeoDetectorNode * GetNextNode() const
KVSeqCollection * AccessIDTelescopeList()
void IterateBackFrom(const KVGeoDetectorNode *node0=nullptr) const
Information on relative positions of detectors & particle trajectories.
KVDetector * GetDetector() const
Import detector array described by ROOT geometry and set up corresponding KVMultiDetArray object.
void AddAcceptedDetectorName(const char *name)
void SetOrigin(double x, double y, double z)
void SetDetectorPlugin(const TString &name)
void ImportGeometry(Double_t dTheta=0.1, Double_t dPhi=1.0, Double_t ThetaMin=0.0, Double_t PhiMin=0.0, Double_t ThetaMax=180.0, Double_t PhiMax=360.0)
void SetNameCorrespondanceList(const Char_t *)
virtual Bool_t Fired(Option_t *opt="any") const
KVDetector * GetDetector(const Char_t *name) const
Return detector in this structure with given name.
Base class for particle reconstruction in one group of a detector array.
static KVGroupReconstructor * Factory(const TString &plugin="")
Group of detectors which can be treated independently of all others in array.
Extended version of ROOT THashList.
Base class for all detectors or associations of detectors in array which can identify charged particl...
void SetGroup(KVGroup *kvg)
KVDetector * GetDetector(UInt_t n) const
virtual void SetIDCode(UShort_t c)
KVGroup * GetGroup() const
virtual void AddDetector(KVDetector *d)
KVString GetDetectorLabelsForGridCoord(const KVString &axis) const
Description of physical materials used to construct detectors & targets; interface to range tables.
virtual Double_t GetThickness() const
virtual TGeoMedium * GetGeoMedium(const Char_t *="")
static KVIonRangeTable * GetRangeTable()
Base class for describing the geometry of a detector array.
void SetDetectorThicknesses()
virtual void GetDetectorEvent(KVDetectorEvent *detev, const TSeqCollection *fired_params=0)
static Bool_t fCloseGeometryNow
virtual KVGroup * GetGroup(const Char_t *) const
Return pointer to group with name.
void CreateGeoManager(Double_t dx=500, Double_t dy=500, Double_t dz=500)
Bool_t fHandledRawData
set to true if multidetector handles data in last call to HandleRawData
KVSeqCollection * fIDTelescopes
deltaE-E telescopes in groups
TString GetDataSet() const
virtual void MakeCalibrationTables(KVExpDB *)
UInt_t GetCurrentRunNumber() const
virtual void SetIdentifications()
const TSeqCollection * GetTrajectories() const
static Bool_t fBuildTarget
virtual void SetRawDataFromReconEvent(KVNameValueList &)
KVUniqueNameList fFiredDetectors
list of fired detectors after reading raw data event
KVNameValueList fReconParameters
general purpose list of parameters for storing information on data reconstruction
TString fDataSet
name of associated dataset, used with MakeMultiDetector()
KVUnownedList fFiredSignals
list of fired signals after reading raw data event
Handles lists of named parameters with different types, a list of KVNamedParameter objects.
Int_t GetIntValue(const Char_t *name) const
Double_t GetDoubleValue(const Char_t *name) const
void SetValue(const Char_t *name, value_type value)
void SetValue64bit(const Char_t *name, ULong64_t)
Bool_t HasIntParameter(const Char_t *name) const
ULong64_t GetValue64bit(const Char_t *name) const
Bool_t HasParameter(const Char_t *name) const
Strings used to represent a set of ranges of values.
KVNameValueList * GetParameters() const
Read Google Protobuf DAQ files.
Nuclei reconstructed from data measured by a detector array .
virtual void Clear(Option_t *option="")
virtual TObject * First() const
virtual void Add(TObject *obj)
virtual void Delete(Option_t *option="")
Extension of ROOT TString class which allows backwards compatibility with ROOT v3....
void Begin(TString delim) const
KVString Next(Bool_t strip_whitespace=kFALSE) const
Calculation/correction of energy losses of particles through an experimental target.
KVList * GetLayers() const
virtual void Add(TObject *obj)