gevi/geci_loader.py

127 lines
3.2 KiB
Python
Raw Normal View History

2024-08-10 20:56:23 +02:00
import numpy as np
import os
import argh
# mouse:int = 0, 1, 2, 3, 4
2024-08-12 10:54:17 +02:00
def loader(mouse: int = 0, fpath: str = "/data_1/hendrik/gevi") -> None:
2024-08-10 20:56:23 +02:00
mouse_name = [
2024-08-12 10:54:17 +02:00
"M_Sert_Cre_41",
"M_Sert_Cre_42",
"M_Sert_Cre_45",
"M_Sert_Cre_46",
"M_Sert_Cre_49",
2024-08-10 20:56:23 +02:00
]
n_tris = [
2024-08-12 10:54:17 +02:00
[
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
2024-08-10 20:56:23 +02:00
]
# 41, 42, 45, 46, 49:
# "1": "control",
# "2": "visual control grating 100 1s",
# "3": "optical Stimulation 20Hz 50% 5 Intervals",
# "4": "optical Stimulation 20Hz 100% 5 Intervals",
# "5": "optical Stimulation 20Hz 50% and grating 100",
# "6": "optical Stimulation 20Hz 100% and grating 100",
# "7": "grating 3s"
lbs = [
2024-08-12 10:54:17 +02:00
[
"control",
"visual control",
"op20 50 5",
"op20 100 5",
"op20 50 grat",
"op20 100 grat",
],
[
"control",
"visual control",
"op20 50 5",
"op20 100 5",
"op20 50 grat",
"op20 100 grat",
],
[
"control",
"visual control",
"op20 50 5",
"op20 100 5",
"op20 50 grat",
"op20 100 grat",
],
["control", "visual control", "op20 50 5", "op20 100 5"],
["control", "visual control", "op20 50 5", "op20 100 5"],
2024-08-10 20:56:23 +02:00
]
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):
2024-08-12 10:54:17 +02:00
experiment_name: str = f"Exp{i_exp + 1:03d}_Trial{i_tri + 1:03d}"
2024-08-10 20:56:23 +02:00
tmp_fname = os.path.join(
2024-08-12 10:54:17 +02:00
fpath,
"output_" + mouse_name[mouse],
experiment_name + "_acceptor_donor.npz",
2024-08-10 20:56:23 +02:00
)
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)
2024-08-12 10:54:17 +02:00
2024-08-10 20:56:23 +02:00
if __name__ == "__main__":
argh.dispatch_command(loader)