Belle II Software  release-06-00-14
miscalibT0.py
1 #!/usr/bin/env python3
2 # -*- coding: utf-8 -*-
3 
4 
11 
12 from ROOT import Belle2
13 
14 payload = Belle2.CDCTimeZeros()
15 
16 wires_in_layer = [
17  160, 160, 160, 160, 160, 160, 160, 160,
18  160, 160, 160, 160, 160, 160,
19  192, 192, 192, 192, 192, 192,
20  224, 224, 224, 224, 224, 224,
21  256, 256, 256, 256, 256, 256,
22  288, 288, 288, 288, 288, 288,
23  320, 320, 320, 320, 320, 320,
24  352, 352, 352, 352, 352, 352,
25  384, 384, 384, 384, 384, 384]
26 
27 for layer in range(0, 56):
28  for wire in range(0, wires_in_layer[layer]):
29  wireid = Belle2.WireID(layer, wire).getEWire()
30 
31  deltaT0 = 0 # T0 miscalibration in ns
32 
33  # only miscalibrate each second wire
34  if wire % 2 == 1:
35  deltaT0 = 2 # ns
36 
37  # We have to use global param access, because TimeZeros do
38  # not have a real setter
39  payload.setT0(layer, wire, 4900 + deltaT0)
40 
41 iov = Belle2.IntervalOfValidity(0, 0, -1, -1)
42 Belle2.Database.Instance().storeData('CDCTimeZeros', payload, iov)
Database object for timing offset (t0).
Definition: CDCTimeZeros.h:26
A class that describes the interval of experiments/runs for which an object in the database is valid.
Class to identify a wire inside the CDC.
Definition: WireID.h:34
static Database & Instance()
Instance of a singleton Database.
Definition: Database.cc:41