m-thesis-introduction/simulations/airshower_beacon_simulation/ab_modify_clocks.py

103 lines
3 KiB
Python
Raw Permalink Normal View History

2022-09-28 15:10:59 +02:00
#!/usr/bin/env python3
2022-11-14 20:49:35 +01:00
# vim: fdm=indent ts=4
"""
Add a uniformly sampled time offset
to the clock of each antenna.
"""
2022-09-28 15:10:59 +02:00
import numpy as np
import json
import h5py
import aa_generate_beacon as beacon
2022-09-28 15:10:59 +02:00
clocks_fname = 'clocks.csv'
if __name__ == "__main__":
from os import path
import sys
2022-12-07 17:27:12 +01:00
max_clock_offset = 100 if len(sys.argv) < 2 else float(sys.argv[1]) # ns
2022-11-14 20:49:35 +01:00
remake_clock_offsets = True
2022-09-28 15:10:59 +02:00
seed = 12345
rng = np.random.default_rng(seed)
fname = "ZH_airshower/mysim.sry"
####
fname_dir = path.dirname(fname)
clocks_fname = path.join(fname_dir, clocks_fname)
antennas_fname = path.join(fname_dir, beacon.antennas_fname)
if path.isfile(clocks_fname) and not remake_clock_offsets:
print("Clock offsets previously generated")
sys.exit()
if not path.isfile(antennas_fname):
print("Antenna file cannot be found, did you try generating a beacon?")
sys.exit(1)
2022-11-25 11:49:55 +01:00
2022-09-28 15:10:59 +02:00
# read in antennas
with h5py.File(antennas_fname, 'a') as fp:
if 'antennas' not in fp.keys():
2022-09-28 15:54:11 +02:00
print("Antenna file corrupted? no antennas")
2022-09-28 15:10:59 +02:00
sys.exit(1)
group = fp['antennas']
N_antennas = len(group.keys())
if True:
2022-12-15 15:08:55 +01:00
print(f"Modifying clocks upto {max_clock_offset}ns.")
clock_offsets = np.zeros( N_antennas )
if not True: # uniform
print("Uniform distribution")
clock_offsets = max_clock_offset * (2*rng.uniform(size=N_antennas) - 1)
else: # normal
print("Gaussian distribution")
clock_offsets = max_clock_offset * rng.normal(0, 1, size=N_antennas)
else: # Hardcoded offsets
print("Hardcoded offsets")
f_beacon = 51.53e-3 # GHz
clock_offsets = np.zeros( N_antennas )
if False:
clock_offsets[59] = np.pi/2 / (2*np.pi*f_beacon)
elif True:
clock_offsets += 1/8 * 1/f_beacon
print(clock_offsets)
2022-09-28 15:10:59 +02:00
# modify time values of each antenna
for i, name in enumerate(group.keys()):
h5ant = group[name]
2022-09-28 15:10:59 +02:00
clk_offset = clock_offsets[i]
if 'traces' not in h5ant.keys():
2022-09-28 15:54:11 +02:00
print(f"Antenna file corrupted? no 'traces' in {name}")
sys.exit(1)
h5ant_attrs = h5ant.attrs
if 'clock_offset' in h5ant_attrs:
tmp_offset = h5ant_attrs['clock_offset']
2022-09-28 15:10:59 +02:00
if remake_clock_offsets:
h5ant['traces'][0, :] -= tmp_offset
h5ant['E_AxB'][0, :] -= tmp_offset
2022-09-28 15:10:59 +02:00
else:
clock_offsets[i] = tmp_offset
continue
h5ant_attrs['clock_offset'] = clk_offset
h5ant['traces'][0, :] += clk_offset
h5ant['E_AxB'][0, :] += clk_offset
2022-09-28 15:10:59 +02:00
# save to simple csv
np.savetxt(clocks_fname, clock_offsets)
print("Antenna clocks modified in " + str(antennas_fname))