diff --git a/modules/aeolus/aeolus_amv.py b/modules/aeolus/aeolus_amv.py index d913e2f9d542a828c4a17f3df84c0eec8c5ea718..aede7f165900fdb6d0501e4804f9baacb57a4e2e 100644 --- a/modules/aeolus/aeolus_amv.py +++ b/modules/aeolus/aeolus_amv.py @@ -80,7 +80,7 @@ def get_file_containing_time(timestamp, files_path, file_time_span, amv_source=' # imports the S4 NOAA output # filename: full path as a string, '/home/user/filename' # returns a dict: time -> list of profiles (a profile is a list of levels) -def get_aeolus_time_dict(filename, lon360=False): +def get_aeolus_time_dict(filename, lon360=False, do_sort=True): time_dict = {} with open(filename) as file: @@ -138,6 +138,17 @@ def get_aeolus_time_dict(filename, lon360=False): file.close() + if do_sort: + keys = np.array(list(time_dict.keys())) + keys.sort() + keys = keys.tolist() + + sorted_time_dict = {} + + for key in keys: + sorted_time_dict[key] = time_dict.get(key) + time_dict = sorted_time_dict + return time_dict @@ -154,6 +165,41 @@ def time_dict_to_nd(time_dict): return time_dict +def concat(t_dct_0, t_dct_1): + keys_0 = list(t_dct_0.keys()) + nda_0 = np.array(keys_0) + + keys_1 = list(t_dct_1.keys()) + nda_1 = np.array(keys_1) + + comm_keys, comm0, comm1 = np.intersect1d(nda_0, nda_1, return_indices=True) + + comm_keys = comm_keys.tolist() + + for key in comm_keys: + t_dct_1.pop(key) + t_dct_0.update(t_dct_1) + + return t_dct_0 + + +def get_aeolus_time_dict_s(filenames, lon360=False, do_sort=True): + dct_s = [] + for fname in filenames: + a_dct = get_aeolus_time_dict(fname, lon360=lon360, do_sort=do_sort) + t_dct = time_dict_to_nd(a_dct) + dct_s.append(t_dct) + print(fname) + + t_dct = dct_s[0] + + for dct in dct_s[1:]: + concat(t_dct, dct) + print(len(dct)) + + return t_dct + + def get_search_box(nav, lon, lat): cc, ll = nav.earth_to_lc(lon, lat)