import pandas as pd
import os.path as osp
from os import listdir
import numpy as np
from sklearn.preprocessing import StandardScaler
from utils.tools import mkdir_if_missing, load_dict, save_dict

# scenarios = ['BK', 'RN', 'SD', 'SW', 'WK']
scenarios = ['BK', 'SD', 'WK']
pkl_name_format = '{}_{}_{}_{}_{}.pkl'
channels = [0, 1, 2, 3, 5, 6, 7]
# subjects = [i for i in range(15)]
subjects = [0, 2, 4, 7, 8, 9, 10, 11, 12, 14]
left_hand = 10


def gen_numpy_from_csv(file_path):
    return np.genfromtxt(file_path, delimiter=',')


def write_pkl_files(file_path, save_path):
    idx = 0
    all_array = []
    scaler = StandardScaler()
    for scen in scenarios:
        scen_path = osp.join(file_path, scen)
        for sub_dir in listdir(scen_path):
            hand = sub_dir[3]
            sub_id = int(sub_dir[-2:])
            if sub_id not in subjects:
                continue
            if hand == 'R':
                continue
        sub_path = osp.join(scen_path, sub_dir)
        csv_path = osp.join(sub_path, '{}.csv'.format(sub_dir))

        # read csv
        csv_data = gen_numpy_from_csv(csv_path)
        for d in csv_data:
            array = np.reshape(d[:-1], (C, W))
            all_array.append(array)
    all_array = np.concatenate(all_array, axis=1)
    all_array = np.transpose(all_array, (1, 0))
    scaler.fit(all_array)

    for scen in scenarios:
        scen_path = osp.join(file_path, scen)
        for sub_dir in listdir(scen_path):
            hand = sub_dir[3]
            sub_id = int(sub_dir[-2:])
            if sub_id not in subjects:
                continue
            if hand == 'R':
                continue
            sub_id = subjects.index(sub_id)
            # if hand == 'L' and sub_id >= left_hand:
            #     continue
            # if hand == 'R' and sub_id < left_hand:
            #     continue
            sub_path = osp.join(scen_path, sub_dir)
            csv_path = osp.join(sub_path, '{}.csv'.format(sub_dir))

            # read csv
            csv_data = gen_numpy_from_csv(csv_path)
            for d in csv_data:
                label = int(d[-1])
                pkl_path = osp.join(save_path, scen, str(sub_id), str(label))
                mkdir_if_missing(pkl_path)
                array = np.reshape(d[:-1], (C, W))
                array = scaler.transform(array.T).T
                array = array[channels]
                pkl_name = pkl_name_format.format(scen, str(sub_id), str(label), hand, idx)
                save_dict(array, osp.join(pkl_path, pkl_name))
                idx += 1
        print("Scenario {} done!".format(scen))


if __name__ == "__main__":
    W = 200
    C = 8
    file_path = "E:/Data/Finger_Raw/"
    save_class_path = "E:/Datasets/Target/Finger/"
    write_pkl_files(file_path, save_class_path)
