import pandas as pd
import os.path as osp
import numpy as np
from scipy import stats
import os

from utils import mkdir_if_missing, load_dict, save_dict, segment


def data_process(data):
    # select data without index
    d = data[:, 1:]
    f_data = d[np.where((d[:, -1] != 0) & (d[:, -1] != 7))]
    x_data = f_data[:, :-1]
    y_data = f_data[:, -1]
    x, y = segment(x_data, y_data, num_channel=num_channel, window_size=width)
    return x, y


def write_files(path, save_path):
    files = []
    for r, d, f in os.walk(path):
        for file in f:
            if '.txt' and 'raw' in file and not file.startswith('.'):
                files.append(os.path.join(r, file))

    dic = {}
    for f in files:
        subject_dir = os.path.dirname(f)
        subject = os.path.basename(subject_dir)
        print("processing file", f)
        f_data = np.loadtxt(f, skiprows=1)
        if subject not in dic.keys():
            dic[subject] = f_data
        else:
            dic[subject] = np.vstack((dic[subject], f_data))

    for key in dic.keys():
        user = str(int(key))
        x, y = data_process(dic[key])
        mkdir_if_missing(osp.join(save_path, user))
        for idx, (d, l) in enumerate(zip(x, y)):
            l = str(int(l - 1))
            mkdir_if_missing(osp.join(save_path, user, l))
            file_path = osp.join(save_path, user, l, "{}_{}_{}.pkl".format(user, l, str(idx)))
            save_dict(d, file_path)
        print("User {} done!".format(user))


if __name__ == "__main__":
    width = 20
    num_channel = 8
    file_path = 'E:/GitHub/SensingData/EMG/EMG_data_for_gestures-master_1'
    save_class_path = "E:/Datasets/Source/Sensing/sEMG"
    write_files(file_path, save_class_path)
