from dataclasses import dataclass

from torch import Tensor

from ._meta_graph import MetaEdgeWeight


@dataclass(frozen=True)
class Cut:
    """
    Describes a graph cut.

    Fields:

    - `connected_components`: For each node in the graph, this specifies which connected component it belongs to.
                              The list of edges in the cut can be reconstructed from this, since an edge is in the cut
                              if and only if its nodes belong to different connected components.
                              Size `[num_nodes]`.
    - `value`: The sum of edge weights over all edges in the cut.
    """

    connected_components: Tensor
    value: MetaEdgeWeight
