import torch
from torch import Tensor


# in python 3.12, we can do this:
# def _optimality_gap[T: (float, Tensor)](optimal_value: T, predicted_value: T) -> T:
# the benefit is that the type checker knows that the output is a Tensor if the inputs are Tensors
@torch.no_grad()
def optimality_gap(optimal_value: float | Tensor, predicted_value: float | Tensor) -> float | Tensor:
    """
    Calculates the optimality gap for minimisation problems, in percent.

    Parameters:
    - `optimal_value`: The value of the ground truth solution (minimum k-cut size, optimal TSP tour length, ...)
    - `predicted_value`: The value of the predicted solution
    """
    optimality_gap = predicted_value / optimal_value - 1
    return optimality_gap * 100
