import numpy as np

import optuna
import logging
logging.basicConfig(level=logging.DEBUG)

from .BO_Objective import Objective


def normalize_trials(trials):
    value_list = np.array([t.values for t in trials])
    mu = np.mean(value_list, axis=0)
    std = np.std(value_list, axis=0)
    return (value_list - mu) / (std + 1e-9)


def radar_area_matrix(values):
    """
    Computes the radar-chart polygon area for each row in 'values'
    using the shoelace formula (vectorized).

    Parameters
    ----------
    values : 2D np.ndarray of shape (m, n)
        - m: number of rows (models/configurations)
        - n: number of radar dimensions (objectives)
        Each row is one set of radial distances for the radar chart.

    Returns
    -------
    areas : 1D np.ndarray of shape (m,)
        The polygon area for each row.
    """
    values = np.asarray(values)
    m, n = values.shape

    # Angles equally spaced
    angles = np.linspace(0, 2 * np.pi, n, endpoint=False)

    x = values * np.cos(angles)
    y = values * np.sin(angles)

    # Shoelace formula
    cross_term = x * np.roll(y, -1, axis=1) - y * np.roll(x, -1, axis=1)
    areas = 0.5 * np.abs(np.sum(cross_term, axis=1))

    return areas

def main():
    from itertools import combinations
    datasets = [
        'cifar10'
                ]
    # root = 'H:\\****\\phd\\****\\autoVisual\\prepare_data\\clip\\features'
    root = 'features'
    seed = 0
    for dataset in datasets:
        for j in range(2, 5):
            label_combinations = list(combinations(range(10), j))
            for i in range(len(label_combinations)):
                dataset_path = f'{dataset}_{j}class_comb{i}_seed{seed}_clip_cdist_3000.tar'
                objective = Objective(dataset_name=f'{dataset}_{j}class_comb{i}_seed{seed}', method='tsne', dataset_path=root + '/' + dataset_path, save_path='res-2')

                algo = optuna.samplers.TPESampler(n_startup_trials=5, n_ei_candidates=24)
                # algo = optuna.samplers.NSGAIISampler()
                # algo = optuna.samplers.GPSampler(n_startup_trials=10)
                # study = optuna.create_study(sampler=algo, direction='maximize', storage="sqlite:///record/ocsvm2.db")
                try:
                    study = optuna.create_study(
                        sampler=algo, 
                        direction='maximize', 
                        storage="sqlite:///record/ocsvm2.db",
                        load_if_exists=True
                    )
                except Exception as e:
                    print(f'i will print the exception message.')
                    logging.error("Error creating Optuna study: %s", e)
                    print('the exception message is printed.')
                    raise
                    
                study.optimize(objective.tsne_search, n_trials=10, show_progress_bar=True)
                print(study.best_trials)

                # objective.plot_results('OCSVM', root='./res-ocsvm-large_data')
                objective.save_result('TSNE')


if __name__ == "__main__":
    main()