import numpy as np
import pandas as pd
from statsmodels.tsa.stattools import adfuller
import argparse
import pickle
import os
import glob

if __name__ == '__main__':
    parser = argparse.ArgumentParser()

    parser.add_argument('--path', type=str, help='The folder of raw yahoo dataset', default='ydata-labeled-time-series-anomalies-v1_0')
    parser.add_argument('-o', '--output', type=str, default='yahoo.pkl')
    args = parser.parse_args()
    
    files_a1 = glob.glob(os.path.join(args.path, 'A1Benchmark/real_*.csv'))
    files_a1.sort()
    files_a2 = glob.glob(os.path.join(args.path, 'A2Benchmark/synthetic_*.csv'))
    files_a2.sort()
    files_a3 = glob.glob(os.path.join(args.path, 'A3Benchmark/A3Benchmark-TS*.csv'))
    files_a3.sort()
    files_a4 = glob.glob(os.path.join(args.path, 'A4Benchmark/A4Benchmark-TS*.csv'))
    files_a4.sort()
    
    dataset = []
    for fn in files_a1:
        df = pd.read_csv(fn)
        dataset.append({
            'timestamp': (1483225200 + 3600 * df['timestamp']).tolist(),
            'value': df['value'].tolist(),
            'label': df['is_anomaly'].tolist()
        })
    for fn in files_a2:
        df = pd.read_csv(fn)
        dataset.append({
            'timestamp': df['timestamp'].tolist(),
            'value': df['value'].tolist(),
            'label': df['is_anomaly'].tolist()
        })
    for fn in files_a3:
        df = pd.read_csv(fn)
        dataset.append({
            'timestamp': df['timestamps'].astype(np.long).tolist(),
            'value': df['value'].tolist(),
            'label': df['anomaly'].tolist()
        })
    for fn in files_a4:
        df = pd.read_csv(fn)
        dataset.append({
            'timestamp': df['timestamps'].astype(np.long).tolist(),
            'value': df['value'].tolist(),
            'label': df['anomaly'].tolist()
        })
    assert len(dataset) == 367, 'Incomplete dataset'
    
    all_train_data = {}
    all_train_labels = {}
    all_train_timestamps = {}
    all_test_data = {}
    all_test_labels = {}
    all_test_timestamps = {}

    for i in range(367):
        ts = dataset[i]
        data = np.array(ts['value'])
        labels = np.array(ts['label'])
        timestamps = np.array(ts['timestamp'])
        k = 'yahoo_' + str(i+1)
        l = len(data) // 2

        n = 0
        while adfuller(data[:l], 1)[1] > 0.05 or adfuller(data[:l])[1] > 0.05:
            data = np.diff(data)
            labels = labels[1:]
            timestamps = timestamps[1:]
            n += 1
        l -= n

        all_train_data[k] = data[:l]
        all_test_data[k] = data[l:]
        all_train_labels[k] = labels[:l]
        all_test_labels[k] = labels[l:]
        all_train_timestamps[k] = timestamps[:l]
        all_test_timestamps[k] = timestamps[l:]

        mean, std = all_train_data[k].mean(), all_train_data[k].std()
        all_train_data[k] = (all_train_data[k] - mean) / std
        all_test_data[k] = (all_test_data[k] - mean) / std

    with open(args.output, 'wb') as f:
        pickle.dump({
            'all_train_data': all_train_data,
            'all_train_labels': all_train_labels,
            'all_train_timestamps': all_train_timestamps,
            'all_test_data': all_test_data,
            'all_test_labels': all_test_labels,
            'all_test_timestamps': all_test_timestamps,
            'delay': 3
        }, f)
    