import numpy as np
from scipy.stats import norm

def workloads(n_env, num_actions):
    mus = np.zeros((n_env, num_actions))
    sigmas = np.zeros((n_env, num_actions))

    for env in range(n_env):
        if env % 3 == 0:
            # Configuration 1: Low mus and sigmas 
            mus[env] = np.random.uniform(low=0.3, high=0.6, size=num_actions)
            sigmas[env] = np.random.uniform(low=0.01, high=0.02, size=num_actions)

            # One action to be dominant 
            dominant_action = np.random.randint(num_actions)
            mus[env, dominant_action] = 0.2
            sigmas[env, dominant_action] = 0.03
        
        elif env % 3 == 1:
            # Configuration 2: Micro workload 
            mus[env] = np.random.uniform(low=0.02, high=0.1, size=num_actions)
            sigmas[env] = np.random.uniform(low=0.005, high=0.015, size=num_actions)

            # One action to be dominant
            dominant_action = np.random.randint(num_actions)
            mus[env, dominant_action] = 0.015
            sigmas[env, dominant_action] = 0.02

        else:
            # Configuration 3: High mus and sigmas 
            mus[env] = np.random.uniform(low=1.5, high=2.5, size=num_actions)
            sigmas[env] = np.random.uniform(low=0.1, high=0.3, size=num_actions)

            # One action to be dominant
            dominant_action = np.random.randint(num_actions)
            mus[env, dominant_action] = 1.0
            sigmas[env, dominant_action] = 0.4

    return mus, sigmas

                   
z_score_95 = norm.ppf(1 - (1 - 0.95) / 2)


num_actions_list = [20, 40, 60, 80, 100,120,140,160]
n_env = 3

environments = {}

for num_actions in num_actions_list:
    
    
    mus, sigmas = workloads(n_env, num_actions)
    environments[num_actions] = [(mus, sigmas)]

