diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingRD/StrippingB2K1MuMu.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingRD/StrippingB2K1MuMu.py new file mode 100644 index 0000000000000000000000000000000000000000..bdbde4d03c84de6f771a3bec5aa816996eec4bea --- /dev/null +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingRD/StrippingB2K1MuMu.py @@ -0,0 +1,193 @@ +############################################################################### +# (c) Copyright 2000-2021 CERN for the benefit of the LHCb Collaboration # +# # +# This software is distributed under the terms of the GNU General Public # +# Licence version 3 (GPL Version 3), copied verbatim in the file "COPYING". # +# # +# In applying this licence, CERN does not waive the privileges and immunities # +# granted to it by virtue of its status as an Intergovernmental Organization # +# or submit itself to any jurisdiction. # +############################################################################### + +""" +Stripping options for "B0 -> ( Jpsi -> mu+ mu- ) ( K1(1270) -> ( K*(892) -> K+ pi- ) pi0 )CC" - reconstructed as Bd -> Jpsi K* for efficiency reasons +Also contains the SS muons line: "B0 -> ( Jpsi -> mu+ mu+ ) ( K1(1270) -> ( K*(892) -> K+ pi- ) pi0 )CC" + +Author: James Brown +""" + +######################################################################## +__author__ = ['James Brown'] +__date__ = '23/06/2023' +__version__ = '$ 1.1 $' + +__all__ = ('Bd2K1MuMuLine', + 'makeBdK1Jpsi', + 'makeJpsis', + 'makeKstars', + 'default_config') + +from Gaudi.Configuration import * + +from GaudiConfUtils.ConfigurableGenerators import CombineParticles +from StandardParticles import StdLooseMuons, StdAllLooseKaons, StdAllLoosePions + +from PhysSelPython.Wrappers import Selection +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder, checkConfig + +default_config = { + 'NAME' : 'Bd2K1MuMu', + 'WGs' : ['RD'], + 'BUILDERTYPE' : 'Bd2K1MuMuLine', + 'CONFIG' : {'PrescaleBd2K1MuMuLine' : 1, + 'PrescaleBd2K1MuMuSSLine' : 1, + ### B0 + 'BMassWindow' : 2500, + 'BDIRA' : 0.9995, + 'BIPCHI2' : 100, + 'BVertexCHI2' : 9, + 'BVDCHI2' : 100, + ### Intermediates - Jpsi/Kst + "InterMIPCHI2DV" : 0, + "InterVertexCHI2" : 9, + "JpsiUpperM" : 9000, + "JpsiLowerM" : 1000, + "KstUpperM" : 1100, + "KstLowerM" : 700, + "Kst_PT" : 800, + ### Final states + "fsPT" : 300, + "fsMIPCHI2DV" : 4, + "fsTRCHI2" : 4, + "fsTRGHOSTPROB" : 0.4, + "fsPROBNN" : 0.4, + "muPROBpi" : 0.95, + "fsM" : 2600, + }, + 'STREAMS' : ['Leptonic'] +} + +class Bd2K1MuMuLine( LineBuilder ) : + + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__( self,name,config ) : + + LineBuilder.__init__(self, name, config) + + Bd2K1MuMuName = name + + # Default SPD hits filter + SPDFilter = { + 'Code' : " ( recSummary(LHCb.RecSummary.nSPDhits,'Raw/Spd/Digits') < 600 )" , + 'Preambulo' : [ "from LoKiNumbers.decorators import *", "from LoKiCore.basic import LHCb" ] + } + + # Make parents + # Mu+Mu-/Mu-Mu+ + self.Jpsi = makeJpsis( "JpsisForBd2K1MuMu", + config['InterMIPCHI2DV'], config['InterVertexCHI2'], config['JpsiLowerM'], config['JpsiUpperM'], + config['fsPT'], config['fsMIPCHI2DV'], config['fsTRCHI2'], config['fsTRGHOSTPROB'], config['fsPROBNN'], config['muPROBpi'], config['fsM'], + sameSign = False) + + # Mu+Mu+/Mu-Mu- (SS) + self.JpsiSS = makeJpsis( "SSJpsisForBd2K1MuMu", + config['InterMIPCHI2DV'], config['InterVertexCHI2'], config['JpsiLowerM'], config['JpsiUpperM'], + config['fsPT'], config['fsMIPCHI2DV'], config['fsTRCHI2'], config['fsTRGHOSTPROB'], config['fsPROBNN'], config['muPROBpi'], config['fsM'], + sameSign = True) + # Kstar candidates + self.Kst = makeKstars( "KstForBd2K1MuMu", + config['InterMIPCHI2DV'], config['InterVertexCHI2'], config['KstLowerM'], config['KstUpperM'], config['Kst_PT'], + config['fsPT'], config['fsMIPCHI2DV'], config['fsTRCHI2'], config['fsTRGHOSTPROB'], config['fsPROBNN'], config['fsM']) + + # Make B0 + self.BdK1Jpsi = makeBdK1Jpsi( name, self.Jpsi, self.Kst, + config['BMassWindow'], config['BVertexCHI2'], config['BIPCHI2'], config['BDIRA'], config['BVDCHI2']) + + # Make B0 with SS + self.BdK1JpsiSS = makeBdK1Jpsi( name+'SS', self.JpsiSS, self.Kst, + config['BMassWindow'], config['BVertexCHI2'], config['BIPCHI2'], config['BDIRA'], config['BVDCHI2']) + + self.lineBd2K1MuMu = StrippingLine( Bd2K1MuMuName+"Line", + prescale = config['PrescaleBd2K1MuMuLine'], + selection = self.BdK1Jpsi, + FILTER = SPDFilter, + EnableFlavourTagging = False, + RequiredRawEvents = ["Trigger","Muon","Calo","Rich","Velo","Tracker"]) + + self.lineBd2K1MuMuSS = StrippingLine( Bd2K1MuMuName+"SSLine", + prescale = config['PrescaleBd2K1MuMuSSLine'], + selection = self.BdK1JpsiSS, + FILTER = SPDFilter, + EnableFlavourTagging = False, + RequiredRawEvents = ["Trigger","Muon","Calo","Rich","Velo","Tracker"]) + + self.registerLine(self.lineBd2K1MuMu) + self.registerLine(self.lineBd2K1MuMuSS) + +############################################################## FUNCTIONS + +def makeBdK1Jpsi( name, Jpsi, K1, + BMassWindow, BVertexCHI2, BIPCHI2, BDIRA, BVDCHI2) : + + _combination_cuts = "( ADAMASS('B0') < %(BMassWindow)s * MeV )" %locals() + + _mother_cuts = "( (VFASPF(VCHI2/VDOF) < %(BVertexCHI2)s ) & (BPVIPCHI2() < %(BIPCHI2)s ) & (BPVDIRA > %(BDIRA)s ) & (BPVVDCHI2 > %(BVDCHI2)s ) )" %locals() + + CombineBdK1Jpsi = CombineParticles( DecayDescriptor = "[B0 -> J/psi(1S) K*(892)0]cc", + CombinationCut = _combination_cuts, + MotherCut = _mother_cuts ) + + return Selection( name, + Algorithm = CombineBdK1Jpsi, + RequiredSelections = [ Jpsi, K1 ] ) + +def makeJpsis( name, + InterMIPCHI2DV, InterVertexCHI2, JpsiLowerM, JpsiUpperM, + fsPT, fsMIPCHI2DV, fsTRCHI2, fsTRGHOSTPROB, fsPROBNN, muPROBpi, fsM, + sameSign) : + + _daughters_cuts = '(HASMUON) & (ISMUON) & ( PT > %(fsPT)s ) & ( MIPCHI2DV(PRIMARY) > %(fsMIPCHI2DV)s ) & ( TRGHOSTPROB < %(fsTRGHOSTPROB)s ) & ( TRCHI2DOF < %(fsTRCHI2)s ) & ( PROBNNpi < %(muPROBpi)s ) & ( PROBNNmu > %(fsPROBNN)s )' %locals() + + _combination_cuts = "(AM > 100*MeV)" + + _mother_cuts = "(MM > %(JpsiLowerM)s *MeV) & (MM < %(JpsiUpperM)s *MeV) & (VFASPF(VCHI2/VDOF)<%(InterVertexCHI2)s) & (MIPCHI2DV(PRIMARY) > %(InterMIPCHI2DV)s )" %locals() + + # identical cuts, just with the muon sign either the same or opposite + if sameSign : + decDesc = "[J/psi(1S) -> mu+ mu+]cc" + else: + decDesc = "J/psi(1S) -> mu+ mu-" + + CombineDiMuons = CombineParticles( DecayDescriptor = decDesc, + DaughtersCuts = { "mu+" : _daughters_cuts, "mu-" : _daughters_cuts}, + CombinationCut = _combination_cuts, + MotherCut = _mother_cuts ) + + DiMuonConf = CombineDiMuons.configurable("CombineDiMuons") + + return Selection( name, + Algorithm = CombineDiMuons, + RequiredSelections = [ StdLooseMuons ] ) + +def makeKstars( name, + InterMIPCHI2DV, InterVertexCHI2, KstLowerM, KstUpperM, Kst_PT, + fsPT, fsMIPCHI2DV, fsTRCHI2, fsTRGHOSTPROB, fsPROBNN, fsM) : + + _daughters_cuts = "(PT > %(fsPT)s) & (MIPCHI2DV(PRIMARY)>%(fsMIPCHI2DV)s) & (TRGHOSTPROB<%(fsTRGHOSTPROB)s) & (TRCHI2DOF<%(fsTRCHI2)s) & (M<%(fsM)s)" %locals() + + _combination_cuts = "(APT > 500 *MeV) & (ADAMASS('K*(892)0') < 300 *MeV) & (ADOCACHI2CUT(30, ''))" + + _mother_cuts = "(MM > %(KstLowerM)s *MeV) & (MM < %(KstUpperM)s *MeV) & (VFASPF(VCHI2/VDOF)<%(InterVertexCHI2)s) & (MIPCHI2DV(PRIMARY) > %(InterMIPCHI2DV)s ) & (PT>%(Kst_PT)s *MeV)" %locals() + + CombineKst = CombineParticles( DecayDescriptor = "[K*(892)0 -> K+ pi-]cc", + DaughtersCuts = {"K+" : _daughters_cuts + " & (PROBNNk>%(fsPROBNN)s)" %locals(), "pi-" : _daughters_cuts + " & (PROBNNpi>%(fsPROBNN)s)" %locals()}, + CombinationCut = _combination_cuts, + MotherCut = _mother_cuts) + + KstConf = CombineKst.configurable("CombineKst") + + return Selection( name, + Algorithm = CombineKst, + RequiredSelections = [ StdAllLooseKaons, StdAllLoosePions ] ) \ No newline at end of file