from awp import run_algorithm, TrainConfig
from dataset import read_dataset

print("Starting experiment...")

# dataset = 'iris'
# epsilon = 0.80

# X, Y0, Y1 = read_dataset(f'datasets/{dataset}')
# n, d = X.shape

# #iris
# summary = run_algorithm(
#     X=X,
#     y=Y0,
#     epsilon=epsilon, # Rashomon parameter, either absolute or multiplicative depending on "relative_epsilon"
#     save_dir=f"./saved_models/{dataset}_{epsilon}",
#     reset_each_i=True, # Controls whether we reset to the base model each iteration for AWP           
#     num_classes=2,               
#     model_hidden=8,
#     model_depth=2,
#     dropout=0.0,
#     base_train_cfg=TrainConfig(epochs=120, lr=1e-3, batch_size=16),
#     opt_num_attempts=30, # Number of random restarts for optimization of the base model
#     ascent_lr=5e-4, # Learning rate for the ascent step in AWP
#     max_steps=1000, # Maximum number of steps for the ascent step in AWP
#     eval_every=10, # How often to evaluate and save the models during ascent step in AWP
#     seed=26,
#     shuffle=True,
#     shuffle_seed=3,
#     relative_epsilon=True, # Whether we use an absolute or multiplicative epsilon
#     reuse_base_model=False,
# )

#seeds

# dataset = 'seeds'
# epsilon = 0.80

# X, Y0, Y1 = read_dataset(f'datasets/{dataset}')
# n, d = X.shape 

# summary = run_algorithm(
#     X=X,
#     y=Y0,
#     epsilon=epsilon, # Rashomon parameter, either absolute or multiplicative depending on "relative_epsilon"
#     save_dir=f"./saved_models/{dataset}_{epsilon}",
#     reset_each_i=True, # Controls whether we reset to the base model each iteration for AWP           
#     num_classes=2,               
#     model_hidden=10,
#     model_depth=3,
#     dropout=0.0,
#     base_train_cfg=TrainConfig(epochs=160, lr=1e-3, batch_size=32),
#     opt_num_attempts=30, # Number of random restarts for optimization of the base model
#     ascent_lr=5e-5, # Learning rate for the ascent step in AWP
#     max_steps=1000, # Maximum number of steps for the ascent step in AWP
#     eval_every=10, # How often to evaluate and save the models during ascent step in AWP
#     seed=26,
#     shuffle=True,
#     shuffle_seed=3,
#     relative_epsilon=True, # Whether we use an absolute or multiplicative epsilon
#     reuse_base_model=False,
# )


# dataset = 'wine'

# X, Y0, Y1 = read_dataset(f'datasets/{dataset}')
# n, d = X.shape

# #wine
# summary = run_algorithm(
#     X=X,
#     y=Y0,
#     epsilon=0.30, # Rashomon parameter, either absolute or multiplicative depending on "relative_epsilon"
#     save_dir=f"./saved_models/{dataset}",
#     reset_each_i=True, # Controls whether we reset to the base model each iteration for AWP           
#     num_classes=2,               
#     model_hidden=25,
#     model_depth=2,
#     dropout=0.0,
#     base_train_cfg=TrainConfig(epochs=200, lr=1e-3, batch_size=16),
#     opt_num_attempts=30, # Number of random restarts for optimization of the base model
#     ascent_lr=5e-5, # Learning rate for the ascent step in AWP
#     max_steps=1000, # Maximum number of steps for the ascent step in AWP
#     eval_every=5, # How often to evaluate and save the models during ascent step in AWP
#     seed=26,
#     shuffle=True,
#     shuffle_seed=4,
#     relative_epsilon=True, # Whether we use an absolute or multiplicative epsilon
#     reuse_base_model=True,
# )

dataset = 'compas'
epsilon = 0.50

X, Y0, Y1 = read_dataset(f'datasets/{dataset}')
n, d = X.shape

#compas
summary = run_algorithm(
    X=X,
    y=Y0,
    epsilon=epsilon, # Rashomon parameter, either absolute or multiplicative depending on "relative_epsilon"
    save_dir=f"./saved_models/{dataset}_{epsilon}",
    reset_each_i=True, # Controls whether we reset to the base model each iteration for AWP           
    num_classes=2,               
    model_hidden=20,
    model_depth=4,
    dropout=0.0,
    base_train_cfg=TrainConfig(epochs=300, lr=3e-4, batch_size=128),
    opt_num_attempts=10, # Number of random restarts for optimization of the base model
    ascent_lr=3e-4, # Learning rate for the ascent step in AWP
    max_steps=1000, # Maximum number of steps for the ascent step in AWP
    eval_every=40, # How often to evaluate and save the models during ascent step in AWP
    seed=26,
    shuffle=True,
    shuffle_seed=4,
    relative_epsilon=True, # Whether we use an absolute or multiplicative epsilon
    reuse_base_model=False,
    num_data_points=500,
)


print("Done. Summary:", summary)
