import numpy as np
import torch
import random

def smoothen_curve_batch(data, num_points):
    smooth_data =[data[0]]
    t =0
    data_av = 0.0
    total_iterations = len(data)
    av_interval = max(1, total_iterations // num_points)

    for count, item in enumerate(data, start=0): 
        data_av = data_av*t/(t+1) + item*(1/(t+1))
        t = t+1
        if count % av_interval == 0:
            smooth_data.append(data_av)
            data_av =0.0
            t=0.0
    return smooth_data

def smoothen_curve_exp(data, num_points):
    smooth_data =[data[0]]
    beta = 0.05
    data_av = data[0]
    total_iterations = len(data)
    av_interval = max(1, total_iterations // num_points)
    for count, item in enumerate(data, start=0): 
        if np.isnan(item):
            continue
        data_av = (1-beta)*data_av + beta*item
        if count % av_interval == 0:
            smooth_data.append(data_av)
    return smooth_data

def smoothen_dict(dict, num_points):
    smooth_dict = {}
    name = dict['name']
    for key in dict.keys():
        if key == 'name':
            continue
        if key == 'learning_rates' and 'sch' in name:
            continue
        if key == 'learning_rates':
            dict[key] = smoothen_curve_exp(dict[key], 400)
        else:
            dict[key] = smoothen_curve_exp(dict[key], num_points)
        # dict[key] = smoothen_curve(dict[key], num_points)

def set_seed(seed):
    random.seed(seed)
    np.random.seed(seed)
    torch.manual_seed(seed)
    torch.cuda.manual_seed(seed)
    torch.cuda.manual_seed_all(seed)  # if you are using multi-GPU
    torch.backends.cudnn.deterministic = True
    torch.backends.cudnn.benchmark = False  # May slow down training but ensures reproducibility

