from abc import ABC, abstractmethod

from torch import Tensor
from torch_geometric.data import Data


class GroundTruthSolverConfig(ABC):
    """
    Configures a solver to a combinatorial optimisation problem that is used to generate ground truth solutions for
    that problem.

    For each solver, a subclass of this class should exist that can hold the configuration parameters for the solver.
    Instances of that subclass can then directly be used to call the solver.

    Subclasses of this class should be annotated with `@yaml_object(YAML())` and `@dataclass()`.
    """

    @abstractmethod
    def solve(self, graph: Data) -> Tensor:
        """
        Calculates the ground truth solution for the given graph.

        Subclasses can implement this by simply assigning the solver function that this config class is intended to
        configure.
        It is important that the function is assigned without a type hint.
        See the documentation of `GraphGeneratorConfig` for more information on this trick.

        The solver function should take an instance of this config class and a graph as arguments, and no other
        arguments.
        It should return the solution as a Tensor.
        """
        pass
