-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPOTATO_processMultiH5.py
79 lines (64 loc) · 2.41 KB
/
POTATO_processMultiH5.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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
"""Copyright 2021 Helmholtz-Zentrum für Infektionsforschung GmbH"""
import pandas as pd
import numpy as np
def split_H5(FD, input_settings, Frequency_value):
d_time = 1 / Frequency_value * input_settings['downsample_value'] * input_settings['step_d']
d = Frequency_value // input_settings['downsample_value']
d_half = int(0.5 * d)
derivation_list = []
t = 0
for i in range(d_half, len(FD) - d_half):
PD_value = (FD[i + d_half, 1] + FD[i - d_half, 1]) / 2
delta_PD = FD[i + d_half, 1] - FD[i - d_half, 1]
PD_dt = delta_PD / d_time
t = t + d_time
derivation_list.append([t, PD_value, PD_dt])
derivation_array = pd.DataFrame(derivation_list)
derivation_array = derivation_array.to_numpy()
forward = []
reverse = []
n = []
x = d_half
x_fw = []
x_rv = []
x_total = []
for i in range(len(derivation_array)):
if derivation_array[i, 2] > -2500 and derivation_array[i, 2] < 2500:
n.append(i + d_half)
x = len(n) + d_half
elif derivation_array[i, 2] > 2500:
x_fw.append(x)
x_total.append(x)
forward.append(FD[i + d_half])
elif derivation_array[i, 2] < -2500:
x_rv.append(x)
x_total.append(x)
reverse.append(FD[i + d_half])
unique_fw = np.unique(x_fw)
unique_rv = np.unique(x_rv)
unique_total = np.unique(x_total)
print('Fw:', len(unique_fw), ', Rev:', len(unique_rv), ', Together:', len(unique_total))
forward = np.vstack(forward)
reverse = np.vstack(reverse)
print(forward)
fw_merge = np.column_stack((forward, x_fw))
rv_merge = np.column_stack((reverse, x_rv))
fw_merge = np.split(fw_merge, np.where(np.diff(fw_merge[:, 2]))[0] + 1)
rv_merge = np.split(rv_merge, np.where(np.diff(rv_merge[:, 2]))[0] + 1)
############################# remove arrays that are way below average length
arr_length = 0
count = 0
for i in fw_merge:
arr_length += len(i)
count += 1
for i in rv_merge:
arr_length += len(i)
count += 1
arr_average = arr_length / count
for i in fw_merge:
if len(i) < 0.5 * arr_average:
fw_merge.remove(i)
for i in rv_merge:
if len(i) < 0.5 * arr_average:
rv_merge.remove(i)
return fw_merge, rv_merge