import matplotlib.pyplot as plt
import os
import pandas as pd
import numpy as np
basepath = 'trained_models/'

data = np.load('data.npz')
labels = data['label']
data_ts = data['data']
print(data_ts.shape)
#Pick a random index
curr_idx = 54654
single_trace = data_ts[curr_idx]
single_trace = (single_trace - np.min(single_trace)) / (np.max(single_trace) - np.min(single_trace))

# Convert to pandas DataFrame (optional: give column name)
df = pd.DataFrame(single_trace, columns=['Values'])

# Save to Excel
df.to_excel('output_1trace.xlsx', index=False)
exit()
#all_ids = np.load('200k_2000cluster/minmax_index.npy')
all_ids = np.load('200k_2000cluster/minmax_balance_0.5_index.npy')

test_key = 1733

num_samples = np.arange(20000,80000, 10000)
print(num_samples)

all_counts = []
for num_sample in num_samples:
    curr_labels = labels[all_ids[:num_sample]]
    unique, counts = np.unique(curr_labels, return_counts=True)
    all_counts.append(counts)

def get_mean(input_list):
    res = []
    for inp in input_list:
        res.append(np.mean(inp))

    return res

def get_min(input_list):
    res = []
    for inp in input_list:
        res.append(np.min(inp))

    return res

def get_max(input_list):
    res = []
    for inp in input_list:
        res.append(np.max(inp))

    return res

def get_std(input_list):
    res = []
    for inp in input_list:
        res.append(np.std(inp))

    return res

#Plot labels distribution

plt.figure(figsize=(10,7))
plt.grid()
#plt.plot(all_occurences_mm, label = 'min max sampling')
#plt.plot(get_mean(count_mm), '--', label = 'min max average num.samples per label')
#plt.plot(get_min(count_mm), '--', label = 'min max min num.samples per label')
#plt.plot(get_max(count_mm), '--', label = 'min max max num.samples per label')
#plt.plot(get_std(count_mm), '--', label = 'min max std num.samples per label')
#plt.plot(all_occurences_random, label = 'random sampling')
plt.plot(get_mean(all_counts), '--', label = 'average num.samples per label')
plt.plot(get_min(all_counts), '--', label = 'min num.samples per label')
plt.plot(get_max(all_counts), '--', label = 'max num.samples per label')
plt.plot(get_std(all_counts), '--', label = 'std num.samples per label')
x = np.arange(len(num_samples))
plt.xticks(x, num_samples /1000)
plt.xlabel('Num. Samples x 1000')
plt.ylabel('Counts in each label')
plt.legend()
#plt.savefig('Label_Distribution_minmax.png')
plt.savefig('Label_Distribution_minmax_balance.png')