from dataclasses import dataclass

from ruamel.yaml import YAML, yaml_object

from .._ground_truth_solver_config import GroundTruthSolverConfig
from ._solver import karger_stein_with_config


@yaml_object(YAML())
@dataclass()
class KargerConfig(GroundTruthSolverConfig):
    """
    Fields:

    - `k`: The parameter k (desired number of connected components) to use for Karger's algorithm when calculating the
           ground-truth minimum k-cut.
    - `num_karger_runs`: The number of times Karger's algorithm should be executed to calculate the ground-truth
                         minimum k-cut.
    """

    k: int
    num_karger_runs: int

    # overriding abstract method (no type hint on purpose)
    solve = karger_stein_with_config
