From b1c364cc13db16eb665672821e18190acf340497 Mon Sep 17 00:00:00 2001 From: Patrik Adlarson <patrik.harri.adlarson@cern.ch> Date: Wed, 5 Jul 2023 15:21:24 +0200 Subject: [PATCH 01/11] "Merge Charm_Xic0ToMuNu_2018-patches' into '2018-patches'" --- .../StrippingCharm/StrippingXic0ToXiMuNu.py | 138 +++++++++++++++++ .../StrippingXic0ToXiMuNu_WS.py | 140 ++++++++++++++++++ 2 files changed, 278 insertions(+) create mode 100755 Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu.py create mode 100644 Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu_WS.py diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu.py new file mode 100755 index 000000000..d908d70e4 --- /dev/null +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu.py @@ -0,0 +1,138 @@ +############################################################################### +# (c) Copyright 2023 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 lines for Xic0 -> Xi- mu+ nu +The lines are used to complement the inclusive Xi Turbo lines by adding +Velo raw banks to study if the Xi- can be reconstructed as an upstream track. +""" +from GaudiConfUtils.ConfigurableGenerators import CombineParticles +from Configurables import FilterDesktop +from PhysConf.Selections import ( + FilterSelection, CombineSelection, MergedSelection) +from PhysSelPython.Wrappers import AutomaticData +from StrippingUtils.Utils import LineBuilder +from StrippingConf.StrippingLine import StrippingLine +__author__ = ["Patrik Adlarson", "Artur Ukleja", + "Marian Stahl", "Laurent Dufour"] + +__all__ = ("Xic0ToXiMuNuConf", "default_config") + +moduleName = "Xic0ToXiMuNu" + + +# Import Packages + +# Default configuration dictionary +default_config = { + "NAME": "Xic0ToXiMuNu", + "BUILDERTYPE": "Xic0ToXiMuNuConf", + "CONFIG": { + "descriptor_xi": ["[Xi- -> Lambda0 pi-]cc"], + "descriptor_ximu": ["[Xi_c0 -> Xi- mu+]cc"], + "RequiredRawEvents": ["Velo"], + "bach_pion": { + "tes": "Phys/StdAllNoPIDsPions/Particles", + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)" + }, + "down_pion": { + "tes": "Phys/StdNoPIDsDownPions/Particles", + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)" + }, + "bach_muon": { + "tes": "Phys/StdAllNoPIDsMuons/Particles", + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)" + }, + "lambda_ll": { + "tes": "Phys/StdVeryLooseLambdaLL/Particles", + "filter": """(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) & + (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & + (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)""" + }, + "lambda_dd": { + "tes": "Phys/StdLooseLambdaDD/Particles", + "filter": """(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) & + (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)""" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": """(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & + (P>8*GeV) & (PT>400*MeV) """ + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": """(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) & + (P>15*GeV) & (PT>600*MeV)""" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": """(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) & + (P>15*GeV) & (PT>600*MeV)""" + }, + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "xc0_lll": { + "comb_cut": """AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)""", + "mother_cut": """(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)""" + }, + "xc0_ddl": { + "comb_cut": """AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)""", + "mother_cut": """(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) """ + }, + "xc0_ddd": { + "comb_cut": """AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)""", + "mother_cut": """(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)""" + }, + }, + "STREAMS": { + "CharmCompleteEvent": ["StrippingXic0ToXiMuNu_{0}Line".format(tt) for tt in ["LLL", "DDL", "DDD"]] + }, + "WGs": ["Charm"] +} + + +class Xic0ToXiMuNuConf(LineBuilder): + + __configuration_keys__ = default_config["CONFIG"].keys() + + def __init__(self, moduleName, config): + LineBuilder.__init__(self, moduleName, config) + # decay products + bach_pion = FilterSelection(moduleName+"_bach_pion", [AutomaticData( + config["bach_pion"]["tes"])], Code=config["bach_pion"]["filter"]) + down_pion = FilterSelection(moduleName+"_down_pion", [AutomaticData( + config["down_pion"]["tes"])], Code=config["down_pion"]["filter"]) + bach_muon = FilterSelection(moduleName+"_bach_muon", [AutomaticData( + config["bach_muon"]["tes"])], Code=config["bach_muon"]["filter"]) + lambda_ll = FilterSelection(moduleName+"_lambda_ll", [AutomaticData( + config["lambda_ll"]["tes"])], Code=config["lambda_ll"]["filter"]) + lambda_dd = FilterSelection(moduleName+"_lambda_dd", [AutomaticData( + config["lambda_dd"]["tes"])], Code=config["lambda_dd"]["filter"]) + xi_lll = CombineSelection(moduleName+"_xi_lll", [lambda_ll, bach_pion], DecayDescriptors=config["descriptor_xi"], + CombinationCut=config["xi_lll"]["comb_cut"], MotherCut=config["xi_lll"]["mother_cut"]) + xi_ddl = CombineSelection(moduleName+"_xi_ddl", [lambda_dd, bach_pion], DecayDescriptors=config["descriptor_xi"], + CombinationCut=config["xi_ddl"]["comb_cut"], MotherCut=config["xi_ddl"]["mother_cut"]) + xi_ddd = CombineSelection(moduleName+"_xi_ddd", [lambda_dd, down_pion], DecayDescriptors=config["descriptor_xi"], + CombinationCut=config["xi_ddd"]["comb_cut"], MotherCut=config["xi_ddd"]["mother_cut"]) + # charm baryon candidates; this could look a bit nicer when looping over track types and channels... + + ximu_lll = CombineSelection(moduleName+"_ximu_lll", [xi_lll, bach_muon], DecayDescriptors=config["descriptor_ximu"], + CombinationCut=config["amass_ximu"]+config["xc0_lll"]["comb_cut"], MotherCut=config["xc0_lll"]["mother_cut"]) + ximu_ddl = CombineSelection(moduleName+"_ximu_ddl", [xi_ddl, bach_muon], DecayDescriptors=config["descriptor_ximu"], + CombinationCut=config["amass_ximu"]+config["xc0_ddl"]["comb_cut"], MotherCut=config["xc0_ddl"]["mother_cut"]) + ximu_ddd = CombineSelection(moduleName+"_ximu_ddd", [xi_ddd, bach_muon], DecayDescriptors=config["descriptor_ximu"], + CombinationCut=config["amass_ximu"]+config["xc0_ddd"]["comb_cut"], MotherCut=config["xc0_ddd"]["mother_cut"]) + + # Create the stripping lines + self.registerLine(StrippingLine( + moduleName+"_LLLLine", RequiredRawEvents=config["RequiredRawEvents"], algos=[ximu_lll], MDSTFlag=True)) + self.registerLine(StrippingLine( + moduleName+"_DDLLine", RequiredRawEvents=config["RequiredRawEvents"], algos=[ximu_ddl], MDSTFlag=True)) + self.registerLine(StrippingLine( + moduleName+"_DDDLine", RequiredRawEvents=config["RequiredRawEvents"], algos=[ximu_ddd], MDSTFlag=True)) diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu_WS.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu_WS.py new file mode 100644 index 000000000..5316c56de --- /dev/null +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic0ToXiMuNu_WS.py @@ -0,0 +1,140 @@ +############################################################################### +# (c) Copyright 2023 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 lines for Xic0 -> Xi- mu+ nu +The lines are used to complement the inclusive Xi Turbo lines by adding +Velo raw banks to study if the Xi- can be reconstructed as an upstream track. +The wrong sign StrippingLine is needed to understand the background from when Xi- +is wrongly combined with a muon from another event. +""" +from GaudiConfUtils.ConfigurableGenerators import CombineParticles +from Configurables import FilterDesktop +from PhysConf.Selections import ( + FilterSelection, CombineSelection, MergedSelection) +from PhysSelPython.Wrappers import AutomaticData +from StrippingUtils.Utils import LineBuilder +from StrippingConf.StrippingLine import StrippingLine +__author__ = ["Patrik Adlarson", "Artur Ukleja", + "Marian Stahl", "Laurent Dufour"] + +__all__ = ("Xic0ToXiMuNu_WSConf", "default_config") + +moduleName = "Xic0ToXiMuNu_WS" + + +# Import Packages + +# Default configuration dictionary +default_config = { + "NAME": "Xic0ToXiMuNu_WS", + "BUILDERTYPE": "Xic0ToXiMuNu_WSConf", + "CONFIG": { + "descriptor_xi": ["[Xi- -> Lambda0 pi-]cc"], + "descriptor_ximu": ["[Xi_c0 -> Xi- mu-]cc"], + "RequiredRawEvents": ["Velo"], + "bach_pion": { + "tes": "Phys/StdAllNoPIDsPions/Particles", + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)" + }, + "down_pion": { + "tes": "Phys/StdNoPIDsDownPions/Particles", + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)" + }, + "bach_muon": { + "tes": "Phys/StdAllNoPIDsMuons/Particles", + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)" + }, + "lambda_ll": { + "tes": "Phys/StdVeryLooseLambdaLL/Particles", + "filter": """(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) & + (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & + (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)""" + }, + "lambda_dd": { + "tes": "Phys/StdLooseLambdaDD/Particles", + "filter": """(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) & + (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)""" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": """(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & + (P>8*GeV) & (PT>400*MeV) """ + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": """(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) & + (P>15*GeV) & (PT>600*MeV)""" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": """(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) & + (P>15*GeV) & (PT>600*MeV)""" + }, + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "xc0_lll": { + "comb_cut": """AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)""", + "mother_cut": """(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)""" + }, + "xc0_ddl": { + "comb_cut": """AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)""", + "mother_cut": """(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) """ + }, + "xc0_ddd": { + "comb_cut": """AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)""", + "mother_cut": """(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)""" + }, + }, + "STREAMS": { + "CharmCompleteEvent": ["StrippingXic0ToXiMuNu_WS_{0}Line".format(tt) for tt in ["LLL", "DDL", "DDD"]] + }, + "WGs": ["Charm"] +} + + +class Xic0ToXiMuNu_WSConf(LineBuilder): + + __configuration_keys__ = default_config["CONFIG"].keys() + + def __init__(self, moduleName, config): + LineBuilder.__init__(self, moduleName, config) + # decay products + bach_pion = FilterSelection(moduleName+"_bach_pion", [AutomaticData( + config["bach_pion"]["tes"])], Code=config["bach_pion"]["filter"]) + down_pion = FilterSelection(moduleName+"_down_pion", [AutomaticData( + config["down_pion"]["tes"])], Code=config["down_pion"]["filter"]) + bach_muon = FilterSelection(moduleName+"_bach_muon", [AutomaticData( + config["bach_muon"]["tes"])], Code=config["bach_muon"]["filter"]) + lambda_ll = FilterSelection(moduleName+"_lambda_ll", [AutomaticData( + config["lambda_ll"]["tes"])], Code=config["lambda_ll"]["filter"]) + lambda_dd = FilterSelection(moduleName+"_lambda_dd", [AutomaticData( + config["lambda_dd"]["tes"])], Code=config["lambda_dd"]["filter"]) + xi_lll = CombineSelection(moduleName+"_xi_lll", [lambda_ll, bach_pion], DecayDescriptors=config["descriptor_xi"], + CombinationCut=config["xi_lll"]["comb_cut"], MotherCut=config["xi_lll"]["mother_cut"]) + xi_ddl = CombineSelection(moduleName+"_xi_ddl", [lambda_dd, bach_pion], DecayDescriptors=config["descriptor_xi"], + CombinationCut=config["xi_ddl"]["comb_cut"], MotherCut=config["xi_ddl"]["mother_cut"]) + xi_ddd = CombineSelection(moduleName+"_xi_ddd", [lambda_dd, down_pion], DecayDescriptors=config["descriptor_xi"], + CombinationCut=config["xi_ddd"]["comb_cut"], MotherCut=config["xi_ddd"]["mother_cut"]) + # charm baryon candidates; this could look a bit nicer when looping over track types and channels... + + ximu_lll = CombineSelection(moduleName+"_ximu_lll", [xi_lll, bach_muon], DecayDescriptors=config["descriptor_ximu"], + CombinationCut=config["amass_ximu"]+config["xc0_lll"]["comb_cut"], MotherCut=config["xc0_lll"]["mother_cut"]) + ximu_ddl = CombineSelection(moduleName+"_ximu_ddl", [xi_ddl, bach_muon], DecayDescriptors=config["descriptor_ximu"], + CombinationCut=config["amass_ximu"]+config["xc0_ddl"]["comb_cut"], MotherCut=config["xc0_ddl"]["mother_cut"]) + ximu_ddd = CombineSelection(moduleName+"_ximu_ddd", [xi_ddd, bach_muon], DecayDescriptors=config["descriptor_ximu"], + CombinationCut=config["amass_ximu"]+config["xc0_ddd"]["comb_cut"], MotherCut=config["xc0_ddd"]["mother_cut"]) + + # Create the stripping lines + self.registerLine(StrippingLine( + moduleName+"_LLLLine", RequiredRawEvents=config["RequiredRawEvents"], algos=[ximu_lll], MDSTFlag=True)) + self.registerLine(StrippingLine( + moduleName+"_DDLLine", RequiredRawEvents=config["RequiredRawEvents"], algos=[ximu_ddl], MDSTFlag=True)) + self.registerLine(StrippingLine( + moduleName+"_DDDLine", RequiredRawEvents=config["RequiredRawEvents"], algos=[ximu_ddd], MDSTFlag=True)) -- GitLab From 01f525aa7d67c035accbf777b23819841f98d38a Mon Sep 17 00:00:00 2001 From: Michele Atzeni <michele.atzeni@cern.ch> Date: Thu, 13 Jul 2023 09:09:42 +0200 Subject: [PATCH 02/11] Stripping line for the LFV search of Dstarm2D0pi2ETau3Pi for Run2 2018 patches --- .../StrippingCharm/StrippingDstarD02ETau.py | 488 ++++++++++++++++++ 1 file changed, 488 insertions(+) create mode 100644 Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingDstarD02ETau.py diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingDstarD02ETau.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingDstarD02ETau.py new file mode 100644 index 000000000..1a94d9d54 --- /dev/null +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingDstarD02ETau.py @@ -0,0 +1,488 @@ +############################################################################### +# (c) Copyright 2000-2023 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. # +############################################################################### +# +__author__ = 'Michele Atzeni, Eluned Anne Smith' +__date__ = '2023/06/30' +__version__ = '$Revision: 1.0 $' +__all__ = ('StrippingDstarD02ETauConf', + 'default_config') +#from Gaudi.Configuration import * +from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles +from PhysSelPython.Wrappers import Selection, DataOnDemand +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder +from StandardParticles import StdNoPIDsPions, StdAllLooseElectrons, StdLooseKaons +from Configurables import TisTosParticleTagger +''' + Stripping for: + Opposite Sign of the leptons (OS) + - D*(2010)+ -> pi+ (D0-> tau+ -> (pi+ pi- pi+ anti-nu_tau) e-) + - D*(2010)+ -> pi+ (D0-> tau- -> (pi+ pi- pi+ nu_tau) e+) + Same Sign of the leptons (SS) + - D*(2010)+ -> pi+ (D0-> tau+ -> (pi+ pi- pi+ anti-nu_tau) e+) + - D*(2010)+ -> pi+ (D0-> tau- -> (pi- pi+ pi- nu_tau) e-) + Control mode OS: + - D*(2010)+ -> pi+ (D0-> pi+ pi- pi+ K-) + Control mode SS: + - D*(2010)+ -> pi+ (D0-> pi+ pi- pi+ K+) +''' + +default_name = "DstarD02ETau" + +default_config = {'NAME': 'DstarD02ETau', + 'WGs': ['Charm'], + 'BUILDERTYPE': 'StrippingDstarD02ETauConf', + 'STREAMS': ['Charm'], + 'CONFIG': {'PrescaleETauBox': 1., + 'PrescaleETauSSBox': 1., + 'PrescaleK3piBox': 0.025, # needed to keep the rates compatible with DST + 'PrescaleK3piSSBox': 0.025, # needed to keep the rates compatible with DST + 'prefix': '', + 'CUTBASED_M_B': '2865', # MeV + 'CUTBASED_MCORR_B_HIGH': '8600', # MeV + 'CUTBASED_MCORR_B_LOW': '3600', # MeV + 'CUTBASED_MISS_MASS': '876', # MeV + 'CUTBASED_M_TAU_HIGH': '1592', # MeV + 'CUTBASED_M_TAU_LOW': '829', # MeV + 'CUTBASED_M_B': '2865', # MeV + 'CUTBASED_MCORR_B_HIGH': '8600', # MeV + 'CUTBASED_MCORR_B_LOW': '3600', # MeV + 'CUTBASED_MISS_MASS': '876', # MeV + 'HLT_DECISIONS_HAD': {'Hlt2Topo(2|3|4)Body.*Decision%TOS': 0}, + # + 'P_THREE_PI': "500", # MeV + 'PT_THREE_PI': "110", # MeV + 'TRACKCHI2_THREE_PI': "4", # dimensionless + 'TRGHOPROB_THREE_PI': "0.4", # dimensionless + 'MINIPCHI2BPV_THREE_PI': "16", # dimensionless + 'CUTBASED_PROBNNPI_THREE_PI': '0.5', #to reduce rate + 'PROBNNGHOST_THREE_PI': '0.4', + # tau + 'TAU_M_LOW_COMB': "400", # MeV + 'TAU_M_HIGH_COMB': "2100", # MeV + 'TAU_AMAXDOCA_PIS': "0.2", # mm + 'TAU_PT': "700.", # MeV + 'TAU_M_LOW': "400", # MeV + 'TAU_M_HIGH': "2100", # MeV + 'TAU_BPVDIRA': "-1.", + 'CUTBASED_TAU_BPVVDRHO_LOW': "0.05", # mm + 'CUTBASED_TAU_BPVVDRHO_HIGH': "7", # mm + 'CUTBASED_TAU_BPVVDZ': "0.5", # mm + 'CUTBASED_TAU_VCHI2': "16", + 'CUTBASED_TAU_BPVVDCHI2': "16", # mm + # Electron + 'P_E': "0", # MeV + 'PT_E': "110", # MeV + 'TRACKCHI2_E': "4", # dimensionless + 'TRGHOPROB_E': "0.4", # dimensionless + 'MINIPCHI2BPV_E': "16", # dimensionless + 'CUTBASED_PROBNNE_E': '0.1', #dimensionless + 'PROBNNGHOST_E': '0.4', #dimensionless + #Kaon for CM + 'CUTBASED_PROBNNK_K': '0.2', #dimensionless + # D0 + 'P_D0': "2000", # MeV + 'PT_D0': "1000", # MeV + 'MINIPCHI2PV_D0': "50", # dimensionless + 'CUTBASED_M_D0_LOW': '500', # MeV + 'CUTBASED_M_D0_HIGH': '2000', # MeV + 'CUTBASED_MCORR_D0_LOW': '1000', # MeV + 'CUTBASED_MCORR_D0_HIGH': '8000', # MeV + 'CUTBASED_MISS_MASS_LOW': '0', # MeV + 'CUTBASED_MISS_MASS_HIGH': '250', # MeV + 'CUTBASED_MISS_MASS_HIGH_KTHREEPI': '1500', # MeV + 'CUTBASED_TAU_TAU_LOW': '-2.5', # ps + 'CUTBASED_TAU_TAU_HIGH': '3', # ps + 'CUTBASED_TAU_BPVVDRHO': '0.33', # mm + 'CUTBASED_VCHI2_TAU': '20.6', # dimensionless + 'CUTBASED_M_TAU_HIGH': '1592', # MeV + # Dstm + 'DstD0DMWin_LOW': "-10.", # MeV + 'DstD0DMWin_HIGH': "100.", # MeV + 'DstmVtxChi2': "10.", # dimensionless + 'DstMassWin_LOW': "-1250.", # MeV + 'DstMassWin_HIGH': "100.", # MeV + 'PT_PI_FROM_DTSM': "110", # MeV + 'TRACKCHI2_PI_FROM_DTSM': "7", # dimensionless + 'MINIPCHI2BPV_PI_FROM_DTSM': "10", # dimensionles + # Isolations + 'ConeAngles': {"08": 0.8, "10": 1.0, "12": 1.2, "14": 1.4}, + 'ConeVariables': ['CONEANGLE', 'CONEMULT', 'CONEPTASYM'], + 'RelInfoTools_D02ETau': [ + {"Type": "RelInfoVertexIsolation", + "Location": "DstVars_VertexIsoInfo", + "DaughterLocations": {"[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_VertexIsoInfo", + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_VertexIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_VertexIsoInfo", + }}, + {"Type": "RelInfoConeIsolation", + "ConeSize": 0.5, + "Variables": [], + "Location": "DstVars_ConeIsoInfo", + "DaughterLocations": {"[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_ConeIsoInfo", + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_ConeIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_ConeIsoInfo", + }}, + ], + 'RelInfoTools_D02K3pi': [ + {"Type": "RelInfoVertexIsolation", + "Location": "DstVars_VertexIsoInfo", + "DaughterLocations": {"[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_VertexIsoInfo", + }}, + {"Type": "RelInfoConeIsolation", + "ConeSize": 0.5, + "Variables": [], + "Location": "DstVars_ConeIsoInfo", + "DaughterLocations": {"[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_ConeIsoInfo", + }}, + ] + } + } + + +class StrippingDstarD02ETauConf(LineBuilder): + """ + Builder for D*(2010)+ -> pi+ (D0-> tau+ (-> pi+ pi- pi+ anti_nutau) e-) stripping lines + """ + + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__(self, name, config): + LineBuilder.__init__(self, name, config) + # Declare line + line_taue_OS_box = self.baseLineETau(name, config, same_sign=False) + line_taue_SS_box = self.baseLineETau(name, config, same_sign=True) + line_K3pi_OS_box = self.baseLineK3pi(name, config, same_sign=False) + line_K3pi_SS_box = self.baseLineK3pi(name, config, same_sign=True) + lines_to_be = [line_taue_OS_box, line_taue_SS_box, + line_K3pi_OS_box, line_K3pi_SS_box, + ] + # register line + for i in lines_to_be: + self.registerLine(i) + + def baseLineETau(self, name, config, same_sign=False): + """ + Returns the stripping line for the decay + D*(2010)+ -> pi+ (D0-> tau+ (-> pi+ pi- pi+ anti_nutau) e-) + and the decay with tau and electron with the same charge + """ + # Define the taus + name += "_SS" if same_sign else "" + combname = "ETauSS" if same_sign else "ETau" + selTau = self._makeTau_3pi(name="Tau_3piFor"+name, + pionSel=self._makePions4Tau23pi( + "3PionSelFor"+name, config), + config=config) + # Define the electron + # TODO: Should we also include Upstream electrons, as it is done for the pions? + selElectrons = self._makeElectrons(name="ElectronsFor"+name, + config=config) + # Combine Tau and Electron to make the D0 + if same_sign: + selD02ETau_3pi = self._makeD02ETau_3pi(name=name, + tauSel=selTau, + eleSel=selElectrons, + config=config, + DecayDescriptors=["[D0 -> tau+ e+]cc", "[D0 -> tau- e-]cc"]) + else: + selD02ETau_3pi = self._makeD02ETau_3pi(name=name, + tauSel=selTau, + eleSel=selElectrons, + config=config, + DecayDescriptors=["[D0 -> tau+ e-]cc", "[D0 -> tau- e+]cc"]) + xxCombSel = selD02ETau_3pi + + # Combine D0 and pion to make a Dstm + dstar_box = self._makeDstar(config) + dst_req_sel = [DataOnDemand("Phys/StdAllNoPIDsPions/Particles"), + DataOnDemand("Phys/StdNoPIDsUpPions/Particles"), + xxCombSel] + + pres = "Prescale"+combname+"Box" + _tag_sel = Selection(name+"_seq_"+combname+"_box", + Algorithm=dstar_box, + RequiredSelections=dst_req_sel) + # Add isolation variables + for conekey, coneitem in (config['ConeAngles']).iteritems(): + config['RelInfoTools_D02ETau'].append({ + 'Type': 'RelInfoConeVariables', 'ConeAngle': coneitem, 'Variables': config['ConeVariables'], + 'Location': 'P2CVDst'+conekey, + 'DaughterLocations': { + '[D*(2010)+ -> ^(Charm -> l l ) pi+]CC': 'P2CVD0'+conekey, + '[D*(2010)+ -> (Charm -> l l ) ^pi+]CC': 'P2CVpis'+conekey, + '[D*(2010)+ -> (Charm -> ^l l ) pi+]CC': 'P2CL1'+conekey, + '[D*(2010)+ -> (Charm -> l ^l ) pi+]CC': 'P2CL2'+conekey, + } + }) + # Declare line + line_box = StrippingLine(name+config['prefix']+"Dst2PiD02"+combname+"Box", + prescale=config[pres], + # postscale + MDSTFlag=False, + RelatedInfoTools=config['RelInfoTools_D02ETau'], + algos=[_tag_sel], + MaxCandidates=50 + ) + return line_box + + def baseLineK3pi(self, name, config, same_sign=False): + """ + Returns the stripping line for the decay + D*(2010)+ -> pi+ (D0-> K- pi+ pi- pi+ ) and the decay with the K with + same charge w.r.t. the combination of the three pions + """ + # Define the taus + name += "_CM_SS" if same_sign else "_CM" + combname = "K3piSS" if same_sign else "K3pi" + selPions = self._makePions4Tau23pi("3PionSelFor"+name, config) + # TODO: align with electron in case we include Upstream + selKaon = self._makeKaons("KaonSelFor"+name, config) + + # Combine Tau and Electron to make the D0 + if same_sign: + selD02ETau_3pi = self._makeD02K3pi(name=name, + piSel=selPions, + KSel=selKaon, + config=config, + DecayDescriptors=["[D0 -> K+ pi+ pi- pi+]cc"]) + else: + selD02ETau_3pi = self._makeD02K3pi(name=name, + piSel=selPions, + KSel=selKaon, + config=config, + DecayDescriptors=["[D0 -> K- pi+ pi- pi+]cc"]) + xxCombSel = selD02ETau_3pi + + # Combine D0 and pion to make a Dstm + dstar_box = self._makeDstar(config) + dst_req_sel = [DataOnDemand("Phys/StdAllNoPIDsPions/Particles"), + DataOnDemand("Phys/StdNoPIDsUpPions/Particles"), + xxCombSel] + + pres = "Prescale"+combname+"Box" + _tag_sel = Selection(name+"_seq_"+combname+"_box", + Algorithm=dstar_box, + RequiredSelections=dst_req_sel) + + for conekey, coneitem in (config['ConeAngles']).iteritems(): + config['RelInfoTools_D02K3pi'].append({ + 'Type': 'RelInfoConeVariables', + 'ConeAngle': coneitem, + 'Variables': config['ConeVariables'], + 'Location': 'P2CVDst'+conekey, + 'DaughterLocations': { + '[D*(2010)+ -> ^(Charm -> X X X X ) pi+]CC': 'P2CVD0'+conekey, + '[D*(2010)+ -> (Charm -> X X X X) ^pi+]CC': 'P2CVpis'+conekey, } + }) + + # Declare line + line_box = StrippingLine(name+config['prefix']+"Dst2PiD02"+combname+"Box", + prescale=config[pres], + # postscale + MDSTFlag=False, + RelatedInfoTools=config['RelInfoTools_D02K3pi'], + algos=[_tag_sel], + MaxCandidates=50 + ) + return line_box + + #################################################### + def _makeElectrons(self, name, config): + """ + Electron selection + """ + _code = self._eFinalStateKinematicCuts(config) + #to reduce rate + _code += " & (PROBNNghost < "+config['PROBNNGHOST_E'] + \ + ") & (PROBNNe > " + config['CUTBASED_PROBNNE_E'] + ")" + _Filter = FilterDesktop(Code=_code) + + return Selection(name, + Algorithm=_Filter, + RequiredSelections=[StdAllLooseElectrons]) + #################################################### + + def _makeKaons(self, name, config): + """ + Kaons selection + """ + _code = self._kaonsFinalStateKinematicCuts(config) + _code += " & (PROBNNghost < "+config['PROBNNGHOST_E'] + \ + ") & (PROBNNk > " + config['CUTBASED_PROBNNK_K'] + ")" + _Filter = FilterDesktop(Code=_code) + + return Selection(name, + Algorithm=_Filter, + RequiredSelections=[StdLooseKaons]) + + ##################################################### + def _eFinalStateKinematicCuts(self, config): + _code = "(P > " + config['P_E'] + "*MeV) & "\ + "(PT > " + config['PT_E'] + "*MeV) & "\ + "(MIPCHI2DV(PRIMARY) > " + config['MINIPCHI2BPV_E'] + ") & "\ + "(TRCHI2DOF < " + config['TRACKCHI2_E'] + ") & "\ + "(TRGHOSTPROB < " + config['TRGHOPROB_E'] + ") " + return _code + ########################################################### + + def _kaonsFinalStateKinematicCuts(self, config): + # keep aligned to electron + _code = "(P > " + config['P_E'] + "*MeV) & "\ + "(PT > " + config['PT_E'] + "*MeV) & "\ + "(MIPCHI2DV(PRIMARY) > " + config['MINIPCHI2BPV_E'] + ") & "\ + "(TRCHI2DOF < " + config['TRACKCHI2_E'] + ") & "\ + "(TRGHOSTPROB < " + config['TRGHOPROB_E'] + ") " + # _code = "(P > 0 )" + return _code + ############################################################# + + def _makeTau_3pi(self, name, pionSel, config): + + # Minimum mass = 3 pions (140 MeV) = 420 MeV + # This is a variation of the StdTightDetachedTau3pi in https://gitlab.cern.ch/lhcb/Stripping/-/blob/2018-patches/Phys/CommonParticlesArchive/python/CommonParticlesArchive/Stripping28r2p1/CommonParticles/StdTightDetachedTau.py + _preambulo = [""] + _combcut = "(APT>500.*MeV) & ((AM>"+config['TAU_M_LOW_COMB'] + "*MeV)"\ + " & (AM<"+config['TAU_M_HIGH_COMB'] + "*MeV)) "\ + " & (AMAXDOCA('')<"+config['TAU_AMAXDOCA_PIS'] + "*mm)"\ + " & (ANUM(PT > 500*MeV) >= 1)" + _mcut = "(PT>"+config['TAU_PT'] + "*MeV) & (M>"+config['TAU_M_LOW'] + "*MeV)"\ + "& (M<"+config['TAU_M_HIGH'] + "*MeV) & (BPVDIRA>"+config['TAU_BPVDIRA'] + ")"\ + "& (VFASPF(VCHI2) < " + config['CUTBASED_TAU_VCHI2'] + ")"\ + "& (BPVVDCHI2>" + config['CUTBASED_TAU_BPVVDCHI2'] + ") "\ + "& (BPVVDRHO>" + config['CUTBASED_TAU_BPVVDRHO_LOW'] + "*mm)"\ + "& (BPVVDRHO<" + config['CUTBASED_TAU_BPVVDRHO_HIGH'] + "*mm)"\ + "& (BPVVDZ>" + config['CUTBASED_TAU_BPVVDZ'] + "*mm)" + + _CombineTau = CombineParticles(DecayDescriptors=["[tau+ -> pi+ pi- pi+]cc"], + CombinationCut=_combcut, + MotherCut=_mcut, + Preambulo=_preambulo) + + return Selection(name, + Algorithm=_CombineTau, + RequiredSelections=[pionSel] + ) + + def _makePions4Tau23pi(self, name, config): + _code = self._hadFinalStateKinematicCuts_3pi(config) + _code += " & (PROBNNghost < "+config['PROBNNGHOST_THREE_PI'] + \ + ") & (PROBNNpi > " + config['CUTBASED_PROBNNPI_THREE_PI'] + ")" + _code += " & (MIPCHI2DV(PRIMARY) > " + \ + config['MINIPCHI2BPV_THREE_PI'] + ")" + _Filter = FilterDesktop(Code=_code) + return Selection(name, + Algorithm=_Filter, + RequiredSelections=[StdNoPIDsPions] + ) + + # Template for combine particles for D* -> D0 pi + def _makeDstar(self, config): + # loosks for all D0s in the decay, returns the largest mass (mass of the D0 since there is only one) and computes the mass difference with the mother + dstcomb_dstcut = "((M-MAXTREE('D0'==ABSID,M)-145.42) < %(DstD0DMWin_HIGH)s *MeV) & ((M-MAXTREE('D0'==ABSID,M)-145.42) > %(DstD0DMWin_LOW)s *MeV) & (VFASPF(VCHI2/VDOF)< %(DstmVtxChi2)s)" + dstcomb_combcut = "( (AM - 2010.26) < %(DstMassWin_HIGH)s * MeV) & ( (AM - 2010.26) > %(DstMassWin_LOW)s * MeV)" + dstcomb_picut = "(PT> %(PT_PI_FROM_DTSM)s * MeV) & ( MIPCHI2DV(PRIMARY)< %(MINIPCHI2BPV_PI_FROM_DTSM)s) & (TRCHI2DOF<%(TRACKCHI2_PI_FROM_DTSM)s) " + #dstcomb_picut += "& (TRGHOSTPROB> %(TRGHOPROB_THREE_PI)s * MeV) & (PROBNNghost> %(PROBNNGHOST_THREE_PI)s * MeV) & (PROBNNpi> %(CUTBASED_PROBNNPI_THREE_PI)s ) " #try to reduce the rate + #dstcomb_picut += "& (TRGHOSTPROB> %(TRGHOPROB_THREE_PI)s * MeV)" # & (PROBNNghost> %(PROBNNGHOST_THREE_PI)s * MeV) " #try to reduce the rate + dstcomb_picut += "& (TRGHOSTPROB< %(TRGHOPROB_THREE_PI)s ) & (PROBNNpi> %(CUTBASED_PROBNNPI_THREE_PI)s) & (PROBNNghost< %(PROBNNGHOST_THREE_PI)s) " #try to reduce the rate + dstcomb_d0cut = "PT>0" + + dstar = CombineParticles(DecayDescriptors=['D*(2010)+ -> D0 pi+', 'D*(2010)- -> D0 pi-'], + DaughtersCuts={"pi+": dstcomb_picut % config, + "D0": dstcomb_d0cut % config + }, + CombinationCut=dstcomb_combcut % config, + MotherCut=dstcomb_dstcut % config + ) + + return dstar + + ################################################## + + def _hadFinalStateKinematicCuts_3pi(self, config): + _code = "(P > " + config['P_THREE_PI'] + "*MeV) & "\ + "(PT > " + config['PT_THREE_PI'] + "*MeV) & "\ + "(TRCHI2DOF < " + config['TRACKCHI2_THREE_PI'] + ") & "\ + "(TRGHOSTPROB < " + config['TRGHOPROB_THREE_PI'] + ") " + + return _code + ################################################## + + def _makeD02ETau_3pi(self, name, tauSel, eleSel, config, DecayDescriptors): + + preambulo = ["PTRANS = P*sqrt( 1-BPVDIRA**2 )", + "MCOR = sqrt(M**2 + PTRANS**2) + PTRANS", + "allpi = ((('pi+') == ABSID) | (('K+') == ABSID)) ", + "sumpt = SUMTREE( allpi , PT )"] + + _combcut = "(AM > 400 *MeV) & "\ + "(AM < 2200 *MeV)" + _mcut = "((CHILD(MIPCHI2DV(PRIMARY),1)) > " + config['MINIPCHI2PV_D0']+") & "\ + "(P > "+config['P_D0']+"*MeV) & (PT > "+config['PT_D0']+"*MeV) & " \ + "(M > " + config['CUTBASED_M_D0_LOW'] + "*MeV) & "\ + "(M < " + config['CUTBASED_M_D0_HIGH'] + "*MeV) & "\ + "(MCOR < " + config['CUTBASED_MCORR_D0_HIGH'] + "*MeV) & "\ + "(MCOR > " + config['CUTBASED_MCORR_D0_LOW'] + "*MeV) & "\ + "(M - CHILD(M,1) - CHILD(M,2) > " + config['CUTBASED_MISS_MASS_LOW'] + "*MeV) & "\ + "(M - CHILD(M,1) - CHILD(M,2) < " + config['CUTBASED_MISS_MASS_HIGH'] + "*MeV) & "\ + "(CHILD(M,1) * (CHILD(VFASPF(VZ),1) - VFASPF(VZ) )/(CHILD(PZ,1) * 0.299792458) < " + config['CUTBASED_TAU_TAU_HIGH'] + ") & "\ + "(CHILD(M,1) * (CHILD(VFASPF(VZ),1) - VFASPF(VZ) )/(CHILD(PZ,1) * 0.299792458) > " + \ + config['CUTBASED_TAU_TAU_LOW'] + ") " + + _CombineTau = CombineParticles(DecayDescriptors=DecayDescriptors, + CombinationCut=_combcut, + MotherCut=_mcut, + Preambulo=preambulo) + + return Selection(name+"_TauE_3pi", + Algorithm=_CombineTau, + RequiredSelections=[tauSel, eleSel]) + + def _makeD02K3pi(self, name, piSel, KSel, config, DecayDescriptors): + + preambulo = ["PTRANS = P*sqrt( 1-BPVDIRA**2 )", + "MCOR = sqrt(M**2 + PTRANS**2) + PTRANS", + "allpi = ((('pi+') == ABSID) | (('K+') == ABSID)) ", + "sumpt = SUMTREE( allpi , PT )", + "THREEPI_PX = (CHILD(PX,2) + CHILD(PX,3) + CHILD(PX,4))", + "THREEPI_PY = (CHILD(PY,2) + CHILD(PY,3) + CHILD(PY,4))", + "THREEPI_PZ = (CHILD(PZ,2) + CHILD(PZ,3) + CHILD(PZ,4))", + "THREEPI_E2 = (CHILD(E,2) + CHILD(E,3) + CHILD(E,4))**2", + "THREEPI_P2 = (THREEPI_PX**2 + THREEPI_PY**2 + THREEPI_PZ**2)", + "THREEPI_M = sqrt(THREEPI_E2 - THREEPI_P2 )"] + + _combcut = "(AM > 400 *MeV) & "\ + "(AM < 2200 *MeV)" + # TODO: The following cut is present in the selection of the LFV channel but not here, might need simulation to understand how the differ w.r.t. CM + # _mcut = "((CHILD(MIPCHI2DV(PRIMARY),1)) > " + config['MINIPCHI2PV_D0']+") & "\ + _mcut = "(P > "+config['P_D0']+"*MeV) & (PT > "+config['PT_D0']+"*MeV) & " \ + "(M > " + config['CUTBASED_M_D0_LOW'] + "*MeV) & "\ + "(M < " + config['CUTBASED_M_D0_HIGH'] + "*MeV) & "\ + "(MCOR < " + config['CUTBASED_MCORR_D0_HIGH'] + "*MeV) & "\ + "(MCOR > " + config['CUTBASED_MCORR_D0_LOW'] + "*MeV) &"\ + "(M - CHILD(M,1) - THREEPI_M > " + config['CUTBASED_MISS_MASS_LOW'] + "*MeV) & "\ + "(M - CHILD(M,1) - THREEPI_M < " + config['CUTBASED_MISS_MASS_HIGH_KTHREEPI'] + "*MeV) "\ + # "(CHILD(M,1) * (CHILD(VFASPF(VZ),1) - VFASPF(VZ) )/(CHILD(PZ,1) * 0.299792458) < " + config['CUTBASED_TAU_TAU_HIGH'] + ") & "\ + # "(CHILD(M,1) * (CHILD(VFASPF(VZ),1) - VFASPF(VZ) )/(CHILD(PZ,1) * 0.299792458) > " + config['CUTBASED_TAU_TAU_LOW'] + ") " + + _CombineTau = CombineParticles(DecayDescriptors=DecayDescriptors, # TOCHECK + CombinationCut=_combcut, + MotherCut=_mcut, + Preambulo=preambulo) + + return Selection(name+"_K3pi", + Algorithm=_CombineTau, + RequiredSelections=[piSel, KSel]) + -- GitLab From 22828bada3001b7c1e2cbac1315cec527b9140b4 Mon Sep 17 00:00:00 2001 From: Ivan Polyakov <ivan.polyakov@cern.ch> Date: Thu, 13 Jul 2023 09:11:04 +0200 Subject: [PATCH 03/11] Charm: add new channels for Charm2PPX --- .../StrippingCharm/StrippingCharm2PPX.py | 576 +++++++++++++++++- .../StrippingCharm/__init__.py | 2 +- 2 files changed, 547 insertions(+), 31 deletions(-) diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharm2PPX.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharm2PPX.py index 23a69ab1c..8e18d20c7 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharm2PPX.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharm2PPX.py @@ -15,6 +15,14 @@ - Hc+ -> ppK- (exch) - Hc+ -> ppK-pi+pi- - Hs+ -> pppi- : LLL and DDD + + for 2023 Restripping update with following modes: + - Hcc++/+ -> ppKs, ppKspi-, Lamppi-, Lamppi+pi- + - Hcs+ -> ppK-K-pi+, pK-pi+Lam, LamLampi+, ppKsK- + - Pc -> pK+pi-pi-, pKspi- + - Ps -> ppi+pi- : LLL and DDD + + + add modes Lc->pKpi, Lam->ppi with 0.01 prescale for reference """ @@ -35,6 +43,10 @@ from StandardParticles import ( StdAllNoPIDsPions, StdNoPIDsDownProtons, StdNoPIDsDownPions, + StdLooseLambdaLL, + StdLooseLambdaDD, + StdLooseKsLL, + StdLooseKsDD, ) from PhysSelPython.Wrappers import Selection from StrippingUtils.Utils import LineBuilder @@ -82,8 +94,13 @@ default_config = { 'Pion_ProbNN_MIN': 0.1, # Hc maximum mass - 'Comb_MASS_MAX': 3500*MeV , # 3350*MeV, - 'HsComb_MASS_MAX': 2125*MeV, + 'Hc_MASS_MAX': 3500*MeV , # 3350*MeV, + 'Hcs_MASS_MAX': 3650*MeV , + 'Hs_MASS_MAX': 2125*MeV, + 'Pc_MASS_MAX': 3100*MeV , + 'Ps_MASS_MAX': 1650*MeV , + 'Lc_MASS_MAX': 2350*MeV , + 'Lam_MASS_MAX': 1170*MeV , # Maximum distance of closest approach of daughters 'Comb_ADOCACHI2_MAX': 16, 'HsComb_ADOCACHI2_MAX': 16, @@ -91,17 +108,17 @@ default_config = { 'Hc_VCHI2VDOF_MAX': 25.0, 'Hs_VCHI2VDOF_MAX': 25.0, # Maximum angle between Hc momentum and Hc direction of flight - 'Hc_BPVIPCHI2_MAX': 16, - 'Hs_BPVIPCHI2_MAX': 16, + #'Hc_BPVIPCHI2_MAX': 16, + #'Hs_BPVIPCHI2_MAX': 16, # Primary vertex displacement requirement, that the Hc is some sigma # away from the PV and it has a minimum flight time 'Hc_BPVVDCHI2_MIN': 9.0, - 'Hc_BPVCTAU_MIN': 0.*mm, # 0.03*mm, + 'Hc_BPVCTAU_MIN': 0.05*mm, # 0.03*mm, 'Hs_BPVVDCHI2_MIN': 9.0, 'HsDown_BPVVDCHI2_MIN': 4.0, 'Hs_BPVCTAU_MIN': 0.1*mm, # Hc minimum transverse momenta - 'Hc_PT_MIN': -1000*MeV, + 'Hc_PT_MIN': 1000*MeV, 'Hs_PT_MIN': -1000*MeV, # HLT filters, only process events firing triggers matching the RegEx 'Hlt1Filter': None, @@ -113,12 +130,43 @@ default_config = { 'PrescaleHc2PPK': 1.0, 'PrescaleHc2PPKPiPi': 1.0, 'PrescaleHs2PPPi': 1.0, + # + 'PrescaleHc2PPKs': 1.0, + 'PrescaleHc2PPKsPi': 1.0, + 'PrescaleHc2LamPPi': 1.0, + 'PrescaleHc2LamPPiPi': 1.0, + 'PrescaleHcs2PPKKPi': 1.0, + 'PrescaleHcs2PPKsK': 1.0, + 'PrescaleHcs2LamPKPi': 1.0, + 'PrescaleHcs2LamLamPi': 1.0, + 'PrescalePc2PKPiPi': 0.1, + 'PrescalePc2PKsPi': 0.1, + 'PrescalePs2PPiPi': 0.1, + # + 'PrescaleLc2PKPi' : 0.01, + 'PrescaleL2PPi' : 0.01, + # Fraction of candidates to randomly throw after before stripping 'PostscaleHc2PP': 1.0, 'PostscaleHc2PPKPi': 1.0, 'PostscaleHc2PPK': 1.0, 'PostscaleHc2PPKPiPi': 1.0, 'PostscaleHs2PPPi': 1.0, + # + 'PostscaleHc2PPKs': 1.0, + 'PostscaleHc2PPKsPi': 1.0, + 'PostscaleHc2LamPPi': 1.0, + 'PostscaleHc2LamPPiPi': 1.0, + 'PostscaleHcs2PPKKPi': 1.0, + 'PostscaleHcs2PPKsK': 1.0, + 'PostscaleHcs2LamPKPi': 1.0, + 'PostscaleHcs2LamLamPi': 1.0, + 'PostscalePc2PKPiPi': 1.0, + 'PostscalePc2PKsPi': 1.0, + 'PostscalePs2PPiPi': 1.0, + # + 'PostscaleLc2PKPi' : 1.0, + 'PostscaleL2PPi' : 1.0, } } @@ -127,14 +175,6 @@ class StrippingCharm2PPXConf(LineBuilder): # Allowed configuration keys __configuration_keys__ = default_config['CONFIG'].keys() - # Decay descriptors - Hc2pp = ['[Sigma_c++ -> p+ p+]cc'] - Hc2ppkpi = ['[Sigma_c++ -> p+ p+ K- pi+]cc'] - Hc2ppk = ['[Sigma_c+ -> p+ p+ K-]cc'] - Hc2ppkpipi = ['[Sigma_c+ -> p+ p+ K- pi+ pi-]cc'] - - Hs2pppi = ['[Sigma_c+ -> p+ p+ pi-]cc'] - def __init__(self, name, config): """Initialise this LineBuilder instance.""" self.name = name @@ -150,6 +190,26 @@ class StrippingCharm2PPXConf(LineBuilder): hs2pppi_name = '{0}Hs2PPPi'.format(name) hs2pppiDown_name = '{0}Hs2PPPiDown'.format(name) + # + hc2ppKs_name = '{0}Hc2PPKs'.format(name) + hc2ppKspi_name = '{0}Hc2PPKsPi'.format(name) + hc2Lppi_name = '{0}Hc2LamPPi'.format(name) + hc2Lppipi_name = '{0}Hc2LamPPiPi'.format(name) + + hcs2ppKKpi_name = '{0}Hcs2PPKKPi'.format(name) + hcs2ppKsK_name = '{0}Hcs2PPKsK'.format(name) + hcs2LpKpi_name = '{0}Hcs2LamPKPi'.format(name) + hcs2LLpi_name = '{0}Hcs2LamLamPi'.format(name) + + pc2pKpipi_name = '{0}Pc2PKPiPi'.format(name) + pc2pKspi_name = '{0}Pc2PKsPi'.format(name) + ps2ppipi_name = '{0}Ps2PPiPi'.format(name) + ps2ppipiDown_name = '{0}Ps2PPiPiDown'.format(name) + + # reference + lc2pKpi_name = '{0}Lc2PKPiRef'.format(name) + l2ppi_name = '{0}L2PPiRef'.format(name) + # Build pion, kaon, and proton cut strings daugCuts = ( '(PT > {0[Daug_All_PT_MIN]})' @@ -228,31 +288,48 @@ class StrippingCharm2PPXConf(LineBuilder): self.selHc2PP = self.makeHc2PPX( name=hc2pp_name, inputSel=[self.inProtons], - decDescriptors=self.Hc2pp + decDescriptors=['[Sigma_c++ -> p+ p+]cc'], + mass_max = self.config["Hc_MASS_MAX"] ) self.selHc2PPKPi = self.makeHc2PPX( name=hc2ppkpi_name, inputSel=[self.inProtons, self.inKaons, self.inPions ], - decDescriptors=self.Hc2ppkpi + decDescriptors=['[Sigma_c++ -> p+ p+ K- pi+]cc', + '[Sigma_c++ -> p+ p+ K+ pi-]cc', + '[Sigma_c++ -> p+ p+ K- pi-]cc', + '[Sigma_c++ -> p+ p+ K+ pi+]cc', + ], + mass_max = self.config["Hc_MASS_MAX"] ) self.selHc2PPK = self.makeHc2PPX( name=hc2ppk_name, inputSel=[self.inProtons, self.inKaons ], - decDescriptors=self.Hc2ppk + decDescriptors=['[Sigma_c+ -> p+ p+ K-]cc', + '[Sigma_c+ -> p+ p+ K+]cc', + ], + mass_max = self.config["Hc_MASS_MAX"] ) self.selHc2PPKPiPi = self.makeHc2PPX( name=hc2ppkpipi_name, inputSel=[self.inProtons, self.inKaons, self.inPions ], - decDescriptors=self.Hc2ppkpipi + decDescriptors=['[Sigma_c+ -> p+ p+ K- pi+ pi-]cc', + '[Sigma_c+ -> p+ p+ K+ pi+ pi-]cc', + '[Sigma_c+ -> p+ p+ K- pi+ pi+]cc', + '[Sigma_c+ -> p+ p+ K+ pi- pi-]cc', + ], + mass_max = self.config["Hc_MASS_MAX"] ) self.selHs2PPPi = self.makeHs2PPX( name=hs2pppi_name, inputSel=[self.inProtons, self.inPions ], - decDescriptors=self.Hs2pppi, + decDescriptors=['[Sigma_c+ -> p+ p+ pi-]cc', + '[Sigma_c+ -> p+ p+ pi+]cc', + ], + mass_max = self.config["Hs_MASS_MAX"], mipchi2_cut = config['HsDaug_1ofAll_BPVIPCHI2_MIN'], vdchi2_cut = config['Hs_BPVVDCHI2_MIN'], ) @@ -260,7 +337,225 @@ class StrippingCharm2PPXConf(LineBuilder): self.selHs2PPPiDown = self.makeHs2PPX( name=hs2pppiDown_name, inputSel=[self.inDownProtons, self.inDownPions ], - decDescriptors=self.Hs2pppi, + decDescriptors=['[Sigma_c+ -> p+ p+ pi-]cc', + '[Sigma_c+ -> p+ p+ pi+]cc', + ], + mass_max = self.config["Hs_MASS_MAX"], + mipchi2_cut = config['HsDownDaug_1ofAll_BPVIPCHI2_MIN'], + vdchi2_cut = config['HsDown_BPVVDCHI2_MIN'], + ) + + ## + self.selHc2PPKs_KsLL = self.makeHc2PPX( + name=hc2ppKs_name + "_KsLL", + inputSel=[StdLooseKsLL, self.inProtons ], + decDescriptors=['[Sigma_c+ -> p+ p+ KS0]cc'], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHc2PPKs_KsDD = self.makeHc2PPX( + name=hc2ppKs_name + "_KsDD", + inputSel=[StdLooseKsDD, self.inProtons ], + decDescriptors=['[Sigma_c+ -> p+ p+ KS0]cc'], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHc2PPKsPi_KsLL = self.makeHc2PPX( + name=hc2ppKspi_name + "_KsLL", + inputSel=[StdLooseKsLL, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> p+ p+ KS0 pi-]cc', + '[Sigma_c+ -> p+ p+ KS0 pi+]cc' ], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHc2PPKsPi_KsDD = self.makeHc2PPX( + name=hc2ppKspi_name + "_KsDD", + inputSel=[StdLooseKsDD, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> p+ p+ KS0 pi-]cc', + '[Sigma_c+ -> p+ p+ KS0 pi+]cc' ], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHc2LamPPi_LamLL = self.makeHc2PPX( + name=hc2Lppi_name + "_LamLL", + inputSel=[StdLooseLambdaLL, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 p+ pi-]cc', + '[Sigma_c+ -> Lambda0 p+ pi+]cc' ], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHc2LamPPi_LamDD = self.makeHc2PPX( + name=hc2Lppi_name + "_LamDD", + inputSel=[StdLooseLambdaDD, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 p+ pi-]cc', + '[Sigma_c+ -> Lambda0 p+ pi+]cc' ], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHc2LamPPiPi_LamLL = self.makeHc2PPX( + name=hc2Lppipi_name + "_LamLL", + inputSel=[StdLooseLambdaLL, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 p+ pi+ pi-]cc', + '[Sigma_c+ -> Lambda0 p+ pi- pi-]cc', + '[Sigma_c+ -> Lambda0 p+ pi+ pi+]cc' ], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHc2LamPPiPi_LamDD = self.makeHc2PPX( + name=hc2Lppipi_name + "_LamDD", + inputSel=[StdLooseLambdaDD, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 p+ pi+ pi-]cc', + '[Sigma_c+ -> Lambda0 p+ pi- pi-]cc', + '[Sigma_c+ -> Lambda0 p+ pi+ pi+]cc' ], + mass_max = self.config["Hc_MASS_MAX"], + ) + + self.selHcs2PPKKPi = self.makeHc2PPX( + name=hcs2ppKKpi_name, + inputSel=[self.inProtons, self.inKaons, self.inPions ], + decDescriptors=['[Sigma_c+ -> p+ p+ K- K- pi+]cc', + '[Sigma_c+ -> p+ p+ K+ K- pi+]cc', + '[Sigma_c+ -> p+ p+ K+ K- pi-]cc', + '[Sigma_c+ -> p+ p+ K- K- pi-]cc', + '[Sigma_c+ -> p+ p+ K+ K+ pi-]cc', + '[Sigma_c+ -> p+ p+ K+ K+ pi+]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selHcs2PPKsK_KsLL = self.makeHc2PPX( + name=hcs2ppKsK_name + "_KsLL", + inputSel=[StdLooseKsLL, self.inProtons, self.inKaons ], + decDescriptors=['[Sigma_c+ -> p+ p+ KS0 K-]cc', + '[Sigma_c+ -> p+ p+ KS0 K+]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selHcs2PPKsK_KsDD = self.makeHc2PPX( + name=hcs2ppKsK_name + "_KsDD", + inputSel=[StdLooseKsDD, self.inProtons, self.inKaons ], + decDescriptors=['[Sigma_c+ -> p+ p+ KS0 K-]cc', + '[Sigma_c+ -> p+ p+ KS0 K+]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selHcs2LamPKPi_LamLL = self.makeHc2PPX( + name=hcs2LpKpi_name + "_LamLL", + inputSel=[StdLooseLambdaLL, self.inProtons, self.inKaons, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 p+ K- pi+]cc', + '[Sigma_c+ -> Lambda0 p+ K- pi-]cc', + '[Sigma_c+ -> Lambda0 p+ K+ pi+]cc', + '[Sigma_c+ -> Lambda0 p+ K+ pi-]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selHcs2LamPKPi_LamDD = self.makeHc2PPX( + name=hcs2LpKpi_name + "_LamDD", + inputSel=[StdLooseLambdaDD, self.inProtons, self.inKaons, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 p+ K- pi+]cc', + '[Sigma_c+ -> Lambda0 p+ K- pi-]cc', + '[Sigma_c+ -> Lambda0 p+ K+ pi+]cc', + '[Sigma_c+ -> Lambda0 p+ K+ pi-]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selHcs2LamLamPi_LamLLLL = self.makeHc2PPX( + name=hcs2LLpi_name + "_LamLLLL", + inputSel=[StdLooseLambdaLL, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 Lambda0 pi+]cc', + '[Sigma_c+ -> Lambda0 Lambda0 pi-]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selHcs2LamLamPi_LamDDDD = self.makeHc2PPX( + name=hcs2LLpi_name + "_LamDDDD", + inputSel=[StdLooseLambdaDD, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 Lambda0 pi+]cc', + '[Sigma_c+ -> Lambda0 Lambda0 pi-]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selHcs2LamLamPi_LamLLDD = self.makeHc2PPX( + name=hcs2LLpi_name + "_LamLLDD", + inputSel=[StdLooseLambdaLL, StdLooseLambdaDD, self.inPions ], + decDescriptors=['[Sigma_c+ -> Lambda0 Lambda0 pi+]cc', + '[Sigma_c+ -> Lambda0 Lambda0 pi-]cc' ], + mass_max = self.config["Hcs_MASS_MAX"], + ) + + self.selPc2PKPiPi = self.makeHc2PPX( + name=pc2pKpipi_name, + inputSel=[self.inProtons, self.inKaons, self.inPions ], + decDescriptors=['[Sigma_c+ -> p+ K+ pi- pi-]cc', + '[Sigma_c+ -> p+ K+ pi+ pi-]cc', + '[Sigma_c+ -> p+ K+ pi+ pi+]cc', + '[Sigma_c+ -> p+ K- pi- pi-]cc', + '[Sigma_c+ -> p+ K- pi+ pi-]cc', + '[Sigma_c+ -> p+ K- pi+ pi+]cc' ], + mass_max = self.config["Pc_MASS_MAX"], + ) + + self.selPc2PKsPi_KsLL = self.makeHc2PPX( + name=pc2pKspi_name + "_KsLL", + inputSel=[StdLooseKsLL, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> p+ KS0 pi-]cc', + '[Sigma_c+ -> p+ KS0 pi+]cc' ], + mass_max = self.config["Pc_MASS_MAX"], + ) + + self.selPc2PKsPi_KsDD = self.makeHc2PPX( + name=pc2pKspi_name + "_KsDD", + inputSel=[StdLooseKsDD, self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> p+ KS0 pi-]cc', + '[Sigma_c+ -> p+ KS0 pi+]cc' ], + mass_max = self.config["Pc_MASS_MAX"], + ) + + self.selPs2PPiPi = self.makeHs2PPX( + name=ps2ppipi_name, + inputSel=[self.inProtons, self.inPions ], + decDescriptors=['[Sigma_c+ -> p+ pi+ pi-]cc', + '[Sigma_c+ -> p+ pi+ pi+]cc', + '[Sigma_c+ -> p+ pi- pi-]cc', + ], + mass_max = self.config["Ps_MASS_MAX"], + mipchi2_cut = config['HsDaug_1ofAll_BPVIPCHI2_MIN'], + vdchi2_cut = config['Hs_BPVVDCHI2_MIN'], + ) + + self.selPs2PPiPiDown = self.makeHs2PPX( + name=ps2ppipiDown_name, + inputSel=[self.inDownProtons, self.inDownPions ], + decDescriptors=['[Sigma_c+ -> p+ pi+ pi-]cc', + '[Sigma_c+ -> p+ pi+ pi+]cc', + '[Sigma_c+ -> p+ pi- pi-]cc', + ], + mass_max = self.config["Ps_MASS_MAX"], + mipchi2_cut = config['HsDownDaug_1ofAll_BPVIPCHI2_MIN'], + vdchi2_cut = config['HsDown_BPVVDCHI2_MIN'], + ) + + ## ref + self.selLc2PKPi = self.makeHc2PPX( + name=lc2pKpi_name, + inputSel=[self.inProtons, self.inKaons, self.inPions ], + decDescriptors=['[Lambda_c+ -> p+ K- pi+]cc'], + mass_max = self.config["Lc_MASS_MAX"], + ) + + self.selL2PPi = self.makeHs2PPX( + name=l2ppi_name, + inputSel=[self.inProtons, self.inPions ], + decDescriptors=['[Lambda0 -> p+ pi-]cc'], + mass_max = self.config["Lam_MASS_MAX"], + mipchi2_cut = config['HsDaug_1ofAll_BPVIPCHI2_MIN'], + vdchi2_cut = config['Hs_BPVVDCHI2_MIN'], + ) + + self.selL2PPiDown = self.makeHs2PPX( + name=l2ppi_name + "Down", + inputSel=[self.inDownProtons, self.inDownPions ], + decDescriptors=['[Lambda0 -> p+ pi-]cc'], + mass_max = self.config["Lam_MASS_MAX"], mipchi2_cut = config['HsDownDaug_1ofAll_BPVIPCHI2_MIN'], vdchi2_cut = config['HsDown_BPVVDCHI2_MIN'], ) @@ -321,6 +616,225 @@ class StrippingCharm2PPXConf(LineBuilder): HLT2=config['Hlt2Filter'] ) + # + self.line_Hc2PPKs_KsLL = self.make_line( + name='{0}Line'.format(hc2ppKs_name + "LL"), + selection=self.selHc2PPKs_KsLL, + prescale=config['PrescaleHc2PPKs'], + postscale=config['PostscaleHc2PPKs'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hc2PPKs_KsDD = self.make_line( + name='{0}Line'.format(hc2ppKs_name + "DD"), + selection=self.selHc2PPKs_KsDD, + prescale=config['PrescaleHc2PPKs'], + postscale=config['PostscaleHc2PPKs'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hc2PPKsPi_KsLL = self.make_line( + name='{0}Line'.format(hc2ppKspi_name + "LL"), + selection=self.selHc2PPKsPi_KsLL, + prescale=config['PrescaleHc2PPKsPi'], + postscale=config['PostscaleHc2PPKsPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hc2PPKsPi_KsDD = self.make_line( + name='{0}Line'.format(hc2ppKspi_name + "DD"), + selection=self.selHc2PPKsPi_KsDD, + prescale=config['PrescaleHc2PPKsPi'], + postscale=config['PostscaleHc2PPKsPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hc2LamPPi_LamLL = self.make_line( + name='{0}Line'.format(hc2Lppi_name + "LL"), + selection=self.selHc2LamPPi_LamLL, + prescale=config['PrescaleHc2LamPPi'], + postscale=config['PostscaleHc2LamPPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hc2LamPPi_LamDD = self.make_line( + name='{0}Line'.format(hc2Lppi_name + "DD"), + selection=self.selHc2LamPPi_LamDD, + prescale=config['PrescaleHc2LamPPi'], + postscale=config['PostscaleHc2LamPPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hc2LamPPiPi_LamLL = self.make_line( + name='{0}Line'.format(hc2Lppipi_name + "LL"), + selection=self.selHc2LamPPiPi_LamLL, + prescale=config['PrescaleHc2LamPPiPi'], + postscale=config['PostscaleHc2LamPPiPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hc2LamPPiPi_LamDD = self.make_line( + name='{0}Line'.format(hc2Lppipi_name + "DD"), + selection=self.selHc2LamPPiPi_LamDD, + prescale=config['PrescaleHc2LamPPiPi'], + postscale=config['PostscaleHc2LamPPiPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2PPKKPi = self.make_line( + name='{0}Line'.format(hcs2ppKKpi_name), + selection=self.selHcs2PPKKPi, + prescale=config['PrescaleHcs2PPKKPi'], + postscale=config['PostscaleHcs2PPKKPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2PPKsK_KsLL = self.make_line( + name='{0}Line'.format(hcs2ppKsK_name + "LL"), + selection=self.selHcs2PPKsK_KsLL, + prescale=config['PrescaleHcs2PPKsK'], + postscale=config['PostscaleHcs2PPKsK'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2PPKsK_KsDD = self.make_line( + name='{0}Line'.format(hcs2ppKsK_name + "DD"), + selection=self.selHcs2PPKsK_KsDD, + prescale=config['PrescaleHcs2PPKsK'], + postscale=config['PostscaleHcs2PPKsK'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2LamPKPi_LamLL = self.make_line( + name='{0}Line'.format(hcs2LpKpi_name + "LL"), + selection=self.selHcs2LamPKPi_LamLL, + prescale=config['PrescaleHcs2LamPKPi'], + postscale=config['PostscaleHcs2LamPKPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2LamPKPi_LamDD = self.make_line( + name='{0}Line'.format(hcs2LpKpi_name + "DD"), + selection=self.selHcs2LamPKPi_LamDD, + prescale=config['PrescaleHcs2LamPKPi'], + postscale=config['PostscaleHcs2LamPKPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2LamLamPi_LamLLLL = self.make_line( + name='{0}Line'.format(hcs2LLpi_name + "LLLL"), + selection=self.selHcs2LamLamPi_LamLLLL, + prescale=config['PrescaleHcs2LamLamPi'], + postscale=config['PostscaleHcs2LamLamPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2LamLamPi_LamDDDD = self.make_line( + name='{0}Line'.format(hcs2LLpi_name + "DDDD"), + selection=self.selHcs2LamLamPi_LamDDDD, + prescale=config['PrescaleHcs2LamLamPi'], + postscale=config['PostscaleHcs2LamLamPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Hcs2LamLamPi_LamLLDD = self.make_line( + name='{0}Line'.format(hcs2LLpi_name + "LLDD"), + selection=self.selHcs2LamLamPi_LamLLDD, + prescale=config['PrescaleHcs2LamLamPi'], + postscale=config['PostscaleHcs2LamLamPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Pc2PKPiPi = self.make_line( + name='{0}Line'.format(pc2pKpipi_name), + selection=self.selPc2PKPiPi, + prescale=config['PrescalePc2PKPiPi'], + postscale=config['PostscalePc2PKPiPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Pc2PKsPi_KsLL = self.make_line( + name='{0}Line'.format(pc2pKspi_name + "LL"), + selection=self.selPc2PKsPi_KsLL, + prescale=config['PrescalePc2PKsPi'], + postscale=config['PostscalePc2PKsPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Pc2PKsPi_KsDD = self.make_line( + name='{0}Line'.format(pc2pKspi_name + "DD"), + selection=self.selPc2PKsPi_KsDD, + prescale=config['PrescalePc2PKsPi'], + postscale=config['PostscalePc2PKsPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Ps2PPiPi = self.make_line( + name='{0}Line'.format(ps2ppipi_name), + selection=self.selPs2PPiPi, + prescale=config['PrescalePs2PPiPi'], + postscale=config['PostscalePs2PPiPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_Ps2PPiPiDown = self.make_line( + name='{0}Line'.format(ps2ppipiDown_name), + selection=self.selPs2PPiPiDown, + prescale=config['PrescalePs2PPiPi'], + postscale=config['PostscalePs2PPiPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + ## reference + + self.line_Lc2PKPi = self.make_line( + name='{0}Line'.format(lc2pKpi_name), + selection=self.selLc2PKPi, + prescale=config['PrescaleLc2PKPi'], + postscale=config['PostscaleLc2PKPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_L2PPi = self.make_line( + name='{0}Line'.format(l2ppi_name), + selection=self.selL2PPi, + prescale=config['PrescaleL2PPi'], + postscale=config['PostscaleL2PPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + + self.line_L2PPiDown = self.make_line( + name='{0}Line'.format(l2ppi_name + "Down"), + selection=self.selL2PPiDown, + prescale=config['PrescaleL2PPi'], + postscale=config['PostscaleL2PPi'], + HLT1=config['Hlt1Filter'], + HLT2=config['Hlt2Filter'] + ) + def make_line(self, name, selection, prescale, postscale, **kwargs): """Create the stripping line defined by the selection. @@ -346,7 +860,7 @@ class StrippingCharm2PPXConf(LineBuilder): else: return False - def makeHc2PPX(self, name, inputSel, decDescriptors): + def makeHc2PPX(self, name, inputSel, decDescriptors, mass_max ): """Return a Selection instance for a Hc -> p+ p+ X decay. Keyword arguments: @@ -357,19 +871,20 @@ class StrippingCharm2PPXConf(LineBuilder): combCuts = ( '(AMAXCHILD(PT) > {0[Daug_1ofAll_PT_MIN]})' + ' & (AM < {1})' ' & (AMAXCHILD(PROBNNp) > {0[Proton_1ofAll_ProbNN_MIN]})' ' & (AMAXCHILD(BPVIPCHI2()) > {0[Daug_1ofAll_BPVIPCHI2_MIN]})' " & (ACUTDOCACHI2({0[Comb_ADOCACHI2_MAX]}, ''))" - ).format(self.config) + ).format(self.config, mass_max + 150*MeV) HcCuts = ( '(VFASPF(VCHI2/VDOF) < {0[Hc_VCHI2VDOF_MAX]})' ' & (BPVVDCHI2 > {0[Hc_BPVVDCHI2_MIN]})' ' & (BPVLTIME(9)*c_light > {0[Hc_BPVCTAU_MIN]})' - ' & (M < {0[Comb_MASS_MAX]})' + ' & (M < {1})' + ' & (PT > {0[Hc_PT_MIN]})' # ' & (BPVIPCHI2() < {0[Hc_BPVIPCHI2_MAX]})' -# ' & (PT > {0[Hc_PT_MIN]})' - ).format(self.config) + ).format(self.config, mass_max) _Hc = CombineParticles( name='Combine{0}'.format(name), @@ -380,7 +895,7 @@ class StrippingCharm2PPXConf(LineBuilder): return Selection(name, Algorithm=_Hc, RequiredSelections=inputSel) - def makeHs2PPX(self, name, inputSel, decDescriptors, mipchi2_cut, vdchi2_cut): + def makeHs2PPX(self, name, inputSel, decDescriptors, mass_max, mipchi2_cut, vdchi2_cut): """Return a Selection instance for a Hs -> p+ p+ X decay. Keyword arguments: @@ -391,19 +906,20 @@ class StrippingCharm2PPXConf(LineBuilder): combCuts = ( '(AMAXCHILD(PT) > {0[HsDaug_1ofAll_PT_MIN]})' + ' & (AM < {2})' ' & (AMAXCHILD(PROBNNp) > {0[HsProton_1ofAll_ProbNN_MIN]})' ' & (AMAXCHILD(BPVIPCHI2()) > {1})' " & (ACUTDOCACHI2({0[HsComb_ADOCACHI2_MAX]}, ''))" - ).format(self.config,mipchi2_cut) + ).format(self.config,mipchi2_cut,mass_max) HsCuts = ( '(VFASPF(VCHI2/VDOF) < {0[Hs_VCHI2VDOF_MAX]})' ' & (BPVVDCHI2 > {1})' ' & (BPVLTIME(9)*c_light > {0[Hs_BPVCTAU_MIN]})' - ' & (M < {0[HsComb_MASS_MAX]})' + ' & (M < {2})' + ' & (PT > {0[Hs_PT_MIN]})' # ' & (BPVIPCHI2() < {0[Hs_BPVIPCHI2_MAX]})' -# ' & (PT > {0[Hs_PT_MIN]})' - ).format(self.config,vdchi2_cut) + ).format(self.config,vdchi2_cut,mass_max) _Hs = CombineParticles( name='Combine{0}'.format(name), diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py index a49a51f04..2c86891df 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py @@ -9,7 +9,7 @@ # or submit itself to any jurisdiction. # ############################################################################### -_selections = ('StrippingLambdacForNeutronPID', 'StrippingXiccSL','StrippingD2KPiPiMuNu','StrippingBs2st2pKpipipi', 'StrippingDstarD2KSHHPi0','StrippingCharmFromBSemi', 'StrippingXcpToXiPipHp', 'StrippingLambdac2V0H', 'StrippingNeutralCBaryons', 'StrippingD2HMuNu', 'StrippingXcpToLambdaKSHp', 'StrippingDstarD2XGamma', 'StrippingCharmedBaryonSL' ) +_selections = ('StrippingLambdacForNeutronPID', 'StrippingXiccSL','StrippingD2KPiPiMuNu','StrippingBs2st2pKpipipi', 'StrippingDstarD2KSHHPi0','StrippingCharmFromBSemi', 'StrippingXcpToXiPipHp', 'StrippingLambdac2V0H', 'StrippingNeutralCBaryons', 'StrippingD2HMuNu', 'StrippingXcpToLambdaKSHp', 'StrippingDstarD2XGamma', 'StrippingCharmedBaryonSL', 'StrippingCharm2PPX' ) for _sel in _selections : try : -- GitLab From e28616d84c7f87cb331afcfc1acc1d03b60ad240 Mon Sep 17 00:00:00 2001 From: Yangjie Su <yangjie.su@cern.ch> Date: Fri, 14 Jul 2023 15:53:25 +0200 Subject: [PATCH 04/11] Add charm meson SL decays, Lc -> Lmd eta pi and tune cuts for charmed baryon SL decays --- .../StrippingCharmedBaryonSL.py | 162 ++++- .../StrippingCharm/StrippingCharmedMesonSL.py | 623 ++++++++++++++++++ .../StrippingLambdac2LambdaEtaPi.py | 362 ++++++++++ 3 files changed, 1141 insertions(+), 6 deletions(-) create mode 100644 Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedMesonSL.py create mode 100644 Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingLambdac2LambdaEtaPi.py diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedBaryonSL.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedBaryonSL.py index 3f89ad6b6..cda2bdf3f 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedBaryonSL.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedBaryonSL.py @@ -62,6 +62,8 @@ default_config={ , 'signalPrescaleViaLc' : 1.0 , 'signalPrescaleViaLcL0DDMuNu' : 0.8 , 'signalPrescaleViaLcPPiMuNu' : 0.25 + , 'signalPrescaleViaLcPPiMuNu_Tight' : 1.0 + , 'signalPrescaleViaLcPKMuNu_Tight' : 1.0 , 'signalPrescaleViaOmegac0' : 1.0 , 'signalPrescaleViaXic' : 1.0 , 'signalPrescaleViaXicL0LLMuNu' : 0.8 @@ -70,6 +72,8 @@ default_config={ , 'controlPrescaleViaLcL0DDPiNC' : 0.8 , 'controlPrescaleViaLcPKPiNC' : 0.09 , 'controlPrescaleViaLcPPiPiNC' : 0.06 + , 'controlPrescaleViaLcPKPiNC_Tight' : 0.5 + , 'controlPrescaleViaLcPPiPiNC_Tight' : 0.5 , 'controlPrescaleViaOmegac0NC' : 1.0 , 'controlPrescaleViaXicL0LLPiNC' : 0.4 , 'controlPrescaleViaXicL0DDPiNC' : 0.8 @@ -78,16 +82,21 @@ default_config={ , 'GhostProb' : 0.3 , 'TrGhostProbMax' : 0.25 # same for all particles , 'MINIPCHI2' : 4.0 # adimensiional, orig. 9 + , 'P_Min_Tight' : 3.5*GeV , 'MuonP' : 3.0*GeV , 'MuonPT' : 500*MeV , 'MuonIPCHI2' : 5.0 , 'MuonPIDmu' : 0.0 , 'PionP' : 3.0*GeV + , 'PionP_ForXi' : 2.0*GeV , 'PionPT' : 500*MeV + , 'PionPT_ForXi' : 100*MeV , 'PionPIDK' : 10.0 , 'Pion_PIDpiPIDK_Min' : 0.0 , 'KaonP' : 3.0*GeV + , 'KaonP_ForOm' : 2.0*GeV , 'KaonPT' : 500*MeV + , 'KaonPT_ForOm' : 100*MeV , 'KaonPIDK' : 10.0 , 'Kaon_PIDKPIDpi_Min' : 5.0 , 'ProtonP' : 3.0*GeV @@ -99,6 +108,7 @@ default_config={ , 'ProbNNk' : 0.4 , 'ProbNNpi' : 0.5 , 'ProbNNpiMax' : 0.95 + , 'MisID_PROB_Max' : 0.7 , 'LambdaLLPMin' :5000.0*MeV , 'LambdaLLPTMin' : 800.0*MeV , 'LambdaLLCutMass' : 20.0*MeV @@ -120,13 +130,22 @@ default_config={ , 'LambdaDDMaxVZ' :2275.0*mm , 'LambdaPr_PT_MIN' : 500.0*MeV , 'LambdaPi_PT_MIN' : 100.0*MeV - , 'Lc_ADMASS_HalfWin' : 80.0*MeV - , 'Lc_Daug_1of3_MIPCHI2DV_Min': 4.0 + , 'Lc_ADMASS_HalfWin' : 80.0*MeV + , 'Lc_ADMASS_HalfWin_Tight' : 55.0*MeV + , 'Lc_Daug_1of3_MIPCHI2DV_Min' : 4.0 + , 'Lc_Daug_1of3_MIPCHI2DV_Min_Tight': 9.0 , 'Lc_ADOCAMAX_Max' : 0.5*mm + , 'Lc_ADOCAMAX_Max_Tight' : 0.15*mm , 'Lc_APT_Min' : 1.0*GeV - , 'Lc_VCHI2_Max' : 30.0 - , 'Lc_BPVVDCHI2_Min' : 16.0 + , 'Lc_APT_Min_Tight_PPiMu' : 1.6*GeV + , 'Lc_APT_Min_Tight_PKMu' : 1.6*GeV + , 'Lc_AP_Min_Tight' : 25.0*GeV + , 'Lc_VCHI2_Max' : 30.0 + , 'Lc_VCHI2_Max_Tight' : 20.0 + , 'Lc_BPVVDCHI2_Min' : 16.0 + , 'Lc_BPVVDCHI2_Min_Tight' : 25.0 , 'Lc_BPVDIRA_Min' : 0.9 + , 'Lc_BPVDIRA_Min_Tight' : 0.99 , 'Omegac0_ADAMASS_HalfWin' : 170.0*MeV , 'Omegac0_ADMASS_HalfWin' : 120.0*MeV , 'Omegac0_4Dau_VCHI2_Max' : 60.0 @@ -170,10 +189,18 @@ class StrippingCharmedBaryonSL(LineBuilder) : Algorithm = self._kaonFilter("Kfor"+name), RequiredSelections = [StdAllLooseKaons]) + self.selKaon_ForOm = Selection( "SelKforOm" + name, + Algorithm = self._kaonFilter_ForOm("KforOm"+name), + RequiredSelections = [StdAllLooseKaons]) + self.selPion = Selection( "SelPifor" + name, Algorithm = self._pionFilter("Pifor"+name), RequiredSelections = [StdAllLoosePions]) + self.selPion_ForXi = Selection( "SelPiforXi" + name, + Algorithm = self._pionFilter_ForXi("PiforXi"+name), + RequiredSelections = [StdAllLoosePions]) + self.selProton = Selection( "SelProtonfor" + name, Algorithm = self._protonFilter("Protonfor"+name), RequiredSelections = [StdAllLooseProtons]) @@ -208,7 +235,7 @@ class StrippingCharmedBaryonSL(LineBuilder) : ########################################################################## self.Ximinus2LambdaPi = self.createCombinationSel(OutputList = "Ximinus2LambdaPifor"+ self.name, DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", - DaughterLists = [self.selPion, self.selAllLambda], + DaughterLists = [self.selPion_ForXi, self.selAllLambda], DaughterCuts = {"pi-" : "(MIPCHI2DV(PRIMARY)>4) "}, PreVertexCuts = "(ADAMASS('Xi-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", PostVertexCuts = "(ADMASS('Xi-')<64*MeV)"\ @@ -222,7 +249,7 @@ class StrippingCharmedBaryonSL(LineBuilder) : ########################################################################## self.Omegaminus2LambdaK = self.createCombinationSel(OutputList = "Omegaminus2LambdaKfor"+ self.name, DecayDescriptor = "[Omega- -> Lambda0 K-]cc", - DaughterLists = [self.selKaon, self.selAllLambda], + DaughterLists = [self.selKaon_ForOm, self.selAllLambda], DaughterCuts = {"K-" : "(MIPCHI2DV(PRIMARY)>4) "}, PreVertexCuts = "(ADAMASS('Omega-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", PostVertexCuts = "(ADMASS('Omega-')<64*MeV)"\ @@ -259,6 +286,16 @@ class StrippingCharmedBaryonSL(LineBuilder) : _pi = FilterDesktop(Code = _code ) return _pi + def _pionFilter_ForXi( self , _name): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(PionP_ForXi)s) & (PT > %(PionPT_ForXi)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK< %(PionPIDK)s)"\ + "& (PROBNNpi > %(ProbNNpi)s)" % self.config + _pi_ForXi = FilterDesktop(Code = _code ) + return _pi_ForXi + def _kaonFilter( self , _name ): _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ "& (P>%(KaonP)s) & (PT > %(KaonPT)s)"\ @@ -270,6 +307,17 @@ class StrippingCharmedBaryonSL(LineBuilder) : _ka = FilterDesktop(Code = _code ) return _ka + def _kaonFilter_ForOm( self , _name ): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(KaonP_ForOm)s) & (PT > %(KaonPT_ForOm)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK> %(KaonPIDK)s) & (PROBNNpi < %(ProbNNpiMax)s)"\ + "& (PROBNNk > %(ProbNNk)s)"\ + "& (HASRICH)&(PIDK-PIDpi>%(Kaon_PIDKPIDpi_Min)s)"% self.config + _ka_ForOm = FilterDesktop(Code = _code ) + return _ka_ForOm + def _protonFilter( self, _name ): _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ "& (PT > %(ProtonPT)s) & (P>%(ProtonP)s)"\ @@ -352,6 +400,58 @@ class StrippingCharmedBaryonSL(LineBuilder) : _strCutComb_L0MuSL = _strCutCombfor + '&' + _strCutComb_MassL0MuSL _strCutComb_pKMuSL = _strCutCombfor + '&' + _strCutComb_MasspKMuSL _strCutComb_ppiMuSL = _strCutCombfor + '&' + _strCutComb_MassppiMuSL + + # Tight cut for Lambda_c+ -> p pi+ mu+ nu to reduce the rate + _strCutCombfor_PPiMu = "(AMINCHILD(MIPCHI2DV(PRIMARY))> %(Lc_Daug_1of3_MIPCHI2DV_Min_Tight)s )" \ + "& (ADOCAMAX('')<%(Lc_ADOCAMAX_Max_Tight)s)" \ + "& (AMINCHILD(P)>%(P_Min_Tight)s)" \ + "& (AP>%(Lc_AP_Min_Tight)s)" \ + "& (APT>%(Lc_APT_Min_Tight_PPiMu)s)" % self.config + _strCutCombfor_PKMu = "(AMINCHILD(MIPCHI2DV(PRIMARY))> %(Lc_Daug_1of3_MIPCHI2DV_Min_Tight)s )" \ + "& (ADOCAMAX('')<%(Lc_ADOCAMAX_Max_Tight)s)" \ + "& (AMINCHILD(P)>%(P_Min_Tight)s)" \ + "& (AP>%(Lc_AP_Min_Tight)s)" \ + "& (APT>%(Lc_APT_Min_Tight_PKMu)s)" % self.config + _strCutCombfor_PPiPi = "(AMINCHILD(MIPCHI2DV(PRIMARY))> %(Lc_Daug_1of3_MIPCHI2DV_Min_Tight)s )" \ + "& (ADOCAMAX('')<%(Lc_ADOCAMAX_Max_Tight)s)" \ + "& (AMINCHILD(P)>%(P_Min_Tight)s)" \ + "& (AP>%(Lc_AP_Min_Tight)s)" \ + "& (APT>%(Lc_APT_Min_Tight_PPiMu)s)" % self.config + _strCutCombfor_PKPi = "(AMINCHILD(MIPCHI2DV(PRIMARY))> %(Lc_Daug_1of3_MIPCHI2DV_Min_Tight)s )" \ + "& (ADOCAMAX('')<%(Lc_ADOCAMAX_Max_Tight)s)" \ + "& (AMINCHILD(P)>%(P_Min_Tight)s)" \ + "& (AP>%(Lc_AP_Min_Tight)s)" \ + "& (APT>%(Lc_APT_Min_Tight_PKMu)s)" % self.config + _strCutMothSL_PPiMu = "(VFASPF(VCHI2) < %(Lc_VCHI2_Max_Tight)s)" \ + "& (BPVVDCHI2>%(Lc_BPVVDCHI2_Min_Tight)s)" \ + "& (BPVDIRA>%(Lc_BPVDIRA_Min_Tight)s)" \ + "& (NINTREE(('pi+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNp < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" \ + "& (NINTREE(('p+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNpi < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" \ + "& (NINTREE(('mu+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNp < %(MisID_PROB_Max)s) & (PROBNNpi < %(MisID_PROB_Max)s)) > 0)" % self.config + _strCutMothSL_PKMu = "(VFASPF(VCHI2) < %(Lc_VCHI2_Max_Tight)s)" \ + "& (BPVVDCHI2>%(Lc_BPVVDCHI2_Min_Tight)s)" \ + "& (BPVDIRA>%(Lc_BPVDIRA_Min_Tight)s)" \ + "& (NINTREE(('K+'==ABSID) & (PROBNNpi < %(MisID_PROB_Max)s) & (PROBNNp < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" \ + "& (NINTREE(('p+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNpi < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" \ + "& (NINTREE(('mu+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNp < %(MisID_PROB_Max)s) & (PROBNNpi < %(MisID_PROB_Max)s)) > 0)" % self.config + _strCutMothSL_PPiPi = "(VFASPF(VCHI2) < 20)" \ + "& (BPVVDCHI2>%(Lc_BPVVDCHI2_Min_Tight)s)" \ + "& (BPVDIRA>%(Lc_BPVDIRA_Min_Tight)s)" \ + "& (NINTREE(('pi+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNp < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 1)" \ + "& (NINTREE(('p+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNpi < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" % self.config + _strCutMothSL_PKPi = "(VFASPF(VCHI2) < %(Lc_VCHI2_Max_Tight)s)" \ + "& (BPVVDCHI2>%(Lc_BPVVDCHI2_Min_Tight)s)" \ + "& (BPVDIRA>%(Lc_BPVDIRA_Min_Tight)s)" \ + "& (NINTREE(('pi+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNp < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" \ + "& (NINTREE(('K+'==ABSID) & (PROBNNpi < %(MisID_PROB_Max)s) & (PROBNNp < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" \ + "& (NINTREE(('p+'==ABSID) & (PROBNNk < %(MisID_PROB_Max)s) & (PROBNNpi < %(MisID_PROB_Max)s) & (PROBNNmu < %(MisID_PROB_Max)s)) > 0)" % self.config + _strCutComb_ppiMuSL_Tight = _strCutCombfor_PPiMu + '&' + _strCutComb_MassppiMuSL + _strCutComb_pKMuSL_Tight = _strCutCombfor_PKMu + '&' + _strCutComb_MasspKMuSL + _strCutComb_ppipiNC_Tight = _strCutCombfor_PPiPi + '&' + "(ADAMASS('Lambda_c+')< 1.1*%(Lc_ADMASS_HalfWin_Tight)s)" % self.config + _strCutMoth_ppipiNC_Tight = _strCutMothSL_PPiPi + '&' + "(ADMASS('Lambda_c+')< %(Lc_ADMASS_HalfWin_Tight)s)" % self.config + _strCutComb_pKpiNC_Tight = _strCutCombfor_PKPi + '&' + "(ADAMASS('Lambda_c+')< 1.1*%(Lc_ADMASS_HalfWin_Tight)s)" % self.config + _strCutMoth_pKpiNC_Tight = _strCutMothSL_PKPi + '&' + "(ADMASS('Lambda_c+')< %(Lc_ADMASS_HalfWin_Tight)s)" % self.config + _strCutMothSL = _strCutMothfor ''' Stripping Lambda_c+ -> Lambda0(LL) mu+ ''' @@ -390,6 +490,18 @@ class StrippingCharmedBaryonSL(LineBuilder) : EnableFlavourTagging = False ) self.registerLine (Lambdac2PKMuNuLine) + ''' Tight Line ''' + Lambdac2PKMuNuTight = self.createCombinationSel(OutputList = "Lambdac2PKMuNuTight" + self.name, + DecayDescriptor = "[Lambda_c+ -> p+ K- mu+]cc", + DaughterLists = [self.selProton, self.selKaon, self.selMuon], + PreVertexCuts = _strCutComb_pKMuSL_Tight, + PostVertexCuts = _strCutMothSL_PKMu ) + Lambdac2PKMuNuTightLine = StrippingLine( self.name + "Lambdac2PKMuNuTightLine", + prescale = self.config['signalPrescaleViaLcPKMuNu_Tight'], + algos = [ Lambdac2PKMuNuTight ], + EnableFlavourTagging = False ) + self.registerLine (Lambdac2PKMuNuTightLine) + ''' Stripping Lambda_c+ -> p+ pi- mu+ ''' Lambdac2PPiMuNu = self.createCombinationSel(OutputList = "Lambdac2PPiMuNu" + self.name, DecayDescriptor = "[Lambda_c+ -> p+ pi- mu+]cc", @@ -402,6 +514,18 @@ class StrippingCharmedBaryonSL(LineBuilder) : EnableFlavourTagging = False ) self.registerLine (Lambdac2PPiMuNuLine) + ''' Tight Line ''' + Lambdac2PPiMuNuTight = self.createCombinationSel(OutputList = "Lambdac2PPiMuNuTight" + self.name, + DecayDescriptor = "[Lambda_c+ -> p+ pi- mu+]cc", + DaughterLists = [self.selProton, self.selPion, self.selMuon], + PreVertexCuts = _strCutComb_ppiMuSL_Tight, + PostVertexCuts = _strCutMothSL_PPiMu ) + Lambdac2PPiMuNuTightLine = StrippingLine( self.name + "Lambdac2PPiMuNuTightLine", + prescale = self.config['signalPrescaleViaLcPPiMuNu_Tight'], + algos = [ Lambdac2PPiMuNuTight ], + EnableFlavourTagging = False ) + self.registerLine (Lambdac2PPiMuNuTightLine) + ''' ---------------------- ''' ''' Normalization channels ''' ''' ---------------------- ''' @@ -441,6 +565,19 @@ class StrippingCharmedBaryonSL(LineBuilder) : EnableFlavourTagging = False ) self.registerLine (Lambdac2PKPiNCLine) + ''' Tight Line ''' + Lambdac2PKPiNCTight = self.createCombinationSel(OutputList = "Lambdac2PKPiNCTight" + self.name, + DecayDescriptor = "[Lambda_c+ -> p+ K- pi+]cc", + DaughterLists = [self.selProton, self.selKaon, self.selPion], + PreVertexCuts = _strCutComb_pKpiNC_Tight, + PostVertexCuts = _strCutMoth_pKpiNC_Tight ) + Lambdac2PKPiNCTightLine = StrippingLine( self.name + "Lambdac2PKPiNCTightLine", + prescale = self.config['controlPrescaleViaLcPKPiNC_Tight'], + L0DU = "L0_CHANNEL('Hadron')", + algos = [ Lambdac2PKPiNCTight ], + EnableFlavourTagging = False ) + self.registerLine (Lambdac2PKPiNCTightLine) + ''' NC Stripping Lambda_c+ -> p+ pi- pi+ ''' Lambdac2PPiPiNC = self.createCombinationSel(OutputList = "Lambdac2PPiPiNC" + self.name, DecayDescriptor = "[Lambda_c+ -> p+ pi- pi+]cc", @@ -452,6 +589,19 @@ class StrippingCharmedBaryonSL(LineBuilder) : algos = [ Lambdac2PPiPiNC ], EnableFlavourTagging = False ) self.registerLine (Lambdac2PPiPiNCLine) + + ''' Tight Line ''' + Lambdac2PPiPiNCTight = self.createCombinationSel(OutputList = "Lambdac2PPiPiNCTight" + self.name, + DecayDescriptor = "[Lambda_c+ -> p+ pi- pi+]cc", + DaughterLists = [self.selProton, self.selPion, self.selPion], + PreVertexCuts = _strCutComb_ppipiNC_Tight, + PostVertexCuts = _strCutMoth_ppipiNC_Tight ) + Lambdac2PPiPiNCTightLine = StrippingLine( self.name + "Lambdac2PPiPiNCTightLine", + prescale = self.config['controlPrescaleViaLcPPiPiNC_Tight'], + L0DU = "L0_CHANNEL('Hadron')", + algos = [ Lambdac2PPiPiNCTight ], + EnableFlavourTagging = False ) + self.registerLine (Lambdac2PPiPiNCTightLine) ## -------------------- End of LambdacSL ------------ ##------------------------------------------------------------------------------------------ diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedMesonSL.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedMesonSL.py new file mode 100644 index 000000000..ac354967d --- /dev/null +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingCharmedMesonSL.py @@ -0,0 +1,623 @@ +############################################################################### +# (c) Copyright 2000-2019 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. # +############################################################################### +''' +Speculative code for charmed meson searches. +Charmed mesons are from beauty decays (Btag) along with WS lines and normalization lines: +Note: +The mass window for B~0 and D+ are wide enough to include B_s~0 and Ds+ + +1. B~0 -> D+ pi- pi- pi+, D+ -> K+ K- mu+ nu : + +2. B~0 -> D+ pi- pi- pi+, D+ -> pi+ pi- mu+ nu : + +3. B- -> D0 pi- pi- pi+, D0 -> eta pi- mu+ nu, eta -> pi+ pi- pi0(gamma): + +4. B- -> D0 pi- pi- pi+, D0 -> pi- pi+ pi- mu+ nu: + +5. B- -> D0 pi- pi- pi+, D0 -> pi- K+ K- mu+ nu : +''' + + +__author__ = ['Xiao-Rui Lyu', 'Yangjie Su'] +__date__ = '2023/06/30' +__version__ = '$Revision: 0.1 $' +__all__ = ('StrippingCharmedMesonSL' + ,'default_config') + + +from Gaudi.Configuration import * +from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles +from StandardParticles import StdLoosePions, StdNoPIDsDownPions, StdLooseKaons, StdLooseDownKaons +from StandardParticles import StdAllLoosePions, StdAllLooseKaons, StdLooseMuons, StdAllLooseProtons, StdAllLooseMuons, StdAllVeryLooseMuons +from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection +from PhysSelPython.Wrappers import MultiSelectionSequence +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder +from GaudiKernel.SystemOfUnits import MeV, GeV, mm, picosecond +import sys + + +default_name='CharmedMesonSL' + #### This is the dictionary of all tunable cuts ######## +default_config={ + 'NAME' : 'CharmedMesonSL', + 'WGs' : ['Charm'], + 'BUILDERTYPE' : 'StrippingCharmedMesonSL', + 'STREAMS' : ['Charm'], + 'CONFIG' : { + 'GEC_nLongTrk' : 160 # adimensional + , 'signalPrescaleViaD2KKmunu' : 1.0 + , 'controlPrescaleViaD2KKpi' : 1.0 + , 'signalPrescaleViaD2pipimunu' : 1.0 + , 'controlPrescaleViaD2pipipi' : 1.0 + , 'signalPrescaleViaD02pipipimunu' : 1.0 + , 'controlPrescaleViaD02pipipipi' : 1.0 + , 'signalPrescaleViaD02KKpimunu' : 1.0 + , 'controlPrescaleViaD02KKpipi' : 1.0 + , 'signalPrescaleViaD02etapimunu' : 1.0 + , 'controlPrescaleViaD02etapipi' : 1.0 + , 'TRCHI2DOFMax' : 3.0 + , 'GhostProb' : 0.3 + , 'TrGhostProbMax' : 0.25 # same for all particles + , 'MINIPCHI2' : 4.0 # adimensiional + , 'MuonP' : 3*GeV + , 'MuonPT' : 250*MeV + , 'MuonIPCHI2' : 4.0 + , 'MuonPIDmu' : 0.0 + , 'PionP' : 3*GeV + , 'PionPT' : 250*MeV + , 'PionPIDK' : 5.0 + , 'Pion_PIDpiPIDK_Min' : 0.0 + , 'KaonP' : 3*GeV + , 'KaonPT' : 250*MeV + , 'KaonPIDK' : 10.0 + , 'Kaon_PIDKPIDpi_Min' : 5.0 + , 'ProbNNk' : 0.4 + , 'ProbNNpi' : 0.5 + , 'ProbNNpiMax' : 0.9 + , 'Dp_ADMASS_Min' : 1800.0*MeV + , 'Dp_ADMASS_Max' : 2030.0*MeV #large enough to cover D_s+ + , 'D0_ADMASS_Min' : 1820.0*MeV + , 'D0_ADMASS_Max' : 1900.0*MeV + , 'Dp_Daug_1of3_MIPCHI2DV_Min': 4.0 + , 'Dp_ADOCAMAX_Max' : 0.25*mm + , 'Dp_APT_Min' : 1.2*GeV + , 'Dp_AP_Min' : 20*GeV + , 'Dp_VCHI2_Max' : 30.0 + , 'Dp_BPVVDCHI2_Min' : 16.0 + , 'Dp_BPVDIRA_Min' : 0.95 + , 'KKMu_AM_Min' : 1100.0*MeV + , 'PiPiMu_AM_Min' : 400.0*MeV + , 'PiPiPiMu_AM_Min' : 530.0*MeV + , 'PiKKMu_AM_Min' : 1240.0*MeV + , 'EtaPiMu_AM_Min' : 800.0*MeV + , 'DpSL_AM_Max' : 2080.0*MeV #large enough to cover D_s+ + , 'D0SL_AM_Max' : 1960.0*MeV + + #For B mesons + , 'B0SL_M_Min': 2800*MeV + , 'B0SL_M_Max': 5600*MeV #large enough to cover B_s0 + , 'B0_M_Min': 5100*MeV + , 'B0_M_Max': 5600*MeV #large enough to cover B_s0 + + , 'BpSL_M_Min': 3000*MeV + , 'BpSL_M_Max': 5700*MeV + , 'Bp_M_Min': 5100*MeV + , 'Bp_M_Max': 5500*MeV + + , 'B_AP_Min': 20*GeV + , 'B_APT_Min': 1.5*GeV + , 'B_VCHI2_Max': 30 + , 'B_BPVVDCHI2_Min': 16 + , 'B_BPVDIRA_Min': 0.95 + } ## end of 'CONFIG' +} ## end of default_config + +#------------------------------------------------------------------------------------------------------------- +class StrippingCharmedMesonSL(LineBuilder) : + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__(self, name, config) : + LineBuilder.__init__(self, name, config) + self.name = name + self.config = config + + GECs = { "Code":"( recSummaryTrack(LHCb.RecSummary.nLongTracks, TrLONG) < %(GEC_nLongTrk)s )" % config, + "Preambulo": ["from LoKiTracks.decorators import *"]} + + ########################################################################## + ## Basic particles: mu, K, pi, eta + ########################################################################## + self.selMuon = Selection( "SelMufor" + name, + Algorithm = self._muonFilter("Mufor"+name), + RequiredSelections = [StdLooseMuons]) + + self.selKaon = Selection( "SelKfor" + name, + Algorithm = self._kaonFilter("Kfor"+name), + RequiredSelections = [StdAllLooseKaons]) + + self.selPion = Selection( "SelPifor" + name, + Algorithm = self._pionFilter("Pifor"+name), + RequiredSelections = [StdAllLoosePions]) + + self.makeEta() + # then use self.Eta2PiPiPi0 and self.Eta2PiPiGamma + + ########################################################################## + ## Charmed Meson SL lines + ########################################################################## + self.DmesonSLList = self.makeDmesonSL() + + + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + # Sub Function + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + def _muonFilter( self , _name): + _code = " (TRCHI2DOF< %(TRCHI2DOFMax)s)"\ + "& (PT>%(MuonPT)s) & (P>%(MuonP)s)"\ + "& (TRGHOSTPROB< %(GhostProb)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MuonIPCHI2)s)"\ + "& (PIDmu > %(MuonPIDmu)s) & ISMUON" % self.config + _mu = FilterDesktop(Code = _code ) + return _mu + + def _pionFilter( self , _name): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(PionP)s) & (PT > %(PionPT)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK< %(PionPIDK)s) "\ + "& (HASRICH)&(PROBNNpi > %(ProbNNpi)s) " % self.config + _pi = FilterDesktop(Code = _code ) + return _pi + + def _kaonFilter( self , _name ): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(KaonP)s) & (PT > %(KaonPT)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK> %(KaonPIDK)s) & (PROBNNpi < %(ProbNNpiMax)s)"\ + "& (PROBNNk > %(ProbNNk)s) "\ + "& (HASRICH)&(PIDK-PIDpi>%(Kaon_PIDKPIDpi_Min)s) "% self.config + _ka = FilterDesktop(Code = _code ) + return _ka + + def makeB0Line(self, line_name, prescale, charmed_meson, is_NC = False): + comb_cut = "(ADOCA(2,3) < %(Dp_ADOCAMAX_Max)s) & (ADOCA(2,4) < %(Dp_ADOCAMAX_Max)s)"\ + "& (AP > %(B_AP_Min)s)"\ + "& (APT > %(B_APT_Min)s)" % self.config + vertex_cut = "(VFASPF(VCHI2) < %(B_VCHI2_Max)s)" \ + "& (BPVVDCHI2>%(B_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(B_BPVDIRA_Min)s)" % self.config + + if is_NC : + comb_cut = comb_cut + "& in_range(%(B0_M_Min)s - 200*MeV, AM, %(B0_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(B0_M_Min)s , M, %(B0_M_Max)s )" % self.config + else: + comb_cut = comb_cut + "& in_range(%(B0SL_M_Min)s - 200*MeV, AM, %(B0SL_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(B0SL_M_Min)s , M, %(B0SL_M_Max)s )" % self.config + + B0 = self.createCombinationSel(OutputList = "B02DPiPiPi_" + line_name, + DecayDescriptor = "[B~0 -> D+ pi+ pi- pi-]cc", + DaughterLists = [charmed_meson, self.selPion, self.selPion, self.selPion], + PreVertexCuts = comb_cut, + PostVertexCuts = vertex_cut ) + B0Line = StrippingLine( line_name, + prescale = prescale, + selection = B0, + EnableFlavourTagging = False ) + return B0Line + + def makeBpLine(self, line_name, prescale, charmed_meson, is_NC = False): + comb_cut = "(ADOCA(2,3) < %(Dp_ADOCAMAX_Max)s) & (ADOCA(2,4) < %(Dp_ADOCAMAX_Max)s)"\ + "& (AP > %(B_AP_Min)s)"\ + "& (APT > %(B_APT_Min)s)" % self.config + vertex_cut = "(VFASPF(VCHI2) < %(B_VCHI2_Max)s)" \ + "& (BPVVDCHI2>%(B_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(B_BPVDIRA_Min)s)" % self.config + + if is_NC : + comb_cut = comb_cut + "& in_range(%(Bp_M_Min)s - 200*MeV, AM, %(Bp_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(Bp_M_Min)s , M, %(Bp_M_Max)s )" % self.config + else: + comb_cut = comb_cut + "& in_range(%(BpSL_M_Min)s - 200*MeV, AM, %(BpSL_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(BpSL_M_Min)s , M, %(BpSL_M_Max)s )" % self.config + + Bp = self.createCombinationSel(OutputList = "B2D0PiPiPi_" + line_name, + DecayDescriptor = ["B- -> D0 pi+ pi- pi-", "B- -> D~0 pi+ pi- pi-", "B- -> D0 pi- pi+ pi+", "B- -> D~0 pi- pi+ pi+"], + DaughterLists = [charmed_meson, self.selPion, self.selPion, self.selPion], + PreVertexCuts = comb_cut, + PostVertexCuts = vertex_cut ) + BpLine = StrippingLine( line_name, + prescale = prescale, + selection = Bp, + EnableFlavourTagging = False ) + return BpLine + + def makeB0WSLine(self, line_name, prescale, charmed_meson, is_NC = False): + comb_cut = "(ADOCA(2,3) < %(Dp_ADOCAMAX_Max)s) & (ADOCA(2,4) < %(Dp_ADOCAMAX_Max)s)"\ + "& (AP > %(B_AP_Min)s)"\ + "& (APT > %(B_APT_Min)s)" % self.config + vertex_cut = "(VFASPF(VCHI2) < %(B_VCHI2_Max)s)" \ + "& (BPVVDCHI2>%(B_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(B_BPVDIRA_Min)s)" % self.config + if is_NC : + comb_cut = comb_cut + "& in_range(%(B0_M_Min)s - 200*MeV, AM, %(B0_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(B0_M_Min)s , M, %(B0_M_Max)s )" % self.config + else: + comb_cut = comb_cut + "& in_range(%(B0SL_M_Min)s - 200*MeV, AM, %(B0SL_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(B0SL_M_Min)s , M, %(B0SL_M_Max)s )" % self.config + + WS_descriptors=[ + "B0 -> D+ pi+ pi+ pi+", + "B0 -> D- pi- pi- pi-", + "B0 -> D+ pi- pi- pi-", + "B0 -> D- pi+ pi+ pi+", + "B0 -> D+ pi+ pi+ pi-", + "B0 -> D- pi- pi- pi+", + ] + + B0 = self.createCombinationSel(OutputList = "B02DPiPiPi_" + line_name, + DecayDescriptor = WS_descriptors, + DaughterLists = [charmed_meson, self.selPion, self.selPion, self.selPion], + PreVertexCuts = comb_cut, + PostVertexCuts = vertex_cut ) + B0Line = StrippingLine( line_name, + prescale = prescale, + selection = B0, + EnableFlavourTagging = False ) + return B0Line + + def makeBpWSLine(self, line_name, prescale, charmed_meson, is_NC = False): + comb_cut = "(ADOCA(2,3) < %(Dp_ADOCAMAX_Max)s) & (ADOCA(2,4) < %(Dp_ADOCAMAX_Max)s)"\ + "& (AP > %(B_AP_Min)s)"\ + "& (APT > %(B_APT_Min)s)" % self.config + vertex_cut = "(VFASPF(VCHI2) < %(B_VCHI2_Max)s)" \ + "& (BPVVDCHI2>%(B_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(B_BPVDIRA_Min)s)" % self.config + if is_NC : + comb_cut = comb_cut + "& in_range(%(Bp_M_Min)s - 200*MeV, AM, %(Bp_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(Bp_M_Min)s , M, %(Bp_M_Max)s )" % self.config + else: + comb_cut = comb_cut + "& in_range(%(BpSL_M_Min)s - 200*MeV, AM, %(BpSL_M_Max)s + 200*MeV)" % self.config + vertex_cut = vertex_cut + "& in_range(%(BpSL_M_Min)s , M, %(BpSL_M_Max)s )" % self.config + + WS_descriptors=[ + "B- -> D0 pi+ pi+ pi+", + "B- -> D~0 pi- pi- pi-", + "B- -> D0 pi- pi- pi-", + "B- -> D~0 pi+ pi+ pi+", + ] + + Bp = self.createCombinationSel(OutputList = "B2D0PiPiPi_" + line_name, + DecayDescriptor = WS_descriptors, + DaughterLists = [charmed_meson, self.selPion, self.selPion, self.selPion], + PreVertexCuts = comb_cut, + PostVertexCuts = vertex_cut ) + BpLine = StrippingLine( line_name, + prescale = prescale, + selection = Bp, + EnableFlavourTagging = False ) + return BpLine + + + ##------------------------------------------------------------------------------------------ + ## -------------------- Begin to DpSL ------------ + def makeDmesonSL( self ): + + _strCutCombfor = "(AMINCHILD(MIPCHI2DV(PRIMARY))>%(Dp_Daug_1of3_MIPCHI2DV_Min)s)" \ + "& (ADOCAMAX('')<%(Dp_ADOCAMAX_Max)s)" \ + "& (AP>%(Dp_AP_Min)s)" \ + "& (APT>%(Dp_APT_Min)s)" % self.config + + _strCutMothfor = "(VFASPF(VCHI2) < %(Dp_VCHI2_Max)s)" \ + "& (BPVVDCHI2>%(Dp_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(Dp_BPVDIRA_Min)s)" % self.config + + _strCutComb_Mass_Dp = "(AM>0.9*%(Dp_ADMASS_Min)s) & (AM<1.1*%(Dp_ADMASS_Max)s)" % self.config + _strCutMoth_Mass_Dp = "(M>%(Dp_ADMASS_Min)s) & (M<%(Dp_ADMASS_Max)s)" % self.config + _strCutComb_Mass_D0 = "(AM>0.9*%(D0_ADMASS_Min)s) & (AM<1.1*%(D0_ADMASS_Max)s)" % self.config + _strCutMoth_Mass_D0 = "(M>%(D0_ADMASS_Min)s) & (M<%(D0_ADMASS_Max)s)" % self.config + + _strCutComb_Mass_D0_with_neutral = "(AM>0.9*%(D0_ADMASS_Min)s) & (AM<1.1*%(D0_ADMASS_Max)s)" % self.config + _strCutMoth_Mass_D0_with_neutral = "(M>%(D0_ADMASS_Min)s - 100*MeV) & (M<%(D0_ADMASS_Max)s + 100*MeV)" % self.config + + _strCutComb_Dp = _strCutCombfor + '&' + _strCutComb_Mass_Dp + _strCutMoth_Dp = _strCutMothfor + '&' + _strCutMoth_Mass_Dp + _strCutComb_D0 = _strCutCombfor + '&' + _strCutComb_Mass_D0 + _strCutMoth_D0 = _strCutMothfor + '&' + _strCutMoth_Mass_D0 + + _strCutComb_D0_with_neutral = _strCutCombfor + '&' + _strCutComb_Mass_D0_with_neutral + _strCutMoth_D0_with_neutral = _strCutMothfor + '&' + _strCutMoth_Mass_D0_with_neutral + + _strCutComb_MassKKMuSL = "(AM>%(KKMu_AM_Min)s) & (AM<%(DpSL_AM_Max)s)" % self.config + _strCutComb_MassPiPiMuSL = "(AM>%(PiPiMu_AM_Min)s) & (AM<%(DpSL_AM_Max)s)" % self.config + _strCutComb_MassPiPiPiMuSL = "(AM>%(PiPiPiMu_AM_Min)s) & (AM<%(D0SL_AM_Max)s)" % self.config + _strCutComb_MassPiKKMuSL = "(AM>%(PiKKMu_AM_Min)s) & (AM<%(D0SL_AM_Max)s)" % self.config + _strCutComb_MassEtaPiMuSL = "(AM>%(EtaPiMu_AM_Min)s) & (AM<%(D0SL_AM_Max)s)" % self.config + + _strCutComb_KKMuSL = _strCutCombfor + '&' + _strCutComb_MassKKMuSL + _strCutComb_PiPiMuSL = _strCutCombfor + '&' + _strCutComb_MassPiPiMuSL + _strCutComb_PiPiPiMuSL = _strCutCombfor + '&' + _strCutComb_MassPiPiPiMuSL + _strCutComb_PiKKMuSL = _strCutCombfor + '&' + _strCutComb_MassPiKKMuSL + _strCutComb_EtaPiMuSL = _strCutCombfor + '&' + _strCutComb_MassEtaPiMuSL + _strCutMothSL = _strCutMothfor + + ''' Stripping D+ -> K+ K- mu+ ''' + KKMuNu = self.createCombinationSel(OutputList = "D2KKMuNu" + self.name, + DecayDescriptor = "[D+ -> K+ K- mu+]cc", + DaughterLists = [self.selKaon, self.selKaon,self.selMuon], + PreVertexCuts = _strCutComb_KKMuSL, + PostVertexCuts = _strCutMothSL ) + + self.registerLine(self.makeB0Line( + line_name=self.name + "B02DPiPiPiD2KKMuNuFromBLine", + prescale=self.config['signalPrescaleViaD2KKmunu'], + charmed_meson=KKMuNu + )) + self.registerLine(self.makeB0WSLine( + line_name=self.name + "B02DPiPiPiD2KKMuNuFromBWSLine", + prescale=self.config['signalPrescaleViaD2KKmunu'], + charmed_meson=KKMuNu + )) + + ''' Stripping D+ -> pi+ pi- mu+ ''' + PiPiMuNu = self.createCombinationSel(OutputList = "D2PiPiMuNu" + self.name, + DecayDescriptor = "[D+ -> pi+ pi- mu+]cc", + DaughterLists = [self.selPion, self.selPion,self.selMuon], + PreVertexCuts = _strCutComb_PiPiMuSL, + PostVertexCuts = _strCutMothSL ) + self.registerLine(self.makeB0Line( + line_name=self.name + "B02DPiPiPiD2PiPiMuNuFromBLine", + prescale=self.config['signalPrescaleViaD2pipimunu'], + charmed_meson=PiPiMuNu + )) + self.registerLine(self.makeB0WSLine( + line_name=self.name + "B02DPiPiPiD2PiPiMuNuFromBWSLine", + prescale=self.config['signalPrescaleViaD2pipimunu'], + charmed_meson=PiPiMuNu + )) + + ''' Stripping D0 -> pi- pi+ pi- mu+ ''' + PiPiPiMuNu = self.createCombinationSel(OutputList = "D02PiPiPiMuNu" + self.name, + DecayDescriptor = "[D0 -> pi- pi- pi+ mu+]cc", + DaughterLists = [self.selPion, self.selPion, self.selPion, self.selMuon], + PreVertexCuts = _strCutComb_PiPiPiMuSL, + PostVertexCuts = _strCutMothSL ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02PiPiPiMuNuFromBLine", + prescale=self.config['signalPrescaleViaD02pipipimunu'], + charmed_meson=PiPiPiMuNu + )) + self.registerLine(self.makeBpWSLine( + line_name=self.name + "B2D0PiPiPiD02PiPiPiMuNuFromBWSLine", + prescale=self.config['signalPrescaleViaD02pipipimunu'], + charmed_meson=PiPiPiMuNu + )) + + ''' Stripping D0 -> pi- K+ K- mu+ ''' + PiKKMuNu = self.createCombinationSel(OutputList = "D02PiKKMuNu" + self.name, + DecayDescriptor = "[D0 -> pi- K+ K- mu+]cc", + DaughterLists = [self.selPion, self.selKaon, self.selKaon, self.selMuon], + PreVertexCuts = _strCutComb_PiKKMuSL, + PostVertexCuts = _strCutMothSL ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02PiKKMuNuFromBLine", + prescale=self.config['signalPrescaleViaD02KKpimunu'], + charmed_meson=PiKKMuNu + )) + self.registerLine(self.makeBpWSLine( + line_name=self.name + "B2D0PiPiPiD02PiKKMuNuFromBWSLine", + prescale=self.config['signalPrescaleViaD02KKpimunu'], + charmed_meson=PiKKMuNu + )) + + ''' Stripping D0 -> eta pi- mu+, eta -> pi+ pi- pi0 ''' + EtaPiMuNuEta2PiPiPi0 = self.createCombinationSel(OutputList = "D02EtaPiMuNu_Eta2PiPi0" + self.name, + DecayDescriptor = "[D0 -> eta pi- mu+]cc", + DaughterLists = [self.Eta2PiPiPi0, self.selPion, self.selMuon], + PreVertexCuts = _strCutComb_EtaPiMuSL, + PostVertexCuts = _strCutMothSL ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02EtaPiMuNuEta2PiPiPi0FromBLine", + prescale=self.config['signalPrescaleViaD02etapimunu'], + charmed_meson=EtaPiMuNuEta2PiPiPi0 + )) + self.registerLine(self.makeBpWSLine( + line_name=self.name + "B2D0PiPiPiD02EtaPiMuNuEta2PiPiPi0FromBWSLine", + prescale=self.config['signalPrescaleViaD02etapimunu'], + charmed_meson=EtaPiMuNuEta2PiPiPi0 + )) + + ''' Stripping D0 -> eta pi- mu+, eta -> pi+ pi- gamma ''' + EtaPiMuNuEta2PiPiGamma = self.createCombinationSel(OutputList = "D02EtaPiMuNu_Eta2PiPiGamma" + self.name, + DecayDescriptor = "[D0 -> eta pi- mu+]cc", + DaughterLists = [self.Eta2PiPiGamma, self.selPion, self.selMuon], + PreVertexCuts = _strCutComb_EtaPiMuSL, + PostVertexCuts = _strCutMothSL ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02EtaPiMuNuEta2PiPiGammaFromBLine", + prescale=self.config['signalPrescaleViaD02etapimunu'], + charmed_meson=EtaPiMuNuEta2PiPiGamma + )) + self.registerLine(self.makeBpWSLine( + line_name=self.name + "B2D0PiPiPiD02EtaPiMuNuEta2PiPiGammaFromBWSLine", + prescale=self.config['signalPrescaleViaD02etapimunu'], + charmed_meson=EtaPiMuNuEta2PiPiGamma + )) + + ''' ---------------------- ''' + ''' Normalization channels ''' + ''' ---------------------- ''' + ''' NC Stripping D+ -> K+ K- pi+ ''' + D2KKPiNC = self.createCombinationSel(OutputList = "D2KKPiNC" + self.name, + DecayDescriptor = "[D+ -> K+ K- pi+]cc", + DaughterLists = [self.selKaon, self.selKaon,self.selPion], + PreVertexCuts = _strCutComb_Dp, + PostVertexCuts = _strCutMoth_Dp ) + + self.registerLine(self.makeB0Line( + line_name=self.name + "B02DPiPiPiD2KKPiNCFromBLine", + prescale=self.config['controlPrescaleViaD2KKpi'], + charmed_meson=D2KKPiNC, + is_NC=True + )) + + ''' NC Stripping D+ -> pi+ pi+ pi-''' + D2PiPiPiNC = self.createCombinationSel(OutputList = "D2PiPiPiNC" + self.name, + DecayDescriptor = "[D+ -> pi+ pi+ pi-]cc", + DaughterLists = [self.selPion, self.selPion,self.selPion], + PreVertexCuts = _strCutComb_Dp, + PostVertexCuts = _strCutMoth_Dp ) + + self.registerLine(self.makeB0Line( + line_name=self.name + "B02DPiPiPiD2PiPiPiNCFromBLine", + prescale=self.config['controlPrescaleViaD2pipipi'], + charmed_meson=D2PiPiPiNC, + is_NC=True + )) + + ''' NC Stripping D0 -> pi+ pi+ pi- pi-''' + D2PiPiPiPiNC = self.createCombinationSel(OutputList = "D02PiPiPiPiNC" + self.name, + DecayDescriptor = "[D0 -> pi+ pi+ pi- pi-]cc", + DaughterLists = [self.selPion, self.selPion,self.selPion, self.selPion], + PreVertexCuts = _strCutComb_D0, + PostVertexCuts = _strCutMoth_D0 ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02PiPiPiPiNCFromBLine", + prescale=self.config['controlPrescaleViaD02pipipipi'], + charmed_meson=D2PiPiPiPiNC, + is_NC=True + )) + + + ''' NC Stripping D0 -> K+ K- pi+ pi-''' + D2KKPiPiNC = self.createCombinationSel(OutputList = "D02KKPiPiNC" + self.name, + DecayDescriptor = "[D0 -> K+ K- pi+ pi-]cc", + DaughterLists = [self.selKaon, self.selKaon,self.selPion, self.selPion], + PreVertexCuts = _strCutComb_D0, + PostVertexCuts = _strCutMoth_D0 ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02PiPiKKNCFromBLine", + prescale=self.config['controlPrescaleViaD02KKpipi'], + charmed_meson=D2KKPiPiNC, + is_NC=True + )) + + '''NC Stripping D0 -> eta pi+ pi-, eta -> pi+ pi- pi0 ''' + EtaPiPiEta2PiPiPi0NC = self.createCombinationSel(OutputList = "D02EtaPiPi_Eta2PiPiPi0NC" + self.name, + DecayDescriptor = "[D0 -> eta pi+ pi-]cc", + DaughterLists = [self.Eta2PiPiPi0, self.selPion, self.selPion], + PreVertexCuts = _strCutComb_D0_with_neutral, + PostVertexCuts = _strCutMoth_D0_with_neutral ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02EtaPiPiEta2PiPiPi0NCFromBLine", + prescale=self.config['controlPrescaleViaD02etapipi'], + charmed_meson=EtaPiPiEta2PiPiPi0NC, + is_NC=True + )) + + '''NC Stripping D0 -> eta pi+ pi-, eta -> pi+ pi- gamma ''' + EtaPiPiEta2PiPiGammaNC = self.createCombinationSel(OutputList = "D02EtaPiPi_Eta2PiPiGammaNC" + self.name, + DecayDescriptor = "[D0 -> eta pi+ pi-]cc", + DaughterLists = [self.Eta2PiPiGamma, self.selPion, self.selPion], + PreVertexCuts = _strCutComb_D0_with_neutral, + PostVertexCuts = _strCutMoth_D0_with_neutral ) + + self.registerLine(self.makeBpLine( + line_name=self.name + "B2D0PiPiPiD02EtaPiPiEta2PiPiGammaNCFromBLine", + prescale=self.config['controlPrescaleViaD02etapipi'], + charmed_meson=EtaPiPiEta2PiPiGammaNC, + is_NC=True + )) + + ## -------------------- End of DpSL ------------ + ##------------------------------------------------------------------------------------------ + def makeEta(self): + #get standard containers + self.Pi0List = DataOnDemand(Location = "Phys/StdLoosePi02gg/Particles") + self.GammaList = DataOnDemand(Location = "Phys/StdLooseAllPhotons/Particles") + self.LoosePionList = DataOnDemand(Location = "Phys/StdLoosePions/Particles") + + #clean neutrals + _tightpi0_cut = "(CHILD(CL,1)>0.05) & (CHILD(CL,2)>0.05) & (PT>1*GeV)" + _tightgamma_cut = "(CL>0.05) & (PT>500*MeV)" + + #pipi vertex cuts + _pipix_cut = "(BPVVDZ>0) & (VFASPF(VCHI2)<9) & (BPVDIRA>0.95) & (BPVVDCHI2>25)" + + #pipix0 cuts + _eta_cut = "(ADAMASS('eta')<100*MeV) & (APT>1500*MeV)" + + #filter standard containers + self.TightPi0List = self.createSubSel( OutputList = self.name + '_TightPi0', InputList = self.Pi0List, Cuts = _tightpi0_cut) + self.TightGammaList = self.createSubSel( OutputList = self.name + '_TightGamma', InputList = self.GammaList, Cuts = _tightgamma_cut) + + #------------- + + self.Eta2PiPiPi0 = self.createCombinationSel( OutputList = self.name + "_Eta2PiPiPi0", + DecayDescriptor = "eta -> pi+ pi- pi0", + DaughterLists = [ self.LoosePionList, self.TightPi0List], + PreVertexCuts = _eta_cut, + PostVertexCuts = _pipix_cut) + #------------- + + self.Eta2PiPiGamma = self.createCombinationSel( OutputList = self.name + "_Eta2PiPiGamma", + DecayDescriptor = "eta -> pi+ pi- gamma", + DaughterLists = [ self.LoosePionList, self.TightGammaList], + PreVertexCuts = _eta_cut, + PostVertexCuts = _pipix_cut ) + + ########################################################################## + ## Basic Function + ########################################################################## + def createSubSel( self, OutputList, InputList, Cuts ) : + '''create a selection using a FilterDesktop''' + filter = FilterDesktop(Code = Cuts) + return Selection( OutputList, + Algorithm = filter, + RequiredSelections = [ InputList ] ) + + def createCombinationSel( self, OutputList, + DecayDescriptor, + DaughterLists, + DaughterCuts = {} , + PreVertexCuts = "ALL", + PostVertexCuts = "ALL") : + '''create a selection using a ParticleCombiner with a single decay descriptor''' + if type(DecayDescriptor) is list: + combiner = CombineParticles( DecayDescriptors = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + else: + combiner = CombineParticles( DecayDescriptor = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + #print "DEBUG here is :",__file__,sys._getframe().f_lineno diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingLambdac2LambdaEtaPi.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingLambdac2LambdaEtaPi.py new file mode 100644 index 000000000..691059c8e --- /dev/null +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingLambdac2LambdaEtaPi.py @@ -0,0 +1,362 @@ +############################################################################### +# (c) Copyright 2000-2019 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. # +############################################################################### +''' +The code is for analysis of the decay + Lambda_c+ -> Lambda0 eta pi+ +where the daughter baryon is reconstructed via: + Lambda0 -> p pi- (from StdLooseLambdaLL/DD) + +A bachelor pi from Lambda_b0 is tagged for reducing the backgrond rate i.e. + Lambda_b0 -> Lambda_c+ pi- +''' + + +__author__ = ['Xiao-Rui Lyu', 'Yangjie Su'] +__date__ = '2023/06/30' +__version__ = '$Revision: 0.1 $' +__all__ = ('StrippingLambdac2LambdaEtaPi' + ,'default_config') + + +from Gaudi.Configuration import * +from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles +from StandardParticles import StdLoosePions, StdNoPIDsDownPions, StdLooseKaons, StdLooseDownKaons +from StandardParticles import StdAllLoosePions, StdAllLooseKaons, StdLooseMuons, StdAllLooseProtons, StdAllLooseMuons, StdAllVeryLooseMuons +from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection +from PhysSelPython.Wrappers import MultiSelectionSequence +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder +from GaudiKernel.SystemOfUnits import MeV, GeV, mm, picosecond +import sys + + +default_name='Lambdac2LambdaEtaPi' + #### This is the dictionary of all tunable cuts ######## +default_config={ + 'NAME' : 'Lambdac2LambdaEtaPi', + 'WGs' : ['Charm'], + 'BUILDERTYPE' : 'StrippingLambdac2LambdaEtaPi', + 'STREAMS' : ['Charm'], + 'CONFIG' : { + 'GEC_nLongTrk' : 160 # adimensional + , 'signalPrescale' : 1.0 + , 'TRCHI2DOFMax' : 3.0 + , 'GhostProb' : 0.3 + , 'TrGhostProbMax' : 0.25 # same for all particles + , 'MINIPCHI2' : 3.0 # adimensiional + , 'MuonP' : 3*GeV + , 'MuonPT' : 250*MeV + , 'MuonIPCHI2' : 4.0 + , 'MuonPIDmu' : 0.0 + , 'PionP' : 3*GeV + , 'PionPT' : 250*MeV + , 'PionPIDK' : 5.0 + , 'Pion_PIDpiPIDK_Min' : 0.0 + , 'KaonP' : 3*GeV + , 'KaonPT' : 250*MeV + , 'KaonPIDK' : 10.0 + , 'Kaon_PIDKPIDpi_Min' : 5.0 + , 'ProbNNpMin' : 0.2 #ProbNNp cut for proton in L0, to suppress the bkg of L0 + , 'ProbNNp' : 0.4 + , 'ProbNNk' : 0.4 + , 'ProbNNpi' : 0.4 + , 'ProbNNpiMax' : 0.9 + , 'LambdaLLPMin' :2000.0*MeV + , 'LambdaLLPTMin' : 500.0*MeV + , 'LambdaLLCutMass' : 50.0*MeV + , 'LambdaLLCutFDChi2' : 100.0 ## unitless + , 'LambdaDDPMin' :2000.0*MeV + , 'LambdaDDPTMin' : 500.0*MeV + , 'LambdaDDCutMass' : 50.0*MeV + , 'LambdaDDCutFDChi2' : 100.0## unitless + , 'LambdaVertexChi2' : 10.0## max chi2/ndf for Lambda0 vertex + + , 'Lc_M_HalfWin' : 200.0*MeV + , 'Lb_M_HalfWin' : 200.0*MeV + , 'Lc_Daug_1of3_MIPCHI2DV_Min': 3.0 + , 'Lc_ADOCAMAX_Max' : 0.15*mm + , 'Lc_APT_Min' : 1.2*GeV + , 'Lc_AP_Min' : 15*GeV + , 'Lc_VCHI2_Max' : 30.0 + , 'Lc_BPVVDCHI2_Min' : 16.0 + , 'Lc_BPVVDZ_Min' : 0.5*mm + , 'Lc_BPVDIRA_Min' : 0.95 + + #For Lb + , 'Lb_AP_Min': 20*GeV + , 'Lb_APT_Min': 1.5*GeV + , 'Lb_VCHI2_Max': 30 + , 'Lb_BPVVDCHI2_Min': 16 + , 'Lb_BPVDIRA_Min': 0.95 + } ## end of 'CONFIG' +} ## end of default_config + +#------------------------------------------------------------------------------------------------------------- +class StrippingLambdac2LambdaEtaPi(LineBuilder) : + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__(self, name, config) : + LineBuilder.__init__(self, name, config) + self.name = name + self.config = config + + GECs = { "Code":"( recSummaryTrack(LHCb.RecSummary.nLongTracks, TrLONG) < %(GEC_nLongTrk)s )" % config, + "Preambulo": ["from LoKiTracks.decorators import *"]} + + ########################################################################## + ## Basic particles: mu, K, pi, eta + ########################################################################## + self.selMuon = Selection( "SelMufor" + name, + Algorithm = self._muonFilter("Mufor"+name), + RequiredSelections = [StdLooseMuons]) + + self.selKaon = Selection( "SelKfor" + name, + Algorithm = self._kaonFilter("Kfor"+name), + RequiredSelections = [StdAllLooseKaons]) + + self.selPion = Selection( "SelPifor" + name, + Algorithm = self._pionFilter("Pifor"+name), + RequiredSelections = [StdAllLoosePions]) + + self.makeEta() + # then use self.Eta2PiPiPi0 and self.Eta2PiPiGamma + + ########################################################################## + ## Lambda0 -> p+ pi- + ########################################################################## + _stdLooseLambdaLL = DataOnDemand("Phys/StdVeryLooseLambdaLL/Particles") + _stdLooseLambdaDD = DataOnDemand("Phys/StdLooseLambdaDD/Particles") + + self.selLambdaLL = Selection("SelLambdaLLfor"+name, + Algorithm = self._LambdaLLFilter("LambdaLLfor"+name), + RequiredSelections = [_stdLooseLambdaLL]) + + self.selLambdaDD = Selection("SelLambdaDDfor"+name, + Algorithm = self._LambdaDDFilter("LambdaDDfor"+name), + RequiredSelections = [_stdLooseLambdaDD]) + + ########################################################################## + ## Charmed Meson SL lines + ########################################################################## + self.DmesonSLList = self.makeLine() + + + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + # Sub Function + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + def _muonFilter( self , _name): + _code = " (TRCHI2DOF< %(TRCHI2DOFMax)s)"\ + "& (PT>%(MuonPT)s) & (P>%(MuonP)s)"\ + "& (TRGHOSTPROB< %(GhostProb)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MuonIPCHI2)s)"\ + "& (PIDmu > %(MuonPIDmu)s) & ISMUON" % self.config + _mu = FilterDesktop(Code = _code ) + return _mu + + def _pionFilter( self , _name): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(PionP)s) & (PT > %(PionPT)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK< %(PionPIDK)s) "\ + "& (HASRICH)&(PROBNNpi > %(ProbNNpi)s) " % self.config + _pi = FilterDesktop(Code = _code ) + return _pi + + def _kaonFilter( self , _name ): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(KaonP)s) & (PT > %(KaonPT)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK> %(KaonPIDK)s) & (PROBNNpi < %(ProbNNpiMax)s)"\ + "& (PROBNNk > %(ProbNNk)s) "\ + "& (HASRICH)&(PIDK-PIDpi>%(Kaon_PIDKPIDpi_Min)s) "% self.config + _ka = FilterDesktop(Code = _code ) + return _ka + + def _LambdaLLFilter( self, _name): + _code = " (P > %(LambdaLLPMin)s) & (PT > %(LambdaLLPTMin)s)" \ + " &(ADMASS('Lambda0')<%(LambdaLLCutMass)s)"\ + " & (BPVVDCHI2> %(LambdaLLCutFDChi2)s)" \ + " & (VFASPF(VCHI2PDOF) < %(LambdaVertexChi2)s)" % self.config + _l0LL = FilterDesktop(Code = _code) + return _l0LL + + def _LambdaDDFilter( self , _name): + _code = " (P> %(LambdaDDPMin)s) & (PT> %(LambdaDDPTMin)s)" \ + " & (ADMASS('Lambda0') < %(LambdaDDCutMass)s) "\ + " & (BPVVDCHI2> %(LambdaDDCutFDChi2)s)" \ + " & (VFASPF(VCHI2PDOF) < %(LambdaVertexChi2)s)" % self.config + _l0DD = FilterDesktop(Code = _code) + return _l0DD + + def makeLb0Line(self, line_name, prescale, Lc): + comb_cut = "(ADAMASS('Lambda_b0') < 1.1*%(Lb_M_HalfWin)s)"\ + "& (AP > %(Lb_AP_Min)s)"\ + "& (APT > %(Lb_APT_Min)s)" % self.config + vertex_cut = " (ADMASS('Lambda_b0') < %(Lb_M_HalfWin)s)"\ + "& (BPVVDCHI2>%(Lb_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(Lb_BPVDIRA_Min)s)" % self.config + + Lb0 = self.createCombinationSel(OutputList = "Lb02LcPi_" + line_name, + DecayDescriptor = "[Lambda_b0 -> Lambda_c+ pi-]cc", + DaughterLists = [Lc, self.selPion], + PreVertexCuts = comb_cut, + PostVertexCuts = vertex_cut ) + Lb0Line = StrippingLine( line_name, + prescale = prescale, + selection = Lb0, + EnableFlavourTagging = False ) + return Lb0Line + + + ##------------------------------------------------------------------------------------------ + ## -------------------- Begin to DpSL ------------ + def makeLine( self ): + + _strCutCombfor = "(AMINCHILD(MIPCHI2DV(PRIMARY))>%(Lc_Daug_1of3_MIPCHI2DV_Min)s)" \ + "& (AP>%(Lc_AP_Min)s)" \ + "& (ADAMASS('Lambda_c+') < %(Lc_M_HalfWin)s)" \ + "& (APT>%(Lc_APT_Min)s)" % self.config + + _strCutMothfor = "(VFASPF(VCHI2) < %(Lc_VCHI2_Max)s)" \ + "& (ADMASS('Lambda_c+') < %(Lc_M_HalfWin)s)" \ + "& (BPVVDCHI2>%(Lc_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(Lc_BPVDIRA_Min)s)" % self.config + + _strCutComb_Mass = "(ADAMASS('Lambda_c+') < 1.1*%(Lc_M_HalfWin)s)" % self.config + _strCutMoth_Mass = "(ADMASS('Lambda_c+') < %(Lc_M_HalfWin)s)" % self.config + + _strCutComb = _strCutCombfor + '&' + _strCutComb_Mass + _strCutMoth = _strCutMothfor + '&' + _strCutMoth_Mass + + ''' Stripping Lambda_c+ -> Lambda eta pi+ ''' + LmdEtaPiLLEta2PiPiPi0 = self.createCombinationSel(OutputList = "Lc2LambdaEtaPiLLEta2PiPiPi0" + self.name, + DecayDescriptor = "[Lambda_c+ -> Lambda0 eta pi+]cc", + DaughterLists = [self.selLambdaLL, self.Eta2PiPiPi0,self.selPion], + PreVertexCuts = _strCutComb, + PostVertexCuts = _strCutMoth ) + self.registerLine(self.makeLb0Line( + line_name=self.name + "Lb2LcPiLc2LambdaEtaPiLLEta2PiPiPi0", + prescale=self.config['signalPrescale'], + Lc=LmdEtaPiLLEta2PiPiPi0 + )) + + ''' Stripping Lambda_c+ -> Lambda eta pi+ ''' + LmdEtaPiLLEta2PiPiGamma = self.createCombinationSel(OutputList = "Lc2LambdaEtaPiLLEta2PiPiGamma" + self.name, + DecayDescriptor = "[Lambda_c+ -> Lambda0 eta pi+]cc", + DaughterLists = [self.selLambdaLL, self.Eta2PiPiGamma,self.selPion], + PreVertexCuts = _strCutComb, + PostVertexCuts = _strCutMoth ) + self.registerLine(self.makeLb0Line( + line_name=self.name + "Lb2LcPiLc2LambdaEtaPiLLEta2PiPiGamma", + prescale=self.config['signalPrescale'], + Lc=LmdEtaPiLLEta2PiPiGamma + )) + + ''' Stripping Lambda_c+ -> Lambda eta pi+ ''' + LmdEtaPiDDEta2PiPiPi0 = self.createCombinationSel(OutputList = "Lc2LambdaEtaPiDDEta2PiPiPi0" + self.name, + DecayDescriptor = "[Lambda_c+ -> Lambda0 eta pi+]cc", + DaughterLists = [self.selLambdaDD, self.Eta2PiPiPi0,self.selPion], + PreVertexCuts = _strCutComb, + PostVertexCuts = _strCutMoth ) + self.registerLine(self.makeLb0Line( + line_name=self.name + "Lb2LcPiLc2LambdaEtaPiDDEta2PiPiPi0", + prescale=self.config['signalPrescale'], + Lc=LmdEtaPiDDEta2PiPiPi0 + )) + + ''' Stripping Lambda_c+ -> Lambda eta pi+ ''' + LmdEtaPiDDEta2PiPiGamma = self.createCombinationSel(OutputList = "Lc2LambdaEtaPiDDEta2PiPiGamma" + self.name, + DecayDescriptor = "[Lambda_c+ -> Lambda0 eta pi+]cc", + DaughterLists = [self.selLambdaDD, self.Eta2PiPiGamma,self.selPion], + PreVertexCuts = _strCutComb, + PostVertexCuts = _strCutMoth ) + self.registerLine(self.makeLb0Line( + line_name=self.name + "Lb2LcPiLc2LambdaEtaPiDDEta2PiPiGamma", + prescale=self.config['signalPrescale'], + Lc=LmdEtaPiDDEta2PiPiGamma + )) + ## -------------------- End of DpSL ------------ + ##------------------------------------------------------------------------------------------ + def makeEta(self): + #get standard containers + self.Pi0List = DataOnDemand(Location = "Phys/StdLoosePi02gg/Particles") + self.GammaList = DataOnDemand(Location = "Phys/StdLooseAllPhotons/Particles") + self.LoosePionList = DataOnDemand(Location = "Phys/StdLoosePions/Particles") + + #clean neutrals + _tightpi0_cut = "(CHILD(CL,1)>0.05) & (CHILD(CL,2)>0.05) & (PT>1*GeV)" + _tightgamma_cut = "(CL>0.05) & (PT>500*MeV)" + + #pipi vertex cuts + _pipix_cut = "(BPVVDZ>0) & (VFASPF(VCHI2)<9) & (BPVDIRA>0.95) & (BPVVDCHI2>25)" + + #pipix0 cuts + _eta_cut = "(ADAMASS('eta')<100*MeV) & (APT>1500*MeV)" + + #filter standard containers + self.TightPi0List = self.createSubSel( OutputList = self.name + '_TightPi0', InputList = self.Pi0List, Cuts = _tightpi0_cut) + self.TightGammaList = self.createSubSel( OutputList = self.name + '_TightGamma', InputList = self.GammaList, Cuts = _tightgamma_cut) + + #------------- + + self.Eta2PiPiPi0 = self.createCombinationSel( OutputList = self.name + "_Eta2PiPiPi0", + DecayDescriptor = "eta -> pi+ pi- pi0", + DaughterLists = [ self.LoosePionList, self.TightPi0List], + PreVertexCuts = _eta_cut, + PostVertexCuts = _pipix_cut) + #------------- + + self.Eta2PiPiGamma = self.createCombinationSel( OutputList = self.name + "_Eta2PiPiGamma", + DecayDescriptor = "eta -> pi+ pi- gamma", + DaughterLists = [ self.LoosePionList, self.TightGammaList], + PreVertexCuts = _eta_cut, + PostVertexCuts = _pipix_cut ) + + ########################################################################## + ## Basic Function + ########################################################################## + def createSubSel( self, OutputList, InputList, Cuts ) : + '''create a selection using a FilterDesktop''' + filter = FilterDesktop(Code = Cuts) + return Selection( OutputList, + Algorithm = filter, + RequiredSelections = [ InputList ] ) + + def createCombinationSel( self, OutputList, + DecayDescriptor, + DaughterLists, + DaughterCuts = {} , + PreVertexCuts = "ALL", + PostVertexCuts = "ALL") : + '''create a selection using a ParticleCombiner with a single decay descriptor''' + if type(DecayDescriptor) is list: + combiner = CombineParticles( DecayDescriptors = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + else: + combiner = CombineParticles( DecayDescriptor = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + #print "DEBUG here is :",__file__,sys._getframe().f_lineno -- GitLab From 078e6b78868118207b051467c7aaba1302266002 Mon Sep 17 00:00:00 2001 From: Yinghao Wang <yinghao.wang@cern.ch> Date: Mon, 17 Jul 2023 11:01:58 +0200 Subject: [PATCH 05/11] Stripping NeutralCBaryons Xib2Xic0PiXic02pK --- StrippingNeutralCBaryons.py | 500 ++++++++++++++++++++++++++++++++++ StrippingXib2Xic0PiXic02pK.py | 150 ++++++++++ 2 files changed, 650 insertions(+) create mode 100644 StrippingNeutralCBaryons.py create mode 100644 StrippingXib2Xic0PiXic02pK.py diff --git a/StrippingNeutralCBaryons.py b/StrippingNeutralCBaryons.py new file mode 100644 index 000000000..4424f47d8 --- /dev/null +++ b/StrippingNeutralCBaryons.py @@ -0,0 +1,500 @@ +############################################################################### +# (c) Copyright 2000-2023 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. # +############################################################################### +''' +1)Xi_c0->Lz Ks +2)Xi_c0->Lz K- pi+ +3)Xi_c0->Xi- pi+, Xi->Lz pi-, Lz->p pi +4)Xi_c0->Xi- K+, Xi->Lz pi-, Lz->p pi +5)Omega_c0 ->Omega- pi+, Omega-> Lz K- + +Update on 2021/02/08 +Added following decays: +Xi_c0 -> p+ K- +Omega+c0 -> Lambda KS0 +Omega_c0 -> p+ K- +Omega_c0 -> Labda K- pi+ + +Update on 2023/07/06 +Added following decays: +Xi_c0 -> p+ K+ K- pi- +Xi_c0 -> Lz pi+ pi- +Optimized following decays: +Xi_c0 -> p+ K- +Omega+c0 -> Lambda KS0 +Xi_c0 -> Lambda KS0 +''' + + +__author__ = ['Xuesong Liu, Xiao-Rui Lyu, Zhenwei Yang', 'Miroslav Saur', 'Ziyi Wang', 'Pei-Rong Li', 'Ying-Hao Wang'] +__date__ = '2023/07/06' +__version__ = '$Revision: 1.1 $' +__all__ = ('StrippingNeutralCBaryonsConf' + ,'default_config') + + +from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles +from StandardParticles import StdAllLoosePions, StdAllLooseKaons, StdAllLooseProtons, StdNoPIDsDownPions, StdLooseDownKaons + +from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection +from PhysSelPython.Wrappers import MultiSelectionSequence +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder +from GaudiKernel.SystemOfUnits import MeV, mm, picosecond + + +default_name='NeutralCBaryons' + #### This is the dictionary of all tunable cuts ######## +default_config={ + 'NAME' : 'NeutralCBaryons', + 'WGs' : ['Charm'], + 'BUILDERTYPE' : 'StrippingNeutralCBaryonsConf', + 'STREAMS' : ['Charm'], + 'CONFIG' : { + 'TRCHI2DOFMax' : 3.0 + , 'PionPIDK' : 10.0 + , 'KaonPIDK' : -5.0 + , 'ProtonPIDp' : 5 #to be studied + , 'ProtonPIDpK' : -3 + , 'tight_ProtonPIDp' : 7 #to be studied + , 'tight_ProtonPIDppi' : 5.0 + , 'tight_ProtonPIDpK' : 0.0 + , 'tight_KaonPIDpi' : 5.0 + , 'tight_KaonPIDK' : 0.0 + , 'LambdaLLMinDecayTime' : 5.0 * picosecond + , 'LambdaLLVtxChi2Max' : 5.0 + , 'LambdaDDVtxChi2Max' : 5.0 + , 'LambdaLLMassWin' : 5.7 * MeV + , 'LambdaDDMassWin' : 5.7 * MeV + , 'LambdaLLMinVZ' : -100. * mm + , 'LambdaLLMaxVZ' : 400. * mm + , 'LambdaDDMinVZ' : 400. * mm + , 'LambdaDDMaxVZ' : 2275. * mm + , 'TrGhostProbMax' : 0.25 + , 'ProbNNkMin' : 0.10 + , 'ProbNNpMinLL' : 0.10 + , 'ProbNNpMinDD' : 0.05 + , 'Bachelor_PT_MIN' : 50 * MeV + , 'LambdaDeltaZ_MIN' : 5.0 * mm + , 'LambdaPr_PT_MIN' : 500. * MeV + , 'LambdaPi_PT_MIN' : 100. * MeV + }## end of 'CONFIG' +}## end of default_config + +#------------------------------------------------------------------------------------------------------------- +class StrippingNeutralCBaryonsConf(LineBuilder) : + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__(self, name, config) : + LineBuilder.__init__(self, name, config) + self.name = name + self.config = config + + # take all long tracks - Long Protons + self.LongProtonsList = MergedSelection("LongProtonsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLooseProtons/Particles")]) + + # take all long tracks - Long Pions + self.LongPionsList = MergedSelection("LongPionsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLoosePions/Particles")]) + + # take all long tracks - Long Kaons + self.LongKaonsList = MergedSelection("LongKaonsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLooseKaons/Particles")]) + + # take all long tracks - Down Pions + self.DownstreamPionsList = MergedSelection("DownstreamPionsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdNoPIDsDownPions/Particles")]) + + # take all long tracks = Down Kaons + self.DownstreamKaonsList = MergedSelection("DownstreamKaonsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseDownKaons/Particles")]) + + # Good tracks - Long Protons + self.GoodLongProtonsList = self.createSubSel( OutputList = "GoodLongProtonsFor" + self.name, + InputList = self.LongProtonsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ + " & (PIDp > %(ProtonPIDp)s) "\ + " & ((PIDp-PIDK)> %(ProtonPIDpK)s) " % self.config ) + + # Good tracks - Tight Protons + self.GoodTightProtonsList = self.createSubSel( OutputList = "GoodTightProtonsFor" + self.name, + InputList = self.LongProtonsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ + " & (PIDp > %(tight_ProtonPIDp)s) "\ + " & ((PIDp-PIDpi) > %(tight_ProtonPIDppi)s) "\ + " & ((PIDp-PIDK) > %(tight_ProtonPIDpK)s) " % self.config ) + # Good tracks - Long Pions + self.GoodLongPionsList = self.createSubSel( OutputList = "GoodLongPionsFor" + self.name, + InputList = self.LongPionsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ + " & (PIDK < %(PionPIDK)s )" % self.config ) + + # Good tracks - Long Kaons + self.GoodLongKaonsList = self.createSubSel( OutputList = "GoodLongKaonsFor" + self.name, + InputList = self.LongKaonsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB < %(TrGhostProbMax)s )" \ + " & (PROBNNk > %(ProbNNkMin)s )" \ + " & (PIDK > %(KaonPIDK)s )" % self.config ) + + # Good tracks - Tight Kaons + self.GoodTightKaonsList = self.createSubSel( OutputList = "GoodTightKaonsFor" + self.name, + InputList = self.LongKaonsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB < %(TrGhostProbMax)s )" \ + " & (PROBNNk > %(ProbNNkMin)s )" \ + " & ((PIDK-PIDpi)>%(tight_KaonPIDpi)s)"\ + " & (PIDK > %(tight_KaonPIDK)s )" % self.config ) + + # Good tracks - Down Pions + self.GoodDownstreamPionsList = self.createSubSel( OutputList = "GoodDownstreamPionsFor" + self.name, + InputList = self.DownstreamPionsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (PIDK < %(PionPIDK)s )" % self.config ) + + # Good tracks - Down Kaons + self.GoodDownstreamKaonsList = self.createSubSel( OutputList = "GoodDownstreamKaonsFor" + self.name, + InputList = self.DownstreamKaonsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (PROBNNk > %(ProbNNkMin)s )" \ + " & (PIDK > %(KaonPIDK)s )" % self.config ) + + self.LambdaListLooseDD = MergedSelection("StdLooseDDLambdaFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaDD/Particles")]) + + self.LambdaListLooseLL = MergedSelection("StdLooseLLLambdaFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaLL/Particles")]) + + self.LambdaListLL = self.createSubSel(OutputList = "LambdaLLFor" + self.name, + InputList = self.LambdaListLooseLL , + Cuts = "(MAXTREE('p+'==ABSID, PT) > %(LambdaPr_PT_MIN)s ) "\ + "& (MAXTREE('pi-'==ABSID, PT) > %(LambdaPi_PT_MIN)s ) " \ + "& (MAXTREE('p+'==ABSID,PROBNNp) > %(ProbNNpMinLL)s ) "\ + "& (MINTREE('pi-'==ABSID, TRGHOSTPROB) < %(TrGhostProbMax)s )"\ + "& (MINTREE('p+'==ABSID, TRGHOSTPROB) < %(TrGhostProbMax)s )"\ + "& (ADMASS('Lambda0') < %(LambdaLLMassWin)s ) " + "& (VFASPF(VCHI2/VDOF) < %(LambdaLLVtxChi2Max)s ) "\ + "& (VFASPF(VZ) > %(LambdaLLMinVZ)s ) " \ + "& (VFASPF(VZ) < %(LambdaLLMaxVZ)s ) " \ + "& (BPVLTIME() > %(LambdaLLMinDecayTime)s )" % self.config \ + ) + + self.LambdaListDD = self.createSubSel(OutputList = "LambdaDDFor" + self.name, + InputList = self.LambdaListLooseDD , + Cuts = "(MAXTREE('p+'==ABSID, PT) > %(LambdaPr_PT_MIN)s ) "\ + "& (MAXTREE('pi-'==ABSID, PT) > %(LambdaPi_PT_MIN)s ) " \ + "& (MAXTREE('p+'==ABSID, PROBNNp) > %(ProbNNpMinDD)s ) "\ + "& (ADMASS('Lambda0') < %(LambdaDDMassWin)s ) " \ + "& (VFASPF(VCHI2/VDOF) < %(LambdaDDVtxChi2Max)s ) "\ + "& (VFASPF(VZ) < %(LambdaDDMaxVZ)s ) " \ + "& (VFASPF(VZ) > %(LambdaDDMinVZ)s )" % self.config \ + ) + + self.LambdaList = MergedSelection("LambdaFor" + self.name, + RequiredSelections = [self.LambdaListLL, self.LambdaListDD] + ) + + self.KS0ListLooseDD = MergedSelection("StdLooseDDKS0For" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseKsDD/Particles")]) + + self.KS0ListLooseLL = MergedSelection("StdLooseLLKS0For" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseKsLL/Particles")]) + + self.KS0ListLL = self.createSubSel(OutputList = "KS0LLFor" + self.name, + InputList = self.KS0ListLooseLL , + Cuts = "(BPVVDZ > 0.0 * mm) " \ + "& (BPVVDZ < 2300.0 * mm) " \ + "& (BPVDIRA > 0.99995 ) " \ + "& (ADMASS('KS0') < 60.0 *MeV) " \ + "& (BPVVDCHI2> 100)" % self.config \ + ) + + self.KS0ListDD = self.createSubSel(OutputList = "KS0DDFor" + self.name, + InputList = self.KS0ListLooseDD , + Cuts = "(BPVVDZ > -1000.0 * mm) " \ + "& (BPVVDZ < 650.0 * mm) " \ + "& (BPVDIRA > 0.99 ) " \ + "& (ADMASS('KS0') < 60.0 *MeV) " \ + "& (BPVVDCHI2> 100)" % self.config \ + ) + + self.KS0List = MergedSelection("KS0For" + self.name, + RequiredSelections = [self.KS0ListLL, self.KS0ListDD]) + + self.Xic0List = self.makeXic0() + self.Omegac0List = self.makeOmegac0() + + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + + def createSubSel( self, OutputList, InputList, Cuts ) : + '''create a selection using a FilterDesktop''' + filter = FilterDesktop(Code = Cuts) + return Selection( OutputList, + Algorithm = filter, + RequiredSelections = [ InputList ] ) + + def createCombinationSel( self, OutputList, + DecayDescriptor, + DaughterLists, + DaughterCuts = {} , + PreVertexCuts = "ALL", + PostVertexCuts = "ALL" ) : + '''create a selection using a ParticleCombiner with a single decay descriptor''' + combiner = CombineParticles( DecayDescriptor = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + + def makeXic0( self ): + ''' Stripping Xi_c0->Lambda0 KS0''' + Xic02LambdaKS0 = self.createCombinationSel(OutputList = "Xic02LambdaKS0"+ self.name, + DecayDescriptor = "[Xi_c0 -> Lambda0 KS0 ]cc", + DaughterLists = [self.LambdaList, self.KS0List], + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02LambdaKS0Line = StrippingLine( self.name + "Xic02LambdaKS0Line", algos = [ Xic02LambdaKS0 ], EnableFlavourTagging = True ) + self.registerLine (Xic02LambdaKS0Line) + + ''' Stripping Xi_c0->Lambda0 K- pi+''' + Xic02LambdaKpi = self.createCombinationSel(OutputList = "Xic02LambdaKpi"+ self.name, + DecayDescriptor = "[Xi_c0 -> Lambda0 K- pi+ ]cc", + DaughterLists = [self.LambdaList, self.GoodLongKaonsList, self.GoodLongPionsList], + DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", + "pi+" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02LambdaKpiLine = StrippingLine( self.name + "Xic02LambdaKpiLine", algos = [ Xic02LambdaKpi ], EnableFlavourTagging = True ) + self.registerLine (Xic02LambdaKpiLine) + + ''' Stripping Xi_c0->Lambda0(LL) pi+ pi-''' + Xic02LambdaLLpipi = self.createCombinationSel(OutputList = "Xic02LambdaLLpipi"+ self.name, + DecayDescriptor = "[Xi_c0 -> Lambda0 pi+ pi- ]cc", + DaughterLists = [self.LambdaListLL, self.GoodLongPionsList, self.GoodLongPionsList], + DaughterCuts = {"pi+" : " (MIPCHI2DV(PRIMARY)>4)", + "pi-" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.0*mm)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02LambdaLLpipiLine = StrippingLine( self.name + "Xic02LambdaLLpipiLine", algos = [ Xic02LambdaLLpipi ], EnableFlavourTagging = True ) + self.registerLine (Xic02LambdaLLpipiLine) + + ''' Stripping Xi_c0->Lambda0(DD) pi+ pi-''' + Xic02LambdaDDpipi = self.createCombinationSel(OutputList = "Xic02LambdaDDpipi"+ self.name, + DecayDescriptor = "[Xi_c0 -> Lambda0 pi+ pi- ]cc", + DaughterLists = [self.LambdaListDD, self.GoodLongPionsList, self.GoodLongPionsList], + DaughterCuts = {"pi+" : " (MIPCHI2DV(PRIMARY)>4)", + "pi-" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.0*mm)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02LambdaDDpipiLine = StrippingLine( self.name + "Xic02LambdaDDpipiLine", algos = [ Xic02LambdaDDpipi ], EnableFlavourTagging = True ) + self.registerLine (Xic02LambdaDDpipiLine) + + ''' Stripping Xi_c- -> Lambda0(DD) pi-(Long)''' + Ximinus2LambdaPiDDL = self.createCombinationSel(OutputList = "Ximinus2LambdaPiDDL"+ self.name, + DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", + DaughterLists = [self.GoodLongPionsList, self.LambdaListDD], + DaughterCuts = {"pi-" : "(MIPCHI2DV(PRIMARY)>4) "}, + PreVertexCuts = "(ADAMASS('Xi-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", + PostVertexCuts = "(ADMASS('Xi-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" + ) + + ''' Stripping Xi_c- -> Lambda0(LL) pi-(Long)''' + Ximinus2LambdaPiLLL = self.createCombinationSel(OutputList = "Ximinus2LambdaPiLLL"+ self.name, + DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", + DaughterLists = [self.GoodLongPionsList, self.LambdaListLL], + DaughterCuts = {"pi-" : "(MIPCHI2DV(PRIMARY)>9)"}, + PreVertexCuts = "(ADAMASS('Xi-') < 50*MeV) & (ADOCACHI2CUT(30, ''))", + PostVertexCuts = "(ADMASS('Xi-')<35*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" + ) + + ''' Stripping Xi_c- -> Lambda0(DD) pi-(Down)''' + Ximinus2LambdaPiDDD = self.createCombinationSel(OutputList = "Ximinus2LambdaPiDDD"+ self.name, + DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", + DaughterLists = [self.GoodDownstreamPionsList, self.LambdaListDD], + DaughterCuts = {"pi-" : "(MIPCHI2DV(PRIMARY)>4) "}, + PreVertexCuts = "(ADAMASS('Xi-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", + PostVertexCuts = "(ADMASS('Xi-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" + ) + + ## Ximinus2LambdaPi is a "Selection" object; MergedSelection passes everything which gets to it + ## even when the output list is empty + Ximinus2LambdaPi = MergedSelection("Ximinus2LambdaPi"+self.name, + RequiredSelections = [Ximinus2LambdaPiLLL,Ximinus2LambdaPiDDL,Ximinus2LambdaPiDDD] ) + + ## NullFilter is a "FilterDesktop" object which is a type of "Algorithm" + ## This one will pass all candidates + NullFilter= FilterDesktop(Code = "ALL") + ## Ximinus2Lambda2PiSelection is *also* a Selection, but it is "more selective" + ## than Ximinus2LambdaPi in the sense that it passes only events when something + ## is in the output list + Ximinus2LambdaPiSelection = Selection( "Ximinus2LambdaPiSelection"+self.name, + Algorithm = NullFilter, + RequiredSelections = [Ximinus2LambdaPi]) + + ''' Stripping Xi_c0 -> p+ K-''' + Xic02pK = self.createCombinationSel(OutputList = "Xic02pK"+ self.name, + DecayDescriptor = "[Xi_c0 -> p+ K-]cc", + DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList], + DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", + "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.5*mm)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02pKLine = StrippingLine( self.name + "Xic02pKLine", algos = [ Xic02pK ], EnableFlavourTagging = True ) + self.registerLine (Xic02pKLine) + + ''' Stripping Xi_c0 -> p+ K+ K- pi-''' + Xic02pKKpi = self.createCombinationSel(OutputList = "Xic02pKKpi"+ self.name, + DecayDescriptor = "[Xi_c0 -> p+ K+ K- pi-]cc", + DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList, self.GoodTightKaonsList, self.GoodLongPionsList], + DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", + "K+" : " (MIPCHI2DV(PRIMARY)>4)", + "pi-" : " (MIPCHI2DV(PRIMARY)>4)", + "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02pKKpiLine = StrippingLine( self.name + "Xic02pKKpiLine", algos = [ Xic02pKKpi ], EnableFlavourTagging = True ) + self.registerLine (Xic02pKKpiLine) + + ''' Stripping Xi_c0->Xi- pi+''' + Xic02Xipi = self.createCombinationSel(OutputList = "Xic02Xipi"+ self.name, + DecayDescriptor = "[Xi_c0 -> Xi- pi+]cc", + DaughterLists = [self.GoodLongPionsList, Ximinus2LambdaPiSelection], + DaughterCuts = {"pi+" : "(PT> %(Bachelor_PT_MIN)s ) "% self.config}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + + Xic02XipiLine = StrippingLine( self.name + "Xic02XipiLine", algos = [ Xic02Xipi ], EnableFlavourTagging = True ) + self.registerLine (Xic02XipiLine) + + ''' Stripping Xi_c0->Xi- K+''' + Xic02XiK = self.createCombinationSel(OutputList = "Xic02XiK"+ self.name, + DecayDescriptor = "[Xi_c0 -> Xi- K+]cc", + DaughterLists = [self.GoodLongKaonsList, Ximinus2LambdaPiSelection], + DaughterCuts = {"K+" : "(PT> %(Bachelor_PT_MIN)s ) "% self.config}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + + Xic02XiKLine = StrippingLine( self.name + "Xic02XiKLine", algos = [ Xic02XiK ], EnableFlavourTagging = True ) + self.registerLine (Xic02XiKLine) + + ## -------------------- end of makeXiminus ------------ + #------------------------------------------------------------------------------------------ + + def makeOmegac0( self ): + + ''' Make an Omega minus candidate ''' + Omegaminus2LambdaKLLL = self.createCombinationSel(OutputList = "Omegaminus2LambdaKLLL"+ self.name, + DecayDescriptor = "[Omega- -> Lambda0 K-]cc", + DaughterLists = [self.GoodLongKaonsList, self.LambdaListLL], + DaughterCuts = {"K-" : "(MIPCHI2DV(PRIMARY)>9) "}, + PreVertexCuts = "(ADAMASS('Omega-') < 50*MeV) & (ADOCACHI2CUT(30, ''))", + PostVertexCuts = "(ADMASS('Omega-')<35*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" + ) + + ''' Make an Omega minus candidate ''' + Omegaminus2LambdaKDDL = self.createCombinationSel(OutputList = "Omegaminus2LambdaKDDL"+ self.name, + DecayDescriptor = "[Omega- -> Lambda0 K-]cc", + DaughterLists = [self.GoodLongKaonsList, self.LambdaListDD], + DaughterCuts = {"K-" : "(MIPCHI2DV(PRIMARY)>4) "}, + PreVertexCuts = "(ADAMASS('Omega-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", + PostVertexCuts = "(ADMASS('Omega-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" + ) + + ''' Make an Omega minus candidate ''' + Omegaminus2LambdaKDDD = self.createCombinationSel(OutputList = "Omegaminus2LambdaKDDD"+ self.name, + DecayDescriptor = "[Omega- -> Lambda0 K-]cc", + DaughterLists = [self.GoodDownstreamKaonsList, self.LambdaListDD], + DaughterCuts = {"K-" : "(MIPCHI2DV(PRIMARY)>4) "}, + PreVertexCuts = "(ADAMASS('Omega-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", + PostVertexCuts = "(ADMASS('Omega-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" + ) + + + ## Omegaminus2LambdaK is a "Selection" object; MergedSelection passes everything which gets to it + ## even when the output list is empty + Omegaminus2LambdaK = MergedSelection("Omegaminus2LambdaK"+self.name, + RequiredSelections = [Omegaminus2LambdaKLLL,Omegaminus2LambdaKDDL,Omegaminus2LambdaKDDD] ) + + ## NullFilter is a "FilterDesktop" object which is a type of "Algorithm" + ## This one will pass all candidates + NullFilter= FilterDesktop(Code = "ALL") + ## Omegaminus2Lambda2PiSelection is *also* a Selection, but it is "more selective" + ## than Omegaminus2LambdaK in the sense that it passes only events when something + ## is in the output list + Omegaminus2LambdaKSelection = Selection( "Omegaminus2LambdaKSelection"+self.name, + Algorithm = NullFilter, + RequiredSelections = [Omegaminus2LambdaK]) + + ''' Stripping Omega_c0->Omega- pi+''' + Omegac02Omegapi = self.createCombinationSel(OutputList = "Omegac02Omegapi"+ self.name, + DecayDescriptor = "[Omega_c0 -> Omega- pi+]cc", + DaughterLists = [self.GoodLongPionsList, Omegaminus2LambdaKSelection], + DaughterCuts = {"pi+" : "(PT> %(Bachelor_PT_MIN)s ) "% self.config}, + PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", + PostVertexCuts = "(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) & (ADMASS('Omega_c0') < 90 *MeV)" + ) + + Omegac02OmegapiLine = StrippingLine( self.name + "Omegac02OmegapiLine", algos = [ Omegac02Omegapi ], EnableFlavourTagging = True ) + self.registerLine (Omegac02OmegapiLine) + + ''' Stripping Omega_c0-> p+- K-''' + Omegac02pK = self.createCombinationSel(OutputList = "Omegac02pK"+ self.name, + DecayDescriptor = "[Omega_c0 -> p+ K-]cc", + DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList], + DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", + "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Omega_c0')<35*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" + ) + + Omegac02pKLine = StrippingLine( self.name + "Omegac02pKLine", algos = [ Omegac02pK ], EnableFlavourTagging = True ) + self.registerLine (Omegac02pKLine) + + + ## Code for Omega_c0 -> Lambda0 KS0; four relevant track classes: LL, LD, DL, DD - those are based on LambdaList and KS0List + Omegac02LambdaKS0 = self.createCombinationSel(OutputList = "Omegac02LambdaKS0"+ self.name, + DecayDescriptor = "[Omega_c0 -> Lambda0 KS0 ]cc", + DaughterLists = [self.LambdaList, self.KS0List], + PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Omega_c0') < 90 *MeV) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Omegac02LambdaKS0Line = StrippingLine( self.name + "Omegac02LambdaKS0Line", algos = [ Omegac02LambdaKS0 ], EnableFlavourTagging = True ) + self.registerLine (Omegac02LambdaKS0Line) + + + ## Code for Omega_c0 -> Lambda0 K- pi+, two relevant track classed: LL, DD + Omegac02LambdaKpi = self.createCombinationSel(OutputList = "Omegac02LambdaKpi"+ self.name, + DecayDescriptor = "[Omega_c0 -> Lambda0 K- pi+ ]cc", + DaughterLists = [self.LambdaList, self.GoodLongKaonsList, self.GoodLongPionsList], + DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", + "pi+" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Omega_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Omegac02LambdaKpiLine = StrippingLine( self.name + "Omegac02LambdaKpiLine", algos = [ Omegac02LambdaKpi ], EnableFlavourTagging = True ) + self.registerLine (Omegac02LambdaKpiLine) + ## -------------------- end of makeOmegaminus ------------ + #------------------------------------------------------------------------------------------ diff --git a/StrippingXib2Xic0PiXic02pK.py b/StrippingXib2Xic0PiXic02pK.py new file mode 100644 index 000000000..18f994365 --- /dev/null +++ b/StrippingXib2Xic0PiXic02pK.py @@ -0,0 +1,150 @@ +############################################################################### +# (c) Copyright 2000-2023 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. # +############################################################################### +''' +1)Xi_b- -> Xi_c0 pi-, Xi_c0 -> p+ K- + +''' + +__author__ = ['Xiao-Rui Lyu', 'Miroslav Saur', 'Ziyi Wang', 'Pei-Rong Li', 'Ying-Hao Wang'] +__date__ = '2023/07/06' +__version__ = '$Revision: 0.1 $' +__all__ = ('StrippingXib2Xic0PiXic02pKConf' + ,'default_config') + + +from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles +from StandardParticles import StdAllLoosePions, StdAllLooseKaons, StdAllLooseProtons + +from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection +from PhysSelPython.Wrappers import MultiSelectionSequence +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder +from GaudiKernel.SystemOfUnits import MeV, mm, picosecond + + +default_name='Xib2Xic0PiXic02pK' + #### This is the dictionary of all tunable cuts ######## +default_config={ + 'NAME' : 'Xib2Xic0PiXic02pK', + 'WGs' : ['Charm'], + 'BUILDERTYPE' : 'StrippingXib2Xic0PiXic02pKConf', + 'STREAMS' : ['Charm'], + 'CONFIG' : { + 'TRCHI2DOFMax' : 3.0 + , 'PionPIDK' : 10.0 + , 'tight_ProtonPIDp' : 7 #to be studied + , 'tight_ProtonPIDppi' : 5.0 + , 'tight_ProtonPIDpK' : 0.0 + , 'tight_KaonPIDpi' : 5.0 + , 'tight_KaonPIDK' : 0.0 + , 'TrGhostProbMax' : 0.25 + , 'ProbNNkMin' : 0.10 + }## end of 'CONFIG' +}## end of default_config + +#------------------------------------------------------------------------------------------------------------- +class StrippingXib2Xic0PiXic02pKConf(LineBuilder) : + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__(self, name, config) : + LineBuilder.__init__(self, name, config) + self.name = name + self.config = config + + # take all long tracks - Long Protons + self.LongProtonsList = MergedSelection("LongProtonsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLooseProtons/Particles")]) + + # take all long tracks - Long Pions + self.LongPionsList = MergedSelection("LongPionsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLoosePions/Particles")]) + + # take all long tracks - Long Kaons + self.LongKaonsList = MergedSelection("LongKaonsFor" + self.name, + RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLooseKaons/Particles")]) + + # Good tracks - Tight Protons + self.GoodTightProtonsList = self.createSubSel( OutputList = "GoodTightProtonsFor" + self.name, + InputList = self.LongProtonsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ + " & (PIDp > %(tight_ProtonPIDp)s) "\ + " & ((PIDp-PIDpi) > %(tight_ProtonPIDppi)s) "\ + " & ((PIDp-PIDK) > %(tight_ProtonPIDpK)s) " % self.config ) + # Good tracks - Long Pions + self.GoodLongPionsList = self.createSubSel( OutputList = "GoodLongPionsFor" + self.name, + InputList = self.LongPionsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ + " & (PIDK < %(PionPIDK)s )" % self.config ) + + # Good tracks - Tight Kaons + self.GoodTightKaonsList = self.createSubSel( OutputList = "GoodTightKaonsFor" + self.name, + InputList = self.LongKaonsList, + Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ + " & (TRGHOSTPROB < %(TrGhostProbMax)s )" \ + " & (PROBNNk > %(ProbNNkMin)s )" \ + " & ((PIDK-PIDpi)>%(tight_KaonPIDpi)s)"\ + " & (PIDK > %(tight_KaonPIDK)s )" % self.config ) + + # Xi_c0 -> p+ K- list + self.Xic0List = self.createCombinationSel(OutputList = "Xic0For"+ self.name, + DecayDescriptor = "[Xi_c0 -> p+ K-]cc", + DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList], + DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", + "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.5*mm)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + + self.XibList = self.makeXib() + + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + + def createSubSel( self, OutputList, InputList, Cuts ) : + '''create a selection using a FilterDesktop''' + filter = FilterDesktop(Code = Cuts) + return Selection( OutputList, + Algorithm = filter, + RequiredSelections = [ InputList ] ) + + def createCombinationSel( self, OutputList, + DecayDescriptor, + DaughterLists, + DaughterCuts = {} , + PreVertexCuts = "ALL", + PostVertexCuts = "ALL" ) : + '''create a selection using a ParticleCombiner with a single decay descriptor''' + combiner = CombineParticles( DecayDescriptor = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + + def makeXib( self ): + + ''' Stripping Xi_b- -> Xi_c0 pi-''' + Xib2Xic0piXic02pK = self.createCombinationSel(OutputList = "Xib2Xic0piXic02pK"+ self.name, + DecayDescriptor = "[Xi_b- -> Xi_c0 pi-]cc", + DaughterLists = [self.Xic0List, self.GoodLongPionsList], + DaughterCuts = {"pi-" : " (MIPCHI2DV(PRIMARY)>4)" + }, + PreVertexCuts = "(ADAMASS('Xi_b-') < 800 *MeV)", + PostVertexCuts = "(ADMASS('Xi_b-') < 400 *MeV)" + ) + Xib2Xic0piXic02pKLine = StrippingLine( self.name + "Xib2Xic0piXic02pKLine", algos = [ Xib2Xic0piXic02pK ], EnableFlavourTagging = True ) + self.registerLine (Xib2Xic0piXic02pKLine) + + #------------------------------------------------------------------------------------------ -- GitLab From 2fd69238a9f63934f79287d71b19369f19731fa4 Mon Sep 17 00:00:00 2001 From: Sergio Jaimes <sergio.jaimes@cern.ch> Date: Mon, 17 Jul 2023 11:02:09 +0200 Subject: [PATCH 06/11] Tunning of Hc2VX lines. --- .../StrippingCharm/StrippingHc2V03H.py | 16 ++++------- .../StrippingCharm/StrippingHc2V2H.py | 22 ++++++++++----- .../StrippingCharm/StrippingHc2V3H.py | 28 ++++++++++++++----- 3 files changed, 42 insertions(+), 24 deletions(-) diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V03H.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V03H.py index d3888168f..661ed2021 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V03H.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V03H.py @@ -74,8 +74,8 @@ default_config = { 'Xic_VCHI2VDOF_MAX_LL': 3.0, 'Xic_VCHI2VDOF_MAX_DD': 3.0, # Maximum logIPCHI2. The Lc+/Xic+ come from the PV - 'Lambdac_logIPCHI2_MAX': 5.0, - 'Xic_logIPCHI2_MAX': 5.0, + #'Lambdac_logIPCHI2_MAX': 5.0, + #'Xic_logIPCHI2_MAX': 5.0, # Maximum angle between Lc+ momentum and Lc+ direction of flight 'Lambdac_acosBPVDIRA_MAX_DD': 45.0 * mrad, 'Lambdac_acosBPVDIRA_MAX_LL': 140.0 * mrad, @@ -315,8 +315,7 @@ class StrippingHc2V03HConf(LineBuilder): "& ((CHILD(VFASPF(VZ),1) - VFASPF(VZ)) > {0[LambdaMinFD_LL]})" "& (min(CHILD(PT,2), CHILD(PT,3), CHILD(PT,4)) > {0[Bach_PT_MIN]})" "& (min(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MIN]})" - "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})" - "& (log(MIPCHI2DV(PRIMARY)) < {0[Lambdac_logIPCHI2_MAX]})").format( + "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})").format( self.config) lambdacCuts_DD = ( @@ -327,8 +326,7 @@ class StrippingHc2V03HConf(LineBuilder): "& ((CHILD(VFASPF(VZ),1) - VFASPF(VZ)) > {0[LambdaMinFD_DD]})" "& (min(CHILD(PT,2), CHILD(PT,3), CHILD(PT,4)) > {0[Bach_PT_MIN]})" "& (min(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MIN]})" - "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})" - "& (log(MIPCHI2DV(PRIMARY)) < {0[Lambdac_logIPCHI2_MAX]})").format( + "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})").format( self.config) comb12Cuts = ("(DAMASS('Lambda_c+') < {0[Comb_ADAMASS_WIN]})" @@ -396,8 +394,7 @@ class StrippingHc2V03HConf(LineBuilder): "& ((CHILD(VFASPF(VZ),1) - VFASPF(VZ)) > {0[LambdaMinFD_LL]})" "& (min(CHILD(PT,2), CHILD(PT,3), CHILD(PT,4)) > {0[Bach_PT_MIN]})" "& (min(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MIN]})" - "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})" - "& (log(MIPCHI2DV(PRIMARY)) < {0[Xic_logIPCHI2_MAX]})").format( + "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})").format( self.config) xicCuts_DD = ( @@ -408,8 +405,7 @@ class StrippingHc2V03HConf(LineBuilder): "& ((CHILD(VFASPF(VZ),1) - VFASPF(VZ)) > {0[LambdaMinFD_DD]})" "& (min(CHILD(PT,2), CHILD(PT,3), CHILD(PT,4)) > {0[Bach_PT_MIN]})" "& (min(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MIN]})" - "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})" - "& (log(MIPCHI2DV(PRIMARY)) < {0[Xic_logIPCHI2_MAX]})").format( + "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})").format( self.config) comb12Cuts = ("(DAMASS('Xi_c+') < {0[Comb_ADAMASS_WIN]})" diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V2H.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V2H.py index eed2a9e39..c2cd5e528 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V2H.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V2H.py @@ -16,8 +16,8 @@ In this file the stripping line for this decay is build Throughout this file, 'Bachelor' refers to the children of the Lambda_c+ which is not part of the V- decay. """ -__author__ = ['Andrea Merli','Louis Henry'] -__date__ = '13/10/2017' +__author__ = ['Andrea Merli','Louis Henry', 'Sergio Jaimes'] +__date__ = '26/06/2023' __all__ = ( 'default_config', @@ -27,9 +27,9 @@ __all__ = ( from GaudiKernel.SystemOfUnits import MeV, GeV, mm, mrad from GaudiConfUtils.ConfigurableGenerators import CombineParticles, FilterDesktop, DaVinci__N3BodyDecays from StandardParticles import StdNoPIDsDownPions as InputDownPions -from StandardParticles import StdNoPIDsPions as InputPions -from StandardParticles import StdNoPIDsKaons as InputKaons -from StandardParticles import StdLooseLambdaLL as InputLambdasLL +from StandardParticles import StdAllLoosePions as InputPions +from StandardParticles import StdAllLooseKaons as InputKaons +from StandardParticles import StdVeryLooseLambdaLL as InputLambdasLL from StandardParticles import StdLooseLambdaDD as InputLambdasDD from PhysSelPython.Wrappers import Selection, MergedSelection, DataOnDemand @@ -40,10 +40,12 @@ default_config = { 'NAME': 'Hc2V2H', 'WGs': ['Charm'], 'BUILDERTYPE': 'StrippingHc2V2HConf', - 'STREAMS': ['CharmCompleteEvent'], + 'STREAMS': ['Charm'], 'CONFIG': { # Minimum Lc+ bachelor momentum 'Bach_P_MIN': 2.0*GeV, + # Minimum Lc+ bachelor transverse momentum + 'Bach_PT_MIN': 150 * MeV, # PID of the Lambda proton "ProbNNpMin_LL" : 0.10, "ProbNNpMin_DD" : 0.0, @@ -183,7 +185,7 @@ class StrippingHc2V2HConf(LineBuilder): RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaDD/Particles")]) self.LambdaListLooseLL = MergedSelection("StdLooseLLLambdaFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaLL/Particles")]) + RequiredSelections = [DataOnDemand(Location = "Phys/StdVeryLooseLambdaLL/Particles")]) self.LambdaListLL = self.createSubSel(OutputList = "LambdaLLFor" + self.name, InputList = self.LambdaListLooseLL , @@ -407,6 +409,7 @@ class StrippingHc2V2HConf(LineBuilder): "& ({0[Hc_PVDispCut_LLL]})" "& (BPVDIRA > cos({0[Hc_acosBPVDIRA_MAX_LLL]}))" "& (ADMASS('Lambda_c+') < {0[Hc_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3)) > {0[Bach_PT_MIN]})" ).format(self.config) lambdacCuts_DDL = ( @@ -414,6 +417,7 @@ class StrippingHc2V2HConf(LineBuilder): "& ({0[Hc_PVDispCut_DDL]})" "& (BPVDIRA > cos({0[Hc_acosBPVDIRA_MAX_DDL]}))" "& (ADMASS('Lambda_c+') < {0[Hc_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3)) > {0[Bach_PT_MIN]})" ).format(self.config) lambdacCuts_DDD = ( @@ -421,6 +425,7 @@ class StrippingHc2V2HConf(LineBuilder): "& ({0[Hc_PVDispCut_DDD]})" "& (BPVDIRA > cos({0[Hc_acosBPVDIRA_MAX_DDD]}))" "& (ADMASS('Lambda_c+') < {0[Hc_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3)) > {0[Bach_PT_MIN]})" ).format(self.config) comb12Cuts = ( @@ -501,6 +506,7 @@ class StrippingHc2V2HConf(LineBuilder): "& ({0[Hc_PVDispCut_LLL]})" "& (BPVDIRA > cos({0[Hc_acosBPVDIRA_MAX_LLL]}))" "& (ADMASS('Xi_c+') < {0[Hc_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3)) > {0[Bach_PT_MIN]})" ).format(self.config) xicCuts_DDL = ( @@ -508,6 +514,7 @@ class StrippingHc2V2HConf(LineBuilder): "& ({0[Hc_PVDispCut_DDL]})" "& (BPVDIRA > cos({0[Hc_acosBPVDIRA_MAX_DDL]}))" "& (ADMASS('Xi_c+') < {0[Hc_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3)) > {0[Bach_PT_MIN]})" ).format(self.config) xicCuts_DDD = ( @@ -515,6 +522,7 @@ class StrippingHc2V2HConf(LineBuilder): "& ({0[Hc_PVDispCut_DDD]})" "& (BPVDIRA > cos({0[Hc_acosBPVDIRA_MAX_DDD]}))" "& (ADMASS('Xi_c+') < {0[Hc_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3)) > {0[Bach_PT_MIN]})" ).format(self.config) comb12Cuts = ( diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V3H.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V3H.py index 859d5c458..66501e01a 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V3H.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingHc2V3H.py @@ -18,8 +18,8 @@ Throughout this file, 'Bachelor' refers to the children of the Lambda_c+ which i not part of the V0 decay. """ -__author__ = ['Louis Henry'] -__date__ = '13/10/2017' +__author__ = ['Louis Henry', 'Sergio Jaimes'] +__date__ = '26/06/2023' __all__ = ( 'default_config', @@ -29,9 +29,9 @@ __all__ = ( from GaudiKernel.SystemOfUnits import MeV, GeV, mm, mrad from GaudiConfUtils.ConfigurableGenerators import CombineParticles, FilterDesktop, DaVinci__N4BodyDecays from StandardParticles import StdNoPIDsDownPions as InputDownPions -from StandardParticles import StdNoPIDsPions as InputPions -from StandardParticles import StdNoPIDsKaons as InputKaons -from StandardParticles import StdLooseLambdaLL as InputLambdasLL +from StandardParticles import StdAllLoosePions as InputPions +from StandardParticles import StdAllLooseKaons as InputKaons +from StandardParticles import StdVeryLooseLambdaLL as InputLambdasLL from StandardParticles import StdLooseLambdaDD as InputLambdasDD from PhysSelPython.Wrappers import Selection, MergedSelection, DataOnDemand @@ -42,10 +42,15 @@ default_config = { 'NAME': 'Hc2V3H', 'WGs': ['Charm'], 'BUILDERTYPE': 'StrippingHc2V3HConf', - 'STREAMS': ['CharmCompleteEvent'], + 'STREAMS': ['Charm'], 'CONFIG': { # Minimum Lc+ bachelor momentum 'Bach_P_MIN': 2.0*GeV, + # Minimum Lc+ bachelor transverse momentum + 'Bach_PT_MIN': 200 * MeV, + # Minimum Lc+ bachelor IPCHI2 + 'Bach_IPCHI2_MIN': 1, + 'Bach_IPCHI2_MAX': 9, # PID of the Lambda proton "ProbNNpMin_LL" : 0.10, "ProbNNpMin_DD" : 0.00, @@ -179,7 +184,7 @@ class StrippingHc2V3HConf(LineBuilder): RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaDD/Particles")]) self.LambdaListLooseLL = MergedSelection("StdLooseLLLambdaFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaLL/Particles")]) + RequiredSelections = [DataOnDemand(Location = "Phys/StdVeryLooseLambdaLL/Particles")]) self.LambdaListLL = self.createSubSel(OutputList = "LambdaLLFor" + self.name, InputList = self.LambdaListLooseLL , @@ -367,6 +372,9 @@ class StrippingHc2V3HConf(LineBuilder): "& ({0[Xic_PVDispCut_LLL]})" "& (BPVDIRA > cos({0[Xic_acosBPVDIRA_MAX_LLL]}))" "& (ADMASS('Xi_c0') < {0[Xic_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3), CHILD(PT,4)) > {0[Bach_PT_MIN]})" + "& (min(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MIN]})" + "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})" ).format(self.config) xicCuts_DDL = ( @@ -374,6 +382,9 @@ class StrippingHc2V3HConf(LineBuilder): "& ({0[Xic_PVDispCut_DDL]})" "& (BPVDIRA > cos({0[Xic_acosBPVDIRA_MAX_DDL]}))" "& (ADMASS('Xi_c0') < {0[Xic_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3), CHILD(PT,4)) > {0[Bach_PT_MIN]})" + "& (min(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MIN]})" + "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})" ).format(self.config) xicCuts_DDD = ( @@ -381,6 +392,9 @@ class StrippingHc2V3HConf(LineBuilder): "& ({0[Xic_PVDispCut_DDD]})" "& (BPVDIRA > cos({0[Xic_acosBPVDIRA_MAX_DDD]}))" "& (ADMASS('Xi_c0') < {0[Xic_ADMASS_WIN]})" + "& (min(CHILD(PT,2), CHILD(PT,3), CHILD(PT,4)) > {0[Bach_PT_MIN]})" + "& (min(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MIN]})" + "& (max(CHILD(MIPCHI2DV(PRIMARY),2), CHILD(MIPCHI2DV(PRIMARY),3), CHILD(MIPCHI2DV(PRIMARY),4)) > {0[Bach_IPCHI2_MAX]})" ).format(self.config) comb12Cuts = ( -- GitLab From 6ebf4548afa94483bcc7b701b38981b79deed71b Mon Sep 17 00:00:00 2001 From: Hong-Jian Wang <hong-jian.wang@cern.ch> Date: Mon, 17 Jul 2023 11:02:33 +0200 Subject: [PATCH 07/11] Merge Charm_Xic2PHH_2018-patches --- StrippingXic2PHH.py | 410 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 410 insertions(+) create mode 100644 StrippingXic2PHH.py diff --git a/StrippingXic2PHH.py b/StrippingXic2PHH.py new file mode 100644 index 000000000..ee622d656 --- /dev/null +++ b/StrippingXic2PHH.py @@ -0,0 +1,410 @@ +############################################################################### +# (c) Copyright 2000-2023 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. # +############################################################################### +__author__ = ['Hong-Jian Wang'] +__date__ = '07/03/2023' +__version__ = '$Revision: 0.1 $' +__all__ = ('StrippingXic2PHH' + ,'default_config') + +from Gaudi.Configuration import * +from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles +from StandardParticles import StdLoosePions, StdLooseKaons, StdLooseProtons +from StandardParticles import StdLooseKsLL, StdLooseKsDD +from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection +from PhysSelPython.Wrappers import MultiSelectionSequence +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder +from GaudiKernel.SystemOfUnits import MeV, GeV, mm, picosecond +import sys + +default_name='Xic2PHH' + #### This is the dictionary of all tunable cuts ######## +default_config={ + 'NAME' : 'Xic2PHH', + 'WGs' : ['Charm'], + 'BUILDERTYPE' : 'StrippingXic2PHH', + 'STREAMS' : ['Charm'], + 'CONFIG' : { + 'GEC_nLongTrk' : 250 # adimensional + , 'signalPrescaleViaXicPKK' : 1.0 + , 'signalPrescaleViaXicPPhi2KK' : 1.0 + , 'signalPrescaleViaXicPPiPi' : 1.0 + , 'signalPrescaleViaXicPKS0LL' : 1.0 + , 'signalPrescaleViaXicPKS0DD' : 1.0 + , 'TRCHI2DOFMax' : 3.0 + , 'GhostProb' : 0.3 + , 'TrGhostProbMax' : 0.25 # same for all particles + , 'MINIPCHI2' : 4.0 # adimensiional, orig. 9 + , 'PionP' : 3.0*GeV + , 'PionPT' : 500*MeV + , 'PionPIDK' : 10.0 + , 'Pion_PIDpiPIDK_Min' : 0.0 + , 'KaonP' : 2.0*GeV + , 'KaonPT' : 200*MeV + , 'KaonPIDK' : 10.0 + , 'Kaon_PIDKPIDpi_Min' : 5.0 + , 'ProtonP' : 3.0*GeV + , 'ProtonPT' : 500*MeV + , 'Proton_PIDpPIDpi_Min' : 5.0 + , 'Proton_PIDpPIDK_Min' : 0.0 + , 'ProbNNpMin' : 0.2 #ProbNNp cut for proton in L0, to suppress the bkg of L0 + , 'ProbNNp' : 0.4 + , 'ProbNNk' : 0.4 + , 'ProbNNpi' : 0.5 + , 'ProbNNpiMax' : 0.95 + , 'Xic_ADAMASS_HalfWin' : 170.0*MeV + , 'Xic_ADMASS_HalfWin' : 120.0*MeV + , 'Xic_BPVVDCHI2_Min' : 25.0 + , 'Xic_BPVDIRA_Min' : 0.9 + , 'pKK_AM_Min' : 2380.0*MeV + , 'ppipi_AM_Min' : 2380.0*MeV + , 'Xic_AM_Max' : 2550.0*MeV + # KS (DD) + , 'MinKsPT_DD' : 200 * MeV + , 'MaxKsVCHI2NDOF_DD' : 20.0 + , 'MinDz_DD' : 250. * mm + , 'MaxDz_DD' : 9999 * mm + , 'MinKsIpChi2_DD' : 3 + , 'KSCutDIRA_DD' : 0.999 + , 'KSCutMass_DD' : 50 * MeV + , 'KSCutFDChi2_DD' : 5 + # KS (LL) + , 'MinKsPT_LL' : 200 * MeV + , 'MaxKsVCHI2NDOF_LL' : 20.0 + , 'MinDz_LL' : 0 * mm + , 'MaxDz_LL' : 9999 * mm + , 'MinKsIpChi2_LL' : 3 + , 'KSCutDIRA_LL' : 0.999 + , 'KSCutMass_LL' : 35 * MeV + , 'KSCutFDChi2_LL' : 5 + # phi1020 + , 'MinPhiPT' : 200 * MeV + , 'MinPhiP' : 3 * GeV + , 'MinPhiEta' : 2.0 + , 'MaxPhiEta' : 5.0 + , 'BPVIPCHI2_Phi' : 4 + , 'PhiCutMass' : 20 * MeV + } ## end of 'CONFIG' +} ## end of default_config + +#------------------------------------------------------------------------------------------------------------- +class StrippingXic2PHH(LineBuilder) : + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__(self, name, config) : + LineBuilder.__init__(self, name, config) + self.name = name + self.config = config + + GECs = { "Code":"( recSummaryTrack(LHCb.RecSummary.nLongTracks, TrLONG) < %(GEC_nLongTrk)s )" % config, + "Preambulo": ["from LoKiTracks.decorators import *"]} + + ########################################################################## + ## Basic particles: K, pi, p + ########################################################################## + self.selKaon = Selection( "SelKfor" + name, + Algorithm = self._kaonFilter("Kfor"+name), + RequiredSelections = [StdLooseKaons]) + + self.selPion = Selection( "SelPifor" + name, + Algorithm = self._pionFilter("Pifor"+name), + RequiredSelections = [StdLoosePions]) + + self.selProton = Selection( "SelPfor" + name, + Algorithm = self._protonFilter("Pfor"+name), + RequiredSelections = [StdLooseProtons]) + ########################################################################## + ## KS0 -> pi+ pi- + ########################################################################## + _stdLooseKs0LL = DataOnDemand("Phys/StdLooseKsLL/Particles") + _stdLooseKs0DD = DataOnDemand("Phys/StdLooseKsDD/Particles") + + self.selKs0LL = Selection("SelKsLL0for"+name, + Algorithm = self._Ks0LLFilter("Ks0LLfor"+name), + RequiredSelections = [_stdLooseKs0LL]) + + self.selKs0DD = Selection("SelKs0DDfor"+name, + Algorithm = self._Ks0DDFilter("Ks0DDfor"+name), + RequiredSelections = [_stdLooseKs0DD]) + ########################################################################## + ## Xi- -> Lambda0 pi- + ########################################################################## + self.phi2KK = self.createCombinationSel(OutputList = "phi2KKfor"+ self.name, + DecayDescriptor = "[phi(1020) -> K+ K-]cc", + DaughterLists = [self.selKaon], + DaughterCuts = {"K+" : "(MIPCHI2DV(PRIMARY)>4) "}, + PreVertexCuts = "(ADAMASS('phi(1020)') < 40*MeV) & (ADOCACHI2CUT(30, ''))", + PostVertexCuts = " (PT > %(MinPhiPT)s) & (P > %(MinPhiP)s)"\ + "& (BPVIPCHI2() > %(BPVIPCHI2_Phi)s)"\ + "& (in_range(%(MinPhiEta)s, ETA, %(MaxPhiEta)s))"\ + "& (ADMASS('phi(1020)') < %(PhiCutMass)s)" % self.config ) + self.Xic2PHHList = self.makeXic2PHH() + + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + # Sub Function + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + def _pionFilter( self , _name): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(PionP)s) & (PT > %(PionPT)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK< %(PionPIDK)s)"\ + "& (PROBNNpi > %(ProbNNpi)s)" % self.config + _pi = FilterDesktop(Code = _code ) + return _pi + + def _kaonFilter( self , _name ): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(KaonP)s) & (PT > %(KaonPT)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK> %(KaonPIDK)s) & (PROBNNpi < %(ProbNNpiMax)s)"\ + "& (PROBNNk > %(ProbNNk)s)"\ + "& (HASRICH)&(PIDK-PIDpi>%(Kaon_PIDKPIDpi_Min)s)"% self.config + _ka = FilterDesktop(Code = _code ) + return _ka + + def _protonFilter( self, _name ): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (PT > %(ProtonPT)s) & (P>%(ProtonP)s)"\ + "& (TRGHOSTPROB < %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PROBNNp > %(ProbNNp)s) & (PROBNNpi < %(ProbNNpiMax)s)"\ + "& (HASRICH)&(PIDp-PIDpi > %(Proton_PIDpPIDpi_Min)s)"\ + "& (HASRICH)&(PIDp-PIDK > %(Proton_PIDpPIDK_Min)s)"% self.config + _pr = FilterDesktop(Code = _code) + return _pr + + def _Ks0LLFilter( self, _name): + _code = " (PT > %(MinKsPT_LL)s)" \ + "& (BPVVDZ > %(MinDz_LL)s ) " \ + "& (BPVVDZ < %(MaxDz_LL)s ) " \ + "& (MIPCHI2DV(PRIMARY) > %(MinKsIpChi2_LL)s) "\ + "& (BPVDIRA > %(KSCutDIRA_LL)s )" \ + "& (ADMASS('KS0') < %(KSCutMass_LL)s)" \ + "& (BPVVDCHI2 > %(KSCutFDChi2_LL)s)" % self.config + _Ks0LL = FilterDesktop(Code = _code) + return _Ks0LL + + def _Ks0DDFilter( self , _name): + _code = " (PT > %(MinKsPT_DD)s)" \ + " & (BPVVDZ > %(MinDz_DD)s ) " \ + " & (BPVVDZ < %(MaxDz_DD)s ) " \ + " & (MIPCHI2DV(PRIMARY) > %(MinKsIpChi2_DD)s) "\ + " & (BPVDIRA > %(KSCutDIRA_DD)s )" \ + " & (ADMASS('KS0') < %(KSCutMass_DD)s)" \ + " & (BPVVDCHI2 > %(KSCutFDChi2_DD)s)" % self.config + _Ks0DD = FilterDesktop(Code = _code) + return _Ks0DD + + ##------------------------------------------------------------------------------------------ + ## -------------------- Begin to makeXic2PHH ------------ + def makeXic2PHH( self ): + #Cut for Basic + + _PreVertexCuts = "(ADAMASS('Xi_c+') < 120*MeV) & (ADOCACHI2CUT(30, ''))" + _PostVertexCuts = "(ADMASS('Xi_c+')<90*MeV)"\ + "& (VFASPF(VCHI2)<25)"\ + "& (P> 1000*MeV) & (PT > 250*MeV)"\ + "& (BPVVDCHI2 > 49.0 )"\ + "& (VFASPF(VCHI2/VDOF) < 12.0)" + + _strCutMothfor = "(BPVVDCHI2>%(Xic_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(Xic_BPVDIRA_Min)s)" % self.config + + _strCutComb_XicMass = "(ADAMASS('Xi_c+') < %(Xic_ADAMASS_HalfWin)s )" % self.config + _strCutMoth_XicMass = "(ADMASS('Xi_c+') < %(Xic_ADMASS_HalfWin)s)" % self.config + + _strCutMothforXicPlus = _strCutMothfor + '&' + _strCutMoth_XicMass + '&' + _PostVertexCuts + + _strCutComb_MassPKK = "(AM>%(pKK_AM_Min)s) & (AM<%(Xic_AM_Max)s)" % self.config + _strCutComb_MassPPiPi = "(AM>%(ppipi_AM_Min)s) & (AM<%(Xic_AM_Max)s)" % self.config + + _strCutComb_Xic2PKK = _strCutComb_XicMass + '&' + _strCutComb_MassPKK + '&' + _PreVertexCuts + _strCutComb_Xic2PPiPi = _strCutComb_XicMass + '&' + _strCutComb_MassPPiPi + '&' + _PreVertexCuts + _strCutMothPHH = _strCutMothforXicPlus + + ''' Stripping Xi_c+ -> p+ K+ K- ''' + Xic2PKK = self.createCombinationSel(OutputList = "Xic2PKK" + self.name, + DecayDescriptor = "[Xi_c+ -> p+ K+ K-]cc", + DaughterLists = [self.selProton, self.selKaon], + PreVertexCuts = _strCutComb_Xic2PKK, + PostVertexCuts = _strCutMothPHH ) + Xic2PKKLine = StrippingLine( self.name + "Xicp2PKKLine", + prescale = self.config['signalPrescaleViaXicPKK'], + algos = [ Xic2PKK ], + EnableFlavourTagging = False, + RelatedInfoTools = self._getRelInfoXic2PKK() ) + self.registerLine (Xic2PKKLine) + + ''' Stripping Xi_c+ -> p+ (phi(1020) -> K+ K-) ''' + Xic2PPhi2KK = self.createCombinationSel(OutputList = "Xic2PPhi2KK" + self.name, + DecayDescriptor = "[Xi_c+ -> p+ phi(1020)]cc", + DaughterLists = [self.selProton, self.phi2KK], + PreVertexCuts = _strCutComb_Xic2PKK, + PostVertexCuts = _strCutMothPHH ) + Xic2PPhi2KKLine = StrippingLine( self.name + "Xicp2PPhi2KKLine", + prescale = self.config['signalPrescaleViaXicPPhi2KK'], + algos = [ Xic2PPhi2KK ], + EnableFlavourTagging = False, + RelatedInfoTools = self._getRelInfoXic2PPhi2KK() ) + self.registerLine (Xic2PPhi2KKLine) + + ''' Stripping Xi_c+ -> p+ pi+ pi-''' + Xic2PPiPi = self.createCombinationSel(OutputList = "Xic2PPiPi" + self.name, + DecayDescriptor = "[Xi_c+ -> p+ pi+ pi-]cc", + DaughterLists = [self.selProton, self.selPion], + PreVertexCuts = _strCutComb_Xic2PPiPi, + PostVertexCuts = _strCutMothPHH ) + Xic2PPiPiLine = StrippingLine( self.name + "Xicp2PPiPiLine", + prescale = self.config['signalPrescaleViaXicPPiPi'], + algos = [ Xic2PPiPi ], + EnableFlavourTagging = False, + RelatedInfoTools = self._getRelInfoXic2PPiPi() ) + self.registerLine (Xic2PPiPiLine) + + ''' Stripping Xi_c+ -> p+ KS0(LL)''' + Xic2PKS0LL = self.createCombinationSel(OutputList = "Xic2PKS0LL" + self.name, + DecayDescriptor = "[Xi_c+ -> p+ KS0]cc", + DaughterLists = [self.selProton, self.selKs0LL], + PreVertexCuts = _strCutComb_Xic2PPiPi, + PostVertexCuts = _strCutMothPHH ) + Xic2PKS0LLLine = StrippingLine( self.name + "Xicp2PKS0LLLine", + prescale = self.config['signalPrescaleViaXicPKS0LL'], + algos = [ Xic2PKS0LL ], + EnableFlavourTagging = False, + RelatedInfoTools = self._getRelInfoXic2PKS0() ) + self.registerLine (Xic2PKS0LLLine) + + ''' Stripping Xi_c+ -> p+ KS0(DD)''' + Xic2PKS0DD = self.createCombinationSel(OutputList = "Xic2PKS0D" + self.name, + DecayDescriptor = "[Xi_c+ -> p+ KS0]cc", + DaughterLists = [self.selProton, self.selKs0DD], + PreVertexCuts = _strCutComb_Xic2PPiPi, + PostVertexCuts = _strCutMothPHH ) + Xic2PKS0DDLine = StrippingLine( self.name + "Xicp2PKS0DDLine", + prescale = self.config['signalPrescaleViaXicPKS0DD'], + algos = [ Xic2PKS0DD ], + EnableFlavourTagging = False, + RelatedInfoTools = self._getRelInfoXic2PKS0() ) + self.registerLine (Xic2PKS0DDLine) + + ## -------------------- end of makeXic2PHH ------------ + ##------------------------------------------------------------------------------------------ + + ########################################################################## + ## Basic Function + ########################################################################## + def createSubSel( self, OutputList, InputList, Cuts ) : + '''create a selection using a FilterDesktop''' + filter = FilterDesktop(Code = Cuts) + return Selection( OutputList, + Algorithm = filter, + RequiredSelections = [ InputList ] ) + + def createCombinationSel( self, OutputList, + DecayDescriptor, + DaughterLists, + DaughterCuts = {} , + PreVertexCuts = "ALL", + PostVertexCuts = "ALL") : + '''create a selection using a ParticleCombiner with a single decay descriptor''' + combiner = CombineParticles( DecayDescriptor = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + #print "DEBUG here is :",__file__,sys._getframe().f_lineno + + def _getRelInfoXic2PKK(self): + relInfo = [] + for coneAngle in [0.8,1.0,1.3,1.7]: + conestr = str(coneAngle).replace('.','') + relInfo += [ + { "Type" : "RelInfoConeVariables", + "ConeAngle" : coneAngle, + "Variables" : ['CONEANGLE', 'CONEMULT', 'CONEPTASYM'], + "DaughterLocations" : { + "^[Xi_c+ -> p+ K+ K-]CC" : 'P2ConeVar%s_Xic' % conestr, + "[Xi_c+ -> ^p+ K+ K-]CC" : 'P2ConeVar%s_proton' % conestr, + "[Xi_c+ -> p+ ^K+ K-]CC" : 'P2ConeVar%s_K1' % conestr, + "[Xi_c+ -> p+ K+ ^K-]CC" : 'P2ConeVar%s_K2' % conestr } } + ] + relInfo += [ { "Type" : "RelInfoVertexIsolation", + "DaughterLocations" : { + "^[Xi_c+ -> p+ K+ K-]CC" : 'VertexIsoInfo_Xic'} } ] + return relInfo + + def _getRelInfoXic2PPhi2KK(self): + relInfo = [] + for coneAngle in [0.8,1.0,1.3,1.7]: + conestr = str(coneAngle).replace('.','') + relInfo += [ + { "Type" : "RelInfoConeVariables", + "ConeAngle" : coneAngle, + "Variables" : ['CONEANGLE', 'CONEMULT', 'CONEPTASYM'], + "DaughterLocations" : { + "^[Xi_c+ -> p+ (phi(1020) -> K+ K-)]CC" : 'P2ConeVar%s_Xic' % conestr, + "[Xi_c+ -> ^p+ (phi(1020) -> K+ K-)]CC" : 'P2ConeVar%s_proton' % conestr, + "[Xi_c+ -> p+ ^(phi(1020) -> K+ K-)]CC" : 'P2ConeVar%s_phi' % conestr, + "[Xi_c+ -> p+ (phi(1020) -> ^K+ K-)]CC" : 'P2ConeVar%s_K1' % conestr, + "[Xi_c+ -> p+ (phi(1020) -> K+ ^K-)]CC" : 'P2ConeVar%s_K2' % conestr } } + ] + relInfo += [ { "Type" : "RelInfoVertexIsolation", + "DaughterLocations" : { + "^[Xi_c+ -> p+ (phi(1020) -> K+ K-)]CC" : 'VertexIsoInfo_Xic', + "[Xi_c+ -> p+ ^(phi(1020) -> K+ K-)]CC" : 'VertexIsoInfo_phi'} } ] + return relInfo + + def _getRelInfoXic2PPiPi(self): + relInfo = [] + for coneAngle in [0.8,1.0,1.3,1.7]: + conestr = str(coneAngle).replace('.','') + relInfo += [ + { "Type" : "RelInfoConeVariables", + "ConeAngle" : coneAngle, + "Variables" : ['CONEANGLE', 'CONEMULT', 'CONEPTASYM'], + "DaughterLocations" : { + "^[Xi_c+ -> p+ pi+ pi-]CC" : 'P2ConeVar%s_Xic' % conestr, + "[Xi_c+ -> ^p+ pi+ pi-]CC" : 'P2ConeVar%s_proton' % conestr, + "[Xi_c+ -> p+ ^pi+ pi-]CC" : 'P2ConeVar%s_pi1' % conestr, + "[Xi_c+ -> p+ pi+ ^pi-]CC" : 'P2ConeVar%s_pi2' % conestr } } + ] + relInfo += [ { "Type" : "RelInfoVertexIsolation", + "DaughterLocations" : { + "^[Xi_c+ -> p+ pi+ pi-]CC" : 'VertexIsoInfo_Xic'} } ] + return relInfo + + def _getRelInfoXic2PKS0(self): + relInfo = [] + for coneAngle in [0.8,1.0,1.3,1.7]: + conestr = str(coneAngle).replace('.','') + relInfo += [ + { "Type" : "RelInfoConeVariables", + "ConeAngle" : coneAngle, + "Variables" : ['CONEANGLE', 'CONEMULT', 'CONEPTASYM'], + "DaughterLocations" : { + "^[Xi_c+ -> p+ (KS0 -> pi+ pi-)]CC" : 'P2ConeVar%s_Xic' % conestr, + "[Xi_c+ -> ^p+ (KS0 -> pi+ pi-)]CC" : 'P2ConeVar%s_proton' % conestr, + "[Xi_c+ -> p+ ^(KS0 -> pi+ pi-)]CC" : 'P2ConeVar%s_KS0' % conestr, + "[Xi_c+ -> p+ (KS0 -> ^pi+ pi-)]CC" : 'P2ConeVar%s_pi1' % conestr, + "[Xi_c+ -> p+ (KS0 -> pi+ ^pi-)]CC" : 'P2ConeVar%s_pi2' % conestr } } + ] + relInfo += [ { "Type" : "RelInfoVertexIsolation", + "DaughterLocations" : { + "^[Xi_c+ -> p+ (KS0 -> pi+ pi-)]CC" : 'VertexIsoInfo_Xic', + "[Xi_c+ -> p+ ^(KS0 -> pi+ pi-)]CC" : 'VertexIsoInfo_KS0'} } ] + return relInfo -- GitLab From 78ce418894c41824817ad1643cf31dc1c21e886c Mon Sep 17 00:00:00 2001 From: Qile Niu <qile.niu@cern.ch> Date: Mon, 17 Jul 2023 11:30:49 +0200 Subject: [PATCH 08/11] Lb2LcpiLc2peta --- StrippingLambdab2PiLambdac2PEta.py | 271 +++++++++++++++++++++++++++++ 1 file changed, 271 insertions(+) create mode 100644 StrippingLambdab2PiLambdac2PEta.py diff --git a/StrippingLambdab2PiLambdac2PEta.py b/StrippingLambdab2PiLambdac2PEta.py new file mode 100644 index 000000000..56113d582 --- /dev/null +++ b/StrippingLambdab2PiLambdac2PEta.py @@ -0,0 +1,271 @@ +############################################################################### +# (c) Copyright 2000-2023 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. # +############################################################################### +''' +Speculative code for charmed baryon searches. +The following two channels are used: +Lambda_b0-> pi (Lambda_c+ -> p+ eta) +Lambda_b0-> pi (Lambda_c+ -> p+ eta') +''' + + +__author__ = ['Xiao-Rui Lyu', 'Pei-Rong Li', 'Miroslav Saur', 'Qi-Le Niu'] +__date__ = '2023/07/12' +__version__ = '$Revision: 0.1 $' +__all__ = ('StrippingLambdac2PEta' + ,'default_config') + + +from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles +from StandardParticles import StdAllLoosePions, StdAllLooseProtons, StdLooseProtons, StdLoosePions +from StandardParticles import StdLooseMergedPi0, StdLooseResolvedPi0 +from StandardParticles import StdLooseResolvedEta, StdLooseEta2gg +from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection +from PhysSelPython.Wrappers import MultiSelectionSequence +from StrippingConf.StrippingLine import StrippingLine +from StrippingUtils.Utils import LineBuilder +from GaudiKernel.SystemOfUnits import MeV, GeV, mm, picosecond +import sys + + +default_name='Lambdac2PEta' + #### This is the dictionary of all tunable cuts ######## +default_config={ + 'NAME' : 'Lambdac2PEta', + 'WGs' : ['Charm'], + 'BUILDERTYPE' : 'StrippingLambdac2PEta', + 'STREAMS' : ['Charm'], + 'CONFIG' : { + 'GEC_nLongTrk' : 160 # adimensional + , 'signalPrescale' : 1.0 + , 'TRCHI2DOFMax' : 3.0 + , 'TrGhostProbMax' : 0.25 # same for all particles + , 'MINIPCHI2' : 3.0 # adimensiional + , 'ProtonP' : 3.0*GeV + , 'ProtonPT' : 500*MeV + , 'Proton_PIDpPIDpi_Min' : 5.0 + , 'Proton_PIDpPIDK_Min' : 0.0 + , 'PionP' : 3*GeV + , 'PionPT' : 250*MeV + , 'PionPIDK' : 5.0 + , 'ProbNNp' : 0.4 + , 'ProbNNpi' : 0.4 + , 'ProbNNpiMax' : 0.9 + + , 'Lc_M_HalfWin' : 200.0*MeV + , 'Lb_M_HalfWin' : 200.0*MeV + , 'Lc_Daug_1of3_MIPCHI2DV_Min': 3.0 + , 'Lc_ADOCAMAX_Max' : 0.15*mm + , 'Lc_APT_Min' : 1.2*GeV + , 'Lc_AP_Min' : 15*GeV + , 'Lc_VCHI2_Max' : 30.0 + , 'Lc_BPVVDCHI2_Min' : 16.0 + , 'Lc_BPVVDZ_Min' : 0.5*mm + , 'Lc_BPVDIRA_Min' : 0.95 + + #For Lb + , 'Lb_AP_Min': 20*GeV + , 'Lb_APT_Min': 1.5*GeV + , 'Lb_VCHI2_Max': 30 + , 'Lb_BPVVDCHI2_Min': 16 + , 'Lb_BPVVDZ_Min': 0.7*mm + , 'Lb_BPVDIRA_Min': 0.95 + } ## end of 'CONFIG' +} ## end of default_config + +#------------------------------------------------------------------------------------------------------------- +class StrippingLambdac2PEta(LineBuilder) : + __configuration_keys__ = default_config['CONFIG'].keys() + + def __init__(self, name, config) : + LineBuilder.__init__(self, name, config) + self.name = name + self.config = config + + GECs = { "Code":"( recSummaryTrack(LHCb.RecSummary.nLongTracks, TrLONG) < %(GEC_nLongTrk)s )" % config, + "Preambulo": ["from LoKiTracks.decorators import *"]} + + ########################################################################## + ## Basic particles: p+, pi + ########################################################################## + + self.selPi = Selection( "SelPifor" + name, + Algorithm = self._piFilter("Pifor"+name), + RequiredSelections = [StdLoosePions]) + + self.selProton = Selection( "SelPfor" + name, + Algorithm = self._protonFilter("Pfor"+name), + RequiredSelections = [StdLooseProtons]) + + self.makeEta() + # then use self.Eta2PiPiPi0 and self.Eta2PiPiGamma + + + ########################################################################## + self.DmesonSLList = self.makeLine() + + + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + # Sub Function + #------------------------------------------------------------------------------------------ + #------------------------------------------------------------------------------------------ + def _protonFilter( self, _name ): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (PT > %(ProtonPT)s) & (P>%(ProtonP)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PROBNNp > %(ProbNNp)s) & (PROBNNpi < %(ProbNNpiMax)s)"\ + "& (HASRICH)&(PIDp-PIDpi>%(Proton_PIDpPIDpi_Min)s)"\ + "& (HASRICH)&(PIDp-PIDK>%(Proton_PIDpPIDK_Min)s)"% self.config + _pr = FilterDesktop(Code = _code) + return _pr + + + def _piFilter( self , _name): + _code = " (TRCHI2DOF < %(TRCHI2DOFMax)s)"\ + "& (P>%(PionP)s) & (PT > %(PionPT)s)"\ + "& (TRGHOSTPROB< %(TrGhostProbMax)s)"\ + "& (MIPCHI2DV(PRIMARY)> %(MINIPCHI2)s)"\ + "& (PIDK< %(PionPIDK)s) "\ + "& (HASRICH)&(PROBNNpi > %(ProbNNpi)s) " % self.config + _pi = FilterDesktop(Code = _code ) + return _pi + + + def makeLb0Line(self, line_name, prescale, Lc): + comb_cut = "in_range(200, AM, 200000)" + vertex_cut = "ALL" + + Lb0 = self.createCombinationSel(OutputList = "Lb02LcPi_" + line_name, + DecayDescriptor = "[Lambda_b0 -> Lambda_c+ pi-]cc", + DaughterLists = [Lc, self.selPi], + PreVertexCuts = comb_cut, + PostVertexCuts = vertex_cut ) + Lb0Line = StrippingLine( line_name, + prescale = prescale, + selection = Lb0, + EnableFlavourTagging = False ) + return Lb0Line + + + ##------------------------------------------------------------------------------------------ + ## -------------------- Begin to DpSL ------------ + def makeLine( self ): + + _strCutCombfor = "(AMINCHILD(MIPCHI2DV(PRIMARY))>%(Lc_Daug_1of3_MIPCHI2DV_Min)s)" \ + "& (AP>%(Lc_AP_Min)s)" \ + "& (ADAMASS('Lambda_c+') < %(Lc_M_HalfWin)s)" \ + "& (APT>%(Lc_APT_Min)s)" % self.config + + _strCutMothfor = "(VFASPF(VCHI2) < %(Lc_VCHI2_Max)s)" \ + "& (ADMASS('Lambda_c+') < %(Lc_M_HalfWin)s)" \ + "& (BPVVDCHI2>%(Lc_BPVVDCHI2_Min)s)" \ + "& (BPVDIRA>%(Lc_BPVDIRA_Min)s)" % self.config + + _strCutComb_Mass = "(ADAMASS('Lambda_c+') < 1.1*%(Lc_M_HalfWin)s)" % self.config + _strCutMoth_Mass = "(ADMASS('Lambda_c+') < %(Lc_M_HalfWin)s)" % self.config + + _strCutComb = _strCutCombfor + '&' + _strCutComb_Mass + _strCutMoth = _strCutMothfor + '&' + _strCutMoth_Mass + + ''' Stripping Lambda_c+ -> p+ eta ''' + PEta2PiPiPi0 = self.createCombinationSel(OutputList = "Lc2PEta2PiPiPi0" + self.name, + DecayDescriptor = "[Lambda_c+ -> p+ eta]cc", + DaughterLists = [self.selProton, self.Eta2PiPiPi0], + PreVertexCuts = _strCutComb, + PostVertexCuts = _strCutMoth ) + self.registerLine(self.makeLb0Line( + line_name=self.name + "Lb2LcPiLc2Eta2PiPiPi0", + prescale=self.config['signalPrescale'], + Lc=PEta2PiPiPi0 + )) + + ''' Stripping Lambda_c+ -> p+ eta_prime ''' + PEtap2PiPiEta = self.createCombinationSel(OutputList = "Lc2PEtap2PiPiEta" + self.name, + DecayDescriptor = "[Lambda_c+ -> p+ eta_prime]cc", + DaughterLists = [self.selProton, self.Etap2PiPiEta], + PreVertexCuts = _strCutComb, + PostVertexCuts = _strCutMoth ) + self.registerLine(self.makeLb0Line( + line_name=self.name + "Lb2LcPiLc2Etap2PiPiEta", + prescale=self.config['signalPrescale'], + Lc=PEtap2PiPiEta + )) + + ## -------------------- End of DpSL ------------ + ##------------------------------------------------------------------------------------------ + def makeEta(self): + #get standard containers + self.Pi0List = DataOnDemand(Location = "Phys/StdLoosePi02gg/Particles") + self.LoosePionList = DataOnDemand(Location = "Phys/StdLoosePions/Particles") + + #clean neutrals + _tightpi0_cut = "(CHILD(CL,1)>0.05) & (CHILD(CL,2)>0.05) & (PT>0.0*GeV)" + + #pipi vertex cuts + _pipix_cut = "(BPVVDZ>0) & (VFASPF(VCHI2)<9) & (BPVDIRA>0.95) & (BPVVDCHI2>25)" + + #pipix0 cuts + _eta_cut = "(ADAMASS('eta')<100*MeV) & (APT>1500*MeV)" + _etap_cut = "(ADAMASS('eta_prime')<200*MeV) & (APT>1500*MeV)" + + #filter standard containers + self.TightPi0List = self.createSubSel( OutputList = self.name + '_TightPi0', InputList = self.Pi0List, Cuts = _tightpi0_cut) + + #------------- + + self.Eta2PiPiPi0 = self.createCombinationSel( OutputList = self.name + "_Eta2PiPiPi0", + DecayDescriptor = "eta -> pi+ pi- pi0", + DaughterLists = [ self.LoosePionList, self.TightPi0List], + PreVertexCuts = _eta_cut, + PostVertexCuts = _pipix_cut) + #------------- + self.Etap2PiPiEta = self.createCombinationSel( OutputList = self.name + "_Etap2PiPiEta", + DecayDescriptor = "eta_prime -> pi+ pi- eta", + DaughterLists = [ self.LoosePionList, self.Eta2PiPiPi0], + PreVertexCuts = _etap_cut, + PostVertexCuts = _pipix_cut) + + ########################################################################## + ## Basic Function + ########################################################################## + def createSubSel( self, OutputList, InputList, Cuts ) : + '''create a selection using a FilterDesktop''' + filter = FilterDesktop(Code = Cuts) + return Selection( OutputList, + Algorithm = filter, + RequiredSelections = [ InputList ] ) + + def createCombinationSel( self, OutputList, + DecayDescriptor, + DaughterLists, + DaughterCuts = {} , + PreVertexCuts = "ALL", + PostVertexCuts = "ALL") : + '''create a selection using a ParticleCombiner with a single decay descriptor''' + if type(DecayDescriptor) is list: + combiner = CombineParticles( DecayDescriptors = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) + else: + combiner = CombineParticles( DecayDescriptor = DecayDescriptor, + DaughtersCuts = DaughterCuts, + MotherCut = PostVertexCuts, + CombinationCut = PreVertexCuts, + ReFitPVs = True) + return Selection ( OutputList, + Algorithm = combiner, + RequiredSelections = DaughterLists) -- GitLab From c431a19bce0c7f2e5fad0c10e11face5a663ca6b Mon Sep 17 00:00:00 2001 From: Sergio Jaimes <sergio.javier.jaimes.elles@cern.ch> Date: Mon, 17 Jul 2023 16:32:54 +0200 Subject: [PATCH 09/11] Update '__init__.py' file with all the modules to be included for re-stripping. --- .../StrippingCharm/__init__.py | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py index 2c86891df..131e42f4a 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/__init__.py @@ -9,7 +9,21 @@ # or submit itself to any jurisdiction. # ############################################################################### -_selections = ('StrippingLambdacForNeutronPID', 'StrippingXiccSL','StrippingD2KPiPiMuNu','StrippingBs2st2pKpipipi', 'StrippingDstarD2KSHHPi0','StrippingCharmFromBSemi', 'StrippingXcpToXiPipHp', 'StrippingLambdac2V0H', 'StrippingNeutralCBaryons', 'StrippingD2HMuNu', 'StrippingXcpToLambdaKSHp', 'StrippingDstarD2XGamma', 'StrippingCharmedBaryonSL', 'StrippingCharm2PPX' ) +_selections = ( 'StrippingXic0ToXiMuNu', + 'StrippingXic0ToXiMuNu_WS', + 'StrippingDstarD02ETau', + 'StrippingCharm2PPX', + 'StrippingCharmedBaryonSL', + 'StrippingCharmedMesonSL', + 'StrippingLambdac2LambdaEtaPi', + 'StrippingNeutralCBaryons', + 'StrippingXib2Xic0PiXic02pK', + 'StrippingHc2V2H', + 'StrippingHc2V3H', + 'StrippingHc2V02H', + 'StrippingHc2V03H', + 'StrippingXic2PHH', + 'StrippingLambdac2PEta' ) for _sel in _selections : try : -- GitLab From 898afdef68f0b2d499e78d86296beca34ab25e5e Mon Sep 17 00:00:00 2001 From: Sergio Jaimes <sergio.javier.jaimes.elles@cern.ch> Date: Tue, 18 Jul 2023 17:15:49 +0200 Subject: [PATCH 10/11] Fixing problem with some newly added lines being located in the wrong directory. --- .../StrippingCharm/StrippingLambdac2PEta.py | 0 .../StrippingNeutralCBaryons.py | 70 ++- .../StrippingXib2Xic0PiXic02pK.py | 0 .../StrippingCharm/StrippingXic2PHH.py | 0 StrippingNeutralCBaryons.py | 500 ------------------ 5 files changed, 57 insertions(+), 513 deletions(-) rename StrippingLambdab2PiLambdac2PEta.py => Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingLambdac2PEta.py (100%) rename StrippingXib2Xic0PiXic02pK.py => Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXib2Xic0PiXic02pK.py (100%) rename StrippingXic2PHH.py => Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic2PHH.py (100%) delete mode 100644 StrippingNeutralCBaryons.py diff --git a/StrippingLambdab2PiLambdac2PEta.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingLambdac2PEta.py similarity index 100% rename from StrippingLambdab2PiLambdac2PEta.py rename to Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingLambdac2PEta.py diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingNeutralCBaryons.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingNeutralCBaryons.py index 65e4490b8..4424f47d8 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingNeutralCBaryons.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingNeutralCBaryons.py @@ -1,5 +1,5 @@ ############################################################################### -# (c) Copyright 2000-2019 CERN for the benefit of the LHCb Collaboration # +# (c) Copyright 2000-2023 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". # @@ -21,20 +21,27 @@ Xi_c0 -> p+ K- Omega+c0 -> Lambda KS0 Omega_c0 -> p+ K- Omega_c0 -> Labda K- pi+ + +Update on 2023/07/06 +Added following decays: +Xi_c0 -> p+ K+ K- pi- +Xi_c0 -> Lz pi+ pi- +Optimized following decays: +Xi_c0 -> p+ K- +Omega+c0 -> Lambda KS0 +Xi_c0 -> Lambda KS0 ''' -__author__ = ['Xuesong Liu, Xiao-Rui Lyu, Zhenwei Yang', 'Miroslav Saur', 'Ziyi Wang'] -__date__ = '2021/03/19' +__author__ = ['Xuesong Liu, Xiao-Rui Lyu, Zhenwei Yang', 'Miroslav Saur', 'Ziyi Wang', 'Pei-Rong Li', 'Ying-Hao Wang'] +__date__ = '2023/07/06' __version__ = '$Revision: 1.1 $' __all__ = ('StrippingNeutralCBaryonsConf' ,'default_config') -from Gaudi.Configuration import * from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles -from StandardParticles import StdLoosePions, StdNoPIDsDownPions, StdLooseKaons, StdLooseDownKaons -from StandardParticles import StdAllLoosePions, StdAllLooseKaons, StdAllLooseProtons +from StandardParticles import StdAllLoosePions, StdAllLooseKaons, StdAllLooseProtons, StdNoPIDsDownPions, StdLooseDownKaons from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection from PhysSelPython.Wrappers import MultiSelectionSequence @@ -78,8 +85,8 @@ default_config={ , 'LambdaDeltaZ_MIN' : 5.0 * mm , 'LambdaPr_PT_MIN' : 500. * MeV , 'LambdaPi_PT_MIN' : 100. * MeV - } ## end of 'CONFIG' -} ## end of default_config + }## end of 'CONFIG' +}## end of default_config #------------------------------------------------------------------------------------------------------------- class StrippingNeutralCBaryonsConf(LineBuilder) : @@ -209,7 +216,7 @@ class StrippingNeutralCBaryonsConf(LineBuilder) : Cuts = "(BPVVDZ > 0.0 * mm) " \ "& (BPVVDZ < 2300.0 * mm) " \ "& (BPVDIRA > 0.99995 ) " \ - "& (ADMASS('KS0') < 40.0 *MeV) " \ + "& (ADMASS('KS0') < 60.0 *MeV) " \ "& (BPVVDCHI2> 100)" % self.config \ ) @@ -217,8 +224,8 @@ class StrippingNeutralCBaryonsConf(LineBuilder) : InputList = self.KS0ListLooseDD , Cuts = "(BPVVDZ > -1000.0 * mm) " \ "& (BPVVDZ < 650.0 * mm) " \ - "& (BPVDIRA > 0.99997 ) " \ - "& (ADMASS('KS0') < 20.0 *MeV) " \ + "& (BPVDIRA > 0.99 ) " \ + "& (ADMASS('KS0') < 60.0 *MeV) " \ "& (BPVVDCHI2> 100)" % self.config \ ) @@ -277,6 +284,30 @@ class StrippingNeutralCBaryonsConf(LineBuilder) : Xic02LambdaKpiLine = StrippingLine( self.name + "Xic02LambdaKpiLine", algos = [ Xic02LambdaKpi ], EnableFlavourTagging = True ) self.registerLine (Xic02LambdaKpiLine) + ''' Stripping Xi_c0->Lambda0(LL) pi+ pi-''' + Xic02LambdaLLpipi = self.createCombinationSel(OutputList = "Xic02LambdaLLpipi"+ self.name, + DecayDescriptor = "[Xi_c0 -> Lambda0 pi+ pi- ]cc", + DaughterLists = [self.LambdaListLL, self.GoodLongPionsList, self.GoodLongPionsList], + DaughterCuts = {"pi+" : " (MIPCHI2DV(PRIMARY)>4)", + "pi-" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.0*mm)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02LambdaLLpipiLine = StrippingLine( self.name + "Xic02LambdaLLpipiLine", algos = [ Xic02LambdaLLpipi ], EnableFlavourTagging = True ) + self.registerLine (Xic02LambdaLLpipiLine) + + ''' Stripping Xi_c0->Lambda0(DD) pi+ pi-''' + Xic02LambdaDDpipi = self.createCombinationSel(OutputList = "Xic02LambdaDDpipi"+ self.name, + DecayDescriptor = "[Xi_c0 -> Lambda0 pi+ pi- ]cc", + DaughterLists = [self.LambdaListDD, self.GoodLongPionsList, self.GoodLongPionsList], + DaughterCuts = {"pi+" : " (MIPCHI2DV(PRIMARY)>4)", + "pi-" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.0*mm)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02LambdaDDpipiLine = StrippingLine( self.name + "Xic02LambdaDDpipiLine", algos = [ Xic02LambdaDDpipi ], EnableFlavourTagging = True ) + self.registerLine (Xic02LambdaDDpipiLine) + ''' Stripping Xi_c- -> Lambda0(DD) pi-(Long)''' Ximinus2LambdaPiDDL = self.createCombinationSel(OutputList = "Ximinus2LambdaPiDDL"+ self.name, DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", @@ -325,13 +356,26 @@ class StrippingNeutralCBaryonsConf(LineBuilder) : DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList], DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.5*mm)", PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " ) - #Xic02pKLine = StrippingLine( self.name + "Xic02pKLine", prescale = 0.5, algos = [ Xic02pK ], EnableFlavourTagging = True ) Xic02pKLine = StrippingLine( self.name + "Xic02pKLine", algos = [ Xic02pK ], EnableFlavourTagging = True ) self.registerLine (Xic02pKLine) + ''' Stripping Xi_c0 -> p+ K+ K- pi-''' + Xic02pKKpi = self.createCombinationSel(OutputList = "Xic02pKKpi"+ self.name, + DecayDescriptor = "[Xi_c0 -> p+ K+ K- pi-]cc", + DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList, self.GoodTightKaonsList, self.GoodLongPionsList], + DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", + "K+" : " (MIPCHI2DV(PRIMARY)>4)", + "pi-" : " (MIPCHI2DV(PRIMARY)>4)", + "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, + PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", + PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " + ) + Xic02pKKpiLine = StrippingLine( self.name + "Xic02pKKpiLine", algos = [ Xic02pKKpi ], EnableFlavourTagging = True ) + self.registerLine (Xic02pKKpiLine) + ''' Stripping Xi_c0->Xi- pi+''' Xic02Xipi = self.createCombinationSel(OutputList = "Xic02Xipi"+ self.name, DecayDescriptor = "[Xi_c0 -> Xi- pi+]cc", diff --git a/StrippingXib2Xic0PiXic02pK.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXib2Xic0PiXic02pK.py similarity index 100% rename from StrippingXib2Xic0PiXic02pK.py rename to Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXib2Xic0PiXic02pK.py diff --git a/StrippingXic2PHH.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic2PHH.py similarity index 100% rename from StrippingXic2PHH.py rename to Phys/StrippingSelections/python/StrippingSelections/StrippingCharm/StrippingXic2PHH.py diff --git a/StrippingNeutralCBaryons.py b/StrippingNeutralCBaryons.py deleted file mode 100644 index 4424f47d8..000000000 --- a/StrippingNeutralCBaryons.py +++ /dev/null @@ -1,500 +0,0 @@ -############################################################################### -# (c) Copyright 2000-2023 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. # -############################################################################### -''' -1)Xi_c0->Lz Ks -2)Xi_c0->Lz K- pi+ -3)Xi_c0->Xi- pi+, Xi->Lz pi-, Lz->p pi -4)Xi_c0->Xi- K+, Xi->Lz pi-, Lz->p pi -5)Omega_c0 ->Omega- pi+, Omega-> Lz K- - -Update on 2021/02/08 -Added following decays: -Xi_c0 -> p+ K- -Omega+c0 -> Lambda KS0 -Omega_c0 -> p+ K- -Omega_c0 -> Labda K- pi+ - -Update on 2023/07/06 -Added following decays: -Xi_c0 -> p+ K+ K- pi- -Xi_c0 -> Lz pi+ pi- -Optimized following decays: -Xi_c0 -> p+ K- -Omega+c0 -> Lambda KS0 -Xi_c0 -> Lambda KS0 -''' - - -__author__ = ['Xuesong Liu, Xiao-Rui Lyu, Zhenwei Yang', 'Miroslav Saur', 'Ziyi Wang', 'Pei-Rong Li', 'Ying-Hao Wang'] -__date__ = '2023/07/06' -__version__ = '$Revision: 1.1 $' -__all__ = ('StrippingNeutralCBaryonsConf' - ,'default_config') - - -from GaudiConfUtils.ConfigurableGenerators import FilterDesktop, CombineParticles -from StandardParticles import StdAllLoosePions, StdAllLooseKaons, StdAllLooseProtons, StdNoPIDsDownPions, StdLooseDownKaons - -from PhysSelPython.Wrappers import Selection, DataOnDemand, MergedSelection -from PhysSelPython.Wrappers import MultiSelectionSequence -from StrippingConf.StrippingLine import StrippingLine -from StrippingUtils.Utils import LineBuilder -from GaudiKernel.SystemOfUnits import MeV, mm, picosecond - - -default_name='NeutralCBaryons' - #### This is the dictionary of all tunable cuts ######## -default_config={ - 'NAME' : 'NeutralCBaryons', - 'WGs' : ['Charm'], - 'BUILDERTYPE' : 'StrippingNeutralCBaryonsConf', - 'STREAMS' : ['Charm'], - 'CONFIG' : { - 'TRCHI2DOFMax' : 3.0 - , 'PionPIDK' : 10.0 - , 'KaonPIDK' : -5.0 - , 'ProtonPIDp' : 5 #to be studied - , 'ProtonPIDpK' : -3 - , 'tight_ProtonPIDp' : 7 #to be studied - , 'tight_ProtonPIDppi' : 5.0 - , 'tight_ProtonPIDpK' : 0.0 - , 'tight_KaonPIDpi' : 5.0 - , 'tight_KaonPIDK' : 0.0 - , 'LambdaLLMinDecayTime' : 5.0 * picosecond - , 'LambdaLLVtxChi2Max' : 5.0 - , 'LambdaDDVtxChi2Max' : 5.0 - , 'LambdaLLMassWin' : 5.7 * MeV - , 'LambdaDDMassWin' : 5.7 * MeV - , 'LambdaLLMinVZ' : -100. * mm - , 'LambdaLLMaxVZ' : 400. * mm - , 'LambdaDDMinVZ' : 400. * mm - , 'LambdaDDMaxVZ' : 2275. * mm - , 'TrGhostProbMax' : 0.25 - , 'ProbNNkMin' : 0.10 - , 'ProbNNpMinLL' : 0.10 - , 'ProbNNpMinDD' : 0.05 - , 'Bachelor_PT_MIN' : 50 * MeV - , 'LambdaDeltaZ_MIN' : 5.0 * mm - , 'LambdaPr_PT_MIN' : 500. * MeV - , 'LambdaPi_PT_MIN' : 100. * MeV - }## end of 'CONFIG' -}## end of default_config - -#------------------------------------------------------------------------------------------------------------- -class StrippingNeutralCBaryonsConf(LineBuilder) : - __configuration_keys__ = default_config['CONFIG'].keys() - - def __init__(self, name, config) : - LineBuilder.__init__(self, name, config) - self.name = name - self.config = config - - # take all long tracks - Long Protons - self.LongProtonsList = MergedSelection("LongProtonsFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLooseProtons/Particles")]) - - # take all long tracks - Long Pions - self.LongPionsList = MergedSelection("LongPionsFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLoosePions/Particles")]) - - # take all long tracks - Long Kaons - self.LongKaonsList = MergedSelection("LongKaonsFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdAllLooseKaons/Particles")]) - - # take all long tracks - Down Pions - self.DownstreamPionsList = MergedSelection("DownstreamPionsFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdNoPIDsDownPions/Particles")]) - - # take all long tracks = Down Kaons - self.DownstreamKaonsList = MergedSelection("DownstreamKaonsFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseDownKaons/Particles")]) - - # Good tracks - Long Protons - self.GoodLongProtonsList = self.createSubSel( OutputList = "GoodLongProtonsFor" + self.name, - InputList = self.LongProtonsList, - Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ - " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ - " & (PIDp > %(ProtonPIDp)s) "\ - " & ((PIDp-PIDK)> %(ProtonPIDpK)s) " % self.config ) - - # Good tracks - Tight Protons - self.GoodTightProtonsList = self.createSubSel( OutputList = "GoodTightProtonsFor" + self.name, - InputList = self.LongProtonsList, - Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ - " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ - " & (PIDp > %(tight_ProtonPIDp)s) "\ - " & ((PIDp-PIDpi) > %(tight_ProtonPIDppi)s) "\ - " & ((PIDp-PIDK) > %(tight_ProtonPIDpK)s) " % self.config ) - # Good tracks - Long Pions - self.GoodLongPionsList = self.createSubSel( OutputList = "GoodLongPionsFor" + self.name, - InputList = self.LongPionsList, - Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ - " & (TRGHOSTPROB <%(TrGhostProbMax)s )" \ - " & (PIDK < %(PionPIDK)s )" % self.config ) - - # Good tracks - Long Kaons - self.GoodLongKaonsList = self.createSubSel( OutputList = "GoodLongKaonsFor" + self.name, - InputList = self.LongKaonsList, - Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ - " & (TRGHOSTPROB < %(TrGhostProbMax)s )" \ - " & (PROBNNk > %(ProbNNkMin)s )" \ - " & (PIDK > %(KaonPIDK)s )" % self.config ) - - # Good tracks - Tight Kaons - self.GoodTightKaonsList = self.createSubSel( OutputList = "GoodTightKaonsFor" + self.name, - InputList = self.LongKaonsList, - Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ - " & (TRGHOSTPROB < %(TrGhostProbMax)s )" \ - " & (PROBNNk > %(ProbNNkMin)s )" \ - " & ((PIDK-PIDpi)>%(tight_KaonPIDpi)s)"\ - " & (PIDK > %(tight_KaonPIDK)s )" % self.config ) - - # Good tracks - Down Pions - self.GoodDownstreamPionsList = self.createSubSel( OutputList = "GoodDownstreamPionsFor" + self.name, - InputList = self.DownstreamPionsList, - Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ - " & (PIDK < %(PionPIDK)s )" % self.config ) - - # Good tracks - Down Kaons - self.GoodDownstreamKaonsList = self.createSubSel( OutputList = "GoodDownstreamKaonsFor" + self.name, - InputList = self.DownstreamKaonsList, - Cuts = "(TRCHI2DOF < %(TRCHI2DOFMax)s )"\ - " & (PROBNNk > %(ProbNNkMin)s )" \ - " & (PIDK > %(KaonPIDK)s )" % self.config ) - - self.LambdaListLooseDD = MergedSelection("StdLooseDDLambdaFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaDD/Particles")]) - - self.LambdaListLooseLL = MergedSelection("StdLooseLLLambdaFor" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseLambdaLL/Particles")]) - - self.LambdaListLL = self.createSubSel(OutputList = "LambdaLLFor" + self.name, - InputList = self.LambdaListLooseLL , - Cuts = "(MAXTREE('p+'==ABSID, PT) > %(LambdaPr_PT_MIN)s ) "\ - "& (MAXTREE('pi-'==ABSID, PT) > %(LambdaPi_PT_MIN)s ) " \ - "& (MAXTREE('p+'==ABSID,PROBNNp) > %(ProbNNpMinLL)s ) "\ - "& (MINTREE('pi-'==ABSID, TRGHOSTPROB) < %(TrGhostProbMax)s )"\ - "& (MINTREE('p+'==ABSID, TRGHOSTPROB) < %(TrGhostProbMax)s )"\ - "& (ADMASS('Lambda0') < %(LambdaLLMassWin)s ) " - "& (VFASPF(VCHI2/VDOF) < %(LambdaLLVtxChi2Max)s ) "\ - "& (VFASPF(VZ) > %(LambdaLLMinVZ)s ) " \ - "& (VFASPF(VZ) < %(LambdaLLMaxVZ)s ) " \ - "& (BPVLTIME() > %(LambdaLLMinDecayTime)s )" % self.config \ - ) - - self.LambdaListDD = self.createSubSel(OutputList = "LambdaDDFor" + self.name, - InputList = self.LambdaListLooseDD , - Cuts = "(MAXTREE('p+'==ABSID, PT) > %(LambdaPr_PT_MIN)s ) "\ - "& (MAXTREE('pi-'==ABSID, PT) > %(LambdaPi_PT_MIN)s ) " \ - "& (MAXTREE('p+'==ABSID, PROBNNp) > %(ProbNNpMinDD)s ) "\ - "& (ADMASS('Lambda0') < %(LambdaDDMassWin)s ) " \ - "& (VFASPF(VCHI2/VDOF) < %(LambdaDDVtxChi2Max)s ) "\ - "& (VFASPF(VZ) < %(LambdaDDMaxVZ)s ) " \ - "& (VFASPF(VZ) > %(LambdaDDMinVZ)s )" % self.config \ - ) - - self.LambdaList = MergedSelection("LambdaFor" + self.name, - RequiredSelections = [self.LambdaListLL, self.LambdaListDD] - ) - - self.KS0ListLooseDD = MergedSelection("StdLooseDDKS0For" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseKsDD/Particles")]) - - self.KS0ListLooseLL = MergedSelection("StdLooseLLKS0For" + self.name, - RequiredSelections = [DataOnDemand(Location = "Phys/StdLooseKsLL/Particles")]) - - self.KS0ListLL = self.createSubSel(OutputList = "KS0LLFor" + self.name, - InputList = self.KS0ListLooseLL , - Cuts = "(BPVVDZ > 0.0 * mm) " \ - "& (BPVVDZ < 2300.0 * mm) " \ - "& (BPVDIRA > 0.99995 ) " \ - "& (ADMASS('KS0') < 60.0 *MeV) " \ - "& (BPVVDCHI2> 100)" % self.config \ - ) - - self.KS0ListDD = self.createSubSel(OutputList = "KS0DDFor" + self.name, - InputList = self.KS0ListLooseDD , - Cuts = "(BPVVDZ > -1000.0 * mm) " \ - "& (BPVVDZ < 650.0 * mm) " \ - "& (BPVDIRA > 0.99 ) " \ - "& (ADMASS('KS0') < 60.0 *MeV) " \ - "& (BPVVDCHI2> 100)" % self.config \ - ) - - self.KS0List = MergedSelection("KS0For" + self.name, - RequiredSelections = [self.KS0ListLL, self.KS0ListDD]) - - self.Xic0List = self.makeXic0() - self.Omegac0List = self.makeOmegac0() - - #------------------------------------------------------------------------------------------ - #------------------------------------------------------------------------------------------ - - def createSubSel( self, OutputList, InputList, Cuts ) : - '''create a selection using a FilterDesktop''' - filter = FilterDesktop(Code = Cuts) - return Selection( OutputList, - Algorithm = filter, - RequiredSelections = [ InputList ] ) - - def createCombinationSel( self, OutputList, - DecayDescriptor, - DaughterLists, - DaughterCuts = {} , - PreVertexCuts = "ALL", - PostVertexCuts = "ALL" ) : - '''create a selection using a ParticleCombiner with a single decay descriptor''' - combiner = CombineParticles( DecayDescriptor = DecayDescriptor, - DaughtersCuts = DaughterCuts, - MotherCut = PostVertexCuts, - CombinationCut = PreVertexCuts, - ReFitPVs = True) - return Selection ( OutputList, - Algorithm = combiner, - RequiredSelections = DaughterLists) - - def makeXic0( self ): - ''' Stripping Xi_c0->Lambda0 KS0''' - Xic02LambdaKS0 = self.createCombinationSel(OutputList = "Xic02LambdaKS0"+ self.name, - DecayDescriptor = "[Xi_c0 -> Lambda0 KS0 ]cc", - DaughterLists = [self.LambdaList, self.KS0List], - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Xic02LambdaKS0Line = StrippingLine( self.name + "Xic02LambdaKS0Line", algos = [ Xic02LambdaKS0 ], EnableFlavourTagging = True ) - self.registerLine (Xic02LambdaKS0Line) - - ''' Stripping Xi_c0->Lambda0 K- pi+''' - Xic02LambdaKpi = self.createCombinationSel(OutputList = "Xic02LambdaKpi"+ self.name, - DecayDescriptor = "[Xi_c0 -> Lambda0 K- pi+ ]cc", - DaughterLists = [self.LambdaList, self.GoodLongKaonsList, self.GoodLongPionsList], - DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", - "pi+" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Xic02LambdaKpiLine = StrippingLine( self.name + "Xic02LambdaKpiLine", algos = [ Xic02LambdaKpi ], EnableFlavourTagging = True ) - self.registerLine (Xic02LambdaKpiLine) - - ''' Stripping Xi_c0->Lambda0(LL) pi+ pi-''' - Xic02LambdaLLpipi = self.createCombinationSel(OutputList = "Xic02LambdaLLpipi"+ self.name, - DecayDescriptor = "[Xi_c0 -> Lambda0 pi+ pi- ]cc", - DaughterLists = [self.LambdaListLL, self.GoodLongPionsList, self.GoodLongPionsList], - DaughterCuts = {"pi+" : " (MIPCHI2DV(PRIMARY)>4)", - "pi-" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.0*mm)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Xic02LambdaLLpipiLine = StrippingLine( self.name + "Xic02LambdaLLpipiLine", algos = [ Xic02LambdaLLpipi ], EnableFlavourTagging = True ) - self.registerLine (Xic02LambdaLLpipiLine) - - ''' Stripping Xi_c0->Lambda0(DD) pi+ pi-''' - Xic02LambdaDDpipi = self.createCombinationSel(OutputList = "Xic02LambdaDDpipi"+ self.name, - DecayDescriptor = "[Xi_c0 -> Lambda0 pi+ pi- ]cc", - DaughterLists = [self.LambdaListDD, self.GoodLongPionsList, self.GoodLongPionsList], - DaughterCuts = {"pi+" : " (MIPCHI2DV(PRIMARY)>4)", - "pi-" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.0*mm)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Xic02LambdaDDpipiLine = StrippingLine( self.name + "Xic02LambdaDDpipiLine", algos = [ Xic02LambdaDDpipi ], EnableFlavourTagging = True ) - self.registerLine (Xic02LambdaDDpipiLine) - - ''' Stripping Xi_c- -> Lambda0(DD) pi-(Long)''' - Ximinus2LambdaPiDDL = self.createCombinationSel(OutputList = "Ximinus2LambdaPiDDL"+ self.name, - DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", - DaughterLists = [self.GoodLongPionsList, self.LambdaListDD], - DaughterCuts = {"pi-" : "(MIPCHI2DV(PRIMARY)>4) "}, - PreVertexCuts = "(ADAMASS('Xi-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", - PostVertexCuts = "(ADMASS('Xi-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" - ) - - ''' Stripping Xi_c- -> Lambda0(LL) pi-(Long)''' - Ximinus2LambdaPiLLL = self.createCombinationSel(OutputList = "Ximinus2LambdaPiLLL"+ self.name, - DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", - DaughterLists = [self.GoodLongPionsList, self.LambdaListLL], - DaughterCuts = {"pi-" : "(MIPCHI2DV(PRIMARY)>9)"}, - PreVertexCuts = "(ADAMASS('Xi-') < 50*MeV) & (ADOCACHI2CUT(30, ''))", - PostVertexCuts = "(ADMASS('Xi-')<35*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" - ) - - ''' Stripping Xi_c- -> Lambda0(DD) pi-(Down)''' - Ximinus2LambdaPiDDD = self.createCombinationSel(OutputList = "Ximinus2LambdaPiDDD"+ self.name, - DecayDescriptor = "[Xi- -> Lambda0 pi-]cc", - DaughterLists = [self.GoodDownstreamPionsList, self.LambdaListDD], - DaughterCuts = {"pi-" : "(MIPCHI2DV(PRIMARY)>4) "}, - PreVertexCuts = "(ADAMASS('Xi-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", - PostVertexCuts = "(ADMASS('Xi-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" - ) - - ## Ximinus2LambdaPi is a "Selection" object; MergedSelection passes everything which gets to it - ## even when the output list is empty - Ximinus2LambdaPi = MergedSelection("Ximinus2LambdaPi"+self.name, - RequiredSelections = [Ximinus2LambdaPiLLL,Ximinus2LambdaPiDDL,Ximinus2LambdaPiDDD] ) - - ## NullFilter is a "FilterDesktop" object which is a type of "Algorithm" - ## This one will pass all candidates - NullFilter= FilterDesktop(Code = "ALL") - ## Ximinus2Lambda2PiSelection is *also* a Selection, but it is "more selective" - ## than Ximinus2LambdaPi in the sense that it passes only events when something - ## is in the output list - Ximinus2LambdaPiSelection = Selection( "Ximinus2LambdaPiSelection"+self.name, - Algorithm = NullFilter, - RequiredSelections = [Ximinus2LambdaPi]) - - ''' Stripping Xi_c0 -> p+ K-''' - Xic02pK = self.createCombinationSel(OutputList = "Xic02pK"+ self.name, - DecayDescriptor = "[Xi_c0 -> p+ K-]cc", - DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList], - DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", - "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV) & (ADOCACHI2CUT(30, '')) & (ADOCAMAX('')<2.5*mm)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Xic02pKLine = StrippingLine( self.name + "Xic02pKLine", algos = [ Xic02pK ], EnableFlavourTagging = True ) - self.registerLine (Xic02pKLine) - - ''' Stripping Xi_c0 -> p+ K+ K- pi-''' - Xic02pKKpi = self.createCombinationSel(OutputList = "Xic02pKKpi"+ self.name, - DecayDescriptor = "[Xi_c0 -> p+ K+ K- pi-]cc", - DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList, self.GoodTightKaonsList, self.GoodLongPionsList], - DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", - "K+" : " (MIPCHI2DV(PRIMARY)>4)", - "pi-" : " (MIPCHI2DV(PRIMARY)>4)", - "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Xic02pKKpiLine = StrippingLine( self.name + "Xic02pKKpiLine", algos = [ Xic02pKKpi ], EnableFlavourTagging = True ) - self.registerLine (Xic02pKKpiLine) - - ''' Stripping Xi_c0->Xi- pi+''' - Xic02Xipi = self.createCombinationSel(OutputList = "Xic02Xipi"+ self.name, - DecayDescriptor = "[Xi_c0 -> Xi- pi+]cc", - DaughterLists = [self.GoodLongPionsList, Ximinus2LambdaPiSelection], - DaughterCuts = {"pi+" : "(PT> %(Bachelor_PT_MIN)s ) "% self.config}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - - Xic02XipiLine = StrippingLine( self.name + "Xic02XipiLine", algos = [ Xic02Xipi ], EnableFlavourTagging = True ) - self.registerLine (Xic02XipiLine) - - ''' Stripping Xi_c0->Xi- K+''' - Xic02XiK = self.createCombinationSel(OutputList = "Xic02XiK"+ self.name, - DecayDescriptor = "[Xi_c0 -> Xi- K+]cc", - DaughterLists = [self.GoodLongKaonsList, Ximinus2LambdaPiSelection], - DaughterCuts = {"K+" : "(PT> %(Bachelor_PT_MIN)s ) "% self.config}, - PreVertexCuts = "(ADAMASS('Xi_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Xi_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - - Xic02XiKLine = StrippingLine( self.name + "Xic02XiKLine", algos = [ Xic02XiK ], EnableFlavourTagging = True ) - self.registerLine (Xic02XiKLine) - - ## -------------------- end of makeXiminus ------------ - #------------------------------------------------------------------------------------------ - - def makeOmegac0( self ): - - ''' Make an Omega minus candidate ''' - Omegaminus2LambdaKLLL = self.createCombinationSel(OutputList = "Omegaminus2LambdaKLLL"+ self.name, - DecayDescriptor = "[Omega- -> Lambda0 K-]cc", - DaughterLists = [self.GoodLongKaonsList, self.LambdaListLL], - DaughterCuts = {"K-" : "(MIPCHI2DV(PRIMARY)>9) "}, - PreVertexCuts = "(ADAMASS('Omega-') < 50*MeV) & (ADOCACHI2CUT(30, ''))", - PostVertexCuts = "(ADMASS('Omega-')<35*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" - ) - - ''' Make an Omega minus candidate ''' - Omegaminus2LambdaKDDL = self.createCombinationSel(OutputList = "Omegaminus2LambdaKDDL"+ self.name, - DecayDescriptor = "[Omega- -> Lambda0 K-]cc", - DaughterLists = [self.GoodLongKaonsList, self.LambdaListDD], - DaughterCuts = {"K-" : "(MIPCHI2DV(PRIMARY)>4) "}, - PreVertexCuts = "(ADAMASS('Omega-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", - PostVertexCuts = "(ADMASS('Omega-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" - ) - - ''' Make an Omega minus candidate ''' - Omegaminus2LambdaKDDD = self.createCombinationSel(OutputList = "Omegaminus2LambdaKDDD"+ self.name, - DecayDescriptor = "[Omega- -> Lambda0 K-]cc", - DaughterLists = [self.GoodDownstreamKaonsList, self.LambdaListDD], - DaughterCuts = {"K-" : "(MIPCHI2DV(PRIMARY)>4) "}, - PreVertexCuts = "(ADAMASS('Omega-') < 80*MeV) & (ADOCACHI2CUT(30, ''))", - PostVertexCuts = "(ADMASS('Omega-')<64*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" - ) - - - ## Omegaminus2LambdaK is a "Selection" object; MergedSelection passes everything which gets to it - ## even when the output list is empty - Omegaminus2LambdaK = MergedSelection("Omegaminus2LambdaK"+self.name, - RequiredSelections = [Omegaminus2LambdaKLLL,Omegaminus2LambdaKDDL,Omegaminus2LambdaKDDD] ) - - ## NullFilter is a "FilterDesktop" object which is a type of "Algorithm" - ## This one will pass all candidates - NullFilter= FilterDesktop(Code = "ALL") - ## Omegaminus2Lambda2PiSelection is *also* a Selection, but it is "more selective" - ## than Omegaminus2LambdaK in the sense that it passes only events when something - ## is in the output list - Omegaminus2LambdaKSelection = Selection( "Omegaminus2LambdaKSelection"+self.name, - Algorithm = NullFilter, - RequiredSelections = [Omegaminus2LambdaK]) - - ''' Stripping Omega_c0->Omega- pi+''' - Omegac02Omegapi = self.createCombinationSel(OutputList = "Omegac02Omegapi"+ self.name, - DecayDescriptor = "[Omega_c0 -> Omega- pi+]cc", - DaughterLists = [self.GoodLongPionsList, Omegaminus2LambdaKSelection], - DaughterCuts = {"pi+" : "(PT> %(Bachelor_PT_MIN)s ) "% self.config}, - PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", - PostVertexCuts = "(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) & (ADMASS('Omega_c0') < 90 *MeV)" - ) - - Omegac02OmegapiLine = StrippingLine( self.name + "Omegac02OmegapiLine", algos = [ Omegac02Omegapi ], EnableFlavourTagging = True ) - self.registerLine (Omegac02OmegapiLine) - - ''' Stripping Omega_c0-> p+- K-''' - Omegac02pK = self.createCombinationSel(OutputList = "Omegac02pK"+ self.name, - DecayDescriptor = "[Omega_c0 -> p+ K-]cc", - DaughterLists = [self.GoodTightProtonsList, self.GoodTightKaonsList], - DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", - "p+" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Omega_c0')<35*MeV) & (VFASPF(VCHI2)<25) & (P> 2000*MeV) &(PT > 250*MeV) & (BPVVDCHI2 > 49.0 ) & (VFASPF(VCHI2/VDOF) < 12.0)" - ) - - Omegac02pKLine = StrippingLine( self.name + "Omegac02pKLine", algos = [ Omegac02pK ], EnableFlavourTagging = True ) - self.registerLine (Omegac02pKLine) - - - ## Code for Omega_c0 -> Lambda0 KS0; four relevant track classes: LL, LD, DL, DD - those are based on LambdaList and KS0List - Omegac02LambdaKS0 = self.createCombinationSel(OutputList = "Omegac02LambdaKS0"+ self.name, - DecayDescriptor = "[Omega_c0 -> Lambda0 KS0 ]cc", - DaughterLists = [self.LambdaList, self.KS0List], - PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Omega_c0') < 90 *MeV) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Omegac02LambdaKS0Line = StrippingLine( self.name + "Omegac02LambdaKS0Line", algos = [ Omegac02LambdaKS0 ], EnableFlavourTagging = True ) - self.registerLine (Omegac02LambdaKS0Line) - - - ## Code for Omega_c0 -> Lambda0 K- pi+, two relevant track classed: LL, DD - Omegac02LambdaKpi = self.createCombinationSel(OutputList = "Omegac02LambdaKpi"+ self.name, - DecayDescriptor = "[Omega_c0 -> Lambda0 K- pi+ ]cc", - DaughterLists = [self.LambdaList, self.GoodLongKaonsList, self.GoodLongPionsList], - DaughterCuts = {"K-" : " (MIPCHI2DV(PRIMARY)>4)", - "pi+" : " (MIPCHI2DV(PRIMARY)>4)"}, - PreVertexCuts = "(ADAMASS('Omega_c0') < 120 *MeV)", - PostVertexCuts = "(ADMASS('Omega_c0') < 90 *MeV) &(VFASPF(VCHI2/VDOF)< 12.) & (BPVVDCHI2 > 16.0) & (BPVDIRA >0.999) " - ) - Omegac02LambdaKpiLine = StrippingLine( self.name + "Omegac02LambdaKpiLine", algos = [ Omegac02LambdaKpi ], EnableFlavourTagging = True ) - self.registerLine (Omegac02LambdaKpiLine) - ## -------------------- end of makeOmegaminus ------------ - #------------------------------------------------------------------------------------------ -- GitLab From 03b5f8a6562b42da739f0804723ba3de30f84ce4 Mon Sep 17 00:00:00 2001 From: Sergio Jaimes <sergio.jaimes@cern.ch> Date: Mon, 24 Jul 2023 13:56:30 +0200 Subject: [PATCH 11/11] Charm lineConfigDictionaries --- .../LineConfigDictionaries_Charm.py | 934 +++++++++++++++++ .../LineConfigDictionaries_Charm.py | 934 +++++++++++++++++ .../LineConfigDictionaries_Charm.py | 936 +++++++++++++++++- 3 files changed, 2803 insertions(+), 1 deletion(-) diff --git a/Phys/StrippingSettings/python/StrippingSettings/Stripping28r2p2/LineConfigDictionaries_Charm.py b/Phys/StrippingSettings/python/StrippingSettings/Stripping28r2p2/LineConfigDictionaries_Charm.py index 759f4f0eb..3c77505f5 100644 --- a/Phys/StrippingSettings/python/StrippingSettings/Stripping28r2p2/LineConfigDictionaries_Charm.py +++ b/Phys/StrippingSettings/python/StrippingSettings/Stripping28r2p2/LineConfigDictionaries_Charm.py @@ -16,3 +16,937 @@ ## Contact person: Sergio Jaimes (sergio.jaimes@cern.ch) ## ################################################################################ +Charm2PPX = { + "BUILDERTYPE": "StrippingCharm2PPXConf", + "CONFIG": { + "Comb_ADOCACHI2_MAX": 16, + "Daug_1ofAll_BPVIPCHI2_MIN": 9.0, + "Daug_1ofAll_PT_MIN": 700.0, + "Daug_All_BPVIPCHI2_MIN": 4.0, + "Daug_All_CloneDist_MIN": 5000, + "Daug_All_MIPCHI2_MIN": 4.0, + "Daug_All_PT_MIN": 200.0, + "Daug_All_TrChostProb_MAX": 0.5, + "Daug_ETA_MAX": 4.9, + "Daug_ETA_MIN": 2.0, + "Daug_P_MAX": 100000.0, + "Daug_P_MIN": 3200.0, + "Hc_BPVCTAU_MIN": 0.05, + "Hc_BPVVDCHI2_MIN": 9.0, + "Hc_MASS_MAX": 3500.0, + "Hc_PT_MIN": 1000.0, + "Hc_VCHI2VDOF_MAX": 25.0, + "Hcs_MASS_MAX": 3650.0, + "Hlt1Filter": None, + "Hlt2Filter": None, + "HsComb_ADOCACHI2_MAX": 16, + "HsDaug_1ofAll_BPVIPCHI2_MIN": 9.0, + "HsDaug_1ofAll_PT_MIN": -500.0, + "HsDownDaug_1ofAll_BPVIPCHI2_MIN": -9.0, + "HsDown_BPVVDCHI2_MIN": 4.0, + "HsProton_1ofAll_ProbNN_MIN": 0.5, + "Hs_BPVCTAU_MIN": 0.1, + "Hs_BPVVDCHI2_MIN": 9.0, + "Hs_MASS_MAX": 2125.0, + "Hs_PT_MIN": -1000.0, + "Hs_VCHI2VDOF_MAX": 25.0, + "Kaon_ProbNN_MIN": 0.1, + "Lam_MASS_MAX": 1170.0, + "Lc_MASS_MAX": 2350.0, + "Pc_MASS_MAX": 3100.0, + "Pion_ProbNN_MIN": 0.1, + "PostscaleHc2LamPPi": 1.0, + "PostscaleHc2LamPPiPi": 1.0, + "PostscaleHc2PP": 1.0, + "PostscaleHc2PPK": 1.0, + "PostscaleHc2PPKPi": 1.0, + "PostscaleHc2PPKPiPi": 1.0, + "PostscaleHc2PPKs": 1.0, + "PostscaleHc2PPKsPi": 1.0, + "PostscaleHcs2LamLamPi": 1.0, + "PostscaleHcs2LamPKPi": 1.0, + "PostscaleHcs2PPKKPi": 1.0, + "PostscaleHcs2PPKsK": 1.0, + "PostscaleHs2PPPi": 1.0, + "PostscaleL2PPi": 1.0, + "PostscaleLc2PKPi": 1.0, + "PostscalePc2PKPiPi": 1.0, + "PostscalePc2PKsPi": 1.0, + "PostscalePs2PPiPi": 1.0, + "PrescaleHc2LamPPi": 1.0, + "PrescaleHc2LamPPiPi": 1.0, + "PrescaleHc2PP": 1.0, + "PrescaleHc2PPK": 1.0, + "PrescaleHc2PPKPi": 1.0, + "PrescaleHc2PPKPiPi": 1.0, + "PrescaleHc2PPKs": 1.0, + "PrescaleHc2PPKsPi": 1.0, + "PrescaleHcs2LamLamPi": 1.0, + "PrescaleHcs2LamPKPi": 1.0, + "PrescaleHcs2PPKKPi": 1.0, + "PrescaleHcs2PPKsK": 1.0, + "PrescaleHs2PPPi": 1.0, + "PrescaleL2PPi": 0.01, + "PrescaleLc2PKPi": 0.01, + "PrescalePc2PKPiPi": 0.1, + "PrescalePc2PKsPi": 0.1, + "PrescalePs2PPiPi": 0.1, + "Proton_1ofAll_ProbNN_MIN": 0.5, + "Proton_PT_MIN": 300.0, + "Proton_P_MIN": 10000.0, + "Proton_ProbNN_MIN": 0.1, + "Proton_ProbNNk_MAX": 0.8, + "Proton_ProbNNpi_MAX": 0.55, + "Ps_MASS_MAX": 1650.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +CharmedBaryonSL = { + "BUILDERTYPE": "StrippingCharmedBaryonSL", + "CONFIG": { + "GEC_nLongTrk": 250, + "GhostProb": 0.3, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 500.0, + "KaonPT_ForOm": 100.0, + "KaonP_ForOm": 2000.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "L0Mu_AM_Min": 1250.0, + "LambdaCutDIRA": 0.99, + "LambdaDDCutFDChi2": 100.0, + "LambdaDDCutMass": 20.0, + "LambdaDDMaxVZ": 2275.0, + "LambdaDDMinVZ": 400.0, + "LambdaDDPMin": 5000.0, + "LambdaDDPTMin": 800.0, + "LambdaDaugTrackChi2": 4.0, + "LambdaLDCutFDChi2": 100.0, + "LambdaLDCutMass": 20.0, + "LambdaLDPMin": 3000.0, + "LambdaLDPTMin": 800.0, + "LambdaLLCutFDChi2": 100.0, + "LambdaLLCutMass": 20.0, + "LambdaLLMaxVZ": 400.0, + "LambdaLLMinVZ": -100.0, + "LambdaLLPMin": 5000.0, + "LambdaLLPTMin": 800.0, + "LambdaPi_PT_MIN": 100.0, + "LambdaPr_PT_MIN": 500.0, + "LambdaVertexChi2": 5.0, + "Lc_ADMASS_HalfWin": 80.0, + "Lc_ADMASS_HalfWin_Tight": 55.0, + "Lc_ADOCAMAX_Max": 0.5, + "Lc_ADOCAMAX_Max_Tight": 0.15, + "Lc_AM_Max": 2370.0, + "Lc_APT_Min": 1000.0, + "Lc_APT_Min_Tight_PKMu": 1600.0, + "Lc_APT_Min_Tight_PPiMu": 1600.0, + "Lc_AP_Min_Tight": 25000.0, + "Lc_BPVDIRA_Min": 0.9, + "Lc_BPVDIRA_Min_Tight": 0.99, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDCHI2_Min_Tight": 25.0, + "Lc_Daug_1of3_MIPCHI2DV_Min": 4.0, + "Lc_Daug_1of3_MIPCHI2DV_Min_Tight": 9.0, + "Lc_VCHI2_Max": 30.0, + "Lc_VCHI2_Max_Tight": 20.0, + "MINIPCHI2": 4.0, + "MisID_PROB_Max": 0.7, + "MuonIPCHI2": 5.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 500.0, + "Oc_AM_Max": 2780.0, + "OmMu_AM_Min": 1780.0, + "Omegac0_4Dau_VCHI2_Max": 60.0, + "Omegac0_ADAMASS_HalfWin": 170.0, + "Omegac0_ADMASS_HalfWin": 120.0, + "Omegac0_BPVDIRA_Min": 0.9, + "Omegac0_BPVVDCHI2_Min": 25.0, + "P_Min_Tight": 3500.0, + "PionP": 3000.0, + "PionPIDK": 10.0, + "PionPT": 500.0, + "PionPT_ForXi": 100.0, + "PionP_ForXi": 2000.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.95, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "XiMu_AM_Min": 1430.0, + "Xic_ADAMASS_HalfWin": 170.0, + "Xic_ADMASS_HalfWin": 120.0, + "Xic_AM_Max": 2550.0, + "Xic_BPVDIRA_Min": 0.9, + "Xic_BPVVDCHI2_Min": 25.0, + "controlPrescaleViaLcL0DDPiNC": 0.8, + "controlPrescaleViaLcL0LLPiNC": 0.4, + "controlPrescaleViaLcPKPiNC": 0.09, + "controlPrescaleViaLcPKPiNC_Tight": 0.5, + "controlPrescaleViaLcPPiPiNC": 0.06, + "controlPrescaleViaLcPPiPiNC_Tight": 0.5, + "controlPrescaleViaOmegac0NC": 1.0, + "controlPrescaleViaXicL0DDPiNC": 0.8, + "controlPrescaleViaXicL0LLPiNC": 0.4, + "controlPrescaleViaXicXiPiNC": 1.0, + "pKMu_AM_Min": 1550.0, + "ppiMu_AM_Min": 1200.0, + "signalPrescaleViaLc": 1.0, + "signalPrescaleViaLcL0DDMuNu": 0.8, + "signalPrescaleViaLcPKMuNu_Tight": 1.0, + "signalPrescaleViaLcPPiMuNu": 0.25, + "signalPrescaleViaLcPPiMuNu_Tight": 1.0, + "signalPrescaleViaOmegac0": 1.0, + "signalPrescaleViaXic": 1.0, + "signalPrescaleViaXicL0DDMuNu": 0.8, + "signalPrescaleViaXicL0LLMuNu": 0.8 + }, + "STREAMS": [ "CharmCompleteEvent" ], + "WGs": [ "Charm" ] +} + +CharmedMesonSL = { + "BUILDERTYPE": "StrippingCharmedMesonSL", + "CONFIG": { + "B0SL_M_Max": 5600.0, + "B0SL_M_Min": 2800.0, + "B0_M_Max": 5600.0, + "B0_M_Min": 5100.0, + "B_APT_Min": 1500.0, + "B_AP_Min": 20000.0, + "B_BPVDIRA_Min": 0.95, + "B_BPVVDCHI2_Min": 16, + "B_VCHI2_Max": 30, + "BpSL_M_Max": 5700.0, + "BpSL_M_Min": 3000.0, + "Bp_M_Max": 5500.0, + "Bp_M_Min": 5100.0, + "D0SL_AM_Max": 1960.0, + "D0_ADMASS_Max": 1900.0, + "D0_ADMASS_Min": 1820.0, + "DpSL_AM_Max": 2080.0, + "Dp_ADMASS_Max": 2030.0, + "Dp_ADMASS_Min": 1800.0, + "Dp_ADOCAMAX_Max": 0.25, + "Dp_APT_Min": 1200.0, + "Dp_AP_Min": 20000.0, + "Dp_BPVDIRA_Min": 0.95, + "Dp_BPVVDCHI2_Min": 16.0, + "Dp_Daug_1of3_MIPCHI2DV_Min": 4.0, + "Dp_VCHI2_Max": 30.0, + "EtaPiMu_AM_Min": 800.0, + "GEC_nLongTrk": 160, + "GhostProb": 0.3, + "KKMu_AM_Min": 1100.0, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 250.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "MINIPCHI2": 4.0, + "MuonIPCHI2": 4.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 250.0, + "PiKKMu_AM_Min": 1240.0, + "PiPiMu_AM_Min": 400.0, + "PiPiPiMu_AM_Min": 530.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.9, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "controlPrescaleViaD02KKpipi": 1.0, + "controlPrescaleViaD02etapipi": 1.0, + "controlPrescaleViaD02pipipipi": 1.0, + "controlPrescaleViaD2KKpi": 1.0, + "controlPrescaleViaD2pipipi": 1.0, + "signalPrescaleViaD02KKpimunu": 1.0, + "signalPrescaleViaD02etapimunu": 1.0, + "signalPrescaleViaD02pipipimunu": 1.0, + "signalPrescaleViaD2KKmunu": 1.0, + "signalPrescaleViaD2pipimunu": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +DstarD02ETau = { + "BUILDERTYPE": "StrippingDstarD02ETauConf", + "CONFIG": { + "CUTBASED_MCORR_B_HIGH": "8600", + "CUTBASED_MCORR_B_LOW": "3600", + "CUTBASED_MCORR_D0_HIGH": "8000", + "CUTBASED_MCORR_D0_LOW": "1000", + "CUTBASED_MISS_MASS": "876", + "CUTBASED_MISS_MASS_HIGH": "250", + "CUTBASED_MISS_MASS_HIGH_KTHREEPI": "1500", + "CUTBASED_MISS_MASS_LOW": "0", + "CUTBASED_M_B": "2865", + "CUTBASED_M_D0_HIGH": "2000", + "CUTBASED_M_D0_LOW": "500", + "CUTBASED_M_TAU_HIGH": "1592", + "CUTBASED_M_TAU_LOW": "829", + "CUTBASED_PROBNNE_E": "0.1", + "CUTBASED_PROBNNK_K": "0.2", + "CUTBASED_PROBNNPI_THREE_PI": "0.5", + "CUTBASED_TAU_BPVVDCHI2": "16", + "CUTBASED_TAU_BPVVDRHO": "0.33", + "CUTBASED_TAU_BPVVDRHO_HIGH": "7", + "CUTBASED_TAU_BPVVDRHO_LOW": "0.05", + "CUTBASED_TAU_BPVVDZ": "0.5", + "CUTBASED_TAU_TAU_HIGH": "3", + "CUTBASED_TAU_TAU_LOW": "-2.5", + "CUTBASED_TAU_VCHI2": "16", + "CUTBASED_VCHI2_TAU": "20.6", + "ConeAngles": { + "08": 0.8, + "10": 1.0, + "12": 1.2, + "14": 1.4 + }, + "ConeVariables": [ + "CONEANGLE", + "CONEMULT", + "CONEPTASYM" + ], + "DstD0DMWin_HIGH": "100.", + "DstD0DMWin_LOW": "-10.", + "DstMassWin_HIGH": "100.", + "DstMassWin_LOW": "-1250.", + "DstmVtxChi2": "10.", + "HLT_DECISIONS_HAD": { + "Hlt2Topo(2|3|4)Body.*Decision%TOS": 0 + }, + "MINIPCHI2BPV_E": "16", + "MINIPCHI2BPV_PI_FROM_DTSM": "10", + "MINIPCHI2BPV_THREE_PI": "16", + "MINIPCHI2PV_D0": "50", + "PROBNNGHOST_E": "0.4", + "PROBNNGHOST_THREE_PI": "0.4", + "PT_D0": "1000", + "PT_E": "110", + "PT_PI_FROM_DTSM": "110", + "PT_THREE_PI": "110", + "P_D0": "2000", + "P_E": "0", + "P_THREE_PI": "500", + "PrescaleETauBox": 1.0, + "PrescaleETauSSBox": 1.0, + "PrescaleK3piBox": 0.025, + "PrescaleK3piSSBox": 0.025, + "RelInfoTools_D02ETau": [ + { + "DaughterLocations": { + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_VertexIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_VertexIsoInfo" + }, + "Location": "DstVars_VertexIsoInfo", + "Type": "RelInfoVertexIsolation" + }, + { + "ConeSize": 0.5, + "DaughterLocations": { + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_ConeIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_ConeIsoInfo" + }, + "Location": "DstVars_ConeIsoInfo", + "Type": "RelInfoConeIsolation", + "Variables": [] + } + ], + "RelInfoTools_D02K3pi": [ + { + "DaughterLocations": { + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_VertexIsoInfo" + }, + "Location": "DstVars_VertexIsoInfo", + "Type": "RelInfoVertexIsolation" + }, + { + "ConeSize": 0.5, + "DaughterLocations": { + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_ConeIsoInfo" + }, + "Location": "DstVars_ConeIsoInfo", + "Type": "RelInfoConeIsolation", + "Variables": [] + } + ], + "TAU_AMAXDOCA_PIS": "0.2", + "TAU_BPVDIRA": "-1.", + "TAU_M_HIGH": "2100", + "TAU_M_HIGH_COMB": "2100", + "TAU_M_LOW": "400", + "TAU_M_LOW_COMB": "400", + "TAU_PT": "700.", + "TRACKCHI2_E": "4", + "TRACKCHI2_PI_FROM_DTSM": "7", + "TRACKCHI2_THREE_PI": "4", + "TRGHOPROB_E": "0.4", + "TRGHOPROB_THREE_PI": "0.4", + "prefix": "" + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +#Hc2V02H = { +# "BUILDERTYPE": "StrippingHc2V02HConf", +# "CONFIG": { +# "Bach_PT_MIN": 250.0, +# "Bach_P_MIN": 2000.0, +# "Comb_ADAMASS_WIN": 120.0, +# "Comb_ADOCAMAX_MAX": 0.4, +# "Hlt1Filter": None, +# "Hlt2Filter": None, +# "Lambda0_FDCHI2_MIN_DD": 4, +# "Lambda0_FDCHI2_MIN_LL": 4, +# "Lambda0_PT_MIN": 250.0, +# "Lambda0_P_MIN": 6000.0, +# "Lambda0_VCHI2VDOF_MAX_DD": 25.0, +# "Lambda0_VCHI2VDOF_MAX_LL": 12.0, +# "LambdaMinFD_DD": 500.0, +# "LambdaMinFD_LL": 5.0, +# "MIPCHI2DV_PRIMARY_Min": 2, +# "PostscaleXic2LambdaKKDD": 1.0, +# "PostscaleXic2LambdaKKLL": 1.0, +# "PostscaleXic2LambdaKPiDD": 1.0, +# "PostscaleXic2LambdaKPiLL": 1.0, +# "PostscaleXic2LambdaPiKDD": 1.0, +# "PostscaleXic2LambdaPiKLL": 1.0, +# "PostscaleXic2LambdaPiPiDD": 1.0, +# "PostscaleXic2LambdaPiPiLL": 1.0, +# "PrescaleXic2LambdaKKDD": 1.0, +# "PrescaleXic2LambdaKKLL": 1.0, +# "PrescaleXic2LambdaKPiDD": 1.0, +# "PrescaleXic2LambdaKPiLL": 1.0, +# "PrescaleXic2LambdaPiKDD": 1.0, +# "PrescaleXic2LambdaPiKLL": 1.0, +# "PrescaleXic2LambdaPiPiDD": 1.0, +# "PrescaleXic2LambdaPiPiLL": 1.0, +# "ProbNNkMin": 0.1, +# "ProbNNpMin_L0_DD": 0.1, +# "ProbNNpMin_L0_LL": 0.1, +# "ProbNNpiMin": 0.1, +# "ProbNNpiMin_L0_DD": 0.1, +# "ProbNNpiMin_L0_LL": 0.1, +# "TrGhostProbMax": 0.3, +# "Xic_ADMASS_WIN": 90.0, +# "Xic_PT_min": 250.0, +# "Xic_P_min": 10000.0, +# "Xic_VCHI2VDOF_MAX_DD": 3.0, +# "Xic_VCHI2VDOF_MAX_LL": 3.0, +# "Xic_acosBPVDIRA_MAX_DD": 0.0316, +# "Xic_acosBPVDIRA_MAX_LL": 0.02, +# "p_L0_PT_LL_min": 100.0, +# "p_L0_P_LL_min": 2000.0, +# "pi_L0_PT_LL_min": 100.0, +# "pi_L0_P_LL_min": 2000.0 +# }, +# "STREAMS": [ "Charm" ], +# "WGs": [ "Charm" ] +#} + +Hc2V03H = { + "BUILDERTYPE": "StrippingHc2V03HConf", + "CONFIG": { + "Bach_IPCHI2_MAX": 9, + "Bach_IPCHI2_MIN": 1, + "Bach_PT_MIN": 150.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 90.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 49, + "Lambda0_PT_MIN": 500.0, + "Lambda0_P_MIN": 10000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "LambdaMinFD_DD": 200.0, + "LambdaMinFD_LL": 25.0, + "Lambdac_ADMASS_WIN": 75.0, + "Lambdac_PVDispCut_DD": "(BPVVDCHI2 > 9.0)", + "Lambdac_PVDispCut_LL": "(BPVVDCHI2 > 16.0)", + "Lambdac_VCHI2VDOF_MAX_DD": 3.0, + "Lambdac_VCHI2VDOF_MAX_LL": 3.0, + "Lambdac_acosBPVDIRA_MAX_DD": 0.045, + "Lambdac_acosBPVDIRA_MAX_LL": 0.14, + "PostscaleLambdac2Lambda3PiDD": 1.0, + "PostscaleLambdac2Lambda3PiLL": 1.0, + "PostscaleLambdac2LambdaK2PiDD": 1.0, + "PostscaleLambdac2LambdaK2PiLL": 1.0, + "PostscaleXic2LambdaK2PiDD": 1.0, + "PostscaleXic2LambdaK2PiLL": 1.0, + "PrescaleLambdac2Lambda3PiDD": 1.0, + "PrescaleLambdac2Lambda3PiLL": 1.0, + "PrescaleLambdac2LambdaK2PiDD": 1.0, + "PrescaleLambdac2LambdaK2PiLL": 1.0, + "PrescaleXic2LambdaK2PiDD": 1.0, + "PrescaleXic2LambdaK2PiLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xic_ADMASS_WIN": 75.0, + "Xic_PVDispCut_DD": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_LL": "(BPVVDCHI2 > 16.0)", + "Xic_VCHI2VDOF_MAX_DD": 3.0, + "Xic_VCHI2VDOF_MAX_LL": 3.0, + "Xic_acosBPVDIRA_MAX_DD": 0.045, + "Xic_acosBPVDIRA_MAX_LL": 0.14 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V2H = { + "BUILDERTYPE": "StrippingHc2V2HConf", + "CONFIG": { + "Bach_PT_MIN": 150.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 120.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hc_ADMASS_WIN": 90.0, + "Hc_PVDispCut_DDD": "(BPVVDCHI2 > 9.0)", + "Hc_PVDispCut_DDL": "(BPVVDCHI2 > 16.0)", + "Hc_PVDispCut_LLL": "(BPVVDCHI2 > 16.0)", + "Hc_VCHI2VDOF_MAX_DDD": 12.0, + "Hc_VCHI2VDOF_MAX_DDL": 12.0, + "Hc_VCHI2VDOF_MAX_LLL": 12.0, + "Hc_acosBPVDIRA_MAX_DDD": 0.14, + "Hc_acosBPVDIRA_MAX_DDL": 0.045, + "Hc_acosBPVDIRA_MAX_LLL": 0.14, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 49, + "Lambda0_PT_MIN": 250.0, + "Lambda0_P_MIN": 2000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "LambdaMinFD_DD": 0.0, + "LambdaMinFD_LL": 25.0, + "PostscaleLambdac2XiKPiDDD": 1.0, + "PostscaleLambdac2XiKPiDDL": 1.0, + "PostscaleLambdac2XiKPiLLL": 1.0, + "PostscaleXic2XiPiPiDDD": 1.0, + "PostscaleXic2XiPiPiDDL": 1.0, + "PostscaleXic2XiPiPiLLL": 1.0, + "PrescaleLambdac2XiKPiDDD": 1.0, + "PrescaleLambdac2XiKPiDDL": 1.0, + "PrescaleLambdac2XiKPiLLL": 1.0, + "PrescaleXic2XiPiPiDDD": 1.0, + "PrescaleXic2XiPiPiDDL": 1.0, + "PrescaleXic2XiPiPiLLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xim_FDCHI2_MIN": 16, + "Xim_PT_MIN": 250.0, + "Xim_P_MIN": 2000.0, + "Xim_VCHI2VDOF_MAX": 12.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V3H = { + "BUILDERTYPE": "StrippingHc2V3HConf", + "CONFIG": { + "Bach_IPCHI2_MAX": 9, + "Bach_IPCHI2_MIN": 1, + "Bach_PT_MIN": 200.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 120.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 25, + "Lambda0_PT_MIN": 250.0, + "Lambda0_P_MIN": 2000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "PostscaleXic2XimPiPiPiDDD": 1.0, + "PostscaleXic2XimPiPiPiDDL": 1.0, + "PostscaleXic2XimPiPiPiLLL": 1.0, + "PrescaleXic2XimPiPiPiDDD": 1.0, + "PrescaleXic2XimPiPiPiDDL": 1.0, + "PrescaleXic2XimPiPiPiLLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xic_ADMASS_WIN": 90.0, + "Xic_PVDispCut_DDD": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_DDL": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_LLL": "(BPVVDCHI2 > 16.0)", + "Xic_VCHI2VDOF_MAX_DDD": 5.0, + "Xic_VCHI2VDOF_MAX_DDL": 5.0, + "Xic_VCHI2VDOF_MAX_LLL": 5.0, + "Xic_acosBPVDIRA_MAX_DDD": 0.14, + "Xic_acosBPVDIRA_MAX_DDL": 0.14, + "Xic_acosBPVDIRA_MAX_LLL": 0.14, + "Xim_FDCHI2_MIN": 9, + "Xim_PT_MIN": 250.0, + "Xim_P_MIN": 2000.0, + "Xim_VCHI2VDOF_MAX": 12.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Lambdac2LambdaEtaPi = { + "BUILDERTYPE": "StrippingLambdac2LambdaEtaPi", + "CONFIG": { + "GEC_nLongTrk": 160, + "GhostProb": 0.3, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 250.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "LambdaDDCutFDChi2": 100.0, + "LambdaDDCutMass": 50.0, + "LambdaDDPMin": 2000.0, + "LambdaDDPTMin": 500.0, + "LambdaLLCutFDChi2": 100.0, + "LambdaLLCutMass": 50.0, + "LambdaLLPMin": 2000.0, + "LambdaLLPTMin": 500.0, + "LambdaVertexChi2": 10.0, + "Lb_APT_Min": 1500.0, + "Lb_AP_Min": 20000.0, + "Lb_BPVDIRA_Min": 0.95, + "Lb_BPVVDCHI2_Min": 16, + "Lb_M_HalfWin": 200.0, + "Lb_VCHI2_Max": 30, + "Lc_ADOCAMAX_Max": 0.15, + "Lc_APT_Min": 1200.0, + "Lc_AP_Min": 15000.0, + "Lc_BPVDIRA_Min": 0.95, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDZ_Min": 0.5, + "Lc_Daug_1of3_MIPCHI2DV_Min": 3.0, + "Lc_M_HalfWin": 200.0, + "Lc_VCHI2_Max": 30.0, + "MINIPCHI2": 3.0, + "MuonIPCHI2": 4.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 250.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.4, + "ProbNNpiMax": 0.9, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "signalPrescale": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Lambdac2PEta = { + "BUILDERTYPE": "StrippingLambdac2PEta", + "CONFIG": { + "GEC_nLongTrk": 160, + "Lb_APT_Min": 1500.0, + "Lb_AP_Min": 20000.0, + "Lb_BPVDIRA_Min": 0.95, + "Lb_BPVVDCHI2_Min": 16, + "Lb_BPVVDZ_Min": 0.7, + "Lb_M_HalfWin": 200.0, + "Lb_VCHI2_Max": 30, + "Lc_ADOCAMAX_Max": 0.15, + "Lc_APT_Min": 1200.0, + "Lc_AP_Min": 15000.0, + "Lc_BPVDIRA_Min": 0.95, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDZ_Min": 0.5, + "Lc_Daug_1of3_MIPCHI2DV_Min": 3.0, + "Lc_M_HalfWin": 200.0, + "Lc_VCHI2_Max": 30.0, + "MINIPCHI2": 3.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "ProbNNp": 0.4, + "ProbNNpi": 0.4, + "ProbNNpiMax": 0.9, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "signalPrescale": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +NeutralCBaryons = { + "BUILDERTYPE": "StrippingNeutralCBaryonsConf", + "CONFIG": { + "Bachelor_PT_MIN": 50.0, + "KaonPIDK": -5.0, + "LambdaDDMassWin": 5.7, + "LambdaDDMaxVZ": 2275.0, + "LambdaDDMinVZ": 400.0, + "LambdaDDVtxChi2Max": 5.0, + "LambdaDeltaZ_MIN": 5.0, + "LambdaLLMassWin": 5.7, + "LambdaLLMaxVZ": 400.0, + "LambdaLLMinDecayTime": 0.005, + "LambdaLLMinVZ": -100.0, + "LambdaLLVtxChi2Max": 5.0, + "LambdaPi_PT_MIN": 100.0, + "LambdaPr_PT_MIN": 500.0, + "PionPIDK": 10.0, + "ProbNNkMin": 0.1, + "ProbNNpMinDD": 0.05, + "ProbNNpMinLL": 0.1, + "ProtonPIDp": 5, + "ProtonPIDpK": -3, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "tight_KaonPIDK": 0.0, + "tight_KaonPIDpi": 5.0, + "tight_ProtonPIDp": 7, + "tight_ProtonPIDpK": 0.0, + "tight_ProtonPIDppi": 5.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Xib2Xic0PiXic02pK = { + "BUILDERTYPE": "StrippingXib2Xic0PiXic02pKConf", + "CONFIG": { + "PionPIDK": 10.0, + "ProbNNkMin": 0.1, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "tight_KaonPIDK": 0.0, + "tight_KaonPIDpi": 5.0, + "tight_ProtonPIDp": 7, + "tight_ProtonPIDpK": 0.0, + "tight_ProtonPIDppi": 5.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Xic0ToXiMuNu = { + "BUILDERTYPE": "Xic0ToXiMuNuConf", + "CONFIG": { + "RequiredRawEvents": [ "Velo" ], + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "bach_muon": { + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)", + "tes": "Phys/StdAllNoPIDsMuons/Particles" + }, + "bach_pion": { + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)", + "tes": "Phys/StdAllNoPIDsPions/Particles" + }, + "descriptor_xi": [ + "[Xi- -> Lambda0 pi-]cc" + ], + "descriptor_ximu": [ + "[Xi_c0 -> Xi- mu+]cc" + ], + "down_pion": { + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)", + "tes": "Phys/StdNoPIDsDownPions/Particles" + }, + "lambda_dd": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) &\n (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)", + "tes": "Phys/StdLooseLambdaDD/Particles" + }, + "lambda_ll": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) &\n (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & \n (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)", + "tes": "Phys/StdVeryLooseLambdaLL/Particles" + }, + "xc0_ddd": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)" + }, + "xc0_ddl": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) " + }, + "xc0_lll": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & \n (P>8*GeV) & (PT>400*MeV) " + } + }, + "STREAMS": { + "CharmCompleteEvent": [ + "StrippingXic0ToXiMuNu_LLLLine", + "StrippingXic0ToXiMuNu_DDLLine", + "StrippingXic0ToXiMuNu_DDDLine" + ] + }, + "WGs": [ "Charm" ] +} + +Xic0ToXiMuNu_WS = { + "BUILDERTYPE": "Xic0ToXiMuNu_WSConf", + "CONFIG": { + "RequiredRawEvents": [ "Velo" ], + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "bach_muon": { + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)", + "tes": "Phys/StdAllNoPIDsMuons/Particles" + }, + "bach_pion": { + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)", + "tes": "Phys/StdAllNoPIDsPions/Particles" + }, + "descriptor_xi": [ + "[Xi- -> Lambda0 pi-]cc" + ], + "descriptor_ximu": [ + "[Xi_c0 -> Xi- mu-]cc" + ], + "down_pion": { + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)", + "tes": "Phys/StdNoPIDsDownPions/Particles" + }, + "lambda_dd": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) &\n (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)", + "tes": "Phys/StdLooseLambdaDD/Particles" + }, + "lambda_ll": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) &\n (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & \n (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)", + "tes": "Phys/StdVeryLooseLambdaLL/Particles" + }, + "xc0_ddd": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)" + }, + "xc0_ddl": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) " + }, + "xc0_lll": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & \n (P>8*GeV) & (PT>400*MeV) " + } + }, + "STREAMS": { + "CharmCompleteEvent": [ + "StrippingXic0ToXiMuNu_WS_LLLLine", + "StrippingXic0ToXiMuNu_WS_DDLLine", + "StrippingXic0ToXiMuNu_WS_DDDLine" + ] + }, + "WGs": [ "Charm" ] +} + +Xic2PHH = { + "BUILDERTYPE": "StrippingXic2PHH", + "CONFIG": { + "BPVIPCHI2_Phi": 4, + "GEC_nLongTrk": 250, + "GhostProb": 0.3, + "KSCutDIRA_DD": 0.999, + "KSCutDIRA_LL": 0.999, + "KSCutFDChi2_DD": 5, + "KSCutFDChi2_LL": 5, + "KSCutMass_DD": 50.0, + "KSCutMass_LL": 35.0, + "KaonP": 2000.0, + "KaonPIDK": 10.0, + "KaonPT": 200.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "MINIPCHI2": 4.0, + "MaxDz_DD": 9999.0, + "MaxDz_LL": 9999.0, + "MaxKsVCHI2NDOF_DD": 20.0, + "MaxKsVCHI2NDOF_LL": 20.0, + "MaxPhiEta": 5.0, + "MinDz_DD": 250.0, + "MinDz_LL": 0.0, + "MinKsIpChi2_DD": 3, + "MinKsIpChi2_LL": 3, + "MinKsPT_DD": 200.0, + "MinKsPT_LL": 200.0, + "MinPhiEta": 2.0, + "MinPhiP": 3000.0, + "MinPhiPT": 200.0, + "PhiCutMass": 20.0, + "PionP": 3000.0, + "PionPIDK": 10.0, + "PionPT": 500.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.95, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "Xic_ADAMASS_HalfWin": 170.0, + "Xic_ADMASS_HalfWin": 120.0, + "Xic_AM_Max": 2550.0, + "Xic_BPVDIRA_Min": 0.9, + "Xic_BPVVDCHI2_Min": 25.0, + "pKK_AM_Min": 2380.0, + "ppipi_AM_Min": 2380.0, + "signalPrescaleViaXicPKK": 1.0, + "signalPrescaleViaXicPKS0DD": 1.0, + "signalPrescaleViaXicPKS0LL": 1.0, + "signalPrescaleViaXicPPhi2KK": 1.0, + "signalPrescaleViaXicPPiPi": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + diff --git a/Phys/StrippingSettings/python/StrippingSettings/Stripping29r2p3/LineConfigDictionaries_Charm.py b/Phys/StrippingSettings/python/StrippingSettings/Stripping29r2p3/LineConfigDictionaries_Charm.py index d992d617d..b725c573b 100644 --- a/Phys/StrippingSettings/python/StrippingSettings/Stripping29r2p3/LineConfigDictionaries_Charm.py +++ b/Phys/StrippingSettings/python/StrippingSettings/Stripping29r2p3/LineConfigDictionaries_Charm.py @@ -16,3 +16,937 @@ ## Contact person: Sergio Jaimes (sergio.jaimes@cern.ch) ## ################################################################################ +Charm2PPX = { + "BUILDERTYPE": "StrippingCharm2PPXConf", + "CONFIG": { + "Comb_ADOCACHI2_MAX": 16, + "Daug_1ofAll_BPVIPCHI2_MIN": 9.0, + "Daug_1ofAll_PT_MIN": 700.0, + "Daug_All_BPVIPCHI2_MIN": 4.0, + "Daug_All_CloneDist_MIN": 5000, + "Daug_All_MIPCHI2_MIN": 4.0, + "Daug_All_PT_MIN": 200.0, + "Daug_All_TrChostProb_MAX": 0.5, + "Daug_ETA_MAX": 4.9, + "Daug_ETA_MIN": 2.0, + "Daug_P_MAX": 100000.0, + "Daug_P_MIN": 3200.0, + "Hc_BPVCTAU_MIN": 0.05, + "Hc_BPVVDCHI2_MIN": 9.0, + "Hc_MASS_MAX": 3500.0, + "Hc_PT_MIN": 1000.0, + "Hc_VCHI2VDOF_MAX": 25.0, + "Hcs_MASS_MAX": 3650.0, + "Hlt1Filter": None, + "Hlt2Filter": None, + "HsComb_ADOCACHI2_MAX": 16, + "HsDaug_1ofAll_BPVIPCHI2_MIN": 9.0, + "HsDaug_1ofAll_PT_MIN": -500.0, + "HsDownDaug_1ofAll_BPVIPCHI2_MIN": -9.0, + "HsDown_BPVVDCHI2_MIN": 4.0, + "HsProton_1ofAll_ProbNN_MIN": 0.5, + "Hs_BPVCTAU_MIN": 0.1, + "Hs_BPVVDCHI2_MIN": 9.0, + "Hs_MASS_MAX": 2125.0, + "Hs_PT_MIN": -1000.0, + "Hs_VCHI2VDOF_MAX": 25.0, + "Kaon_ProbNN_MIN": 0.1, + "Lam_MASS_MAX": 1170.0, + "Lc_MASS_MAX": 2350.0, + "Pc_MASS_MAX": 3100.0, + "Pion_ProbNN_MIN": 0.1, + "PostscaleHc2LamPPi": 1.0, + "PostscaleHc2LamPPiPi": 1.0, + "PostscaleHc2PP": 1.0, + "PostscaleHc2PPK": 1.0, + "PostscaleHc2PPKPi": 1.0, + "PostscaleHc2PPKPiPi": 1.0, + "PostscaleHc2PPKs": 1.0, + "PostscaleHc2PPKsPi": 1.0, + "PostscaleHcs2LamLamPi": 1.0, + "PostscaleHcs2LamPKPi": 1.0, + "PostscaleHcs2PPKKPi": 1.0, + "PostscaleHcs2PPKsK": 1.0, + "PostscaleHs2PPPi": 1.0, + "PostscaleL2PPi": 1.0, + "PostscaleLc2PKPi": 1.0, + "PostscalePc2PKPiPi": 1.0, + "PostscalePc2PKsPi": 1.0, + "PostscalePs2PPiPi": 1.0, + "PrescaleHc2LamPPi": 1.0, + "PrescaleHc2LamPPiPi": 1.0, + "PrescaleHc2PP": 1.0, + "PrescaleHc2PPK": 1.0, + "PrescaleHc2PPKPi": 1.0, + "PrescaleHc2PPKPiPi": 1.0, + "PrescaleHc2PPKs": 1.0, + "PrescaleHc2PPKsPi": 1.0, + "PrescaleHcs2LamLamPi": 1.0, + "PrescaleHcs2LamPKPi": 1.0, + "PrescaleHcs2PPKKPi": 1.0, + "PrescaleHcs2PPKsK": 1.0, + "PrescaleHs2PPPi": 1.0, + "PrescaleL2PPi": 0.01, + "PrescaleLc2PKPi": 0.01, + "PrescalePc2PKPiPi": 0.1, + "PrescalePc2PKsPi": 0.1, + "PrescalePs2PPiPi": 0.1, + "Proton_1ofAll_ProbNN_MIN": 0.5, + "Proton_PT_MIN": 300.0, + "Proton_P_MIN": 10000.0, + "Proton_ProbNN_MIN": 0.1, + "Proton_ProbNNk_MAX": 0.8, + "Proton_ProbNNpi_MAX": 0.55, + "Ps_MASS_MAX": 1650.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +CharmedBaryonSL = { + "BUILDERTYPE": "StrippingCharmedBaryonSL", + "CONFIG": { + "GEC_nLongTrk": 250, + "GhostProb": 0.3, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 500.0, + "KaonPT_ForOm": 100.0, + "KaonP_ForOm": 2000.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "L0Mu_AM_Min": 1250.0, + "LambdaCutDIRA": 0.99, + "LambdaDDCutFDChi2": 100.0, + "LambdaDDCutMass": 20.0, + "LambdaDDMaxVZ": 2275.0, + "LambdaDDMinVZ": 400.0, + "LambdaDDPMin": 5000.0, + "LambdaDDPTMin": 800.0, + "LambdaDaugTrackChi2": 4.0, + "LambdaLDCutFDChi2": 100.0, + "LambdaLDCutMass": 20.0, + "LambdaLDPMin": 3000.0, + "LambdaLDPTMin": 800.0, + "LambdaLLCutFDChi2": 100.0, + "LambdaLLCutMass": 20.0, + "LambdaLLMaxVZ": 400.0, + "LambdaLLMinVZ": -100.0, + "LambdaLLPMin": 5000.0, + "LambdaLLPTMin": 800.0, + "LambdaPi_PT_MIN": 100.0, + "LambdaPr_PT_MIN": 500.0, + "LambdaVertexChi2": 5.0, + "Lc_ADMASS_HalfWin": 80.0, + "Lc_ADMASS_HalfWin_Tight": 55.0, + "Lc_ADOCAMAX_Max": 0.5, + "Lc_ADOCAMAX_Max_Tight": 0.15, + "Lc_AM_Max": 2370.0, + "Lc_APT_Min": 1000.0, + "Lc_APT_Min_Tight_PKMu": 1600.0, + "Lc_APT_Min_Tight_PPiMu": 1600.0, + "Lc_AP_Min_Tight": 25000.0, + "Lc_BPVDIRA_Min": 0.9, + "Lc_BPVDIRA_Min_Tight": 0.99, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDCHI2_Min_Tight": 25.0, + "Lc_Daug_1of3_MIPCHI2DV_Min": 4.0, + "Lc_Daug_1of3_MIPCHI2DV_Min_Tight": 9.0, + "Lc_VCHI2_Max": 30.0, + "Lc_VCHI2_Max_Tight": 20.0, + "MINIPCHI2": 4.0, + "MisID_PROB_Max": 0.7, + "MuonIPCHI2": 5.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 500.0, + "Oc_AM_Max": 2780.0, + "OmMu_AM_Min": 1780.0, + "Omegac0_4Dau_VCHI2_Max": 60.0, + "Omegac0_ADAMASS_HalfWin": 170.0, + "Omegac0_ADMASS_HalfWin": 120.0, + "Omegac0_BPVDIRA_Min": 0.9, + "Omegac0_BPVVDCHI2_Min": 25.0, + "P_Min_Tight": 3500.0, + "PionP": 3000.0, + "PionPIDK": 10.0, + "PionPT": 500.0, + "PionPT_ForXi": 100.0, + "PionP_ForXi": 2000.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.95, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "XiMu_AM_Min": 1430.0, + "Xic_ADAMASS_HalfWin": 170.0, + "Xic_ADMASS_HalfWin": 120.0, + "Xic_AM_Max": 2550.0, + "Xic_BPVDIRA_Min": 0.9, + "Xic_BPVVDCHI2_Min": 25.0, + "controlPrescaleViaLcL0DDPiNC": 0.8, + "controlPrescaleViaLcL0LLPiNC": 0.4, + "controlPrescaleViaLcPKPiNC": 0.09, + "controlPrescaleViaLcPKPiNC_Tight": 0.5, + "controlPrescaleViaLcPPiPiNC": 0.06, + "controlPrescaleViaLcPPiPiNC_Tight": 0.5, + "controlPrescaleViaOmegac0NC": 1.0, + "controlPrescaleViaXicL0DDPiNC": 0.8, + "controlPrescaleViaXicL0LLPiNC": 0.4, + "controlPrescaleViaXicXiPiNC": 1.0, + "pKMu_AM_Min": 1550.0, + "ppiMu_AM_Min": 1200.0, + "signalPrescaleViaLc": 1.0, + "signalPrescaleViaLcL0DDMuNu": 0.8, + "signalPrescaleViaLcPKMuNu_Tight": 1.0, + "signalPrescaleViaLcPPiMuNu": 0.25, + "signalPrescaleViaLcPPiMuNu_Tight": 1.0, + "signalPrescaleViaOmegac0": 1.0, + "signalPrescaleViaXic": 1.0, + "signalPrescaleViaXicL0DDMuNu": 0.8, + "signalPrescaleViaXicL0LLMuNu": 0.8 + }, + "STREAMS": [ "CharmCompleteEvent" ], + "WGs": [ "Charm" ] +} + +CharmedMesonSL = { + "BUILDERTYPE": "StrippingCharmedMesonSL", + "CONFIG": { + "B0SL_M_Max": 5600.0, + "B0SL_M_Min": 2800.0, + "B0_M_Max": 5600.0, + "B0_M_Min": 5100.0, + "B_APT_Min": 1500.0, + "B_AP_Min": 20000.0, + "B_BPVDIRA_Min": 0.95, + "B_BPVVDCHI2_Min": 16, + "B_VCHI2_Max": 30, + "BpSL_M_Max": 5700.0, + "BpSL_M_Min": 3000.0, + "Bp_M_Max": 5500.0, + "Bp_M_Min": 5100.0, + "D0SL_AM_Max": 1960.0, + "D0_ADMASS_Max": 1900.0, + "D0_ADMASS_Min": 1820.0, + "DpSL_AM_Max": 2080.0, + "Dp_ADMASS_Max": 2030.0, + "Dp_ADMASS_Min": 1800.0, + "Dp_ADOCAMAX_Max": 0.25, + "Dp_APT_Min": 1200.0, + "Dp_AP_Min": 20000.0, + "Dp_BPVDIRA_Min": 0.95, + "Dp_BPVVDCHI2_Min": 16.0, + "Dp_Daug_1of3_MIPCHI2DV_Min": 4.0, + "Dp_VCHI2_Max": 30.0, + "EtaPiMu_AM_Min": 800.0, + "GEC_nLongTrk": 160, + "GhostProb": 0.3, + "KKMu_AM_Min": 1100.0, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 250.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "MINIPCHI2": 4.0, + "MuonIPCHI2": 4.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 250.0, + "PiKKMu_AM_Min": 1240.0, + "PiPiMu_AM_Min": 400.0, + "PiPiPiMu_AM_Min": 530.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.9, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "controlPrescaleViaD02KKpipi": 1.0, + "controlPrescaleViaD02etapipi": 1.0, + "controlPrescaleViaD02pipipipi": 1.0, + "controlPrescaleViaD2KKpi": 1.0, + "controlPrescaleViaD2pipipi": 1.0, + "signalPrescaleViaD02KKpimunu": 1.0, + "signalPrescaleViaD02etapimunu": 1.0, + "signalPrescaleViaD02pipipimunu": 1.0, + "signalPrescaleViaD2KKmunu": 1.0, + "signalPrescaleViaD2pipimunu": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +DstarD02ETau = { + "BUILDERTYPE": "StrippingDstarD02ETauConf", + "CONFIG": { + "CUTBASED_MCORR_B_HIGH": "8600", + "CUTBASED_MCORR_B_LOW": "3600", + "CUTBASED_MCORR_D0_HIGH": "8000", + "CUTBASED_MCORR_D0_LOW": "1000", + "CUTBASED_MISS_MASS": "876", + "CUTBASED_MISS_MASS_HIGH": "250", + "CUTBASED_MISS_MASS_HIGH_KTHREEPI": "1500", + "CUTBASED_MISS_MASS_LOW": "0", + "CUTBASED_M_B": "2865", + "CUTBASED_M_D0_HIGH": "2000", + "CUTBASED_M_D0_LOW": "500", + "CUTBASED_M_TAU_HIGH": "1592", + "CUTBASED_M_TAU_LOW": "829", + "CUTBASED_PROBNNE_E": "0.1", + "CUTBASED_PROBNNK_K": "0.2", + "CUTBASED_PROBNNPI_THREE_PI": "0.5", + "CUTBASED_TAU_BPVVDCHI2": "16", + "CUTBASED_TAU_BPVVDRHO": "0.33", + "CUTBASED_TAU_BPVVDRHO_HIGH": "7", + "CUTBASED_TAU_BPVVDRHO_LOW": "0.05", + "CUTBASED_TAU_BPVVDZ": "0.5", + "CUTBASED_TAU_TAU_HIGH": "3", + "CUTBASED_TAU_TAU_LOW": "-2.5", + "CUTBASED_TAU_VCHI2": "16", + "CUTBASED_VCHI2_TAU": "20.6", + "ConeAngles": { + "08": 0.8, + "10": 1.0, + "12": 1.2, + "14": 1.4 + }, + "ConeVariables": [ + "CONEANGLE", + "CONEMULT", + "CONEPTASYM" + ], + "DstD0DMWin_HIGH": "100.", + "DstD0DMWin_LOW": "-10.", + "DstMassWin_HIGH": "100.", + "DstMassWin_LOW": "-1250.", + "DstmVtxChi2": "10.", + "HLT_DECISIONS_HAD": { + "Hlt2Topo(2|3|4)Body.*Decision%TOS": 0 + }, + "MINIPCHI2BPV_E": "16", + "MINIPCHI2BPV_PI_FROM_DTSM": "10", + "MINIPCHI2BPV_THREE_PI": "16", + "MINIPCHI2PV_D0": "50", + "PROBNNGHOST_E": "0.4", + "PROBNNGHOST_THREE_PI": "0.4", + "PT_D0": "1000", + "PT_E": "110", + "PT_PI_FROM_DTSM": "110", + "PT_THREE_PI": "110", + "P_D0": "2000", + "P_E": "0", + "P_THREE_PI": "500", + "PrescaleETauBox": 1.0, + "PrescaleETauSSBox": 1.0, + "PrescaleK3piBox": 0.025, + "PrescaleK3piSSBox": 0.025, + "RelInfoTools_D02ETau": [ + { + "DaughterLocations": { + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_VertexIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_VertexIsoInfo" + }, + "Location": "DstVars_VertexIsoInfo", + "Type": "RelInfoVertexIsolation" + }, + { + "ConeSize": 0.5, + "DaughterLocations": { + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_ConeIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_ConeIsoInfo" + }, + "Location": "DstVars_ConeIsoInfo", + "Type": "RelInfoConeIsolation", + "Variables": [] + } + ], + "RelInfoTools_D02K3pi": [ + { + "DaughterLocations": { + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_VertexIsoInfo" + }, + "Location": "DstVars_VertexIsoInfo", + "Type": "RelInfoVertexIsolation" + }, + { + "ConeSize": 0.5, + "DaughterLocations": { + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_ConeIsoInfo" + }, + "Location": "DstVars_ConeIsoInfo", + "Type": "RelInfoConeIsolation", + "Variables": [] + } + ], + "TAU_AMAXDOCA_PIS": "0.2", + "TAU_BPVDIRA": "-1.", + "TAU_M_HIGH": "2100", + "TAU_M_HIGH_COMB": "2100", + "TAU_M_LOW": "400", + "TAU_M_LOW_COMB": "400", + "TAU_PT": "700.", + "TRACKCHI2_E": "4", + "TRACKCHI2_PI_FROM_DTSM": "7", + "TRACKCHI2_THREE_PI": "4", + "TRGHOPROB_E": "0.4", + "TRGHOPROB_THREE_PI": "0.4", + "prefix": "" + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +#Hc2V02H = { +# "BUILDERTYPE": "StrippingHc2V02HConf", +# "CONFIG": { +# "Bach_PT_MIN": 250.0, +# "Bach_P_MIN": 2000.0, +# "Comb_ADAMASS_WIN": 120.0, +# "Comb_ADOCAMAX_MAX": 0.4, +# "Hlt1Filter": None, +# "Hlt2Filter": None, +# "Lambda0_FDCHI2_MIN_DD": 4, +# "Lambda0_FDCHI2_MIN_LL": 4, +# "Lambda0_PT_MIN": 250.0, +# "Lambda0_P_MIN": 6000.0, +# "Lambda0_VCHI2VDOF_MAX_DD": 25.0, +# "Lambda0_VCHI2VDOF_MAX_LL": 12.0, +# "LambdaMinFD_DD": 500.0, +# "LambdaMinFD_LL": 5.0, +# "MIPCHI2DV_PRIMARY_Min": 2, +# "PostscaleXic2LambdaKKDD": 1.0, +# "PostscaleXic2LambdaKKLL": 1.0, +# "PostscaleXic2LambdaKPiDD": 1.0, +# "PostscaleXic2LambdaKPiLL": 1.0, +# "PostscaleXic2LambdaPiKDD": 1.0, +# "PostscaleXic2LambdaPiKLL": 1.0, +# "PostscaleXic2LambdaPiPiDD": 1.0, +# "PostscaleXic2LambdaPiPiLL": 1.0, +# "PrescaleXic2LambdaKKDD": 1.0, +# "PrescaleXic2LambdaKKLL": 1.0, +# "PrescaleXic2LambdaKPiDD": 1.0, +# "PrescaleXic2LambdaKPiLL": 1.0, +# "PrescaleXic2LambdaPiKDD": 1.0, +# "PrescaleXic2LambdaPiKLL": 1.0, +# "PrescaleXic2LambdaPiPiDD": 1.0, +# "PrescaleXic2LambdaPiPiLL": 1.0, +# "ProbNNkMin": 0.1, +# "ProbNNpMin_L0_DD": 0.1, +# "ProbNNpMin_L0_LL": 0.1, +# "ProbNNpiMin": 0.1, +# "ProbNNpiMin_L0_DD": 0.1, +# "ProbNNpiMin_L0_LL": 0.1, +# "TrGhostProbMax": 0.3, +# "Xic_ADMASS_WIN": 90.0, +# "Xic_PT_min": 250.0, +# "Xic_P_min": 10000.0, +# "Xic_VCHI2VDOF_MAX_DD": 3.0, +# "Xic_VCHI2VDOF_MAX_LL": 3.0, +# "Xic_acosBPVDIRA_MAX_DD": 0.0316, +# "Xic_acosBPVDIRA_MAX_LL": 0.02, +# "p_L0_PT_LL_min": 100.0, +# "p_L0_P_LL_min": 2000.0, +# "pi_L0_PT_LL_min": 100.0, +# "pi_L0_P_LL_min": 2000.0 +# }, +# "STREAMS": [ "Charm" ], +# "WGs": [ "Charm" ] +#} + +Hc2V03H = { + "BUILDERTYPE": "StrippingHc2V03HConf", + "CONFIG": { + "Bach_IPCHI2_MAX": 9, + "Bach_IPCHI2_MIN": 1, + "Bach_PT_MIN": 150.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 90.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 49, + "Lambda0_PT_MIN": 500.0, + "Lambda0_P_MIN": 10000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "LambdaMinFD_DD": 200.0, + "LambdaMinFD_LL": 25.0, + "Lambdac_ADMASS_WIN": 75.0, + "Lambdac_PVDispCut_DD": "(BPVVDCHI2 > 9.0)", + "Lambdac_PVDispCut_LL": "(BPVVDCHI2 > 16.0)", + "Lambdac_VCHI2VDOF_MAX_DD": 3.0, + "Lambdac_VCHI2VDOF_MAX_LL": 3.0, + "Lambdac_acosBPVDIRA_MAX_DD": 0.045, + "Lambdac_acosBPVDIRA_MAX_LL": 0.14, + "PostscaleLambdac2Lambda3PiDD": 1.0, + "PostscaleLambdac2Lambda3PiLL": 1.0, + "PostscaleLambdac2LambdaK2PiDD": 1.0, + "PostscaleLambdac2LambdaK2PiLL": 1.0, + "PostscaleXic2LambdaK2PiDD": 1.0, + "PostscaleXic2LambdaK2PiLL": 1.0, + "PrescaleLambdac2Lambda3PiDD": 1.0, + "PrescaleLambdac2Lambda3PiLL": 1.0, + "PrescaleLambdac2LambdaK2PiDD": 1.0, + "PrescaleLambdac2LambdaK2PiLL": 1.0, + "PrescaleXic2LambdaK2PiDD": 1.0, + "PrescaleXic2LambdaK2PiLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xic_ADMASS_WIN": 75.0, + "Xic_PVDispCut_DD": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_LL": "(BPVVDCHI2 > 16.0)", + "Xic_VCHI2VDOF_MAX_DD": 3.0, + "Xic_VCHI2VDOF_MAX_LL": 3.0, + "Xic_acosBPVDIRA_MAX_DD": 0.045, + "Xic_acosBPVDIRA_MAX_LL": 0.14 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V2H = { + "BUILDERTYPE": "StrippingHc2V2HConf", + "CONFIG": { + "Bach_PT_MIN": 150.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 120.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hc_ADMASS_WIN": 90.0, + "Hc_PVDispCut_DDD": "(BPVVDCHI2 > 9.0)", + "Hc_PVDispCut_DDL": "(BPVVDCHI2 > 16.0)", + "Hc_PVDispCut_LLL": "(BPVVDCHI2 > 16.0)", + "Hc_VCHI2VDOF_MAX_DDD": 12.0, + "Hc_VCHI2VDOF_MAX_DDL": 12.0, + "Hc_VCHI2VDOF_MAX_LLL": 12.0, + "Hc_acosBPVDIRA_MAX_DDD": 0.14, + "Hc_acosBPVDIRA_MAX_DDL": 0.045, + "Hc_acosBPVDIRA_MAX_LLL": 0.14, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 49, + "Lambda0_PT_MIN": 250.0, + "Lambda0_P_MIN": 2000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "LambdaMinFD_DD": 0.0, + "LambdaMinFD_LL": 25.0, + "PostscaleLambdac2XiKPiDDD": 1.0, + "PostscaleLambdac2XiKPiDDL": 1.0, + "PostscaleLambdac2XiKPiLLL": 1.0, + "PostscaleXic2XiPiPiDDD": 1.0, + "PostscaleXic2XiPiPiDDL": 1.0, + "PostscaleXic2XiPiPiLLL": 1.0, + "PrescaleLambdac2XiKPiDDD": 1.0, + "PrescaleLambdac2XiKPiDDL": 1.0, + "PrescaleLambdac2XiKPiLLL": 1.0, + "PrescaleXic2XiPiPiDDD": 1.0, + "PrescaleXic2XiPiPiDDL": 1.0, + "PrescaleXic2XiPiPiLLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xim_FDCHI2_MIN": 16, + "Xim_PT_MIN": 250.0, + "Xim_P_MIN": 2000.0, + "Xim_VCHI2VDOF_MAX": 12.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V3H = { + "BUILDERTYPE": "StrippingHc2V3HConf", + "CONFIG": { + "Bach_IPCHI2_MAX": 9, + "Bach_IPCHI2_MIN": 1, + "Bach_PT_MIN": 200.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 120.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 25, + "Lambda0_PT_MIN": 250.0, + "Lambda0_P_MIN": 2000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "PostscaleXic2XimPiPiPiDDD": 1.0, + "PostscaleXic2XimPiPiPiDDL": 1.0, + "PostscaleXic2XimPiPiPiLLL": 1.0, + "PrescaleXic2XimPiPiPiDDD": 1.0, + "PrescaleXic2XimPiPiPiDDL": 1.0, + "PrescaleXic2XimPiPiPiLLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xic_ADMASS_WIN": 90.0, + "Xic_PVDispCut_DDD": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_DDL": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_LLL": "(BPVVDCHI2 > 16.0)", + "Xic_VCHI2VDOF_MAX_DDD": 5.0, + "Xic_VCHI2VDOF_MAX_DDL": 5.0, + "Xic_VCHI2VDOF_MAX_LLL": 5.0, + "Xic_acosBPVDIRA_MAX_DDD": 0.14, + "Xic_acosBPVDIRA_MAX_DDL": 0.14, + "Xic_acosBPVDIRA_MAX_LLL": 0.14, + "Xim_FDCHI2_MIN": 9, + "Xim_PT_MIN": 250.0, + "Xim_P_MIN": 2000.0, + "Xim_VCHI2VDOF_MAX": 12.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Lambdac2LambdaEtaPi = { + "BUILDERTYPE": "StrippingLambdac2LambdaEtaPi", + "CONFIG": { + "GEC_nLongTrk": 160, + "GhostProb": 0.3, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 250.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "LambdaDDCutFDChi2": 100.0, + "LambdaDDCutMass": 50.0, + "LambdaDDPMin": 2000.0, + "LambdaDDPTMin": 500.0, + "LambdaLLCutFDChi2": 100.0, + "LambdaLLCutMass": 50.0, + "LambdaLLPMin": 2000.0, + "LambdaLLPTMin": 500.0, + "LambdaVertexChi2": 10.0, + "Lb_APT_Min": 1500.0, + "Lb_AP_Min": 20000.0, + "Lb_BPVDIRA_Min": 0.95, + "Lb_BPVVDCHI2_Min": 16, + "Lb_M_HalfWin": 200.0, + "Lb_VCHI2_Max": 30, + "Lc_ADOCAMAX_Max": 0.15, + "Lc_APT_Min": 1200.0, + "Lc_AP_Min": 15000.0, + "Lc_BPVDIRA_Min": 0.95, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDZ_Min": 0.5, + "Lc_Daug_1of3_MIPCHI2DV_Min": 3.0, + "Lc_M_HalfWin": 200.0, + "Lc_VCHI2_Max": 30.0, + "MINIPCHI2": 3.0, + "MuonIPCHI2": 4.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 250.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.4, + "ProbNNpiMax": 0.9, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "signalPrescale": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Lambdac2PEta = { + "BUILDERTYPE": "StrippingLambdac2PEta", + "CONFIG": { + "GEC_nLongTrk": 160, + "Lb_APT_Min": 1500.0, + "Lb_AP_Min": 20000.0, + "Lb_BPVDIRA_Min": 0.95, + "Lb_BPVVDCHI2_Min": 16, + "Lb_BPVVDZ_Min": 0.7, + "Lb_M_HalfWin": 200.0, + "Lb_VCHI2_Max": 30, + "Lc_ADOCAMAX_Max": 0.15, + "Lc_APT_Min": 1200.0, + "Lc_AP_Min": 15000.0, + "Lc_BPVDIRA_Min": 0.95, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDZ_Min": 0.5, + "Lc_Daug_1of3_MIPCHI2DV_Min": 3.0, + "Lc_M_HalfWin": 200.0, + "Lc_VCHI2_Max": 30.0, + "MINIPCHI2": 3.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "ProbNNp": 0.4, + "ProbNNpi": 0.4, + "ProbNNpiMax": 0.9, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "signalPrescale": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +NeutralCBaryons = { + "BUILDERTYPE": "StrippingNeutralCBaryonsConf", + "CONFIG": { + "Bachelor_PT_MIN": 50.0, + "KaonPIDK": -5.0, + "LambdaDDMassWin": 5.7, + "LambdaDDMaxVZ": 2275.0, + "LambdaDDMinVZ": 400.0, + "LambdaDDVtxChi2Max": 5.0, + "LambdaDeltaZ_MIN": 5.0, + "LambdaLLMassWin": 5.7, + "LambdaLLMaxVZ": 400.0, + "LambdaLLMinDecayTime": 0.005, + "LambdaLLMinVZ": -100.0, + "LambdaLLVtxChi2Max": 5.0, + "LambdaPi_PT_MIN": 100.0, + "LambdaPr_PT_MIN": 500.0, + "PionPIDK": 10.0, + "ProbNNkMin": 0.1, + "ProbNNpMinDD": 0.05, + "ProbNNpMinLL": 0.1, + "ProtonPIDp": 5, + "ProtonPIDpK": -3, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "tight_KaonPIDK": 0.0, + "tight_KaonPIDpi": 5.0, + "tight_ProtonPIDp": 7, + "tight_ProtonPIDpK": 0.0, + "tight_ProtonPIDppi": 5.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Xib2Xic0PiXic02pK = { + "BUILDERTYPE": "StrippingXib2Xic0PiXic02pKConf", + "CONFIG": { + "PionPIDK": 10.0, + "ProbNNkMin": 0.1, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "tight_KaonPIDK": 0.0, + "tight_KaonPIDpi": 5.0, + "tight_ProtonPIDp": 7, + "tight_ProtonPIDpK": 0.0, + "tight_ProtonPIDppi": 5.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Xic0ToXiMuNu = { + "BUILDERTYPE": "Xic0ToXiMuNuConf", + "CONFIG": { + "RequiredRawEvents": [ "Velo" ], + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "bach_muon": { + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)", + "tes": "Phys/StdAllNoPIDsMuons/Particles" + }, + "bach_pion": { + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)", + "tes": "Phys/StdAllNoPIDsPions/Particles" + }, + "descriptor_xi": [ + "[Xi- -> Lambda0 pi-]cc" + ], + "descriptor_ximu": [ + "[Xi_c0 -> Xi- mu+]cc" + ], + "down_pion": { + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)", + "tes": "Phys/StdNoPIDsDownPions/Particles" + }, + "lambda_dd": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) &\n (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)", + "tes": "Phys/StdLooseLambdaDD/Particles" + }, + "lambda_ll": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) &\n (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & \n (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)", + "tes": "Phys/StdVeryLooseLambdaLL/Particles" + }, + "xc0_ddd": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)" + }, + "xc0_ddl": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) " + }, + "xc0_lll": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & \n (P>8*GeV) & (PT>400*MeV) " + } + }, + "STREAMS": { + "CharmCompleteEvent": [ + "StrippingXic0ToXiMuNu_LLLLine", + "StrippingXic0ToXiMuNu_DDLLine", + "StrippingXic0ToXiMuNu_DDDLine" + ] + }, + "WGs": [ "Charm" ] +} + +Xic0ToXiMuNu_WS = { + "BUILDERTYPE": "Xic0ToXiMuNu_WSConf", + "CONFIG": { + "RequiredRawEvents": [ "Velo" ], + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "bach_muon": { + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)", + "tes": "Phys/StdAllNoPIDsMuons/Particles" + }, + "bach_pion": { + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)", + "tes": "Phys/StdAllNoPIDsPions/Particles" + }, + "descriptor_xi": [ + "[Xi- -> Lambda0 pi-]cc" + ], + "descriptor_ximu": [ + "[Xi_c0 -> Xi- mu-]cc" + ], + "down_pion": { + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)", + "tes": "Phys/StdNoPIDsDownPions/Particles" + }, + "lambda_dd": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) &\n (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)", + "tes": "Phys/StdLooseLambdaDD/Particles" + }, + "lambda_ll": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) &\n (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & \n (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)", + "tes": "Phys/StdVeryLooseLambdaLL/Particles" + }, + "xc0_ddd": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)" + }, + "xc0_ddl": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) " + }, + "xc0_lll": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & \n (P>8*GeV) & (PT>400*MeV) " + } + }, + "STREAMS": { + "CharmCompleteEvent": [ + "StrippingXic0ToXiMuNu_WS_LLLLine", + "StrippingXic0ToXiMuNu_WS_DDLLine", + "StrippingXic0ToXiMuNu_WS_DDDLine" + ] + }, + "WGs": [ "Charm" ] +} + +Xic2PHH = { + "BUILDERTYPE": "StrippingXic2PHH", + "CONFIG": { + "BPVIPCHI2_Phi": 4, + "GEC_nLongTrk": 250, + "GhostProb": 0.3, + "KSCutDIRA_DD": 0.999, + "KSCutDIRA_LL": 0.999, + "KSCutFDChi2_DD": 5, + "KSCutFDChi2_LL": 5, + "KSCutMass_DD": 50.0, + "KSCutMass_LL": 35.0, + "KaonP": 2000.0, + "KaonPIDK": 10.0, + "KaonPT": 200.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "MINIPCHI2": 4.0, + "MaxDz_DD": 9999.0, + "MaxDz_LL": 9999.0, + "MaxKsVCHI2NDOF_DD": 20.0, + "MaxKsVCHI2NDOF_LL": 20.0, + "MaxPhiEta": 5.0, + "MinDz_DD": 250.0, + "MinDz_LL": 0.0, + "MinKsIpChi2_DD": 3, + "MinKsIpChi2_LL": 3, + "MinKsPT_DD": 200.0, + "MinKsPT_LL": 200.0, + "MinPhiEta": 2.0, + "MinPhiP": 3000.0, + "MinPhiPT": 200.0, + "PhiCutMass": 20.0, + "PionP": 3000.0, + "PionPIDK": 10.0, + "PionPT": 500.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.95, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "Xic_ADAMASS_HalfWin": 170.0, + "Xic_ADMASS_HalfWin": 120.0, + "Xic_AM_Max": 2550.0, + "Xic_BPVDIRA_Min": 0.9, + "Xic_BPVVDCHI2_Min": 25.0, + "pKK_AM_Min": 2380.0, + "ppipi_AM_Min": 2380.0, + "signalPrescaleViaXicPKK": 1.0, + "signalPrescaleViaXicPKS0DD": 1.0, + "signalPrescaleViaXicPKS0LL": 1.0, + "signalPrescaleViaXicPPhi2KK": 1.0, + "signalPrescaleViaXicPPiPi": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + diff --git a/Phys/StrippingSettings/python/StrippingSettings/Stripping34r0p3/LineConfigDictionaries_Charm.py b/Phys/StrippingSettings/python/StrippingSettings/Stripping34r0p3/LineConfigDictionaries_Charm.py index a40c91384..ddd0f4db8 100644 --- a/Phys/StrippingSettings/python/StrippingSettings/Stripping34r0p3/LineConfigDictionaries_Charm.py +++ b/Phys/StrippingSettings/python/StrippingSettings/Stripping34r0p3/LineConfigDictionaries_Charm.py @@ -1,5 +1,5 @@ ############################################################################### -# (c) Copyright 2000-2019 CERN for the benefit of the LHCb Collaboration # +# (c) Copyright 2000-2023 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". # @@ -16,3 +16,937 @@ ## Contact person: Sergio Jaimes (sergio.jaimes@cern.ch) ## ################################################################################ +Charm2PPX = { + "BUILDERTYPE": "StrippingCharm2PPXConf", + "CONFIG": { + "Comb_ADOCACHI2_MAX": 16, + "Daug_1ofAll_BPVIPCHI2_MIN": 9.0, + "Daug_1ofAll_PT_MIN": 700.0, + "Daug_All_BPVIPCHI2_MIN": 4.0, + "Daug_All_CloneDist_MIN": 5000, + "Daug_All_MIPCHI2_MIN": 4.0, + "Daug_All_PT_MIN": 200.0, + "Daug_All_TrChostProb_MAX": 0.5, + "Daug_ETA_MAX": 4.9, + "Daug_ETA_MIN": 2.0, + "Daug_P_MAX": 100000.0, + "Daug_P_MIN": 3200.0, + "Hc_BPVCTAU_MIN": 0.05, + "Hc_BPVVDCHI2_MIN": 9.0, + "Hc_MASS_MAX": 3500.0, + "Hc_PT_MIN": 1000.0, + "Hc_VCHI2VDOF_MAX": 25.0, + "Hcs_MASS_MAX": 3650.0, + "Hlt1Filter": None, + "Hlt2Filter": None, + "HsComb_ADOCACHI2_MAX": 16, + "HsDaug_1ofAll_BPVIPCHI2_MIN": 9.0, + "HsDaug_1ofAll_PT_MIN": -500.0, + "HsDownDaug_1ofAll_BPVIPCHI2_MIN": -9.0, + "HsDown_BPVVDCHI2_MIN": 4.0, + "HsProton_1ofAll_ProbNN_MIN": 0.5, + "Hs_BPVCTAU_MIN": 0.1, + "Hs_BPVVDCHI2_MIN": 9.0, + "Hs_MASS_MAX": 2125.0, + "Hs_PT_MIN": -1000.0, + "Hs_VCHI2VDOF_MAX": 25.0, + "Kaon_ProbNN_MIN": 0.1, + "Lam_MASS_MAX": 1170.0, + "Lc_MASS_MAX": 2350.0, + "Pc_MASS_MAX": 3100.0, + "Pion_ProbNN_MIN": 0.1, + "PostscaleHc2LamPPi": 1.0, + "PostscaleHc2LamPPiPi": 1.0, + "PostscaleHc2PP": 1.0, + "PostscaleHc2PPK": 1.0, + "PostscaleHc2PPKPi": 1.0, + "PostscaleHc2PPKPiPi": 1.0, + "PostscaleHc2PPKs": 1.0, + "PostscaleHc2PPKsPi": 1.0, + "PostscaleHcs2LamLamPi": 1.0, + "PostscaleHcs2LamPKPi": 1.0, + "PostscaleHcs2PPKKPi": 1.0, + "PostscaleHcs2PPKsK": 1.0, + "PostscaleHs2PPPi": 1.0, + "PostscaleL2PPi": 1.0, + "PostscaleLc2PKPi": 1.0, + "PostscalePc2PKPiPi": 1.0, + "PostscalePc2PKsPi": 1.0, + "PostscalePs2PPiPi": 1.0, + "PrescaleHc2LamPPi": 1.0, + "PrescaleHc2LamPPiPi": 1.0, + "PrescaleHc2PP": 1.0, + "PrescaleHc2PPK": 1.0, + "PrescaleHc2PPKPi": 1.0, + "PrescaleHc2PPKPiPi": 1.0, + "PrescaleHc2PPKs": 1.0, + "PrescaleHc2PPKsPi": 1.0, + "PrescaleHcs2LamLamPi": 1.0, + "PrescaleHcs2LamPKPi": 1.0, + "PrescaleHcs2PPKKPi": 1.0, + "PrescaleHcs2PPKsK": 1.0, + "PrescaleHs2PPPi": 1.0, + "PrescaleL2PPi": 0.01, + "PrescaleLc2PKPi": 0.01, + "PrescalePc2PKPiPi": 0.1, + "PrescalePc2PKsPi": 0.1, + "PrescalePs2PPiPi": 0.1, + "Proton_1ofAll_ProbNN_MIN": 0.5, + "Proton_PT_MIN": 300.0, + "Proton_P_MIN": 10000.0, + "Proton_ProbNN_MIN": 0.1, + "Proton_ProbNNk_MAX": 0.8, + "Proton_ProbNNpi_MAX": 0.55, + "Ps_MASS_MAX": 1650.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +CharmedBaryonSL = { + "BUILDERTYPE": "StrippingCharmedBaryonSL", + "CONFIG": { + "GEC_nLongTrk": 250, + "GhostProb": 0.3, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 500.0, + "KaonPT_ForOm": 100.0, + "KaonP_ForOm": 2000.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "L0Mu_AM_Min": 1250.0, + "LambdaCutDIRA": 0.99, + "LambdaDDCutFDChi2": 100.0, + "LambdaDDCutMass": 20.0, + "LambdaDDMaxVZ": 2275.0, + "LambdaDDMinVZ": 400.0, + "LambdaDDPMin": 5000.0, + "LambdaDDPTMin": 800.0, + "LambdaDaugTrackChi2": 4.0, + "LambdaLDCutFDChi2": 100.0, + "LambdaLDCutMass": 20.0, + "LambdaLDPMin": 3000.0, + "LambdaLDPTMin": 800.0, + "LambdaLLCutFDChi2": 100.0, + "LambdaLLCutMass": 20.0, + "LambdaLLMaxVZ": 400.0, + "LambdaLLMinVZ": -100.0, + "LambdaLLPMin": 5000.0, + "LambdaLLPTMin": 800.0, + "LambdaPi_PT_MIN": 100.0, + "LambdaPr_PT_MIN": 500.0, + "LambdaVertexChi2": 5.0, + "Lc_ADMASS_HalfWin": 80.0, + "Lc_ADMASS_HalfWin_Tight": 55.0, + "Lc_ADOCAMAX_Max": 0.5, + "Lc_ADOCAMAX_Max_Tight": 0.15, + "Lc_AM_Max": 2370.0, + "Lc_APT_Min": 1000.0, + "Lc_APT_Min_Tight_PKMu": 1600.0, + "Lc_APT_Min_Tight_PPiMu": 1600.0, + "Lc_AP_Min_Tight": 25000.0, + "Lc_BPVDIRA_Min": 0.9, + "Lc_BPVDIRA_Min_Tight": 0.99, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDCHI2_Min_Tight": 25.0, + "Lc_Daug_1of3_MIPCHI2DV_Min": 4.0, + "Lc_Daug_1of3_MIPCHI2DV_Min_Tight": 9.0, + "Lc_VCHI2_Max": 30.0, + "Lc_VCHI2_Max_Tight": 20.0, + "MINIPCHI2": 4.0, + "MisID_PROB_Max": 0.7, + "MuonIPCHI2": 5.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 500.0, + "Oc_AM_Max": 2780.0, + "OmMu_AM_Min": 1780.0, + "Omegac0_4Dau_VCHI2_Max": 60.0, + "Omegac0_ADAMASS_HalfWin": 170.0, + "Omegac0_ADMASS_HalfWin": 120.0, + "Omegac0_BPVDIRA_Min": 0.9, + "Omegac0_BPVVDCHI2_Min": 25.0, + "P_Min_Tight": 3500.0, + "PionP": 3000.0, + "PionPIDK": 10.0, + "PionPT": 500.0, + "PionPT_ForXi": 100.0, + "PionP_ForXi": 2000.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.95, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "XiMu_AM_Min": 1430.0, + "Xic_ADAMASS_HalfWin": 170.0, + "Xic_ADMASS_HalfWin": 120.0, + "Xic_AM_Max": 2550.0, + "Xic_BPVDIRA_Min": 0.9, + "Xic_BPVVDCHI2_Min": 25.0, + "controlPrescaleViaLcL0DDPiNC": 0.8, + "controlPrescaleViaLcL0LLPiNC": 0.4, + "controlPrescaleViaLcPKPiNC": 0.09, + "controlPrescaleViaLcPKPiNC_Tight": 0.5, + "controlPrescaleViaLcPPiPiNC": 0.06, + "controlPrescaleViaLcPPiPiNC_Tight": 0.5, + "controlPrescaleViaOmegac0NC": 1.0, + "controlPrescaleViaXicL0DDPiNC": 0.8, + "controlPrescaleViaXicL0LLPiNC": 0.4, + "controlPrescaleViaXicXiPiNC": 1.0, + "pKMu_AM_Min": 1550.0, + "ppiMu_AM_Min": 1200.0, + "signalPrescaleViaLc": 1.0, + "signalPrescaleViaLcL0DDMuNu": 0.8, + "signalPrescaleViaLcPKMuNu_Tight": 1.0, + "signalPrescaleViaLcPPiMuNu": 0.25, + "signalPrescaleViaLcPPiMuNu_Tight": 1.0, + "signalPrescaleViaOmegac0": 1.0, + "signalPrescaleViaXic": 1.0, + "signalPrescaleViaXicL0DDMuNu": 0.8, + "signalPrescaleViaXicL0LLMuNu": 0.8 + }, + "STREAMS": [ "CharmCompleteEvent" ], + "WGs": [ "Charm" ] +} + +CharmedMesonSL = { + "BUILDERTYPE": "StrippingCharmedMesonSL", + "CONFIG": { + "B0SL_M_Max": 5600.0, + "B0SL_M_Min": 2800.0, + "B0_M_Max": 5600.0, + "B0_M_Min": 5100.0, + "B_APT_Min": 1500.0, + "B_AP_Min": 20000.0, + "B_BPVDIRA_Min": 0.95, + "B_BPVVDCHI2_Min": 16, + "B_VCHI2_Max": 30, + "BpSL_M_Max": 5700.0, + "BpSL_M_Min": 3000.0, + "Bp_M_Max": 5500.0, + "Bp_M_Min": 5100.0, + "D0SL_AM_Max": 1960.0, + "D0_ADMASS_Max": 1900.0, + "D0_ADMASS_Min": 1820.0, + "DpSL_AM_Max": 2080.0, + "Dp_ADMASS_Max": 2030.0, + "Dp_ADMASS_Min": 1800.0, + "Dp_ADOCAMAX_Max": 0.25, + "Dp_APT_Min": 1200.0, + "Dp_AP_Min": 20000.0, + "Dp_BPVDIRA_Min": 0.95, + "Dp_BPVVDCHI2_Min": 16.0, + "Dp_Daug_1of3_MIPCHI2DV_Min": 4.0, + "Dp_VCHI2_Max": 30.0, + "EtaPiMu_AM_Min": 800.0, + "GEC_nLongTrk": 160, + "GhostProb": 0.3, + "KKMu_AM_Min": 1100.0, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 250.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "MINIPCHI2": 4.0, + "MuonIPCHI2": 4.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 250.0, + "PiKKMu_AM_Min": 1240.0, + "PiPiMu_AM_Min": 400.0, + "PiPiPiMu_AM_Min": 530.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.9, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "controlPrescaleViaD02KKpipi": 1.0, + "controlPrescaleViaD02etapipi": 1.0, + "controlPrescaleViaD02pipipipi": 1.0, + "controlPrescaleViaD2KKpi": 1.0, + "controlPrescaleViaD2pipipi": 1.0, + "signalPrescaleViaD02KKpimunu": 1.0, + "signalPrescaleViaD02etapimunu": 1.0, + "signalPrescaleViaD02pipipimunu": 1.0, + "signalPrescaleViaD2KKmunu": 1.0, + "signalPrescaleViaD2pipimunu": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +DstarD02ETau = { + "BUILDERTYPE": "StrippingDstarD02ETauConf", + "CONFIG": { + "CUTBASED_MCORR_B_HIGH": "8600", + "CUTBASED_MCORR_B_LOW": "3600", + "CUTBASED_MCORR_D0_HIGH": "8000", + "CUTBASED_MCORR_D0_LOW": "1000", + "CUTBASED_MISS_MASS": "876", + "CUTBASED_MISS_MASS_HIGH": "250", + "CUTBASED_MISS_MASS_HIGH_KTHREEPI": "1500", + "CUTBASED_MISS_MASS_LOW": "0", + "CUTBASED_M_B": "2865", + "CUTBASED_M_D0_HIGH": "2000", + "CUTBASED_M_D0_LOW": "500", + "CUTBASED_M_TAU_HIGH": "1592", + "CUTBASED_M_TAU_LOW": "829", + "CUTBASED_PROBNNE_E": "0.1", + "CUTBASED_PROBNNK_K": "0.2", + "CUTBASED_PROBNNPI_THREE_PI": "0.5", + "CUTBASED_TAU_BPVVDCHI2": "16", + "CUTBASED_TAU_BPVVDRHO": "0.33", + "CUTBASED_TAU_BPVVDRHO_HIGH": "7", + "CUTBASED_TAU_BPVVDRHO_LOW": "0.05", + "CUTBASED_TAU_BPVVDZ": "0.5", + "CUTBASED_TAU_TAU_HIGH": "3", + "CUTBASED_TAU_TAU_LOW": "-2.5", + "CUTBASED_TAU_VCHI2": "16", + "CUTBASED_VCHI2_TAU": "20.6", + "ConeAngles": { + "08": 0.8, + "10": 1.0, + "12": 1.2, + "14": 1.4 + }, + "ConeVariables": [ + "CONEANGLE", + "CONEMULT", + "CONEPTASYM" + ], + "DstD0DMWin_HIGH": "100.", + "DstD0DMWin_LOW": "-10.", + "DstMassWin_HIGH": "100.", + "DstMassWin_LOW": "-1250.", + "DstmVtxChi2": "10.", + "HLT_DECISIONS_HAD": { + "Hlt2Topo(2|3|4)Body.*Decision%TOS": 0 + }, + "MINIPCHI2BPV_E": "16", + "MINIPCHI2BPV_PI_FROM_DTSM": "10", + "MINIPCHI2BPV_THREE_PI": "16", + "MINIPCHI2PV_D0": "50", + "PROBNNGHOST_E": "0.4", + "PROBNNGHOST_THREE_PI": "0.4", + "PT_D0": "1000", + "PT_E": "110", + "PT_PI_FROM_DTSM": "110", + "PT_THREE_PI": "110", + "P_D0": "2000", + "P_E": "0", + "P_THREE_PI": "500", + "PrescaleETauBox": 1.0, + "PrescaleETauSSBox": 1.0, + "PrescaleK3piBox": 0.025, + "PrescaleK3piSSBox": 0.025, + "RelInfoTools_D02ETau": [ + { + "DaughterLocations": { + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_VertexIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_VertexIsoInfo" + }, + "Location": "DstVars_VertexIsoInfo", + "Type": "RelInfoVertexIsolation" + }, + { + "ConeSize": 0.5, + "DaughterLocations": { + "[D*(2010)+ -> (Charm -> ^l l) pi+]CC": "Tau_ConeIsoInfo", + "[D*(2010)+ -> (Charm -> l ^l) pi+]CC": "E_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) ^pi+]CC": "pi_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> l l) pi+]CC": "D0_ConeIsoInfo" + }, + "Location": "DstVars_ConeIsoInfo", + "Type": "RelInfoConeIsolation", + "Variables": [] + } + ], + "RelInfoTools_D02K3pi": [ + { + "DaughterLocations": { + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_VertexIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_VertexIsoInfo" + }, + "Location": "DstVars_VertexIsoInfo", + "Type": "RelInfoVertexIsolation" + }, + { + "ConeSize": 0.5, + "DaughterLocations": { + "[D*(2010)+ -> ^(Charm -> X X X X) ^pi+]CC": "pi_ConeIsoInfo", + "[D*(2010)+ -> ^(Charm -> X X X X) pi+]CC": "D0_ConeIsoInfo" + }, + "Location": "DstVars_ConeIsoInfo", + "Type": "RelInfoConeIsolation", + "Variables": [] + } + ], + "TAU_AMAXDOCA_PIS": "0.2", + "TAU_BPVDIRA": "-1.", + "TAU_M_HIGH": "2100", + "TAU_M_HIGH_COMB": "2100", + "TAU_M_LOW": "400", + "TAU_M_LOW_COMB": "400", + "TAU_PT": "700.", + "TRACKCHI2_E": "4", + "TRACKCHI2_PI_FROM_DTSM": "7", + "TRACKCHI2_THREE_PI": "4", + "TRGHOPROB_E": "0.4", + "TRGHOPROB_THREE_PI": "0.4", + "prefix": "" + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V02H = { + "BUILDERTYPE": "StrippingHc2V02HConf", + "CONFIG": { + "Bach_PT_MIN": 250.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 120.0, + "Comb_ADOCAMAX_MAX": 0.4, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN_DD": 4, + "Lambda0_FDCHI2_MIN_LL": 4, + "Lambda0_PT_MIN": 250.0, + "Lambda0_P_MIN": 6000.0, + "Lambda0_VCHI2VDOF_MAX_DD": 25.0, + "Lambda0_VCHI2VDOF_MAX_LL": 12.0, + "LambdaMinFD_DD": 500.0, + "LambdaMinFD_LL": 5.0, + "MIPCHI2DV_PRIMARY_Min": 2, + "PostscaleXic2LambdaKKDD": 1.0, + "PostscaleXic2LambdaKKLL": 1.0, + "PostscaleXic2LambdaKPiDD": 1.0, + "PostscaleXic2LambdaKPiLL": 1.0, + "PostscaleXic2LambdaPiKDD": 1.0, + "PostscaleXic2LambdaPiKLL": 1.0, + "PostscaleXic2LambdaPiPiDD": 1.0, + "PostscaleXic2LambdaPiPiLL": 1.0, + "PrescaleXic2LambdaKKDD": 1.0, + "PrescaleXic2LambdaKKLL": 1.0, + "PrescaleXic2LambdaKPiDD": 1.0, + "PrescaleXic2LambdaKPiLL": 1.0, + "PrescaleXic2LambdaPiKDD": 1.0, + "PrescaleXic2LambdaPiKLL": 1.0, + "PrescaleXic2LambdaPiPiDD": 1.0, + "PrescaleXic2LambdaPiPiLL": 1.0, + "ProbNNkMin": 0.1, + "ProbNNpMin_L0_DD": 0.1, + "ProbNNpMin_L0_LL": 0.1, + "ProbNNpiMin": 0.1, + "ProbNNpiMin_L0_DD": 0.1, + "ProbNNpiMin_L0_LL": 0.1, + "TrGhostProbMax": 0.3, + "Xic_ADMASS_WIN": 90.0, + "Xic_PT_min": 250.0, + "Xic_P_min": 10000.0, + "Xic_VCHI2VDOF_MAX_DD": 3.0, + "Xic_VCHI2VDOF_MAX_LL": 3.0, + "Xic_acosBPVDIRA_MAX_DD": 0.0316, + "Xic_acosBPVDIRA_MAX_LL": 0.02, + "p_L0_PT_LL_min": 100.0, + "p_L0_P_LL_min": 2000.0, + "pi_L0_PT_LL_min": 100.0, + "pi_L0_P_LL_min": 2000.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V03H = { + "BUILDERTYPE": "StrippingHc2V03HConf", + "CONFIG": { + "Bach_IPCHI2_MAX": 9, + "Bach_IPCHI2_MIN": 1, + "Bach_PT_MIN": 150.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 90.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 49, + "Lambda0_PT_MIN": 500.0, + "Lambda0_P_MIN": 10000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "LambdaMinFD_DD": 200.0, + "LambdaMinFD_LL": 25.0, + "Lambdac_ADMASS_WIN": 75.0, + "Lambdac_PVDispCut_DD": "(BPVVDCHI2 > 9.0)", + "Lambdac_PVDispCut_LL": "(BPVVDCHI2 > 16.0)", + "Lambdac_VCHI2VDOF_MAX_DD": 3.0, + "Lambdac_VCHI2VDOF_MAX_LL": 3.0, + "Lambdac_acosBPVDIRA_MAX_DD": 0.045, + "Lambdac_acosBPVDIRA_MAX_LL": 0.14, + "PostscaleLambdac2Lambda3PiDD": 1.0, + "PostscaleLambdac2Lambda3PiLL": 1.0, + "PostscaleLambdac2LambdaK2PiDD": 1.0, + "PostscaleLambdac2LambdaK2PiLL": 1.0, + "PostscaleXic2LambdaK2PiDD": 1.0, + "PostscaleXic2LambdaK2PiLL": 1.0, + "PrescaleLambdac2Lambda3PiDD": 1.0, + "PrescaleLambdac2Lambda3PiLL": 1.0, + "PrescaleLambdac2LambdaK2PiDD": 1.0, + "PrescaleLambdac2LambdaK2PiLL": 1.0, + "PrescaleXic2LambdaK2PiDD": 1.0, + "PrescaleXic2LambdaK2PiLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xic_ADMASS_WIN": 75.0, + "Xic_PVDispCut_DD": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_LL": "(BPVVDCHI2 > 16.0)", + "Xic_VCHI2VDOF_MAX_DD": 3.0, + "Xic_VCHI2VDOF_MAX_LL": 3.0, + "Xic_acosBPVDIRA_MAX_DD": 0.045, + "Xic_acosBPVDIRA_MAX_LL": 0.14 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V2H = { + "BUILDERTYPE": "StrippingHc2V2HConf", + "CONFIG": { + "Bach_PT_MIN": 150.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 120.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hc_ADMASS_WIN": 90.0, + "Hc_PVDispCut_DDD": "(BPVVDCHI2 > 9.0)", + "Hc_PVDispCut_DDL": "(BPVVDCHI2 > 16.0)", + "Hc_PVDispCut_LLL": "(BPVVDCHI2 > 16.0)", + "Hc_VCHI2VDOF_MAX_DDD": 12.0, + "Hc_VCHI2VDOF_MAX_DDL": 12.0, + "Hc_VCHI2VDOF_MAX_LLL": 12.0, + "Hc_acosBPVDIRA_MAX_DDD": 0.14, + "Hc_acosBPVDIRA_MAX_DDL": 0.045, + "Hc_acosBPVDIRA_MAX_LLL": 0.14, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 49, + "Lambda0_PT_MIN": 250.0, + "Lambda0_P_MIN": 2000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "LambdaMinFD_DD": 0.0, + "LambdaMinFD_LL": 25.0, + "PostscaleLambdac2XiKPiDDD": 1.0, + "PostscaleLambdac2XiKPiDDL": 1.0, + "PostscaleLambdac2XiKPiLLL": 1.0, + "PostscaleXic2XiPiPiDDD": 1.0, + "PostscaleXic2XiPiPiDDL": 1.0, + "PostscaleXic2XiPiPiLLL": 1.0, + "PrescaleLambdac2XiKPiDDD": 1.0, + "PrescaleLambdac2XiKPiDDL": 1.0, + "PrescaleLambdac2XiKPiLLL": 1.0, + "PrescaleXic2XiPiPiDDD": 1.0, + "PrescaleXic2XiPiPiDDL": 1.0, + "PrescaleXic2XiPiPiLLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xim_FDCHI2_MIN": 16, + "Xim_PT_MIN": 250.0, + "Xim_P_MIN": 2000.0, + "Xim_VCHI2VDOF_MAX": 12.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Hc2V3H = { + "BUILDERTYPE": "StrippingHc2V3HConf", + "CONFIG": { + "Bach_IPCHI2_MAX": 9, + "Bach_IPCHI2_MIN": 1, + "Bach_PT_MIN": 200.0, + "Bach_P_MIN": 2000.0, + "Comb_ADAMASS_WIN": 120.0, + "Comb_ADOCAMAX_MAX": 0.5, + "Hlt1Filter": None, + "Hlt2Filter": None, + "Lambda0_FDCHI2_MIN": 25, + "Lambda0_PT_MIN": 250.0, + "Lambda0_P_MIN": 2000.0, + "Lambda0_VCHI2VDOF_MAX": 12.0, + "PostscaleXic2XimPiPiPiDDD": 1.0, + "PostscaleXic2XimPiPiPiDDL": 1.0, + "PostscaleXic2XimPiPiPiLLL": 1.0, + "PrescaleXic2XimPiPiPiDDD": 1.0, + "PrescaleXic2XimPiPiPiDDL": 1.0, + "PrescaleXic2XimPiPiPiLLL": 1.0, + "ProbNNpMin_DD": 0.0, + "ProbNNpMin_LL": 0.1, + "Xic_ADMASS_WIN": 90.0, + "Xic_PVDispCut_DDD": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_DDL": "(BPVVDCHI2 > 9.0)", + "Xic_PVDispCut_LLL": "(BPVVDCHI2 > 16.0)", + "Xic_VCHI2VDOF_MAX_DDD": 5.0, + "Xic_VCHI2VDOF_MAX_DDL": 5.0, + "Xic_VCHI2VDOF_MAX_LLL": 5.0, + "Xic_acosBPVDIRA_MAX_DDD": 0.14, + "Xic_acosBPVDIRA_MAX_DDL": 0.14, + "Xic_acosBPVDIRA_MAX_LLL": 0.14, + "Xim_FDCHI2_MIN": 9, + "Xim_PT_MIN": 250.0, + "Xim_P_MIN": 2000.0, + "Xim_VCHI2VDOF_MAX": 12.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Lambdac2LambdaEtaPi = { + "BUILDERTYPE": "StrippingLambdac2LambdaEtaPi", + "CONFIG": { + "GEC_nLongTrk": 160, + "GhostProb": 0.3, + "KaonP": 3000.0, + "KaonPIDK": 10.0, + "KaonPT": 250.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "LambdaDDCutFDChi2": 100.0, + "LambdaDDCutMass": 50.0, + "LambdaDDPMin": 2000.0, + "LambdaDDPTMin": 500.0, + "LambdaLLCutFDChi2": 100.0, + "LambdaLLCutMass": 50.0, + "LambdaLLPMin": 2000.0, + "LambdaLLPTMin": 500.0, + "LambdaVertexChi2": 10.0, + "Lb_APT_Min": 1500.0, + "Lb_AP_Min": 20000.0, + "Lb_BPVDIRA_Min": 0.95, + "Lb_BPVVDCHI2_Min": 16, + "Lb_M_HalfWin": 200.0, + "Lb_VCHI2_Max": 30, + "Lc_ADOCAMAX_Max": 0.15, + "Lc_APT_Min": 1200.0, + "Lc_AP_Min": 15000.0, + "Lc_BPVDIRA_Min": 0.95, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDZ_Min": 0.5, + "Lc_Daug_1of3_MIPCHI2DV_Min": 3.0, + "Lc_M_HalfWin": 200.0, + "Lc_VCHI2_Max": 30.0, + "MINIPCHI2": 3.0, + "MuonIPCHI2": 4.0, + "MuonP": 3000.0, + "MuonPIDmu": 0.0, + "MuonPT": 250.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.4, + "ProbNNpiMax": 0.9, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "signalPrescale": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Lambdac2PEta = { + "BUILDERTYPE": "StrippingLambdac2PEta", + "CONFIG": { + "GEC_nLongTrk": 160, + "Lb_APT_Min": 1500.0, + "Lb_AP_Min": 20000.0, + "Lb_BPVDIRA_Min": 0.95, + "Lb_BPVVDCHI2_Min": 16, + "Lb_BPVVDZ_Min": 0.7, + "Lb_M_HalfWin": 200.0, + "Lb_VCHI2_Max": 30, + "Lc_ADOCAMAX_Max": 0.15, + "Lc_APT_Min": 1200.0, + "Lc_AP_Min": 15000.0, + "Lc_BPVDIRA_Min": 0.95, + "Lc_BPVVDCHI2_Min": 16.0, + "Lc_BPVVDZ_Min": 0.5, + "Lc_Daug_1of3_MIPCHI2DV_Min": 3.0, + "Lc_M_HalfWin": 200.0, + "Lc_VCHI2_Max": 30.0, + "MINIPCHI2": 3.0, + "PionP": 3000.0, + "PionPIDK": 5.0, + "PionPT": 250.0, + "ProbNNp": 0.4, + "ProbNNpi": 0.4, + "ProbNNpiMax": 0.9, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "signalPrescale": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +NeutralCBaryons = { + "BUILDERTYPE": "StrippingNeutralCBaryonsConf", + "CONFIG": { + "Bachelor_PT_MIN": 50.0, + "KaonPIDK": -5.0, + "LambdaDDMassWin": 5.7, + "LambdaDDMaxVZ": 2275.0, + "LambdaDDMinVZ": 400.0, + "LambdaDDVtxChi2Max": 5.0, + "LambdaDeltaZ_MIN": 5.0, + "LambdaLLMassWin": 5.7, + "LambdaLLMaxVZ": 400.0, + "LambdaLLMinDecayTime": 0.005, + "LambdaLLMinVZ": -100.0, + "LambdaLLVtxChi2Max": 5.0, + "LambdaPi_PT_MIN": 100.0, + "LambdaPr_PT_MIN": 500.0, + "PionPIDK": 10.0, + "ProbNNkMin": 0.1, + "ProbNNpMinDD": 0.05, + "ProbNNpMinLL": 0.1, + "ProtonPIDp": 5, + "ProtonPIDpK": -3, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "tight_KaonPIDK": 0.0, + "tight_KaonPIDpi": 5.0, + "tight_ProtonPIDp": 7, + "tight_ProtonPIDpK": 0.0, + "tight_ProtonPIDppi": 5.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Xib2Xic0PiXic02pK = { + "BUILDERTYPE": "StrippingXib2Xic0PiXic02pKConf", + "CONFIG": { + "PionPIDK": 10.0, + "ProbNNkMin": 0.1, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "tight_KaonPIDK": 0.0, + "tight_KaonPIDpi": 5.0, + "tight_ProtonPIDp": 7, + "tight_ProtonPIDpK": 0.0, + "tight_ProtonPIDppi": 5.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + +Xic0ToXiMuNu = { + "BUILDERTYPE": "Xic0ToXiMuNuConf", + "CONFIG": { + "RequiredRawEvents": [ "Velo" ], + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "bach_muon": { + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)", + "tes": "Phys/StdAllNoPIDsMuons/Particles" + }, + "bach_pion": { + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)", + "tes": "Phys/StdAllNoPIDsPions/Particles" + }, + "descriptor_xi": [ + "[Xi- -> Lambda0 pi-]cc" + ], + "descriptor_ximu": [ + "[Xi_c0 -> Xi- mu+]cc" + ], + "down_pion": { + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)", + "tes": "Phys/StdNoPIDsDownPions/Particles" + }, + "lambda_dd": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) &\n (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)", + "tes": "Phys/StdLooseLambdaDD/Particles" + }, + "lambda_ll": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) &\n (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & \n (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)", + "tes": "Phys/StdVeryLooseLambdaLL/Particles" + }, + "xc0_ddd": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)" + }, + "xc0_ddl": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) " + }, + "xc0_lll": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & \n (P>8*GeV) & (PT>400*MeV) " + } + }, + "STREAMS": { + "CharmCompleteEvent": [ + "StrippingXic0ToXiMuNu_LLLLine", + "StrippingXic0ToXiMuNu_DDLLine", + "StrippingXic0ToXiMuNu_DDDLine" + ] + }, + "WGs": [ "Charm" ] +} + +Xic0ToXiMuNu_WS = { + "BUILDERTYPE": "Xic0ToXiMuNu_WSConf", + "CONFIG": { + "RequiredRawEvents": [ "Velo" ], + "amass_ximu": "(in_range(1400*MeV,AMASS(),4500*MeV)) & ", + "bach_muon": { + "filter": "(PT>200*MeV) & (P>3000*MeV) & (PROBNNmu>0.3) & (BPVIPCHI2()>4)", + "tes": "Phys/StdAllNoPIDsMuons/Particles" + }, + "bach_pion": { + "filter": "(PT > 120*MeV) & (P > 1000*MeV) & (MIPDV(PRIMARY)>0.01*mm) & (MIPCHI2DV(PRIMARY) > 9.0) & (PROBNNpi>0.03)", + "tes": "Phys/StdAllNoPIDsPions/Particles" + }, + "descriptor_xi": [ + "[Xi- -> Lambda0 pi-]cc" + ], + "descriptor_ximu": [ + "[Xi_c0 -> Xi- mu-]cc" + ], + "down_pion": { + "filter": "(P>1000*MeV) & (PT>150*MeV) & (PROBNNpi>0.03)", + "tes": "Phys/StdNoPIDsDownPions/Particles" + }, + "lambda_dd": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>12*GeV) & (PT>400*MeV) & (CHILDIP(1)<2*mm) & (MAXTREE('p+'==ABSID,P)>9*GeV) & (CHI2VXNDF<30) &\n (MAXTREE('p+'==ABSID,PT)>200*MeV) & (MAXTREE('pi+'==ABSID,PT)>150*MeV) & (VFASPF(VZ) > 300.*mm) & (VFASPF(VZ) < 2485.*mm)", + "tes": "Phys/StdLooseLambdaDD/Particles" + }, + "lambda_ll": { + "filter": "(ADMASS('Lambda0')<20*MeV) & (P>6*GeV) & (PT>200*MeV) & (BPVVDZ>8*mm) & (BPVLTIME() > 2.0*ps) & (CHI2VXNDF<20) &\n (MAXTREE('p+'==ABSID,MIPCHI2DV(PRIMARY))>9) & (MAXTREE('pi-'==ABSID,MIPCHI2DV(PRIMARY))>24) & \n (MAXTREE('p+'==ABSID,PT)>100*MeV) & (MAXTREE('p+'==ABSID,P)>5.0*GeV) & (VFASPF(VZ) > -100.*mm) & (VFASPF(VZ) < 640.*mm) & (BPVVDCHI2 > 100)", + "tes": "Phys/StdVeryLooseLambdaLL/Particles" + }, + "xc0_ddd": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<5.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV)" + }, + "xc0_ddl": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<3.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>20*GeV) & (PT>200*MeV) " + }, + "xc0_lll": { + "comb_cut": "AHASCHILD( (ABSID == 'mu+') ) & (ADOCA(1,2)<1.5)", + "mother_cut": "(VFASPF(VCHI2/VDOF)<25) & (BPVVDCHI2>4) & (P>12*GeV) & (PT>200*MeV)" + }, + "xi_ddd": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>20) & (ADOCA(1,2)<5*mm) & (ACHI2DOCA(1,2)<12)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>10) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_ddl": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ADOCA(1,2)<2.5*mm) & (ACHI2DOCA(1,2)<12) ", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>20) & (BPVLTIME() > 2.0*picosecond) &\n (P>15*GeV) & (PT>600*MeV)" + }, + "xi_lll": { + "comb_cut": "(ASUM(PT)>0.5*GeV) & (ADAMASS('Xi-')<30*MeV) & (ACHILD(2,MIPCHI2DV(PRIMARY))>9) & (ADOCA(1,2)<0.5*mm) & (ACHI2DOCA(1,2)<20)", + "mother_cut": "(ADMASS('Xi-')<25*MeV) & (VFASPF(VCHI2PDOF) < 10.0) & (BPVVDCHI2>15) & (BPVLTIME() > 2.0*picosecond) & \n (P>8*GeV) & (PT>400*MeV) " + } + }, + "STREAMS": { + "CharmCompleteEvent": [ + "StrippingXic0ToXiMuNu_WS_LLLLine", + "StrippingXic0ToXiMuNu_WS_DDLLine", + "StrippingXic0ToXiMuNu_WS_DDDLine" + ] + }, + "WGs": [ "Charm" ] +} + +Xic2PHH = { + "BUILDERTYPE": "StrippingXic2PHH", + "CONFIG": { + "BPVIPCHI2_Phi": 4, + "GEC_nLongTrk": 250, + "GhostProb": 0.3, + "KSCutDIRA_DD": 0.999, + "KSCutDIRA_LL": 0.999, + "KSCutFDChi2_DD": 5, + "KSCutFDChi2_LL": 5, + "KSCutMass_DD": 50.0, + "KSCutMass_LL": 35.0, + "KaonP": 2000.0, + "KaonPIDK": 10.0, + "KaonPT": 200.0, + "Kaon_PIDKPIDpi_Min": 5.0, + "MINIPCHI2": 4.0, + "MaxDz_DD": 9999.0, + "MaxDz_LL": 9999.0, + "MaxKsVCHI2NDOF_DD": 20.0, + "MaxKsVCHI2NDOF_LL": 20.0, + "MaxPhiEta": 5.0, + "MinDz_DD": 250.0, + "MinDz_LL": 0.0, + "MinKsIpChi2_DD": 3, + "MinKsIpChi2_LL": 3, + "MinKsPT_DD": 200.0, + "MinKsPT_LL": 200.0, + "MinPhiEta": 2.0, + "MinPhiP": 3000.0, + "MinPhiPT": 200.0, + "PhiCutMass": 20.0, + "PionP": 3000.0, + "PionPIDK": 10.0, + "PionPT": 500.0, + "Pion_PIDpiPIDK_Min": 0.0, + "ProbNNk": 0.4, + "ProbNNp": 0.4, + "ProbNNpMin": 0.2, + "ProbNNpi": 0.5, + "ProbNNpiMax": 0.95, + "ProtonP": 3000.0, + "ProtonPT": 500.0, + "Proton_PIDpPIDK_Min": 0.0, + "Proton_PIDpPIDpi_Min": 5.0, + "TRCHI2DOFMax": 3.0, + "TrGhostProbMax": 0.25, + "Xic_ADAMASS_HalfWin": 170.0, + "Xic_ADMASS_HalfWin": 120.0, + "Xic_AM_Max": 2550.0, + "Xic_BPVDIRA_Min": 0.9, + "Xic_BPVVDCHI2_Min": 25.0, + "pKK_AM_Min": 2380.0, + "ppipi_AM_Min": 2380.0, + "signalPrescaleViaXicPKK": 1.0, + "signalPrescaleViaXicPKS0DD": 1.0, + "signalPrescaleViaXicPKS0LL": 1.0, + "signalPrescaleViaXicPPhi2KK": 1.0, + "signalPrescaleViaXicPPiPi": 1.0 + }, + "STREAMS": [ "Charm" ], + "WGs": [ "Charm" ] +} + -- GitLab