diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_B2DXBuilder.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_B2DXBuilder.py index 618daf1c5f1b959478bcbe5e35a473276063e70e..e09eee02a4e707193dc68708260c5dc3c629733b 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_B2DXBuilder.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_B2DXBuilder.py @@ -25,14 +25,17 @@ class B2DXBuilder(object): '''Makes all B->DX decays for the Beauty2Charm module.''' def __init__(self, d, dst, topoPions, topoPionsLoose, topoKaons, - topoKaons_PID, topoPions_PID, muons, ks, pi0, hh, hhh, + topoKaonsLoose, + topoKaons_PID, topoPions_PID, topoProtons_PID, muons, ks, pi0, hh, hhh, config): self.config = config self.topoPions = [topoPions] self.topoPionsLoose = [topoPionsLoose] + self.topoKaonsLoose = [topoKaonsLoose] self.topoKaons = [topoKaons] self.topoKaons_PID = [topoKaons_PID] self.topoPions_PID = [topoPions_PID] + self.topoProtons_PID = [topoProtons_PID] self.muons = muons self.d = d self.dst = dst @@ -110,6 +113,9 @@ class B2DXBuilder(object): self._makeB2DKS('D2HHH', self.d.hhh, 'DD') # B+- -> D+-(HHH) KS self._makeB2DKS('D2HHH', self.d.hhh, 'LL') # B+- -> D+-(HHH) KS self._makeB02DV('D2HHHCFPID', self.d.hhh_cf_pid) + + self._makeB2DHH('D2HHHPP', self.d.ds_hhh_pid_tight) + # B -> D(KSH[H]) X (LL & DD) self._makeB02DH('D2KSHLL', self.d.ksh_ll) # B0 -> D+-(KSLLH) H-+ (+WS) @@ -239,6 +245,10 @@ class B2DXBuilder(object): self._makeB2D0ppbarH('D2HH', self.d.hh_pid) self._makeB02DppbarH('D2HHH', self.d.hhh) + #B+ -> D0 phi K+ + self._makeB2D0phiK('D2HHPID', self.d.hh_pid) + self._makeB2D0phiK('D2HHHHPID', self.d.hhhh_pid) + # B+- -> D0(HH) H+H-H+ self._makeB02DstHHH('Dstar2D0PiPID', self.dst.d0pi_pid) @@ -334,6 +344,14 @@ class B2DXBuilder(object): self._makeB02D0D0KS('LL') self._makeB2DstD0KS('LL') self._makeB02DstDstKS('LL') + # B->D Ds pi pi + self._makeB02DDspipi() + self._makeB2D0Dspipi() + self._makeB02DstDspipi() + # B->D Ds1(2460) + self._makeB02DDs2460() + self._makeB2D0Ds2460() + self._makeB02DstDs2460() # B->DDKK self._makeB2D0DKK() self._makeB2D0DKPi() @@ -422,12 +440,16 @@ class B2DXBuilder(object): 'B2D0PiPi0Resolved': ["B+ -> D0 pi+ pi0", "B- -> D0 pi- pi0"], 'B2D0KsPiDD': ["B+ -> D0 pi+ KS0", "B- -> D0 pi- KS0"], 'B2D0KsPiLL': ["B+ -> D0 pi+ KS0", "B- -> D0 pi- KS0"], + 'B2D0KsKDD': ["B+ -> D0 K+ KS0", "B- -> D0 K- KS0"], + 'B2D0KsKLL': ["B+ -> D0 K+ KS0", "B- -> D0 K- KS0"], 'B2D0KPi0Resolved': ["B+ -> D0 K+ pi0", "B- -> D0 K- pi0"] } inputs = { 'B2D0PiPi0Resolved': d2x + self.topoPions + self.pi0['Resolved'], 'B2D0KsPiDD': d2x + self.topoPionsLoose + self.ks['DD'], 'B2D0KsPiLL': d2x + self.topoPionsLoose + self.ks['LL'], + 'B2D0KsKDD': d2x + self.topoKaonsLoose + self.ks['DD'], + 'B2D0KsKLL': d2x + self.topoKaonsLoose + self.ks['LL'], 'B2D0KPi0Resolved': d2x + self.topoKaons + self.pi0['Resolved'] } b2d0hh = makeB2XSels(decays, dname, inputs, config) @@ -472,12 +494,14 @@ class B2DXBuilder(object): decays = { 'B2DPiPi': ["B+ -> D+ rho(770)0", "B- -> D- rho(770)0"], 'B2DKPi': ["[B- -> D- K*(892)0]cc", "[B+ -> D+ K*(892)0]cc"], - 'B2DKK': ["B+ -> D+ phi(1020)", "B- -> D- phi(1020)"] + 'B2DKK': ["B+ -> D+ phi(1020)", "B- -> D- phi(1020)"], + 'B2DPP': ["B- -> D- p+ p~-", "B+ -> D+ p~- p+"] } inputs = { 'B2DPiPi': d2x + self.hh.pipi_pid, 'B2DKPi': d2x + self.hh.kpi_pid, - 'B2DKK': d2x + self.hh.kk_pid + 'B2DKK': d2x + self.hh.kk_pid, + 'B2DPP': d2x + self.topoProtons_PID } b2dhh = makeB2XSels(decays, dname, inputs, self.config) decays = {'B2DHHOS': ["B- -> D+ rho(770)-", "B+ -> D- rho(770)+"]} @@ -827,6 +851,12 @@ class B2DXBuilder(object): self.lines.append(ProtoLine(b02dhhh_rs, 1.0)) self.lines.append(ProtoLine(b02dhhh_ws, 0.1)) + def _makeB2D0phiK(self, dname, d2x): + decays = {'B2D0phiK': ["B+ -> D0 phi(1020) K+", "B- -> D0 phi(1020) K-"]} + inputs = {'B2D0phiK': d2x + self.hh.kk_pid + self.topoKaons_PID} + b2d0phik = makeB2XSels(decays, dname, inputs, self.config) + self.lines.append(ProtoLine(b2d0phik, 1.0)) + def _makeB02DHHH_FULLDST(self, dname, d2x): '''Makes RS and WS B0 -> D + h- + c.c. (Tighter selection for Full DST)''' config = deepcopy(self.config) @@ -1659,6 +1689,116 @@ class B2DXBuilder(object): self.config) self.lines.append(ProtoLine(b2dstdstks_ws, 0.1)) + def _makeB02DDspipi(self): + '''Makes B0 -> D- D_s+ pi+ pi- + cc''' + decays = { + 'B02DDspipi': [ + "[B0 -> D- D+ pi+ pi-]cc" + ] + } + inputs = { + 'B02DDspipi': + self.d.d_and_ds_cf_pid + self.topoPionsLoose + } + b02ddspipi = makeB2XSels(decays, '', inputs, self.config) + self.lines.append(ProtoLine(b02ddspipi, 1.0)) + + def _makeB2D0Dspipi(self): + '''Makes B+ -> D0 D_s+ pi+ pi-, B- -> D0 D_s- pi- pi+''' + decays = { + 'B2D0Dspipi': [ + "B+ -> D0 D+ pi+ pi-", "B- -> D0 D- pi- pi+" + ] + } + inputs = { + 'B2D0Dspipi': + self.d.kpi_pid + self.d.d_and_ds_cf_pid + self.topoPionsLoose + } + b2d0dspipi = makeB2XSels(decays, '', inputs, self.config) + self.lines.append(ProtoLine(b2d0dspipi, 1.0)) + inputs = { + 'B2D0Dspipi': + self.d.k3pi_pid_tight + self.d.d_and_ds_cf_pid + self.topoPionsLoose + } + b2d0dspipi = makeB2XSels(decays, 'D02K3Pi', inputs, self.config) + self.lines.append(ProtoLine(b2d0dspipi, 1.0)) + + def _makeB02DstDspipi(self): + '''Makes B0 -> D*(2010)- D_s+ pi+ pi- + cc''' + decays = { + 'B02DstDspipi': [ + "[B0 -> D*(2010)- D+ pi+ pi-]cc" + ] + } + inputs = { + 'B02DstDspipi': + self.dst.d0pi_pid + self.d.d_and_ds_cf_pid + self.topoPionsLoose + } + b02dstdspipi = makeB2XSels(decays, '', inputs, self.config) + self.lines.append(ProtoLine(b02dstdspipi, 1.0)) + inputs = { + 'B02DstDspipi': + self.dst.d0pi_k3pi_pid + self.d.d_and_ds_cf_pid + self.topoPionsLoose + } + b02dstdspipi = makeB2XSels(decays, 'DstarD02K3Pi', inputs, self.config) + self.lines.append(ProtoLine(b02dstdspipi, 1.0)) + + def _makeB02DDs2460(self): + '''Makes B0 -> D- D_s1(2460)+ + cc''' + decays = { + 'B02DDs2460': [ + "[B0 -> D- D_s1(2460)+]cc" + ] + } + inputs = { + 'B02DDs2460': + self.d.d_and_ds_cf_loose_pid + self.dst.ds1_dspipi + } + b02dds2460 = makeB2XSels(decays, '', inputs, self.config) + self.lines.append(ProtoLine(b02dds2460, 1.0)) + + def _makeB2D0Ds2460(self): + '''Makes B+ -> D0 D_s1(2460)+, B- -> D0 D_s1(2460)-''' + decays = { + 'B2D0Ds2460': [ + "B+ -> D0 D_s1(2460)+", "B- -> D0 D_s1(2460)-" + ] + } + inputs = { + 'B2D0Ds2460': + self.d.kpi_loose_pid + self.dst.ds1_dspipi + } + b2d0ds2460 = makeB2XSels(decays, '', inputs, self.config) + self.lines.append(ProtoLine(b2d0ds2460, 1.0)) + inputs = { + 'B2D0Ds2460': + self.d.k3pi_loose_pid + self.dst.ds1_dspipi + } + b2d0ds2460 = makeB2XSels(decays, 'D02K3Pi', inputs, self.config) + self.lines.append(ProtoLine(b2d0ds2460, 1.0)) + + def _makeB02DstDs2460(self): + '''Makes B0 -> D*(2010)- D_s1(2460)+ + cc''' + decays = { + 'B02DstDs2460': [ + "[B0 -> D*(2010)- D_s1(2460)+]cc" + ] + } + inputs = { + 'B02DstDs2460': + self.dst.d0pi_loose_pid + self.dst.ds1_dspipi + } + b02dstds2460 = makeB2XSels(decays, '', inputs, self.config) + self.lines.append(ProtoLine(b02dstds2460, 1.0)) + inputs = { + 'B02DstDs2460': + self.dst.d0pi_k3pi_loose_pid + self.dst.ds1_dspipi + } + b02dstds2460 = makeB2XSels(decays, 'DstarD02K3Pi', inputs, self.config) + self.lines.append(ProtoLine(b02dstds2460, 1.0)) + + + def _makeB2D0DKK(self): '''Makes RS B- -> D0D-K+K- + c.c. B- ->Ds- D0 K+ K+ + cc''' decays = { diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Bc2DXBuilder.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Bc2DXBuilder.py index af663b7592071fc14302f44aa5c2a5b5eb5608d2..fa4393f4320eca4493b5c91b82425ac0ff84a0c5 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Bc2DXBuilder.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Bc2DXBuilder.py @@ -17,14 +17,19 @@ from Beauty2Charm_Utils import * class Bc2DXBuilder(object): - def __init__(self, d, dst, hh, pions, kaons, config): + def __init__(self, lc, protons, + d, dst, hh, pions, pions_pid, kaons, kaons_pid, config): self.config = config + self.lc = lc.pkpi + self.protons = [protons] self.d = d self.dst = dst self.hh = hh self.pions = [pions] + self.pions_pid = [pions_pid] self.kaons = [kaons] + self.kaons_pid = [kaons_pid] self.lines = [] d_hh_pid = self.d.hh_pid @@ -41,6 +46,10 @@ class Bc2DXBuilder(object): self._makeBc2DX("D2HHHPID", d_hhh_pid_tight, self.config) self._makeBc2DstX("Dstar2D0PiD02HHPID", dst_hh_pid, self.config) self._makeBc2DstX("Dstar2D0PiD02HHHHPID", dst_hhhh_pid, self.config) + self._makeBc2Dsppbar("", self.d.d_and_ds_cf_pid, self.config) + self._makeBc2D0Kpipi("D02KPIPID", self.d.kpi_pid, self.config) + self._makeBc2D0Kpipi("D02K3PIPID", self.d.k3pi_pid, self.config) + self._makeBc2LcKpbar("LC2PKPI", self.lc, self.config) def _makeBc2D0X(self, bname, d, config): decays = { @@ -103,3 +112,33 @@ class Bc2DXBuilder(object): } bc2dstx = makeBc2DstXSels(decays, bname, inputs, config) self.lines.append(ProtoLine(bc2dstx, 1.0)) + + def _makeBc2Dsppbar(self, bname, d, config): + decays = { + 'Bc2Dsppbar': ["[B_c+ -> D- p+ p~-]cc"], + } + inputs = { + 'Bc2Dsppbar': d + self.protons, + } + bc2dsppbar = makeBc2DXSels(decays, bname, inputs, config) + self.lines.append(ProtoLine(bc2dsppbar, 1.0)) + + def _makeBc2D0Kpipi(self, bname, d, config): + decays = { + 'Bc2D0Kpipi': ["B_c+ -> D0 K+ pi+ pi-", "B_c- -> D0 K- pi- pi+"], + } + inputs = { + 'Bc2D0Kpipi': d + self.kaons_pid + self.pions_pid, + } + bc2d0kpipi = makeBc2DXSels(decays, bname, inputs, config) + self.lines.append(ProtoLine(bc2d0kpipi, 1.0)) + + def _makeBc2LcKpbar(self, bname, lc, config): + decays = { + 'Bc2LcKpbar': ["[B_c+ -> Lambda_c+ K+ p~-]cc"], + } + inputs = { + 'Bc2LcKpbar': lc + self.kaons + self.protons, + } + bc2lckpbar = makeBc2DXSels(decays, bname, inputs, config) + self.lines.append(ProtoLine(bc2lckpbar, 1.0)) diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_DBuilder.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_DBuilder.py index f64abfc3630ae0bce1d748602c9861f718332619..ddf8f1925bd2e01a80dcd30b8edb5d49622495aa 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_DBuilder.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_DBuilder.py @@ -105,6 +105,10 @@ class DBuilder(object): self.hhh = self._makeD2hhh() self.hhhh = self._makeD2hhhh() + self.hhLoose = self._makeD2hhLoose() + self.hhhLoose = self._makeD2hhhLoose() + self.hhhhLoose = self._makeD2hhhhLoose() + self.ksh_ll = self._makeD2KSh("LL") self.ksh_dd = self._makeD2KSh("DD") self.kshh_ll = self._makeD2KShh("LL") @@ -273,10 +277,12 @@ class DBuilder(object): oneK = "NINTREE(ABSID=='K+') == 1" self.kpi = [filterSelection('D2KPi', oneK, self.hh)] + self.kpi_loose = [filterSelection('D2KPiLoose', oneK, self.hhLoose)] d_cf = "(((ID=='D+') & (NINTREE(ID=='K-')==1) & (%s)) | "\ "((ID=='D-') & (NINTREE(ID=='K+')==1) & (%s)))" % (oneK,oneK) ds_cf = "((NINTREE(ID=='K-')==1) & (NINTREE(ID=='K+')==1))" self.kpi_pid = [filterSelection('D2KPIPID', oneK, self.hh_pid)] + self.kpi_loose_pid = [filterSelection('D2KPILoosePID', oneK, self.hhLoose)] self.kpi_pid_tight = [ filterSelection('D2KPITIGHTPID', oneK, self.hh_pid_tight) ] @@ -307,6 +313,24 @@ class DBuilder(object): RequiredSelections=self.kpkmpip_cc_pid + self.kmpippip_cc_pid) ] + self.kpkmpip_cc_loose = [ + filterSelection('D2KpKmPip_cc_loose', loki_kpkmpip_cc, self.hhhLoose) + ] + self.kmpippip_cc_loose = [ + filterSelection('D2KmPipPip_cc_loose', loki_kmpippip_cc, self.hhhLoose) + ] + self.kpkmpip_cc_loose_pid = [ + filterPID('D2KpKmPip_cc_loose_PID', self.kpkmpip_cc_loose, config_pid) + ] + self.kmpippip_cc_loose_pid = [ + filterPID('D2KmPipPip_cc_loose_PID', self.kmpippip_cc_loose, config_pid) + ] + self.d_and_ds_cf_loose_pid = [ + MergedSelection( + 'DANDDSCFLoosePIDBeauty2Charm', + RequiredSelections=self.kpkmpip_cc_loose_pid + self.kmpippip_cc_loose_pid) + ] + atLeastOneK = "NINTREE(ABSID=='K+') > 0" self.k2h = [filterSelection('D2K2H', atLeastOneK, self.hhh)] self.k3h = [filterSelection('D2K3H', atLeastOneK, self.hhhh)] @@ -343,8 +367,10 @@ class DBuilder(object): filterSelection('D2KPITIGHTPIDUP', oneK, self.hh_pid_tight_up) ] self.k3pi = [filterSelection('D2K3PI', oneK, self.hhhh)] + self.k3pi_loose = [filterSelection('D2K3PILoose', oneK, self.hhhhLoose)] self.k3pi_up = [filterSelection('D2K3PIUP', oneK, self.hhhh_up)] self.k3pi_pid = [filterPID('D2K3PIPID', self.k3pi, config_pid)] + self.k3pi_loose_pid = [filterPID('D2K3PILoosePID', self.k3pi_loose, config_pid)] self.k3pi_pid_tight = [ filterPID('D2K3PIPIDTIGHT', self.k3pi, config_pid['TIGHT']) ] @@ -567,6 +593,24 @@ class DBuilder(object): Algorithm=cp, RequiredSelections=inputs) + def _makeD2TwoBodyLoose(self, name, decays, wm, up, config, inputs): + ''' Makes all D -> HH selections.''' + if up: + wm += '& (ANUM(ISUP)==1)' + name += 'UP' + comboCuts = [LoKiCuts(['ASUMPT'], config).code(), wm, hasTopoChild_Loose()] + comboCuts.append(LoKiCuts(['ADOCA12'], config).code()) + comboCuts = LoKiCuts.combine(comboCuts) + momCuts = LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], config).code() + cp = CombineParticles( + CombinationCut=comboCuts, + MotherCut=momCuts, + DecayDescriptors=decays) + return Selection( + 'Proto_Loose' + name + 'Beauty2Charm', + Algorithm=cp, + RequiredSelections=inputs) + def _makeD2ThreeBody(self, name, decays, wm, up, config, inputs): ''' Makes all D -> HHH selections.''' if up: @@ -589,6 +633,28 @@ class DBuilder(object): Algorithm=cp, RequiredSelections=inputs) + def _makeD2ThreeBodyLoose(self, name, decays, wm, up, config, inputs): + ''' Makes all D -> HHH selections.''' + if up: + wm += '& (ANUM(ISUP)==1)' + name += 'UP' + comboCuts = [LoKiCuts(['ASUMPT'], config).code(), wm, hasTopoChild_UltraLoose()] + comboCuts12 = [LoKiCuts(['ADOCA12'], config).code()] + comboCuts.append(LoKiCuts(['ADOCA13'], config).code()) + comboCuts.append(LoKiCuts(['ADOCA23'], config).code()) + comboCuts = LoKiCuts.combine(comboCuts) + comboCuts12 = LoKiCuts.combine(comboCuts12) + momCuts = LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], config).code() + cp = DaVinci__N3BodyDecays( + Combination12Cut=comboCuts12, + CombinationCut=comboCuts, + MotherCut=momCuts, + DecayDescriptors=decays) + return Selection( + 'Proto_Loose' + name + 'Beauty2Charm', + Algorithm=cp, + RequiredSelections=inputs) + def _makeD2FourBody(self, name, decays, wm, up, config, inputs): ''' Makes all D -> HHHH selections.''' if up: @@ -617,6 +683,34 @@ class DBuilder(object): Algorithm=cp, RequiredSelections=inputs) + def _makeD2FourBodyLoose(self, name, decays, wm, up, config, inputs): + ''' Makes all D -> HHHH selections.''' + if up: + wm += '& (ANUM(ISUP)==1)' + name += 'UP' + comboCuts = [LoKiCuts(['ASUMPT'], config).code(), wm, hasTopoChild_Loose()] + comboCuts12 = [LoKiCuts(['ADOCA12'], config).code()] + comboCuts123 = ["AALL"] + comboCuts123.append(LoKiCuts(['ADOCA13'], config).code()) + comboCuts123.append(LoKiCuts(['ADOCA23'], config).code()) + comboCuts.append(LoKiCuts(['ADOCA14'], config).code()) + comboCuts.append(LoKiCuts(['ADOCA24'], config).code()) + comboCuts.append(LoKiCuts(['ADOCA34'], config).code()) + comboCuts = LoKiCuts.combine(comboCuts) + comboCuts12 = LoKiCuts.combine(comboCuts12) + comboCuts123 = LoKiCuts.combine(comboCuts123) + momCuts = LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], config).code() + cp = DaVinci__N4BodyDecays( + Combination12Cut=comboCuts12, + Combination123Cut=comboCuts123, + CombinationCut=comboCuts, + MotherCut=momCuts, + DecayDescriptors=decays) + return Selection( + 'Proto_Loose' + name + 'Beauty2Charm', + Algorithm=cp, + RequiredSelections=inputs) + def _makeD2FiveBody(self, name, decays, wm, up, config, inputs): ''' Makes all D -> HHHHH selections.''' if up: @@ -741,6 +835,32 @@ class DBuilder(object): 'D2HH' + tag + 'Beauty2Charm', RequiredSelections=sels) ] + def _makeD2hhLoose(self, up=False): + '''Makes D->hh''' + + tag = '' + if up: tag = 'UP' + + min, max = self._massWindow('D0') + + decays = [['pi+', 'pi-'], ['K+', 'pi-'], ['K+', 'K-'], ['K-', 'pi+']] + + sels = [] + + for dec in decays: + name = makeSelName('D', dec) + sel = makeSel('D0', dec) + inputs = self.getInputs(dec, up, []) + sels += [ + self._makeD2TwoBodyLoose(name, [sel], awmFunctor([dec], min, max), + up, self.config, inputs) + ] + + return [ + MergedSelection( + 'D2HHLoose' + tag + 'Beauty2Charm', RequiredSelections=sels) + ] + ## # Implementation using SubPID ## def _makeD2hhWS(self,up=False): ## '''Makes D->hh WS''' @@ -890,6 +1010,43 @@ class DBuilder(object): 'D2HHH' + tag + 'Beauty2Charm', RequiredSelections=sels) ] + def _makeD2hhhLoose(self, up=False): + '''Makes D->hhh''' + + tag = '' + if up: tag = 'UP' + + min, max = self._massWindow('D+') + + decaysp = [['pi+', 'pi+', 'pi-'], ['pi+', 'pi+', 'K-'], + ['K+', 'pi+', 'pi-'], ['K+', 'pi+', 'K-'], + ['K+', 'K+', 'pi-'], ['K+', 'K+', 'K-']] + decaysm = getCCs(decaysp) + + sels = [] + + for dec in decaysp: + name = makeSelName('D+', dec, tag) + sel = makeSel('D+', dec) + inputs = self.getInputs(dec, up, []) + sels += [ + self._makeD2ThreeBodyLoose(name, [sel], awmFunctor([dec], min, max), + up, self.config, inputs) + ] + for dec in decaysm: + name = makeSelName('D-', dec, tag) + sel = makeSel('D-', dec) + inputs = self.getInputs(dec, up, []) + sels += [ + self._makeD2ThreeBodyLoose(name, [sel], awmFunctor([dec], min, max), + up, self.config, inputs) + ] + + return [ + MergedSelection( + 'D2HHHLoose' + tag + 'Beauty2Charm', RequiredSelections=sels) + ] + ## # Implementation using SubPID ## def _makeD2KSh(self,which,up=False): ## '''Makes D->Ksh''' @@ -1993,6 +2150,47 @@ class DBuilder(object): ## return [MergedSelection('D2HHHH'+tag+'WSBeauty2Charm',RequiredSelections=sels)] + def _makeD2hhhhLoose(self, up=False): + '''Makes D->hhhh''' + + tag = '' + if up: tag = 'UP' + + min, max = self._massWindow('D0') + + decays = [ + # 4pi + ['pi+', 'pi+', 'pi-', 'pi-'], + # K3pi + ['pi+', 'pi+', 'K-', 'pi-'], + ['K+', 'pi+', 'pi-', 'pi-'], + # 2K2pi + ['K+', 'K+', 'pi-', 'pi-'], + ['pi+', 'K+', 'K-', 'pi-'], + ['pi+', 'pi+', 'K-', 'K-'], + # 3Kpi + ['K+', 'K+', 'K-', 'pi-'], + ['K+', 'pi+', 'K-', 'K-'], + # 4K + ['K+', 'K+', 'K-', 'K-'] + ] + + sels = [] + + for dec in decays: + name = makeSelName('D', dec) + sel = makeSel('D0', dec) + inputs = self.getInputs(dec, up, []) + sels += [ + self._makeD2FourBodyLoose(name, [sel], awmFunctor([dec], min, max), + up, self.config, inputs) + ] + + return [ + MergedSelection( + 'D2HHHHLoose' + tag + 'Beauty2Charm', RequiredSelections=sels) + ] + # Implementation not using SubPID at all def _makeD2hhhhWS(self, up=False): '''Makes D->hhhh WS''' @@ -2077,7 +2275,9 @@ class DstarBuilder(object): self.config = config #self.d0pi = self._makeDstar2D0pi('',self.d.hh) self.d0pi = self._makeDstar2D0pi('D2HHPID', self.d.hh_pid) + self.d0pi_loose = self._makeDstar2D0pi('D2KPiLoosePID', self.d.kpi_loose_pid) self.d0pi_k3pi = self._makeDstar2D0pi('D2K3Pi', self.d.k3pi) + self.d0pi_k3pi_loose = self._makeDstar2D0pi('D2K3PiLoosePID', self.d.k3pi_loose_pid) self.d0pi_hhhh = self._makeDstar2D0pi('D2HHHH', self.d.hhhh) self.d0pi_hhhh_pid = self._makeDstar2D0pi('D2HHHHPID', self.d.hhhh_pid) self.d0pi_k3h = self._makeDstar2D0pi('D2K3H', self.d.k3h) @@ -2090,9 +2290,13 @@ class DstarBuilder(object): self.d0pi_kshh_dd_pid = self._makeDstar2D0pi('D2KSHHDDPID', self.d.kshh_dd_pid) self.d0pi_pid = [filterPID('Dstar2D0PiPID', self.d0pi, config_pid, 2)] + self.d0pi_loose_pid = [filterPID('Dstar2D0PiLoosePID', self.d0pi_loose, config_pid, 2)] self.d0pi_k3pi_pid = [ filterPID('Dstar2D0PiK3PiPID', self.d0pi_k3pi, config_pid, 2) ] + self.d0pi_k3pi_loose_pid = [ + filterPID('Dstar2D0PiK3PiLoosePID', self.d0pi_k3pi_loose, config_pid, 2) + ] self.d0pi_kspi0hh_ll_merged = self._makeDstar2D0pi( 'D2KSLLPI0MERGEDHH', self.d.kspi0hh_ll_merged) @@ -2421,6 +2625,15 @@ class DstarBuilder(object): self.dsgammacpv_hhh = self._makeDsst2DGammaCPV( 'D2HHH', ds4dsgammacpv) # self.d.hhh_pid + # Linxuan Zhu: Ds1(2460) Ds pi pi + ds_ds1 = [ + filterSelection('ds_ds1', + "(MM > 1910*MeV) & (MM < 2030*MeV)", + self.d.d_and_ds_cf_loose_pid) + ] + self.ds1_dspipi = self._makeDs12Dspipi( + 'Ds12Dspipi', ds_ds1) + def _makeHc2Dpi(self, name, massCut, momCut, decays, inputs): comboCuts = [massCut, LoKiCuts(['ADOCA12'], self.config).code()] comboCuts = LoKiCuts.combine(comboCuts) @@ -2604,5 +2817,51 @@ class DstarBuilder(object): RequiredSelections=d2x + [self.vlaphotons]) ] + def _makeDs12ThreeBody(self, name, decays, wm, config, inputs): + ''' Makes Ds1 -> Ds pi pi selections.''' + comboCuts = [LoKiCuts(['ASUMPT'], config).code(), wm] + comboCuts12 = [LoKiCuts(['ADOCA12'], config).code()] + comboCuts.append(LoKiCuts(['ADOCA13'], config).code()) + comboCuts.append(LoKiCuts(['ADOCA23'], config).code()) + comboCuts = LoKiCuts.combine(comboCuts) + comboCuts12 = LoKiCuts.combine(comboCuts12) + momCuts = LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], config).code() + cp = DaVinci__N3BodyDecays( + Combination12Cut=comboCuts12, + CombinationCut=comboCuts, + MotherCut=momCuts, + DecayDescriptors=decays) + return Selection( + 'Proto' + name + 'Beauty2Charm', + Algorithm=cp, + RequiredSelections=inputs) + + + + #Linxuan Zhu for Ds1(2460) + def _makeDs12Dspipi(self, name, ds_ds1): + decayp = ["D_s1(2460)+ -> D+ pi+ pi-"] + decp = ["D+", "pi+", "pi-"] + decaym = ["D_s1(2460)- -> D- pi- pi+"] + decm = ["D-", "pi-", "pi+"] + + sels = [] + name = makeSelName("D_s1(2460)+", decp, "") + sel = makeSel("D_s1(2460)+", decp) + sels += [ + self._makeDs12ThreeBody(name, [sel], awmFunctor([decp], 1800., 2700.), self.config, ds_ds1+[self.pions]) + ] + name = makeSelName("D_s1(2460)-", decm, "") + sel = makeSel("D_s1(2460)-", decm) + sels += [ + self._makeDs12ThreeBody(name, [sel], awmFunctor([decm], 1800., 2700.), self.config, ds_ds1+[self.pions]) + ] + + return [ + MergedSelection( + "Ds12Dspipi" + "Beauty2Charm", RequiredSelections = sels + ) + ] + #\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\# diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_HHBuilder.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_HHBuilder.py index 1be993e8c07d24b4a4a881d749d631e18cbed671..b93e76aa8d28f556b63bfa3249f812d6ba675570 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_HHBuilder.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_HHBuilder.py @@ -58,6 +58,7 @@ class HHBuilder(object): self.kspi = self._makeKsPi() self.kpi0 = self._makeKPi0() self.pipi0 = self._makePiPi0() + self.ppi0 = self._makePPi0() self.kpi = self._makeKPi(self.pipi) self.kpi_loose = self._makeKPi_Loose(self.pipi_loose) self.kk = self._makeKK(self.pipi) @@ -67,6 +68,7 @@ class HHBuilder(object): self.phi = self._makePhi(self.kk) self.rho0 = self._makeRho0(self.pipi) self.rhopm = self._makeRhoPM(self.pipi0) + self.sigmapm = self._makeSigmaPM(self.ppi0) self.kstarpm = self._makeKstarPM(self.kpi0) self.ppbar = self._makePPbar() # WS selections (ie doubly-charged ones) @@ -282,6 +284,18 @@ class HHBuilder(object): MergedSelection('X2PiPi0Beauty2Charm', RequiredSelections=[m, r]) ] + def _makePPi0(self): + '''Makes X -> p+ pi0''' + m = self._makeXPLUS2HH('X2PPi0Merged', ['[Sigma+ -> p+ pi0]cc'], + 'AM < 5*GeV', self.config, + [self.protons] + self.pi0["Merged"], True) + r = self._makeXPLUS2HH('X2PPi0Resolved', ['[Sigma+ -> p+ pi0]cc'], + 'AM < 5*GeV', self.config, + [self.protons] + self.pi0["Resolved"], True) + return [ + MergedSelection('X2PPi0Beauty2Charm', RequiredSelections=[m, r]) + ] + def _makeRho0(self, pipi): mass = self._massWindow('RHO', 'rho(770)0').replace( 'ADAMASS', 'ADMASS') @@ -301,6 +315,11 @@ class HHBuilder(object): 'ADAMASS', 'ADMASS') return [filterSelection('RHOPM', mass, pipi)] + def _makeSigmaPM(self, ppi0): + mass = self._massWindow('SIGMA', 'Sigma+').replace( + 'ADAMASS', 'ADMASS') + return [filterSelection('SIGMAPM', mass, ppi0)] + def _makeKstarPM(self, kpi): mass = self._massWindow('KST', 'K*(892)+').replace('ADAMASS', 'ADMASS') return [filterSelection('K*PM', mass, kpi)] diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Lb2XBuilder.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Lb2XBuilder.py index e13427945d885b9093d157e70dcf30d7792a4ddd..56c294acd9284df3d17df41e014db8e243a44f40 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Lb2XBuilder.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Lb2XBuilder.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". # @@ -24,14 +24,17 @@ from Beauty2Charm_Utils import * class LcBuilder(object): '''Produces all Lambda_c baryons for the Beauty2Charm module.''' - def __init__(self, pions, kaons, protons, config, config_pid): + def __init__(self, pions, kaons, protons, lambda0, config, config_pid): self.pions = pions self.kaons = kaons self.protons = protons + self.lambda0 = lambda0 self.config = config self.pkpi = [self._makeLc2phh()] self.pkk = [self._makeLc2phh("PKK")] self.ppipi = [self._makeLc2phh("PPiPi")] + self.lambdapiLL = [self._makeLc2Lambdapi("LL")] + self.lambdapiDD = [self._makeLc2Lambdapi("DD")] self.xic_pkpi = [self._makeXic2pKpi()] self.xic0_pkkpi = [self._makeXic02pKKpi()] self.omegac0_pkkpi = [self._makeOmegac02pKKpi()] @@ -113,6 +116,36 @@ class LcBuilder(object): Algorithm=cp, RequiredSelections=inputs[mode]) + def _makeLc2Lambdapi(self, lambda0): + '''Makes Lambda_c+ -> Lambda0 pi+''' + dm, units = LoKiCuts.cutValue(self.config['MASS_WINDOW']) + comboCuts = [ + LoKiCuts(['ASUMPT'], self.config).code(), + "(ADAMASS('Lambda_c+') < %s*%s) " % (dm + 10, units), + ] + comboCuts.append(LoKiCuts(['ADOCA12'], self.config).code()) + comboCuts = LoKiCuts.combine(comboCuts) + momCuts = [ + "(ADMASS('Lambda_c+') < %s*%s) " % (dm, units), + LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], self.config).code() + ] + momCuts = LoKiCuts.combine(momCuts) + + decays = {'Lc2Lambdapi' + lambda0: ["[Lambda_c+ -> Lambda0 pi+]cc"]} + inputs = { + 'Lc2Lambdapi' + lambda0: + self.lambda0[lambda0] + [self.pions], + } + mode = 'Lc2Lambdapi' + lambda0 + cp = CombineParticles( + CombinationCut=comboCuts, + MotherCut=momCuts, + DecayDescriptors=decays[mode]) + return Selection( + "%sBeauty2Charm" % mode, + Algorithm=cp, + RequiredSelections=inputs[mode]) + def _makeXic2pKpi(self): '''Makes Xic -> p K pi + cc''' dm, units = LoKiCuts.cutValue(self.config['MASS_WINDOW']) @@ -352,6 +385,60 @@ class LooseLcBuilder(object): #\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\# +class LcstarBuilder(object): + '''Produces Lambda_c star baryons for the Beauty2Charm module''' + def __init__(self, lc, pions, config): + self.lc = lc.pkpi + self.pions = pions + self.config = config + self.lcstar2595 = [self._makeLcstar2Lcpipi("Lcstar2595")] + self.lcstar2625 = [self._makeLcstar2Lcpipi("Lcstar2625")] + + def _makeLcstar2Lcpipi(self, mode): + '''Makes Lambda_c(2595)+ -> Lambda_c+ pi+ pi-''' + '''Makes Lambda_c(2625)+ -> Lambda_c+ pi+ pi-''' + decays = { + "Lcstar2595" : "[Lambda_c(2595)+ -> Lambda_c+ pi+ pi-]cc", + "Lcstar2625" : "[Lambda_c(2625)+ -> Lambda_c+ pi+ pi-]cc", + } + inputs = { + "Lcstar2595" : self.lc+[self.pions], + "Lcstar2625" : self.lc+[self.pions], + } + dm, units = LoKiCuts.cutValue(self.config['MASS_WINDOW']) + comboCuts = { + "Lcstar2595":[ + LoKiCuts(['ASUMPT'], self.config).code(), + "(ADAMASS('Lambda_c(2595)+') < %s*%s) " % (dm + 10, units),], + "Lcstar2625":[ + LoKiCuts(['ASUMPT'], self.config).code(), + "(ADAMASS('Lambda_c(2625)+') < %s*%s) " % (dm + 10, units),], + } + comboCuts12 = [LoKiCuts(['ADOCA12'], self.config).code()] + comboCuts[mode].append(LoKiCuts(['ADOCA13'], self.config).code()) + comboCuts[mode].append(LoKiCuts(['ADOCA23'], self.config).code()) + comboCuts12 = LoKiCuts.combine(comboCuts12) + comboCuts[mode] = LoKiCuts.combine(comboCuts[mode]) + momCuts = { + "Lcstar2595": [ + "(ADMASS('Lambda_c(2595)+') < %s*%s) " % (dm, units), + LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], self.config).code()], + "Lcstar2625": [ + "(ADMASS('Lambda_c(2625)+') < %s*%s) " % (dm, units), + LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], self.config).code()], + } + momCuts[mode] = LoKiCuts.combine(momCuts[mode]) + cp = DaVinci__N3BodyDecays( + Combination12Cut=comboCuts12, + CombinationCut=comboCuts[mode], + MotherCut=momCuts[mode], + DecayDescriptors=[decays[mode]]) + return Selection( + "Lc2%sBeauty2Charm" % mode, + Algorithm=cp, + RequiredSelections=inputs[mode]) + + class XiccBuilder(object): @@ -762,13 +849,17 @@ class XibcBuilder(object): class Lb2XBuilder(object): '''Makes all Lambda_b -> X lines.''' - def __init__(self, lc, xicc, d, hh, topoPions, topoPions_PID, topoKaons, + def __init__(self, lc, lcstar, xicc, d, hh, topoPions, topoPions_PID, topoKaons, topoKaons_PID, topoProtons, topoProtons_PID, pions, kaons, ks, hhh, dst, lambda0, config): self.lc = lc.pkpi self.lc_pkk = lc.pkk self.lc_ppipi = lc.ppipi + self.lc_lambdapiLL = lc.lambdapiLL + self.lc_lambdapiDD = lc.lambdapiDD + self.lcstar2595 = lcstar.lcstar2595 + self.lcstar2625 = lcstar.lcstar2625 self.xic = lc.xic_pkpi self.xic0 = lc.xic0_pkkpi self.omegac0 = lc.omegac0_pkkpi @@ -805,6 +896,10 @@ class Lb2XBuilder(object): self.lines = [] # Lb -> Lc+- H-+ (+WS) self._makeLb2LcH() + # Lb -> Lc+ D-/D_s-/D*-/D_s*- + self._makeLb2LcDm() + # Lb -> Lc+/Lc(2595)+/Lc(2625)+ D_s- + self._makeLb2LcDs() # Lb -> Xic+- H-+ (+WS) self._makeLb2XicH() @@ -881,6 +976,8 @@ class Lb2XBuilder(object): self._makeLb2LcDst() # X -> Lc Lc (+WS) self._makeX2LcLc() + # Lb -> Lc Lc n (+WS) + self._makeLb2LcLcn() # Lb -> Lc 5pi self._makeLb2Lc5Pi() # Lb -> D0 Lambda0, D0(HH/K3Pi) @@ -911,8 +1008,15 @@ class Lb2XBuilder(object): # Lb -> D0 p h (D02K3Pi/D02KsDDHH/D02KsLLHH) self._makeLb2D0ph('D02K3Pi', self.d.k3pi_pid) + self._makeLb2D0ph('D02HHHHPID', self.d.hhhh_pid) self._makeLb2D0ph('D02KsDDHH', self.d.kshh_dd_pid) self._makeLb2D0ph('D02KsLLHH', self.d.kshh_ll_pid) + # Lb -> D0 p h WS + self._makeLb2D0phWS('D02K3PiWS', self.d.k3pi_pid) + self._makeLb2D0phWS('D02HHHHPIDWS', self.d.hhhh_pid) + self._makeLb2D0phWS('D02KsDDHHWS', self.d.kshh_dd_pid) + self._makeLb2D0phWS('D02KsLLHHWS', self.d.kshh_ll_pid) + # Lb -> D(s)- D0(K3Pi/HH) p self._makeLb2DD0p('D02K3Pi', self.d.k3pi_pid) self._makeLb2DD0p('D2HH', self.d.hh_pid) @@ -949,6 +1053,9 @@ class Lb2XBuilder(object): # B0 -> Lc+ Sigmacpp(LcPi) K+ self._makeB02LcSigmacppK() + # Bs -> Lc- Sigma+ + self._makeBs2LcSigma() + # B+ -> Lc+ Xic- pi+ self._makeB2LcXicPi() @@ -1028,6 +1135,161 @@ class Lb2XBuilder(object): self.lines.append(ProtoLine(rs_ppipi, 1.0)) self.lines.append(ProtoLine(ws_ppipi, 0.1)) + def _makeLb2LcDm(self): + '''Make Lb0 -> Lc+ D-/D_s- + cc.''' + '''Make Lb0 -> Lc+ D*- + cc.''' + '''Make Lb0 -> Lc+ D_s*- + cc.''' + lcLL = self.lc_lambdapiLL + lcDD = self.lc_lambdapiDD + d2x = self.d.hhh_pid + decays = { + 'Lb2LcDLc2Lambda0LLPi': ["[Lambda_b0 -> Lambda_c+ D-]cc"], + 'Lb2LcDLc2Lambda0DDPi': ["[Lambda_b0 -> Lambda_c+ D-]cc"], + } + inputs = { + 'Lb2LcDLc2Lambda0LLPi': lcLL + d2x, + 'Lb2LcDLc2Lambda0DDPi': lcDD + d2x, + } + dname = "D2HHHPID" + rs = makeB2XSels(decays, dname, inputs, self.config) + self.lines.append(ProtoLine(rs, 1.0)) + + #comboCuts = [ + # LoKiCuts(['AM'], self.config).code(), + #] + #comboCuts = LoKiCuts.combine(comboCuts) + #momCuts = [ + # #LoKiCuts(['VCHI2DOF', 'BPVVDCHI2', 'BPVDIRA'], self.config).code() + # 'ALL', + #] + #momCuts = LoKiCuts.combine(momCuts) + + d2x = self.dst.d0pi_pid + decays = { + 'Lb2LcDstLc2Lambda0LLPi': ["[Lambda_b0 -> Lambda_c+ D*(2010)-]cc"], + 'Lb2LcDstLc2Lambda0DDPi': ["[Lambda_b0 -> Lambda_c+ D*(2010)-]cc"], + } + inputs = { + 'Lb2LcDstLc2Lambda0LLPi': lcLL + d2x, + 'Lb2LcDstLc2Lambda0DDPi': lcDD + d2x, + } + + dname = "" + #names = list(decays.keys()) + #rs = [] + #sname = names[0] + dname + 'Beauty2Charm' + #cp = CombineParticles( + # CombinationCut=comboCuts, + # MotherCut=momCuts, + # DecayDescriptors=decays[names[0]]) + #r = Selection( + # sname, + # Algorithm=cp, + # RequiredSelections=inputs[names[0]]) + #rs.append(r) + #sname = names[1] + dname + 'Beauty2Charm' + #cp = CombineParticles( + # CombinationCut=comboCuts, + # MotherCut=momCuts, + # DecayDescriptors=decays[names[1]]) + #r = Selection( + # sname, + # Algorithm=cp, + # RequiredSelections=inputs[names[1]]) + #rs.append(r) + #self.lines.append(ProtoLine(rs, 1.0)) + rs = makeB2XSels(decays, dname, inputs, self.config) + self.lines.append(ProtoLine(rs, 1.0)) + + d2x = self.dst.d0pi_k3pi_pid + decays = { + 'Lb2LcDstLc2Lambda0LLPi': ["[Lambda_b0 -> Lambda_c+ D*(2010)-]cc"], + 'Lb2LcDstLc2Lambda0DDPi': ["[Lambda_b0 -> Lambda_c+ D*(2010)-]cc"], + } + inputs = { + 'Lb2LcDstLc2Lambda0LLPi': lcLL + d2x, + 'Lb2LcDstLc2Lambda0DDPi': lcDD + d2x, + } + dname = "DstarD02K3Pi" + #names = list(decays.keys()) + #rs = [] + #sname = names[0] + dname + 'Beauty2Charm' + #cp = CombineParticles( + # CombinationCut=comboCuts, + # MotherCut=momCuts, + # DecayDescriptors=decays[names[0]]) + #r = Selection( + # sname, + # Algorithm=cp, + # RequiredSelections=inputs[names[0]]) + #rs.append(r) + #sname = names[1] + dname + 'Beauty2Charm' + #cp = CombineParticles( + # CombinationCut=comboCuts, + # MotherCut=momCuts, + # DecayDescriptors=decays[names[1]]) + #r = Selection( + # sname, + # Algorithm=cp, + # RequiredSelections=inputs[names[1]]) + #rs.append(r) + #self.lines.append(ProtoLine(rs, 1.0)) + rs = makeB2XSels(decays, dname, inputs, self.config) + self.lines.append(ProtoLine(rs, 1.0)) + + d2x = self.dst.dgamma_hhh_pid + decays = { + 'Lb2LcDsstarLc2Lambda0LLPi': ["[Lambda_b0 -> Lambda_c+ D*_s-]cc"], + 'Lb2LcDsstarLc2Lambda0DDPi': ["[Lambda_b0 -> Lambda_c+ D*_s-]cc"], + } + inputs = { + 'Lb2LcDsstarLc2Lambda0LLPi': lcLL + d2x, + 'Lb2LcDsstarLc2Lambda0DDPi': lcDD + d2x, + } + dname = "DsstarD02HHHPID" + rs = makeB2XSels(decays, dname, inputs, self.config) + self.lines.append(ProtoLine(rs, 1.0)) + + def _makeLb2LcDs(self): + '''Make Lambda_b0 -> Lambda_c+ D_s-''' + '''Make Lambda_b0 -> Lambda_c(2595)+ D_s-''' + '''Make Lambda_b0 -> Lambda_c(2625)+ D_s-''' + + config = deepcopy(self.config) + config['AM_MIN'] = '4700*MeV' + config['AM_MAX'] = '6500*MeV' + + lc = self.lc + lcstar2595 = self.lcstar2595 + lcstar2625 = self.lcstar2625 + d2x = self.d.hhh_pid + decays = { + 'Lb2LcDs': ["[Lambda_b0 -> Lambda_c+ D-]cc"], + 'Lb2Lc2595Ds': ["[Lambda_b0 -> Lambda_c(2595)+ D-]cc"], + 'Lb2Lc2625Ds': ["[Lambda_b0 -> Lambda_c(2625)+ D-]cc"], + } + inputs = { + 'Lb2LcDs': lc + d2x, + 'Lb2Lc2595Ds': lcstar2595 + d2x, + 'Lb2Lc2625Ds': lcstar2625 + d2x, + } + dname = "D2HHHPID" + rs = makeB2XSels(decays, dname, inputs, config) + self.lines.append(ProtoLine(rs, 1.0)) + decays = { + 'Lb2LcDsWS': ["[Lambda_b0 -> Lambda_c+ D+]cc"], + 'Lb2Lc2595DsWS': ["[Lambda_b0 -> Lambda_c(2595)+ D+]cc"], + 'Lb2Lc2625DsWS': ["[Lambda_b0 -> Lambda_c(2625)+ D+]cc"], + } + inputs = { + 'Lb2LcDsWS': lc + d2x, + 'Lb2Lc2595DsWS': lcstar2595 + d2x, + 'Lb2Lc2625DsWS': lcstar2625 + d2x, + } + ws = makeB2XSels(decays, dname, inputs, config) + self.lines.append(ProtoLine(ws, 1.0)) + + def _makeB2Lcpbar(self): '''Make RS and WS B -> Lc pbar + cc.''' protons = self.protons @@ -1044,9 +1306,11 @@ class Lb2XBuilder(object): def _makeB2LcLcK(self): '''Make B- -> Lc- Lc+ K- + cc.''' + config = deepcopy(self.config) + config['BPVIPCHI2_MAX'] = '50' decays = {'B2LcLcK': ["[B- -> Lambda_c~- Lambda_c+ K-]cc"]} inputs = {'B2LcLcK': self.lc + self.topoKaons_pid} - rs = makeB2XSels(decays, 'Lc2PKPi', inputs, self.config) + rs = makeB2XSels(decays, 'Lc2PKPi', inputs, config) self.lines.append(ProtoLine(rs, 1.0)) def _makeLb2XicH(self): @@ -1869,6 +2133,25 @@ class Lb2XBuilder(object): ws = makeB2XSels(decays, '', inputs, config) self.lines.append(ProtoLine(ws, 0.1)) + def _makeLb2LcLcn(self): + """ + Makes Lb -> Lc Lc~ n (Lc->p K pi) + c.c. + The neutron is not reconstructed. + """ + config = deepcopy(self.config) + config['AM_MIN'] = '4000*MeV' + config['BPVIPCHI2_MAX'] = '50' + + decays = {'Lb2LcLcn': ["Lambda_b0 -> Lambda_c+ Lambda_c~-"]} + inputs = {'Lb2LcLcn': self.lc} + rs = makeB2XSels(decays, 'Lc2PKPi', inputs, config) + self.lines.append(ProtoLine(rs, 1.0)) + + decays = {'Lb2LcLcnWS': ["[Lambda_b0 -> Lambda_c+ Lambda_c+]cc"]} + inputs = {'Lb2LcLcnWS': self.lc} + ws = makeB2XSels(decays, 'Lc2PKPi', inputs, config) + self.lines.append(ProtoLine(ws, 0.1)) + def _makeLb2Lc5Pi(self): decays = { 'Lb2Lc5Pi': ["[Lambda_b0 -> Lambda_c+ a_1(1260)- rho(770)0]cc"] @@ -1924,18 +2207,32 @@ class Lb2XBuilder(object): protons_pid = self.protons_pid kaons_pid = self.topoKaons_pid pions_pid = self.topoPions_pid - decays_k = {'Lb2D0pK': ["Lambda_b0 -> D0 p+ K-", "Lambda_b0 -> D0 p~- K+"]} + decays_k = {'Lb2D0pK': ["Lambda_b0 -> D0 p+ K-", "Lambda_b~0 -> D0 p~- K+"]} inputs_k = {'Lb2D0pK': d2x + protons_pid + kaons_pid} rs_k = makeB2XSels(decays_k, dname, inputs_k, self.config) self.lines.append(ProtoLine(rs_k, 1.0)) - decays_pi = {'Lb2D0pPi': ["Lambda_b0 -> D0 p+ pi-", "Lambda_b0 -> D0 p~- pi+"]} + decays_pi = {'Lb2D0pPi': ["Lambda_b0 -> D0 p+ pi-", "Lambda_b~0 -> D0 p~- pi+"]} + inputs_pi = {'Lb2D0pPi': d2x + protons_pid + pions_pid} + rs_pi = makeB2XSels(decays_pi, dname, inputs_pi, self.config) + self.lines.append(ProtoLine(rs_pi, 1.0)) + + def _makeLb2D0phWS(self, dname, d2x): + '''Make RS Lb -> D0(K3pi) p h + cc.''' + protons_pid = self.protons_pid + kaons_pid = self.topoKaons_pid + pions_pid = self.topoPions_pid + decays_k = {'Lb2D0pK': ["Lambda_b0 -> D0 p+ K+", "Lambda_b~0 -> D0 p~- K-"]} + inputs_k = {'Lb2D0pK': d2x + protons_pid + kaons_pid} + rs_k = makeB2XSels(decays_k, dname, inputs_k, self.config) + self.lines.append(ProtoLine(rs_k, 1.0)) + decays_pi = {'Lb2D0pPi': ["Lambda_b0 -> D0 p+ pi+", "Lambda_b~0 -> D0 p~- pi-"]} inputs_pi = {'Lb2D0pPi': d2x + protons_pid + pions_pid} rs_pi = makeB2XSels(decays_pi, dname, inputs_pi, self.config) self.lines.append(ProtoLine(rs_pi, 1.0)) def _makeLb2DD0p(self, dname, d2x): '''Make Lb -> D(s)- D0(K3pi) p + cc.''' - decays = {'Lb2DD0pD2HHH': ["Lambda_b0 -> D- D0 p+", "Lambda_b0 -> D+ D0 p~-"]} + decays = {'Lb2DD0pD2HHH': ["Lambda_b0 -> D- D0 p+", "Lambda_b~0 -> D+ D0 p~-"]} inputs = {'Lb2DD0pD2HHH': self.d.hhh_cf_pid + d2x + self.protons_pid} rs = makeB2XSels(decays, dname, inputs, self.config) self.lines.append(ProtoLine(rs, 1.0)) @@ -2136,6 +2433,14 @@ class Lb2XBuilder(object): rs = makeB2XSels(decays, 'Sigmacpp2LcPiLc2PKPi', inputs, self.config) self.lines.append(ProtoLine(rs, 1.0)) + def _makeBs2LcSigma(self): + '''Make Bs0 -> Lambda_c~- Sigma+''' + sigma = self.hh.sigmapm + decays = {'Bs2LcSigmap': ["[B_s0 -> Lambda_c~- Sigma+]cc"]} + inputs = {'Bs2LcSigmap': self.lc + sigma} + rs = makeB2XSels(decays, 'Lc2PKPiSigmap2PPiz', inputs, self.config) + self.lines.append(ProtoLine(rs, 1.0)) + def _makeLb2DDpK(self): '''Make Lb -> D+ D- p K- + cc.''' protons = self.protons_pid diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Utils.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Utils.py index 67273aefde064f8e3e7796f6dbd209b2ceb9bdfb..3f9ac55e6679418b70cfe0da40b67aab9d9d5487 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Utils.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/Beauty2Charm_Utils.py @@ -72,6 +72,8 @@ def topoInputsCuts(): # Don't need IP chi2 cut b/c is in 1st filter def topoInputsLooseCuts(): return "HASTRACK & (TRCHI2DOF<4.) & (PT > 250*MeV) & (P > 2500*MeV)" +def topoInputsUltraLooseCuts(): + return "HASTRACK & (TRCHI2DOF<4.) & (PT > 100*MeV) & (P > 1000*MeV)" def topoKSInputsCuts(): # Don't need IP chi2 cut b/c is in 1st filter return "(PT > 500*MeV) & (P > 5000*MeV) & (BPVVDCHI2 > 1000)" @@ -87,6 +89,10 @@ def topoInputsLoose(tag, inputs): return filterSelection(tag + 'TopoInputsLoose', topoInputsLooseCuts(), inputs) +def topoInputsUltraLoose(tag, inputs): + '''Selects tracks that could have been used by the Topo.''' + return filterSelection(tag + 'TopoInputsLoose', topoInputsUltraLooseCuts(), + inputs) def hasTopoChild(): return "AHASCHILD((ISBASIC & "+topoInputsCuts()+")|((ABSID=='KS0') & "\ @@ -97,6 +103,9 @@ def hasTopoChild_Loose(): return "AHASCHILD((ISBASIC & "+topoInputsLooseCuts()+")|((ABSID=='KS0') & "\ +topoKSInputsCuts() +"))" +def hasTopoChild_UltraLoose(): + return "AHASCHILD((ISBASIC & "+topoInputsUltraLooseCuts()+")|((ABSID=='KS0') & "\ + +topoKSInputsCuts() +"))" def hasTopoChildren(): return "NINTREE((ISBASIC & "+topoInputsCuts()+")|((ABSID=='KS0') & "\ @@ -107,6 +116,8 @@ def has1TrackChild(): return "INTREE(HASTRACK & (P>10000*MeV) & (PT>1700*MeV) & (TRCHI2DOF<4.) "\ "& (MIPCHI2DV(PRIMARY)>16) & (MIPDV(PRIMARY)>0.1*mm))" +def has1TrackChild_Loose(): + return "INTREE(HASTRACK & (P>10000*MeV) & (PT>1000*MeV) & (TRCHI2DOF<4.)) " def makeTOSFilter(name, specs): from Configurables import TisTosParticleTagger @@ -217,7 +228,15 @@ def makeB2X(name, decay, inputs, config, useIP=True, resVert=True): "(M-MAXTREE(ABSID=='D0',M) < 4000*MeV) & (M-MAXTREE(ABSID=='D0',M) > 2600*MeV)" ) comboCuts += "& (ACHILD(P,2) <100000*MeV)" - + + if name.find('Lb2LcLcn') >= 0 or name.find('B2LcLcK') >= 0: + comboCuts = LoKiCuts(['AM'], config).code() + momCuts = [ + LoKiCuts(['VCHI2DOF'], config).code(), + has1TrackChild_Loose(), + hasTopoChildren(), + LoKiCuts(flightCuts, config).code()] + momCuts = LoKiCuts.combine(momCuts) b2x = CombineParticles( DecayDescriptors=decay, diff --git a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/StrippingBeauty2Charm.py b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/StrippingBeauty2Charm.py index dea06de96fc8faf3894811fe7e9263be9ee06d8e..a62d403dc9f63a36befa91c8497da17bec732016 100644 --- a/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/StrippingBeauty2Charm.py +++ b/Phys/StrippingSelections/python/StrippingSelections/StrippingB2OC/StrippingBeauty2Charm.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". # @@ -186,6 +186,23 @@ default_config = { 'BPVDIRA_MIN': 0, 'MASS_WINDOW': '100*MeV' }, + "Lcstar": { # Cuts made on all Lcstar's used in all lines + 'ASUMPT_MIN': '1800*MeV', + 'ADOCA12_MAX': '0.5*mm', + 'ADOCA13_MAX': '0.5*mm', + 'ADOCA23_MAX': '0.5*mm', + 'ADOCA14_MAX': '0.5*mm', + 'ADOCA24_MAX': '0.5*mm', + 'ADOCA34_MAX': '0.5*mm', + 'ADOCA15_MAX': '0.5*mm', + 'ADOCA25_MAX': '0.5*mm', + 'ADOCA35_MAX': '0.5*mm', + 'ADOCA45_MAX': '0.5*mm', + 'VCHI2DOF_MAX': 10, + 'BPVVDCHI2_MIN': 36, + 'BPVDIRA_MIN': 0, + 'MASS_WINDOW': '500*MeV' + }, "LC_FOR_XIBC": { # Cuts made on Lc's/Xic(0) used in Xibc lines 'ASUMPT_MIN': '1800*MeV', 'ADOCA12_MAX': '0.5*mm', @@ -296,7 +313,8 @@ default_config = { 'MASS_WINDOW': { 'KST': '150*MeV', 'RHO': '150*MeV', - 'PHI': '150*MeV' + 'PHI': '150*MeV', + 'SIGMA': '150*MeV' }, 'DAUGHTERS': { 'PT_MIN': '100*MeV', @@ -918,6 +936,10 @@ default_config = { 'StrippingB2D0KPi0ResolvedD2HHHHWSBeauty2CharmLine', 'StrippingB2D0KsPiLLD2HHHHWSBeauty2CharmLine', 'StrippingB2D0PiPi0ResolvedD2HHHHWSBeauty2CharmLine', + 'StrippingB2D0KsKDDD2HHBeauty2CharmLine', + 'StrippingB2D0KsKLLD2HHBeauty2CharmLine', + 'StrippingB2D0KsKDDD2HHHHBeauty2CharmLine', + 'StrippingB2D0KsKLLD2HHHHBeauty2CharmLine', 'StrippingB02DKD2PhiMuNuBeauty2CharmLine', 'StrippingB02DPiD2PhiMuNuBeauty2CharmLine', 'StrippingB02DKWSD2PhiMuNuBeauty2CharmLine', @@ -945,6 +967,7 @@ default_config = { 'StrippingB02DKsKLLWSD2HHHCFPIDBeauty2CharmLine', 'StrippingB02DKsKDDWSD2HHHCFPIDBeauty2CharmLine', 'StrippingB2DKKD2HHHCFPIDBeauty2CharmLine', + 'StrippingB2DPPD2HHHPPBeauty2CharmLine', 'StrippingB2DKPiD2HHHCFPIDBeauty2CharmLine', 'StrippingB2DPiPiD2HHHCFPIDBeauty2CharmLine', 'StrippingB2DHHOSD2HHHCFPIDBeauty2CharmLine', @@ -1111,6 +1134,8 @@ default_config = { 'StrippingB2D0ppbarPiD2HHBeauty2CharmLine', 'StrippingB02DppbarKD2HHHBeauty2CharmLine', 'StrippingB02DppbarPiD2HHHBeauty2CharmLine', + 'StrippingB2D0phiKD2HHPIDBeauty2CharmLine', + 'StrippingB2D0phiKD2HHHHPIDBeauty2CharmLine', 'StrippingB02DstKKPiDstar2D0PiPIDBeauty2CharmLine', 'StrippingB02DstKPiPiDstar2D0PiPIDBeauty2CharmLine', 'StrippingB02DstPiPiPiDstar2D0PiPIDBeauty2CharmLine', @@ -1308,6 +1333,18 @@ default_config = { 'StrippingB02DstDstKKBeauty2CharmLine', 'StrippingB02DstDstKKDstarD02K3PiBeauty2CharmLine', 'StrippingB02DstDstKKDstarD02K3PiDstarD02K3PiBeauty2CharmLine', + ##### DDspipi lines ### + 'StrippingB02DDspipiBeauty2CharmLine', + 'StrippingB2D0DspipiBeauty2CharmLine', + 'StrippingB2D0DspipiD02K3PiBeauty2CharmLine', + 'StrippingB02DstDspipiBeauty2CharmLine', + 'StrippingB02DstDspipiDstarD02K3PiBeauty2CharmLine', + ##### DDs2460 lines ### + 'StrippingB02DDs2460Beauty2CharmLine', + 'StrippingB2D0Ds2460Beauty2CharmLine', + 'StrippingB2D0Ds2460D02K3PiBeauty2CharmLine', + 'StrippingB02DstDs2460Beauty2CharmLine', + 'StrippingB02DstDs2460DstarD02K3PiBeauty2CharmLine', #### DDPi lines ### 'StrippingB2DDPiBeauty2CharmLine', 'StrippingB2DDPiWSBeauty2CharmLine', @@ -1352,6 +1389,14 @@ default_config = { 'StrippingLb2LcPiWSLc2PKKBeauty2CharmLine', 'StrippingLb2LcPiWSLc2PPiPiBeauty2CharmLine', 'StrippingLb2LcPiNoIPWSLc2PKPiBeauty2CharmLine', + 'StrippingLb2LcDLc2Lambda0LLPiD2HHHPIDBeauty2CharmLine', + 'StrippingLb2LcDLc2Lambda0DDPiD2HHHPIDBeauty2CharmLine', + 'StrippingLb2LcDstLc2Lambda0LLPiBeauty2CharmLine', + 'StrippingLb2LcDstLc2Lambda0DDPiBeauty2CharmLine', + 'StrippingLb2LcDstLc2Lambda0LLPiDstarD02K3PiBeauty2CharmLine', + 'StrippingLb2LcDstLc2Lambda0DDPiDstarD02K3PiBeauty2CharmLine', + 'StrippingLb2LcDsstarLc2Lambda0LLPiDsstarD02HHHPIDBeauty2CharmLine', + 'StrippingLb2LcDsstarLc2Lambda0DDPiDsstarD02HHHPIDBeauty2CharmLine', 'StrippingLb2XicPiXic2PKPiBeauty2CharmLine', 'StrippingLb2XicKXic2PKPiBeauty2CharmLine', 'StrippingLb2XicKWSXic2PKPiBeauty2CharmLine', @@ -1396,6 +1441,22 @@ default_config = { 'StrippingLb2D0PHNoPIDWSD02HHBeauty2CharmLine', 'StrippingLb2D0PHD02K3PiBeauty2CharmLine', 'StrippingLb2D0PHWSD02K3PiBeauty2CharmLine', + 'StrippingLb2D0pKD02K3PiBeauty2CharmLine', + 'StrippingLb2D0pKD02HHHHPIDBeauty2CharmLine', + 'StrippingLb2D0pKD02KsDDHHBeauty2CharmLine', + 'StrippingLb2D0pKD02KsLLHHBeauty2CharmLine', + 'StrippingLb2D0pKD02K3PiWSBeauty2CharmLine', + 'StrippingLb2D0pKD02HHHHPIDWSBeauty2CharmLine', + 'StrippingLb2D0pKD02KsDDHHWSBeauty2CharmLine', + 'StrippingLb2D0pKD02KsLLHHWSBeauty2CharmLine', + 'StrippingLb2D0pPiD02K3PiBeauty2CharmLine', + 'StrippingLb2D0pPiD02HHHHPIDBeauty2CharmLine', + 'StrippingLb2D0pPiD02KsDDHHBeauty2CharmLine', + 'StrippingLb2D0pPiD02KsLLHHBeauty2CharmLine', + 'StrippingLb2D0pPiD02K3PiWSBeauty2CharmLine', + 'StrippingLb2D0pPiD02HHHHPIDWSBeauty2CharmLine', + 'StrippingLb2D0pPiD02KsDDHHWSBeauty2CharmLine', + 'StrippingLb2D0pPiD02KsLLHHWSBeauty2CharmLine', 'StrippingLb2D0PPbarD02HHBeauty2CharmLine', 'StrippingLb2D0PPbarWSD02HHBeauty2CharmLine', 'StrippingLb2LcKSKLLLc2PKPiBeauty2CharmLine', @@ -1424,6 +1485,12 @@ default_config = { 'StrippingB02LcpbarKPiWSLc2PKPiBeauty2CharmLine', 'StrippingLb2LcDD2HHHPIDBeauty2CharmLine', 'StrippingLb2LcDWSD2HHHPIDBeauty2CharmLine', + 'StrippingLb2LcDsD2HHHPIDBeauty2CharmLine', + 'StrippingLb2LcDsWSD2HHHPIDBeauty2CharmLine', + 'StrippingLb2Lc2595DsD2HHHPIDBeauty2CharmLine', + 'StrippingLb2Lc2595DsWSD2HHHPIDBeauty2CharmLine', + 'StrippingLb2Lc2625DsD2HHHPIDBeauty2CharmLine', + 'StrippingLb2Lc2625DsWSD2HHHPIDBeauty2CharmLine', 'StrippingLb2LcDKstBeauty2CharmLine', 'StrippingLb2LcDstKstBeauty2CharmLine', 'StrippingLb2LcDst0KLc2PKPiDst02D0GammaD2HHBeauty2CharmLine', @@ -1464,6 +1531,8 @@ default_config = { 'StrippingLb2LcDstWSDstar2D0PiPIDBeauty2CharmLine', 'StrippingX2LcLcBeauty2CharmLine', 'StrippingX2LcLcWSBeauty2CharmLine', + 'StrippingLb2LcLcnLc2PKPiBeauty2CharmLine', + 'StrippingLb2LcLcnWSLc2PKPiBeauty2CharmLine', 'StrippingLb2Lc5PiLc2PKPiPIDBeauty2CharmLine', 'StrippingLb2D0Lambda0DDD02HHBeauty2CharmLine', 'StrippingLb2D0Lambda0LLD02HHBeauty2CharmLine', @@ -1475,11 +1544,11 @@ default_config = { 'StrippingXib2D0pKKD02HHBeauty2CharmLine', 'StrippingXib2D0pPiPiD02HHBeauty2CharmLine', 'StrippingXib2D0pKPiD02HHBeauty2CharmLine', - 'StrippingLb2D0pKD02K3PiBeauty2CharmLine', - 'StrippingLb2D0pKD02KsDDHHBeauty2CharmLine', - 'StrippingLb2D0pKD02KsLLHHBeauty2CharmLine', - 'StrippingLb2D0pPiD02KsDDHHBeauty2CharmLine', - 'StrippingLb2D0pPiD02KsLLHHBeauty2CharmLine', + #'StrippingLb2D0pKD02K3PiBeauty2CharmLine', + #'StrippingLb2D0pKD02KsDDHHBeauty2CharmLine', + #'StrippingLb2D0pKD02KsLLHHBeauty2CharmLine', + #'StrippingLb2D0pPiD02KsDDHHBeauty2CharmLine', + #'StrippingLb2D0pPiD02KsLLHHBeauty2CharmLine', 'StrippingLb2DD0pD2HHHD02K3PiBeauty2CharmLine', 'StrippingLb2DD0pD2HHHD2HHBeauty2CharmLine', 'StrippingXibc2DpKD2HHHBeauty2CharmLine', @@ -1510,6 +1579,7 @@ default_config = { 'StrippingLb2sigmacppD0KPiSigmacpp2LcPiLc2PKPiBeauty2CharmLine', 'StrippingB02LcSigmacppKSigmacpp2LcPiLc2PKPiBeauty2CharmLine', 'StrippingB2LcXicPiXic2PKPiLc2PKPiBeauty2CharmLine', + 'StrippingBs2LcSigmapLc2PKPiSigmap2PPizBeauty2CharmLine', 'StrippingB02DKLTUBD2HHHBeauty2CharmLine', 'StrippingB02DsKPiPiLTUBD2HHHBeauty2CharmLine', 'StrippingB02DsstarKLTUBDsstar2DGammaD2HHHBeauty2CharmLine', @@ -1643,6 +1713,12 @@ default_config = { 'StrippingBc2DstDst0Dst2DPI0D2KSHDst02D0PI0D02KSHHBeauty2CharmLine', 'StrippingBc2DstDst0Dst2DPI0D2KSHDst02D0GammaD02HHBeauty2CharmLine', + ##B_c+ + 'StrippingBc2DsppbarBeauty2CharmLine', + 'StrippingBc2D0KpipiD02KPIPIDBeauty2CharmLine', + 'StrippingBc2D0KpipiD02K3PIPIDBeauty2CharmLine', + 'StrippingBc2LcKpbarLC2PKPIBeauty2CharmLine', + #Xibc 'StrippingXibc2LcD0D02KPiBeauty2CharmLine', 'StrippingXibc2LcD0PiD02KPiBeauty2CharmLine', @@ -1811,8 +1887,9 @@ class Beauty2CharmConf(LineBuilder): config['Dstar'], config['PID']) # Lc -> X - lc = LcBuilder(pions_pid, kaons_pid, protons_pid, config['D2X'], + lc = LcBuilder(pions_pid, kaons_pid, protons_pid, lambda0, config['D2X'], config['PID']) + lcstar = LcstarBuilder(lc, pions_pid, config['Lcstar']) xicc = XiccBuilder(lc, pions_pid, config['D2X']) # Loose Lc, for Xibc lcLoose = LooseLcBuilder(pions_Xc_Xibc, kaons_Xc_Xibc, protons_Xc_Xibc, @@ -1821,8 +1898,8 @@ class Beauty2CharmConf(LineBuilder): config['LC_FOR_XIBC']) # make B->DX - b2dx = B2DXBuilder(d, dst, topoPions, topoPionsLoose, topoKaons, - topoKaons_PID, topoPions_PID, muons, ks, pi0_fromB, + b2dx = B2DXBuilder(d, dst, topoPions, topoPionsLoose, topoKaons, topoKaonsLoose, + topoKaons_PID, topoPions_PID, topoProtons_PID, muons, ks, pi0_fromB, hh, hhh, config['B2X']) self._makeLines(b2dx.lines, config) @@ -1836,12 +1913,12 @@ class Beauty2CharmConf(LineBuilder): self._makeLines(bc2bx.lines, config) #Bc -> DX lines - bc2dx = Bc2DXBuilder(d, dst, hh, topoPionsLoose, topoKaonsLoose, + bc2dx = Bc2DXBuilder(lc, topoProtons_PID, d, dst, hh, topoPionsLoose, topoPions_PID, topoKaonsLoose, topoKaons_PID, config['Bc2DX']) self._makeLines(bc2dx.lines, config) # Lb -> X - lb2x = Lb2XBuilder(lc, xicc, d, hh, topoPions, topoPions_PID, + lb2x = Lb2XBuilder(lc, lcstar, xicc, d, hh, topoPions, topoPions_PID, topoKaons, topoKaons_PID, topoProtons, topoProtons_PID, pions, kaons, ks, hhh, dst, lambda0, config['B2X'])