import os.path as osp
import numpy as np
import os
import csv
from scipy import stats
from utils import mkdir_if_missing, save_dict, segment, map_label, windowz
import h5py as h5


def segment_opp(x_train, y_train, window_size):
    segments = np.zeros(((len(x_train) // (window_size // 2)) - 1, window_size, 77))
    labels = np.zeros(((len(y_train) // (window_size // 2)) - 1))
    i_segment = 0
    i_label = 0
    for (start, end) in windowz(x_train, window_size):
        if (len(x_train[start:end]) == window_size):
            m = stats.mode(y_train[start:end])
            segments[i_segment] = x_train[start:end]
            labels[i_label] = m[0]
            i_label += 1
            i_segment += 1
    return segments, labels


def data_process(x, y):
    mask = np.isin(y, except_classes, invert=True)
    x_data = x[mask]
    y_data = y[mask]
    x, y = segment_opp(x_data, y_data, window_size=width)
    return x, y


def write_files(path, save_path):
    idx = 0
    filename = osp.join(path, 'opportunity.h5')
    f = h5.File(filename, 'r')
    x_train = f.get('train').get('inputs')[()]
    y_train = f.get('train').get('targets')[()]

    x_test = f.get('test').get('inputs')[()]
    y_test = f.get('test').get('targets')[()]
    user = '1'

    x, y = data_process(x_train, y_train)
    x = np.transpose(x, (0, 2, 1))
    mkdir_if_missing(osp.join(save_path, user))
    for d, l in zip(x, y):
        l = str(map_label(except_classes, l))
        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)
        idx += 1

    x, y = data_process(x_test, y_test)
    x = np.transpose(x, (0, 2, 1))
    mkdir_if_missing(osp.join(save_path, user))
    for d, l in zip(x, y):
        l = str(map_label(except_classes, l))
        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)
        idx += 1
    print("User {} done!".format(user))


if __name__ == "__main__":
    except_classes = [0, 1, 9, 10, 11, 12, 13, 14]

    width = 100
    num_channel = 77
    file_path = 'E:/SensingRawData/OPPORTUNITY'
    save_class_path = "E:/Datasets/Source/Sensing/OPPORTUNITY"
    write_files(file_path, save_class_path)
