import pandas as pd
import os.path as osp
from utils.tools import mkdir_if_missing, load_dict, save_dict


def write_hhar_files(csv_path, save_path):
    OVERLAPPING_WIN_LEN = 256 // 2
    users = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i']
    class2id = {'bike': '0', 'sit': '1', 'stand': '2', 'walk': '3', 'stairsup': '4', 'stairsdown': '5'}
    df = pd.read_csv(csv_path)

    for user in users:
        print("User %s :" % (user))
        df_a = df[df['User'] == user]
        mkdir_if_missing(osp.join(save_path, user))
        mode_set = set()
        st_set = set()
        for idx in range(max(len(df_a) // OVERLAPPING_WIN_LEN - 1, 0)):
            user = df_a.iloc[idx * OVERLAPPING_WIN_LEN, 9]
            model = df_a.iloc[idx * OVERLAPPING_WIN_LEN, 10]
            device = df_a.iloc[idx * OVERLAPPING_WIN_LEN, 11]
            class_label = df_a.iloc[idx * OVERLAPPING_WIN_LEN, 12]
            feature = df_a.iloc[idx * OVERLAPPING_WIN_LEN:(idx + 2) * OVERLAPPING_WIN_LEN, 3:9].values
            feature = feature.T
            # print("idx %d" % (idx))
            mkdir_if_missing(osp.join(save_path, user, str(class2id[class_label])))
            file_name = osp.join(save_path, user, str(class2id[class_label]), model + "_" + str(idx) + '.pkl')
            save_dict(feature, file_name)
            mode_set.add(model)
            st_set.add(class_label)
        print("User {} done!".format(user))
        print("user:", user, "models", mode_set, "st", st_set)


if __name__ == "__main__":
    file_path = "D:/Dataset/HybridCrossDataset/hhar_minmax_scaling_all.csv"
    save_class_path = "D:/Dataset/HybridCrossDataset/HHar/"
    write_hhar_files(file_path, save_class_path)
