16 from ROOT
import Belle2
20 from rawdata
import add_packers
21 from rawdata
import add_unpackers
23 pxd_rawhits_pack_unpack_collection =
"PXDRawHits_test"
24 pxd_rawhits_pack_unpack_collection_digits =
"PXDDigits_test"
25 pxd_rawhits_pack_unpack_collection_adc = pxd_rawhits_pack_unpack_collection +
"_adc"
26 pxd_rawhits_pack_unpack_collection_roi = pxd_rawhits_pack_unpack_collection +
"_roi"
27 b2.set_random_seed(42)
33 Module which checks if a collection of PXDDigits and
34 a collection of PXDRawHits from the packing/unpacking procedure are equal.
35 The PXDUnpacker does not create PXDDigits but PXDRawHits and therefore these two lists
39 def __init__(self, rawhits_collection='PXDRawHits', digits_collection="PXDDigits"):
50 """ use a some digit information to sort the PXDDigits list
51 Returns a python-list containing the PXDDigts
55 py_list = [x
for x
in unsortedPyStoreArray]
66 """ use a some digit information to sort the PXDRawHits list
67 Returns a python-list containing the PXDRawHits
71 py_list = [x
for x
in unsortedPyStoreArray]
82 """ load the PXD Digits of the simulation and the packed/unpacked ones
93 pxdDigits = self.
sortDigitssortDigits(pxdDigits_unsorted)
94 pxdRawHitsPackedUnpacked = self.
sortRawHitssortRawHits(pxdRawHitsPackedUnpacked_unsorted)
96 if not len(pxdDigits) == len(pxdRawHitsPackedUnpacked):
97 b2.B2FATAL(
"PXDDigits and PXDRawHits count not equal after packing and unpacking")
99 print(f
"Comparing {len(pxdDigits)} pxd digits ")
102 for i
in range(len(pxdDigits)):
104 rawHitPackedUnpacked = pxdRawHitsPackedUnpacked[i]
108 assert rawHitPackedUnpacked.getSensorID().
getID() == digit.getSensorID().
getID()
109 assert rawHitPackedUnpacked.getRow() == digit.getVCellID()
110 assert rawHitPackedUnpacked.getColumn() == digit.getUCellID()
114 assert numpy.isclose(min(255.0, digit.getCharge()), rawHitPackedUnpacked.getCharge())
118 particlegun = b2.register_module(
'ParticleGun')
119 particlegun.param(
'pdgCodes', [13, -13])
120 particlegun.param(
'nTracks', 10)
123 eventinfosetter = b2.register_module(
'EventInfoSetter')
124 eventinfosetter.param({
'evtNumList': [50]})
126 progress = b2.register_module(
'Progress')
128 main = b2.create_path()
130 main.add_module(eventinfosetter)
131 main.add_module(particlegun)
134 b2.set_module_parameters(main, type=
"Geometry", useDB=
False, components=[
"PXD"])
136 main.add_module(progress)
139 add_packers(main, components=[
'PXD'])
142 add_unpackers(main, components=[
'PXD'])
145 for e
in main.modules():
146 if e.name() ==
'PXDUnpacker':
147 e.param(
"PXDRawHitsName", pxd_rawhits_pack_unpack_collection)
148 e.param(
"PXDRawAdcsName", pxd_rawhits_pack_unpack_collection_adc)
149 e.param(
"PXDRawROIsName", pxd_rawhits_pack_unpack_collection_roi)
151 if e.name() ==
'PXDRawHitSorter':
152 e.param(
'rawHits', pxd_rawhits_pack_unpack_collection)
153 e.param(
'digits', pxd_rawhits_pack_unpack_collection_digits)
165 rawhits_collection=pxd_rawhits_pack_unpack_collection,
166 digits_collection=pxd_rawhits_pack_unpack_collection_digits))
A (simplified) python wrapper for StoreArray.
def sortDigits(self, unsortedPyStoreArray)
digits_collection
the PXDDigits
rawhits_collection
the PXDRawHits
def __init__(self, rawhits_collection='PXDRawHits', digits_collection="PXDDigits")
def sortRawHits(self, unsortedPyStoreArray)
int getID(const std::vector< double > &breaks, double t)
get id of the time point t
def add_simulation(path, components=None, bkgfiles=None, bkgOverlay=True, forceSetPXDDataReduction=False, usePXDDataReduction=True, cleanupPXDDataReduction=True, generate_2nd_cdc_hits=False, simulateT0jitter=True, isCosmics=False, FilterEvents=False, usePXDGatedMode=False, skipExperimentCheckForBG=False, save_slow_pions_in_mc=False)