-
Notifications
You must be signed in to change notification settings - Fork 0
/
reduce.py
43 lines (35 loc) · 1.23 KB
/
reduce.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import argparse
import os
import ROOT
ROOT.gROOT.SetBatch(True)
def main(path, fraction, output):
print("Input file: {}".format(path))
df = ROOT.RDataFrame("Events", path)
count = df.Count()
num_events = count.GetValue()
print("Number of events: {}".format(num_events))
reduced_events = int(num_events * fraction)
print("Reduce the initial dataset to {} events".format(reduced_events))
basename = os.path.basename(path)
fullpath = os.path.join(output, basename)
print("Write out to {}".format(fullpath))
df.Range(reduced_events).Snapshot("Events", fullpath)
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument(
"path",
type=str,
help="Full path to NanoAOD file such as given to TFile::Open or the RDataFrame constructor",
)
parser.add_argument(
"fraction",
type=float,
help="Fraction of events to be kept, e.g., fraction=0.1 keeps 10% of the original file",
)
parser.add_argument(
"output",
type=str,
help="Output directory for the reduced NanoAOD file, the basename of the input file is kept.",
)
args = parser.parse_args()
main(args.path, args.fraction, args.output)