from bayes_opt.model import Bayesian_Optimization

def run_bayesian_optimization():
    # Run the Bayesian Optimization process
    simulation_function = ['schwefel', 'powell', 'eggholder', 'ackley', 'shekel', 'griewank', 'hartmann_3', 'hartmann_6']
    bounds = [[-500.0, 500.0], [-4.0, 5.0], [-512.0, 512.0], [-32.768, 32.768], [0.0, 10.0], [-600.0, 600.0], [0.0, 1.0], [0.0, 1.0]]
    dims = [3, 3, 1, 3, 3, 5, 2, 5]
    Y_best = [0.0, 0.0, 959.6, 0.0, 10.0, 0.0, 3.8, 3.3]
    use_evenly_spaced_time = True  # Set to True for evenly spaced time, False for real-time
    num_time_points = 120  # Number of evenly spaced time points to use
    time_limit = 600 #seconds
    initial_samples = 15
    for BOBA_beta in [1.0, 2.0, 4.0, 8.0, 16.0, 32.0]:
        for func in range(len(simulation_function)):
            for _ in range(10):

                BO = Bayesian_Optimization(
                    time_limit, 
                    initial_samples, 
                    dims[func], bounds[func], simulation_function[func],
                    use_evenly_spaced_time=use_evenly_spaced_time,
                    num_time_points=num_time_points,
                    Y_best=Y_best[func],
                    debug_timing=False,  # Enable timing measurements
                    verbose_timing=False
                )
                
                # Choose your model type here - just change this one line!
                model_type = "BOBA"  # Options: "GP-UCB", "BOBA", "WDBO", "WDBO_BOBA"
                BOBA_normalization = True
                
                X, Y, best_x, best_y = BO.bayesian_optimization(model_type=model_type, BOBA_beta=BOBA_beta, BOBA_normalization=BOBA_normalization)    
    

if __name__ == '__main__':
    # Set up communication between processes
    run_bayesian_optimization()
   