13 This file tests the functionality of sampling needed to train the flavor tagger. 
   18 from basf2 
import set_random_seed, create_path, process
 
   19 import modularAnalysis 
as ma
 
   20 import flavorTagger 
as ft
 
   27 set_random_seed(
"1337")
 
   32 testpath = create_path()
 
   33 testpath.add_module(
'RootInput', inputFileNames=testinput)
 
   35 ma.fillParticleListFromMC(
'nu_tau', 
'', path=testpath)
 
   36 ma.reconstructMCDecay(decayString=
'B0:sig -> nu_tau anti-nu_tau', cut=
'', path=testpath)
 
   39 ma.buildRestOfEvent(
'B0:sig', path=testpath)
 
   42 ma.applyCuts(
'B0:sig', 
' abs(isRelatedRestOfEventB0Flavor) == 1', path=testpath)
 
   46 roe_path = create_path()
 
   47 deadEndPath = create_path()
 
   49 ma.signalSideParticleListsFilter(
 
   51             'nROE_Charged(all, 0) > 0 and abs(qrCombined) == 1',
 
   56 ma.fillParticleList(
'e+:inRoe', 
'isInRestOfEvent > 0.5 and passesROEMask() > 0.5 and ' +
 
   57                     'isNAN(p) !=1 and isInfinity(p) != 1', path=roe_path)
 
   60 methodPrefixEventLevel = 
"FlavorTagger_Belle2_B2nunuBGx1EventLevelElectronFBDT" 
   61 targetVariable = 
'isRightCategory(Electron)' 
   62 ma.applyCuts(
'e+:inRoe', 
'isRightCategory(mcAssociated) > 0', path=roe_path)
 
   65 eventLevelpath = create_path()
 
   66 SkipEmptyParticleList = basf2.register_module(
"SkimFilter")
 
   67 SkipEmptyParticleList.set_name(
'SkimFilter_EventLevelElectron')
 
   68 SkipEmptyParticleList.param(
'particleLists', 
'e+:inRoe')
 
   69 SkipEmptyParticleList.if_true(eventLevelpath, basf2.AfterConditionPath.CONTINUE)
 
   70 roe_path.add_module(SkipEmptyParticleList)
 
   72 ntuple = basf2.register_module(
'VariablesToNtuple')
 
   73 ntuple.param(
'fileName', methodPrefixEventLevel + 
"sampled0.root")
 
   74 ntuple.param(
'treeName', methodPrefixEventLevel + 
"_tree")
 
   77 ft.set_FlavorTagger_pid_aliases()
 
   79 variablesToBeSaved = [
'useCMSFrame(p)',
 
   88                       'BtagToWBosonVariables(recoilMassSqrd)',
 
   89                       'BtagToWBosonVariables(pMissCMS)',
 
   90                       'BtagToWBosonVariables(cosThetaMissCMS)',
 
   91                       'BtagToWBosonVariables(EW90)',
 
   94                       'hasHighestProbInCat(e+:inRoe, isRightTrack(Electron))',
 
   95                       targetVariable, 
'ancestorHasWhichFlavor',
 
   96                       'isSignal', 
'mcPDG', 
'mcErrors', 
'genMotherPDG',
 
   97                       'nMCMatches', 
'B0mcErrors' 
   99 ntuple.param(
'variables', variablesToBeSaved)
 
  100 ntuple.param(
'particleList', 
'e+:inRoe')
 
  101 eventLevelpath.add_module(ntuple)
 
  103 testpath.for_each(
'RestOfEvent', 
'RestOfEvents', roe_path)
 
  111     assert os.path.isfile(methodPrefixEventLevel + 
"sampled0.root"), methodPrefixEventLevel + 
"sampled0.root" + 
" wasn't created" 
  112     f = ROOT.TFile(methodPrefixEventLevel + 
"sampled0.root")
 
  113     t1 = f.Get(methodPrefixEventLevel + 
"_tree")
 
  114     assert bool(t1), methodPrefixEventLevel + 
"_tree" + 
" isn't contained in file" 
  115     assert t1.GetEntries() > 0, methodPrefixEventLevel + 
"_tree" + 
"contains zero entries" 
  116     for iVariable 
in variablesToBeSaved:
 
  117         iROOTVariable = str(ROOT.Belle2.MakeROOTCompatible.makeROOTCompatible(iVariable))
 
  118         assert t1.GetListOfBranches().Contains(iROOTVariable),  iROOTVariable +\
 
  119             " branch is missing from " + methodPrefixEventLevel + 
"_tree" 
  121     assert t1.GetEntries() == 40, 
"40 entries should be saved in the test training ntuple, otherwise some problem happened." 
  124         211.0,        211.0,        211.0,        211.0,        211.0,        321.0,        13.0,        11.0,
 
  125         211.0,        211.0,        211.0,        11.0,        211.0,        211.0,        211.0,        211.0,
 
  126         211.0,        11.0,        211.0,        211.0,        211.0,        211.0,        211.0,        211.0,        211.0,
 
  127         2212.0,        211.0,        211.0,        2212.0,        211.0,        13.0,        211.0,        211.0,
 
  128         211.0,        211.0,        211.0,        211.0,        321.0,        321.0,        211.0]
 
  130     for iEntry 
in range(t1.GetEntries()):
 
  132         assert abs(t1.useCMSFrame__bop__bc) > 0, 
" p* should be greater than 0" 
  133         assert abs(t1.useCMSFrame__bopt__bc) > 0, 
" pt* should be greater than 0" 
  134         assert abs(t1.p) > 0, 
" p should be greater than 0" 
  135         assert abs(t1.pt) > 0, 
" pt should be greater than 0" 
  136         assert abs(t1.cosTheta) > 0, 
" cosTheta should be greater than 0" 
  137         assert abs(t1.electronID) > 0, 
" electronID should be greater than 0" 
  138         assert abs(t1.BtagToWBosonVariables__borecoilMassSqrd__bc) > 0, 
" recoilMassSqrd should be greater than 0" 
  139         assert abs(t1.BtagToWBosonVariables__bopMissCMS__bc) > 0, 
" pMissCMS should be greater than 0" 
  140         assert abs(t1.BtagToWBosonVariables__bocosThetaMissCMS__bc) > 0, 
" cosThetaMissCMS should be greater than 0" 
  141         assert abs(t1.BtagToWBosonVariables__boEW90__bc) > 0, 
" EW90 should be greater than 0" 
  142         assert abs(t1.cosTPTO) > 0, 
" cosTPTO should be greater than 0" 
  143         assert abs(t1.chiProb) > 0, 
" chiProb should be greater than 0" 
  145             t1.hasHighestProbInCat__boe__pl__clinRoe__cm__spisRightTrack__boElectron__bc__bc
 
  147             basf2.B2FATAL(
" hasHighestProbInCat Electron should not be nan")
 
  148         if math.isnan(t1.isRightCategory__boElectron__bc):
 
  149             basf2.B2FATAL(
" isRightCategory Electron should not be nan ")
 
  150         if math.isnan(t1.ancestorHasWhichFlavor):
 
  151             basf2.B2FATAL(
" ancestorHasWhichFlavor should not be nan")
 
  152         if math.isnan(t1.isSignal):
 
  153             basf2.B2FATAL(
" isSignal should not be nan")
 
  154         assert abs(t1.mcPDG) == mcPDGCodes[iEntry], 
" Some mismatch between PDG codes happened in entry " + iEntry
 
  155         if math.isnan(t1.mcErrors):
 
  156             basf2.B2FATAL(
" mcErrors should not be equal to nan")
 
  157         assert abs(t1.genMotherPDG) > 0, 
" genMotherPDG should be greater than 0" 
  158         assert abs(t1.nMCMatches) > 0, 
" nMCMatches should be greater than 0" 
def configure_logging_for_tests(user_replacements=None)
def require_file(filename, data_type="", py_case=None)
def clean_working_directory()