21 def _bitwiseConversion(value, i='f', o='i'):
 
   23     Bitwise conversion between to python types 
   24     This is equivalently to 
   31     @param i input data type (e.g. f for float) 
   32     @param o output data type (e.g. i for integer) 
   34     s = struct.pack(
'>' + i, value)
 
   35     return struct.unpack(
'>' + o, s)[0]
 
   38 def _decayHashFloatToInt(decayHash, decayHashExtended):
 
   40     Convert decayHash and decayHashExtended 32 bit floats to an 64 bit integer 
   42     decayHashInt = _bitwiseConversion(np.float32(decayHash))
 
   43     decayHashExtendedInt = _bitwiseConversion(np.float32(decayHashExtended))
 
   44     decayHashFullInt = decayHashInt << 32
 
   45     decayHashFullInt += decayHashExtendedInt
 
   46     return decayHashFullInt
 
   51     DecayHashMap using the C++ implementation of DecayTree and DecayNode 
   54     def __init__(self, rootfile, removeRadiativeGammaFlag=False):
 
   58         with uproot.open(rootfile) 
as rf:
 
   60             assert len(trees) == 1
 
   61             ntuple = rf[trees[0]].arrays(library=
'np')
 
   67         for decayHash, decayHashExtended, decayString 
in zip(
 
   68                 ntuple[
'decayHash'], ntuple[
'decayHashExtended'], ntuple[
'decayString']):
 
   69             decayInt = ROOT.Belle2.DecayForest.decayHashFloatToInt(decayHash, decayHashExtended)
 
   70             if decayInt 
in self.
_string_string:
 
   72             self.
_string_string[decayInt] = decayString
 
   73             self.
_forest_forest[decayInt] = ROOT.Belle2.DecayForest(decayString, 
True, removeRadiativeGammaFlag)
 
   77         Return DecayString given the decayHash and decayHashExtended 
   78         @param decayHash output of extraInfo(decayHash) 
   79         @param decayHashExtended output of extraInfo(decayHashExtended) 
   83         return self.
_string_string[ROOT.Belle2.DecayForest.decayHashFloatToInt(decayHash, decayHashExtended)]
 
   87         Return original (MC) DecayTree given the decayHash and decayHashExtended 
   88         @param decayHash output of extraInfo(decayHash) 
   89         @param decayHashExtended output of extraInfo(decayHashExtended) 
   93         return self.
_forest_forest[ROOT.Belle2.DecayForest.decayHashFloatToInt(decayHash, decayHashExtended)].getOriginalTree()
 
   97         Return reconstructed DecayTree given the decayHash and decayHashExtended 
   98         @param decayHash output of extraInfo(decayHash) 
   99         @param decayHashExtended output of extraInfo(decayHashExtended) 
  103         return self.
_forest_forest[ROOT.Belle2.DecayForest.decayHashFloatToInt(decayHash, decayHashExtended)].getReconstructedTree()
 
  107         Print the DecayString in a fancy way given the decayHash and decayHashExtended 
  108         @param decayHash output of extraInfo(decayHash) 
  109         @param decayHashExtended output of extraInfo(decayHashExtended) 
  111         entry = self.
get_stringget_string(decayHash, decayHashExtended)
 
  112         entries = entry.split(
'|')
 
  113         all_particles = re.findall(
r"(-?[0-9]+)", entries[0])
 
  115         if len(all_particles) != len(entries) - 1:
 
  117             raise RuntimeError(
"Bad format of decay string: " +
 
  118                                str(len(all_particles)) + 
" " + str(len(entries)) + 
" " + str(entries))
 
  121         table.append([
"Decay ", prettify_pdg_codes(entries[0])])
 
  122         for particle, mc_decay_string 
in zip(all_particles, entries[1:]):
 
  123             table.append([prettify_pdg_codes(particle), prettify_pdg_codes(mc_decay_string)])
 
  125         basf2.pretty_print_table(table, column_widths=[6, 
'*'])
 
  130     Convert PDG code to a name 
  139     pdg_string = str(pdg_code)
 
  142     except BaseException:
 
  146         if pybasf2.LogPythonInterface.terminal_supports_colors():
 
  147             return '\x1b[31m' + pdg_string + 
'\x1b[0m' 
  149             return '^' + pdg_string
 
  153 def prettify_pdg_codes(text):
 
  155     Prettifiy a string containing PDG codes by replacing PDG codes 
  156     with their corresponding names. 
  159     text = re.sub(
r"(\^?-?[0-9]+)", 
lambda x: _pdg_to_name(x.group(0)), text)
 
  160     text = text.replace(
'gamma', 
'g').replace(
'--> ', 
'').replace(
'anti-', 
'a-')
 
  161     text = text.replace(
'Upsilon', 
'Y').replace(
') ', 
')').replace(
' (', 
'(')
 
_forest
Dict Int -> Reconstructed DecayTree.
_string
Dict Int -> DecayStrings.
def get_original_decay(self, decayHash, decayHashExtended)
def get_reconstructed_decay(self, decayHash, decayHashExtended)
def __init__(self, rootfile, removeRadiativeGammaFlag=False)
def get_string(self, decayHash, decayHashExtended)
def print_hash(self, decayHash, decayHashExtended)