gevi/geci_loader.py

88 lines
2.1 KiB
Python

import numpy as np
import os
import argh
# mouse:int = 0, 1, 2, 3, 4
def loader(mouse: int = 0, fpath: str = "/data_1/hendrik/gevi") -> None:
mouse_name = [
"M_Sert_Cre_41",
"M_Sert_Cre_42",
"M_Sert_Cre_45",
"M_Sert_Cre_46",
"M_Sert_Cre_49",
]
n_tris = [
[
15,
15,
30,
30,
30,
30,
], # 0 in cond 7
[
15,
15,
30,
30,
30,
30,
], # 0 in cond 7
[
15,
15,
30,
30,
30,
30,
], # 0 in cond 7
[
20,
40,
20,
20,
], # 0, 0, 0 in cond 5-7
[
20,
40,
20,
20,
], # 0, 0, 0 in cond 5-7
]
n_exp = len(n_tris[mouse])
for i_exp in range(n_exp):
n_tri = n_tris[mouse][i_exp]
for i_tri in range(n_tri):
experiment_name: str = f"Exp{i_exp + 1:03d}_Trial{i_tri + 1:03d}"
tmp_fname = os.path.join(
fpath,
"output_" + mouse_name[mouse],
experiment_name + "_acceptor_donor.npz",
)
print(f'Processing file "{tmp_fname}"...')
tmp = np.load(tmp_fname)
tmp_data_sequence = tmp["data_donor"]
tmp_light_signal = tmp["data_acceptor"]
if (i_exp == 0) and (i_tri == 0):
mask = tmp["mask"]
new_shape = [n_exp, *tmp_data_sequence.shape]
data_sequence = np.zeros(new_shape)
light_signal = np.zeros(new_shape)
data_sequence[i_exp] += tmp_data_sequence / n_tri
light_signal[i_exp] += tmp_light_signal / n_tri
np.save("dsq_" + mouse_name[mouse], data_sequence)
np.save("lsq_" + mouse_name[mouse], light_signal)
np.save("msq_" + mouse_name[mouse], mask)
if __name__ == "__main__":
argh.dispatch_command(loader)