"""
Experiment definitions.
"""
import alglab

import algorithms
import datasets

class DynamicGraphSchedule(alglab.experiment.ExperimentSchedule):

    def __init__(self, dataset: datasets.DynamicGraphDataset):
        super().__init__(dataset)
        self.dataset = dataset

    def schedule(self):
        for t in range(self.dataset.num_updates):
            self.dataset.set_iteration(t)
            node_insertions, node_deletions, edge_insertions, edge_deletions = self.dataset.get_update(t)

            yield 'add_nodes', node_insertions, None
            yield 'add_edges', [tuple(edge) for edge in edge_insertions], None
            yield 'remove_edges', [tuple(edge) for edge in edge_deletions], None
            
            yield 'remove_nodes', node_deletions, None
            yield 'predict', self.dataset.get_num_clusters_at_time(t), self.dataset.gt_labels

    @staticmethod
    def all_method_names():
        return ['add_nodes', 'add_edges', 'remove_edges', 'predict', 'remove_nodes']

k = 30
n = 1000
coreset_size = 4096
pid_target = -0.5
sbm_new_clusters_experiment_nols24 = alglab.experiment.ExperimentalSuite(
    [
        algorithms.FasterDynamicCSC,
        algorithms.DynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicSBMAddingSmallClusters,
    DynamicGraphSchedule,
    "results/sbm_new_clusters_nols24.csv",
    parameters={
        'dataset.k': k,
        'dataset.n': n,
        'dataset.p': 0.5,
        'dataset.q': 1/(n*k),
        'dataset.n_new': 1000,
        'dataset.s': 0.000001,
        'dataset.num_updates': 10,
        "DynamicCSC.coreset_size":coreset_size,
        "DynamicCSC.degree_threshold": 2.0,
        "DynamicCSC.pid_target": pid_target,
        "DynamicCSC.coreset_modifier": k*8,
        "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 8,
        "FasterDynamicCSC.coreset_size":coreset_size,
        
    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10
)

k = 30
n = 300
coreset_size = 2048
pid_target = -0.5
sbm_new_clusters_experiment = alglab.experiment.ExperimentalSuite(
    [        
        algorithms.LS24,
        algorithms.FasterDynamicCSC,
        algorithms.DynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicSBMAddingSmallClusters,
    DynamicGraphSchedule,
    "results/sbm_new_clusters.csv",
    parameters={
        'dataset.k': k,
        'dataset.n': n,
        'dataset.p': 0.5,
        'dataset.q': 1/(n*k),
        'dataset.n_new': n,
        'dataset.s': 0.000001,
        'dataset.num_updates': 20,
        'LS24.sampling_constant': 5,
        'LS24.degree_trigger': 0.8,

        "DynamicCSC.coreset_size":coreset_size,
        "DynamicCSC.degree_threshold": 1.0,
        "DynamicCSC.pid_target": pid_target,
        "DynamicCSC.coreset_modifier": k*8,
        "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 8,
    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10
)


k = 50
n = 2500
coreset_size = 1024
pid_target = -0.5
sbm_new_clusters_experiment_large = alglab.experiment.ExperimentalSuite(
    [        
        algorithms.FasterDynamicCSC,
        algorithms.StaticCSC,
    ],
    datasets.DynamicSBMAddingSmallClusters,
    DynamicGraphSchedule,
    "results/sbm_new_clusters_large.csv",
    parameters={
        'dataset.k': k,
        'dataset.n': n,
        'dataset.p': 0.5,
        'dataset.q': 1/(n*k),
        'dataset.n_new': n,
        'dataset.s': 0.000001,
        'dataset.num_updates': 20,

        "StaticCSC.coreset_size": coreset_size,
        "StaticCSC.coreset_modifier": k*4,
        "StaticCSC.fixed_pid_shift": 0.1,

        "FasterDynamicCSC.coreset_size": coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 4,
    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10
)

total_clusters = 20
n = 100
updates = 10
coreset_size = 2048
pid_target = -0.5
sbm_merge_clusters_experiment = alglab.experiment.ExperimentalSuite(
    [        
        algorithms.LS24,
        algorithms.FasterDynamicCSC,
        algorithms.DynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicSBMMergingClusters,
    DynamicGraphSchedule,
    "results/sbm_merge_clusters.csv",
    parameters={
        'dataset.cluster_sizes': [[n]*total_clusters],
        'dataset.p': 0.5,
        'dataset.q': 1/(n*total_clusters),
        'dataset.r': 0.95,
        'dataset.s': 1/(updates*n*total_clusters),
        'dataset.num_updates': updates,
        'LS24.sampling_constant': 5,
        'LS24.degree_trigger': 0.8,
        "DynamicCSC.coreset_size":coreset_size,
        "DynamicCSC.degree_threshold": 1.0,
        "DynamicCSC.pid_target": pid_target,
        "DynamicCSC.coreset_modifier": total_clusters*6,
        "DynamicCSC.coreset_modifier": total_clusters*6,
        "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 6,
        "FasterDynamicCSC.coreset_modifier": 6,


    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10
)

n = 1000
sbm_merge_clusters_experiment_nols24 = alglab.experiment.ExperimentalSuite(
    [
        algorithms.FasterDynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicSBMMergingClusters,
    DynamicGraphSchedule,
    "results/sbm_merge_clusters_nols24.csv",
    parameters={
        'dataset.cluster_sizes': [[n]*total_clusters],
        'dataset.p': 0.5,
        'dataset.q': 1/(n*total_clusters),
        'dataset.r': 0.95,
        'dataset.s': 1/(updates*n*total_clusters),
        'dataset.num_updates': updates,

        # "DynamicCSC.coreset_size":coreset_size,
        # "DynamicCSC.degree_threshold": 1.0,
        # "DynamicCSC.pid_target": pid_target,
        # "DynamicCSC.coreset_modifier": total_clusters*4,
        # "DynamicCSC.update_buffer_size": 10,


        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 10,
    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10
)


coreset_size = 2048
pid_target = -0.5
k = 10
knn_mnist_experiment = alglab.experiment.ExperimentalSuite(
    [
        # algorithms.LS24,
        # algorithms.DynamicCSC,


        # algorithms.DynamicCSC,


        algorithms.FasterDynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicMNISTDataset,
    DynamicGraphSchedule,
    "results/knn_mnist.csv",
    parameters={
        'dataset.batch_size': [1000],
        'dataset.k': [300],
        # 'LS24.sampling_constant': 1,
        # 'LS24.degree_trigger': 0.2,
        # 'LS24.reinit_threshold': 100000,

        # "DynamicCSC.coreset_size":coreset_size,
        # "DynamicCSC.degree_threshold": 1.0,
        # "DynamicCSC.pid_target": pid_target,
        # "DynamicCSC.coreset_modifier": k*10,
        # "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 8,
    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10,
)

knn_mnist_experiment_with_deletions = alglab.experiment.ExperimentalSuite(
    [
        algorithms.FasterDynamicCSC,
        # algorithms.DynamicCSC,
        algorithms.NaiveDynamicSC,
        # algorithms.StaticCSC,
    ],
    datasets.DynamicMNISTDataset,
    DynamicGraphSchedule,
    "results/knn_mnist_deletions.csv",
    parameters={
        'dataset.batch_size': [1000],
        'dataset.k': [300],
        'dataset.include_deletions': True,

        # "DynamicCSC.coreset_size":coreset_size,
        # "DynamicCSC.degree_threshold": 1.0,
        # "DynamicCSC.pid_target": pid_target,
        # "DynamicCSC.coreset_modifier": k*10,
        # "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 8,

        # "StaticCSC.coreset_size": coreset_size,
        # "StaticCSC.coreset_modifier": 10,
        # "StaticCSC.fixed_pid_shift": 1000,
    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10,
)


coreset_size = 8192
pid_target = -0.5
k = 26
knn_emnist_experiment = alglab.experiment.ExperimentalSuite(
    [
        # algorithms.LS24,
        algorithms.FasterDynamicCSC,
        # algorithms.DynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicEMNISTDataset,
    DynamicGraphSchedule,
    "results/knn_emnist.csv",
    parameters={
        'dataset.batch_size': [1000],
        'dataset.k': [300],
        # 'LS24.sampling_constant': 1,
        # 'LS24.degree_trigger': 0.2,
        # 'LS24.reinit_threshold': 100000,

        # "DynamicCSC.coreset_size":coreset_size,
        # "DynamicCSC.degree_threshold": 1.0,
        # "DynamicCSC.pid_target": pid_target,
        # "DynamicCSC.coreset_modifier": k*4,
        # "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 4,
    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10,
)

knn_emnist_experiment_with_deletions = alglab.experiment.ExperimentalSuite(
    [
        algorithms.FasterDynamicCSC,
        # algorithms.DynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicEMNISTDataset,
    DynamicGraphSchedule,
    "results/knn_emnist_deletions.csv",
    parameters={
        'dataset.batch_size': [1000],
        'dataset.k': [300],
        'dataset.include_deletions': True,

        # "DynamicCSC.coreset_size":coreset_size,
        # "DynamicCSC.degree_threshold": 1.0,
        # "DynamicCSC.pid_target": pid_target,
        # "DynamicCSC.coreset_modifier": k*4,
        # "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 2,

    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10,
)

total_clusters = 10
n = 1000
coreset_size = 2048
pid_target = 0.02
sbm_change_clusters_experiment = alglab.experiment.ExperimentalSuite(
    [
        algorithms.FasterDynamicCSC,
        algorithms.DynamicCSC,
        algorithms.NaiveDynamicSC,
    ],
    datasets.DynamicSBMChangingClusters,
    DynamicGraphSchedule,
    "results/sbm_change_clusters.csv",
    parameters={
        'dataset.cluster_size': n,
        'dataset.p': 0.5,
        'dataset.q': 1/(n*total_clusters),
        'dataset.k': total_clusters,
        "DynamicCSC.coreset_size":coreset_size,
        "DynamicCSC.degree_threshold": 1.0,
        "DynamicCSC.pid_target": pid_target,
        "DynamicCSC.coreset_modifier": total_clusters*8,
        "DynamicCSC.update_buffer_size": 10,

        "FasterDynamicCSC.coreset_size":coreset_size,
        "FasterDynamicCSC.fixed_pid_shift": 1000,
        "FasterDynamicCSC.coreset_modifier": 8,

    },
    evaluators=[alglab.evaluation.adjusted_rand_index],
    num_runs=10,
)
