2024-02-23 16:00:50 +01:00
|
|
|
# flake8: noqa
|
2023-12-19 13:00:59 +01:00
|
|
|
import ROOT
|
|
|
|
|
|
|
|
|
|
|
|
def preselection(
|
|
|
|
cuts: str = "",
|
|
|
|
input_file: str = None,
|
|
|
|
outfile_postfix: str = "selected",
|
2024-02-23 16:00:50 +01:00
|
|
|
tree_name: str = "PrParameterisationData_2ece6184.PrDebugTrackingTool/Tuple",
|
2023-12-19 13:00:59 +01:00
|
|
|
) -> str:
|
|
|
|
"""Function that apply a selection to given data.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
cuts (str, optional): String specifying the selection. Defaults to "".
|
|
|
|
input_file (str, optional): Defaults to None.
|
|
|
|
outfile_postfix (str, optional): Defaults to "selected".
|
2024-02-23 16:00:50 +01:00
|
|
|
tree_name (str, optional): Defaults to "PrParameterisationData_2ece6184.PrDebugTrackingTool/Tuple".
|
2023-12-19 13:00:59 +01:00
|
|
|
|
|
|
|
Returns:
|
|
|
|
str: Path to the output file.
|
|
|
|
"""
|
|
|
|
rdf = ROOT.RDataFrame(tree_name, input_file)
|
|
|
|
rdf = rdf.Filter(cuts, "Selection")
|
|
|
|
out_file = input_file.strip(".root") + f"_{outfile_postfix}.root"
|
|
|
|
rdf.Snapshot("Selected", out_file)
|
|
|
|
return out_file
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
import argparse
|
|
|
|
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
parser.add_argument(
|
|
|
|
"--input-file",
|
|
|
|
type=str,
|
|
|
|
help="Path to the input file",
|
|
|
|
)
|
|
|
|
parser.add_argument(
|
|
|
|
"--cuts",
|
|
|
|
type=str,
|
|
|
|
default="chi2_comb < 5 && pt > 10 && p > 1500 && p < 100000 && pid != 11",
|
|
|
|
help="Cuts of the preselection",
|
|
|
|
)
|
|
|
|
args = parser.parse_args()
|
|
|
|
preselection(**vars(args))
|