import scipy.stats as stats
import numpy as np
from envs.constants import *

app_info={
    SPEECH_RECOGNITION : {'workload':10435,
        'popularity': 0.5,
        'min_bits':40*KB,
        'max_bits':300*KB
    },NLP : {'workload':25346,
        'popularity': 0.8,
        'min_bits':4*KB,
        'max_bits':100*KB
    },VR : {'workload':40305,
        'popularity': 0.1,
        'min_bits':0.1*MB,
        'max_bits':3*MB
    }
}


def app_type_list():
    return app_info.keys()

def app_type_pop():
    return [(i, app_info[i]['popularity']) for i in list(app_info.keys())]

def get_info(type, info_name='workload'):
    return app_info[type][info_name]

def arrival_bits(app_type, dist = 'normal', size=1):
    min_bits = app_info[app_type]['min_bits']
    max_bits = app_info[app_type]['max_bits']
    mu = (min_bits+max_bits)/2
    sigma = (max_bits-min_bits)/4
    if dist=='normal':
        if size==1:
            return int(stats.truncnorm.rvs((min_bits-mu)/sigma, (max_bits-mu)/sigma, loc=mu, scale=sigma))
        return stats.truncnorm.rvs((min_bits-mu)/sigma, (max_bits-mu)/sigma, loc=mu, scale=sigma, size=size).astype(int)
    elif dist=='deterministic':
        return mu
    else:
        return 1

def main():
    result =[]
    for i in range(1,9):
        arrival_bits(i)
        result.append(app_info[i]['workload']*app_info[i]['popularity']*arrival_bits(i, dist='deterministic'))
    result = np.array(result)/GHZ
    import pdb; pdb.set_trace()

def normal_dist(list, mu, sig, peak):
    return peak*np.exp(-(list-mu)**2/2/sig**2)/sig/np.sqrt(2*np.pi)

import matplotlib.pyplot as plt
def random_task_generation():
    import math
    # 24 hours = 86400 secs.
    timeline = np.arange((60*60*24)*7*3)
    # weekdays
    mu_days_el = np.array([60*60*7, int(60*60*12.5), 60*60*15, 60*60*19, 60*60*22])
    std_days = [60*60*0.5, 60*60, 60*60, 60*60, 60*60*3]*5
    peak_days = [3,10,1,20,30]*5
    mu_days = np.array([], dtype=int)
    import pdb; pdb.set_trace()
    for i in range(5):
        mu_days=np.concatenate((mu_days, mu_days_el+i*60*60*24))
    # weekends
    mu_Sat = np.array([60*60*10, 60*60*15, 60*60*22])+60*60*24*5
    mu_Sun = np.array([60*60*10, 60*60*15, 60*60*21])+60*60*24*6
    std_ends = [60*60*1, 60*60*3, 60*60*6, 60*60*1, 60*60*3, 60*60*2]
    peak_ends = [25,35,45,10,30,20]

    mu = np.concatenate((mu_days, mu_Sat, mu_Sun))
    stds = std_days+std_ends
    peaks = peak_days+peak_ends

    mu = np.concatenate((mu,mu+60*60*24*7,mu+60*60*24*14))
    stds = stds*3
    peaks = peaks*3
    import pdb; pdb.set_trace()
    graph = np.zeros(60*60*24*7*3)
    for i in range(len(mu)):
        graph += normal_dist(timeline, mu[i], stds[i], peaks[i])
        print(i)
    import pdb; pdb.set_trace()

    data_size = np.random.poisson(graph*2000)*arrival_bits(2,size=len(timeline))
    import pdb; pdb.set_trace()
    plt.plot(timeline, data_size)
    plt.plot(timeline, graph)

    np.save("graph", np.array([timeline, graph]))
    np.save("data_size", np.array([timeline, data_size]))

    plt.show()
    return graph, data_size


if __name__=='__main__':
    main()
