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 gen_numpy_from_csv(file_path):
    return np.genfromtxt(file_path, delimiter=',')


def transpose_3d(data):
    inputs = data[:, :-1]
    label = data[:, -1]
    inputs = np.reshape(inputs, (-1, num_channel, width))
    label = label - 1
    return inputs, label


def write_files(path, save_path):
    idx = 0
    train_path = osp.join(path, 'nor_train.csv')
    test_path = osp.join(path, 'nor_test.csv')
    train = gen_numpy_from_csv(train_path)
    test = gen_numpy_from_csv(test_path)

    user = '1'

    x, y = transpose_3d(train)
    mkdir_if_missing(osp.join(save_path, user))
    for d, l in zip(x, y):
        l = str(int(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 = transpose_3d(test)
    mkdir_if_missing(osp.join(save_path, user))
    for d, l in zip(x, y):
        l = str(int(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__":

    width = 512
    num_channel = 9
    file_path = 'E:/SensingRawData/PAMAP2'
    save_class_path = "E:/Datasets/Source/Sensing/PAMAP2"
    write_files(file_path, save_class_path)
