Skip to content

Commit

Permalink
Ported DDSimpleMuonDigi
Browse files Browse the repository at this point in the history
  • Loading branch information
Katerina Kostova committed Jul 31, 2024
1 parent a0e69a5 commit f1bb546
Show file tree
Hide file tree
Showing 5 changed files with 271 additions and 224 deletions.
2 changes: 1 addition & 1 deletion k4GaudiPandora/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#[[
Copyright (c) 2020-2023 Key4hep-Project.
Copyright (c) 2020-2024 Key4hep-Project.
This file is part of Key4hep.
See https://key4hep.github.io/key4hep-doc/ for further info.
Expand Down
196 changes: 84 additions & 112 deletions k4GaudiPandora/include/CalorimeterHitType.h
Original file line number Diff line number Diff line change
@@ -1,4 +1,22 @@
#ifndef CalorimeterHitType_h
/*
* Copyright (c) 2020-2024 Key4hep-Project.
*
* This file is part of Key4hep.
* See https://key4hep.github.io/key4hep-doc/ for further info.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef CalorimeterHitType_h
#define CalorimeterHitType_h 1

#include <iostream>
Expand All @@ -9,182 +27,136 @@
* Example usage: <br>
* <pre>
* lcio::CalorimeterHit* cHit = .... ;
*
* // set the type (e.g. in digitization )
*
* // set the type (e.g. in digitization )
* cHit->setType( CHT( CHT::em , CHT::ecal , CHT::plug , 12 ) ) ;
*
* ...
*
* CHT cht = cHit->getType() ;
*
*
* // sum energies for electromagentic, hadronic and tailcatcher:
* if( cht.is( CHT::em ) )
* if( cht.is( CHT::em ) )
* e_em += cHit->getEnergy() ;
* else
* if ( cht.is(CHT::had ) )
* else
* if ( cht.is(CHT::had ) )
* e_had += cHit->getEnergy() ;
* else
* e_muon += cHit->getEnergy() ;
*
*
* // use only EcalPlug hits:
* if( cht.is( CHT::ecal) && cht.is( CHT::plug) )
*
* // get the layer number (e.g. for calibration or clustering)
* unsigned l = cht.layer() ;
* if( cht.is( CHT::ecal) && cht.is( CHT::plug) )
*
* // get the layer number (e.g. for calibration or clustering)
* unsigned l = cht.layer() ;
* // or directly :
* unsigned l = CHT( cHit->getType() ).layer() ;
*
* // detailed print:
* std::cout << CHT( cHit->getType() ) << std::endl ;
*
* </pre>
*
*
* F.Gaede, DESY, 12/2008
*/

class CHT{

class CHT {
public:

/** calorimeter types */
typedef enum {
em = 0 ,
had = 1,
muon = 2
} CaloType ;

typedef enum { em = 0, had = 1, muon = 2 } CaloType;

/** calo ids - specific to ILD */
typedef enum {
unknown = 0 ,
ecal = 1 ,
hcal = 2 ,
yoke = 3 ,
lcal = 4 ,
lhcal = 5 ,
bcal = 6
} CaloID ;

/** calo layout / subdetector */
typedef enum {
any = 0 ,
barrel = 1 ,
endcap = 2 ,
plug = 3 ,
ring = 4
} Layout ;


typedef enum { unknown = 0, ecal = 1, hcal = 2, yoke = 3, lcal = 4, lhcal = 5, bcal = 6 } CaloID;

/** calo layout / subdetector */
typedef enum { any = 0, barrel = 1, endcap = 2, plug = 3, ring = 4 } Layout;

/** C'tor for initialization from CalorimeterHit::getType() */
CHT(int type) :_type(type) {
}

CHT(int type) : _type(type) {}

/** C'tor for encoding the calo type inforamtion */
CHT(CaloType c, CaloID n, Layout l , unsigned lay):
_type(c * fCaloType + n * fCaloID + l * fLayout + lay * fLayer)
{}

CHT(CaloType c, CaloID n, Layout l, unsigned lay) : _type(c * fCaloType + n * fCaloID + l * fLayout + lay * fLayer) {}

/** calorimeter type: CHT::em , CHT::had, CHT::muon */
CaloType caloType() const {
return (CaloType) (_type % fCaloID ) ;
}
CaloType caloType() const { return (CaloType)(_type % fCaloID); }

/** calo ID - see enum CaloID for allowed values */
CaloID caloID() const {
return (CaloID) ( (_type % fLayout ) / fCaloID ) ;
}

CaloID caloID() const { return (CaloID)((_type % fLayout) / fCaloID); }

/** calo layout - see enum layout for allowed values */
Layout layout() const {
return (Layout) ( (_type % fLayer ) / fLayout ) ;
}

Layout layout() const { return (Layout)((_type % fLayer) / fLayout); }

/** calo layer of hit */
unsigned layer() const {
return unsigned ( _type ) / fLayer ;
}

bool is(CaloType t) const {
return caloType() == t ;
}

bool is(CaloID n) const {
return caloID() == n ;
}

bool is(Layout l) const {
return layout() == l ;
}

unsigned layer() const { return unsigned(_type) / fLayer; }

bool is(CaloType t) const { return caloType() == t; }

bool is(CaloID n) const { return caloID() == n; }

bool is(Layout l) const { return layout() == l; }

/** automatic conversion to int */
operator int() const { return _type ;}
operator int() const { return _type; }

/** explicit conversion to int */
int toInt() const { return _type ;}
int toInt() const { return _type; }

protected:

int _type ;

static const int fCaloType = 1 ;
static const int fCaloID = 10 ;
static const int fLayout = 1000 ;
static const int fLayer = 10000 ;

} ;
int _type;

/** detailed string for calo type */
std::ostream& operator<<(std::ostream& os, const CHT& cht) ;
static const int fCaloType = 1;
static const int fCaloID = 10;
static const int fLayout = 1000;
static const int fLayer = 10000;
};

/** detailed string for calo type */
std::ostream& operator<<(std::ostream& os, const CHT& cht);

/** Return Layout based on the collection name, e.g. if name contains tolower("endcap") CHT::endcap is returned. In case no known layout
is found, CHT::any is returned.*/
CHT::Layout layoutFromString(const std::string& name) ;
CHT::Layout layoutFromString(const std::string& name);

/** Return caloID based on the collection name, e.g. if name contains tolower("HCal") CHT::hcal is returned. In case no known type
is found, CHT::unknown is returned.*/
CHT::CaloID caloIDFromString(const std::string& name) ;
CHT::CaloID caloIDFromString(const std::string& name);

/** Return caloType from string, e.g. if name contains tolower("Had") CHT::had is returned. In case no known type
is found, CHT::em is returned.*/
CHT::CaloType caloTypeFromString(const std::string& name) ;


CHT::CaloType caloTypeFromString(const std::string& name);

#endif


// int main(){

// CHT ct( CHT::em , CHT::ecal , CHT::plug , 12 ) ;

// std::cout << ct << std::endl ;

// std::cout << " caloType : " << ct.toInt() << std::endl ;
// std::cout << " caloID " << ct.caloID()
// << " is bcal " << ct.is( CHT::bcal )
// << " is muon " << ct.is( CHT::muon )
// << " layer " << ct.layer()

// std::cout << " caloID " << ct.caloID()
// << " is bcal " << ct.is( CHT::bcal )
// << " is muon " << ct.is( CHT::muon )
// << " layer " << ct.layer()
// << std::endl ;

// int i = CHT( CHT::muon , CHT::ecal , CHT::endcap , 123 ) ;

// std::cout << " type i : " << i << std::endl ;


// std::cout << " layer from int : " << CHT(i).layer() << std::endl ;

// CHT it(i) ;

// std::cout << " caloID " << it.caloID()
// << " is bcal " << it.is( CHT::bcal )
// << " is muon " << it.is( CHT::muon )
// << " is endcap " << it.is( CHT::endcap )
// << " layer " << it.layer()
// << " layout " << it.layout()
// std::cout << " caloID " << it.caloID()
// << " is bcal " << it.is( CHT::bcal )
// << " is muon " << it.is( CHT::muon )
// << " is endcap " << it.is( CHT::endcap )
// << " layer " << it.layer()
// << " layout " << it.layout()
// << std::endl ;


// std::cout << it << std::endl ;

// CHT ct2 = 12345678 ;
Expand Down
76 changes: 48 additions & 28 deletions k4GaudiPandora/include/DDSimpleMuonDigi.h
Original file line number Diff line number Diff line change
@@ -1,70 +1,90 @@
/*
* Copyright (c) 2020-2024 Key4hep-Project.
*
* This file is part of Key4hep.
* See https://key4hep.github.io/key4hep-doc/ for further info.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef DDSimpleMuonDigi_H
#define DDSimpleMuonDigi_H

#include "Gaudi/Property.h"
#include "GaudiAlg/Transformer.h"
#include "edm4hep/SimCalorimeterHitCollection.h"
#include "edm4hep/CaloHitContributionCollection.h"
#include "edm4hep/CalorimeterHitCollection.h"
#include "edm4hep/EventHeaderCollection.h"
#include "edm4hep/MCRecoCaloAssociationCollection.h"
#include "edm4hep/CaloHitContributionCollection.h"
#include "edm4hep/SimCalorimeterHitCollection.h"

#include "CalorimeterHitType.h"
#include "DDRec/SurfaceManager.h"
#include "k4FWCore/Transformer.h"
#include "k4Interface/IGeoSvc.h"
#include "k4Interface/IUniqueIDGenSvc.h"
#include "k4FWCore/Transformer.h"
#include "DDRec/SurfaceManager.h"

#include <random>
#include <string>
#include <vector>

struct DDSimpleMuonDigi final
: k4FWCore::MultiTransformer<
std::tuple<edm4hep::CalorimeterHitCollection,edm4hep::MCRecoCaloAssociationCollection>(
const edm4hep::SimCalorimeterHitCollection&, const edm4hep::EventHeaderCollection&)> {
: k4FWCore::MultiTransformer<
std::tuple<edm4hep::CalorimeterHitCollection, edm4hep::MCRecoCaloAssociationCollection>(
const edm4hep::SimCalorimeterHitCollection&, const edm4hep::EventHeaderCollection&)> {
DDSimpleMuonDigi(const std::string& name, ISvcLocator* svcLoc);

StatusCode initialize() override;
//StatusCode finalize() override;

std::tuple<edm4hep::CalorimeterHitCollection, edm4hep::MCRecoCaloAssociationCollection> operator()
(const edm4hep::SimCalorimeterHitCollection& simCaloHits,
const edm4hep::EventHeaderCollection& headers) const override;
std::tuple<edm4hep::CalorimeterHitCollection, edm4hep::MCRecoCaloAssociationCollection> operator()(
const edm4hep::SimCalorimeterHitCollection& simCaloHits,
const edm4hep::EventHeaderCollection& headers) const override;

private:
Gaudi::Property<std::string> m_subDetName{this, "SubDetectorName", "VXD", "Name of the subdetector"};
Gaudi::Property<std::string> m_subDetName{this, "SubDetectorName", "VXD", "Name of the subdetector"};
Gaudi::Property<std::vector<int>> m_layersToKeepBarrelVec{
this, "KeepBarrelLayersVec", {0}, "Vector of Barrel layers to be kept. Layers start at 1!"};
this, "KeepBarrelLayersVec", {0}, "Vector of Barrel layers to be kept. Layers start at 1!"};
Gaudi::Property<std::vector<int>> m_layersToKeepEndCapVec{
this, "KeepEndcapLayersVec", {0}, "Vector of Endcap layers to be kept. Layers start at 1!"};
this, "KeepEndcapLayersVec", {0}, "Vector of Endcap layers to be kept. Layers start at 1!"};
//Gaudi::Property<std::vector<bool>> useLayersBarrelVec{this, "useBarrelLayerVector", false, "whether to use the endcap layer vector"};
//Gaudi::Property<std::vector<bool>> useLayersEndcapVec{this, "useEndCapLayerVector", false, "whether to use the EndCap layer vector"};
Gaudi::Property<std::string> m_muonCollections{this, "muonCollections", "muonCollections", "The input collection of Muons"};
Gaudi::Property<std::string> m_muonCollections{this, "muonCollections", "muonCollections",
"The input collection of Muons"};
Gaudi::Property<std::string> outputRelCollection{this, "outputRelCollection", "outputRelCollection",
"The output collection of relations"};
Gaudi::Property<std::string> outputMuonCollection{this, "outputMuonCollection","outputMuonCollection",
"The output collection of muons"};
"The output collection of relations"};
Gaudi::Property<std::string> outputMuonCollection{this, "outputMuonCollection", "outputMuonCollection",
"The output collection of muons"};
Gaudi::Property<std::string> m_encodingStringVariable{
this, "EncodingStringParameterName", "GlobalTrackerReadoutID",
"The name of the DD4hep constant that contains the Encoding string for tracking detectors"};
Gaudi::Property<std::string> m_cellIDLayerString {this, "CellIDLayerString","Layer", "Name of the part of the cellID that holds the layer"};
Gaudi::Property<float> m_thresholdMuon{this, "MuonThreshold", {0.025}, "Threshold for muon"};
Gaudi::Property<float> m_timeThresholdMuon{this, "timethresholdMuon", {0.025}, "time threshold for muons"};
Gaudi::Property<float> m_calibrCoeffMuon{this, "calibrationCoeffmuon", {120000.0}, "Callibration coefficient of muons"};
Gaudi::Property<std::string> m_cellIDLayerString{this, "CellIDLayerString", "Layer",
"Name of the part of the cellID that holds the layer"};
Gaudi::Property<float> m_thresholdMuon{this, "MuonThreshold", {0.025}, "Threshold for muon"};
Gaudi::Property<float> m_timeThresholdMuon{this, "timethresholdMuon", {0.025}, "time threshold for muons"};
Gaudi::Property<float> m_calibrCoeffMuon{
this, "calibrationCoeffmuon", {120000.0}, "Callibration coefficient of muons"};
Gaudi::Property<float> m_maxHitEnergyMuon{this, "maxMuonHitEnergy", {2.0}, "Threshold for maximum muon hit energy"};
Gaudi::Property<std::string> m_detectorNameBarrel{this, "detectornameB", "YokeBarrel", "Name of the subdetector"};
Gaudi::Property<std::string> m_detectorNameEndcap{this, "detectornameE", "YokeEndcap",
"Name of the second subdetector"};
std::string m_collName;
std::vector<bool> m_useLayersBarrelVec{}, m_useLayersEndcapVec{};
"Name of the second subdetector"};

std::string m_collName;
std::vector<bool> m_useLayersBarrelVec{}, m_useLayersEndcapVec{};
SmartIF<IGeoSvc> m_geoSvc;
SmartIF<IUniqueIDGenSvc> m_uidSvc;

bool useLayer(CHT::Layout caloLayout, unsigned int layer) const ;
float computeHitTime( const edm4hep:: SimCalorimeterHit &h ) const ;

bool useLayer(CHT::Layout caloLayout, unsigned int layer) const;
float computeHitTime(const edm4hep::SimCalorimeterHit& h) const;
};
DECLARE_COMPONENT(DDSimpleMuonDigi)
#endif
Expand Down
Loading

0 comments on commit f1bb546

Please sign in to comment.