
import torch
import torch.nn.functional as F
from torch.autograd import Function
from gurobipy import GRB                     # noqa

from method.Models.abcOptModel import optModel
from method.utils_method import do_reduction, to_tensor

def gumbel_soft_stats(problem, cost_vec, params, ptoSolver, tau, n_samples):
    """
    Draw n Gumbel-perturbed cost vectors, solve each, return
        exp_w  = E[w]              1-D  (d,)
        second = E[w wᵀ]           2-D  (d,d)
    All tensors are flattened to row-shape to avoid (d,1) issues.
    """
    pass

    return exp_w, second


class _RVFEFunc(Function):
    @staticmethod
    def forward(ctx,
                coeff_hat, coeff_true, params,
                problem, ptoSolver,
                beta, tau, delta, eps_adv,
                sigma_pred, sigma_dec,
                n_g, modelSense):


        return losses

    @staticmethod
    def backward(ctx, g):

        return grad, None, None, None, None, None, None, None, None, None, None, None, None


class RVFE(optModel):
    def __init__(
        self,
        ptoSolver,
        beta0=1.0, tau0=1.0,
        gamma_up=1.05, gamma_down=0.90, alpha_tau=1.02,
        eps_adv=0.05, mu_margin=0.3, n_gumbel=8, **kwargs
    ):
        super().__init__(ptoSolver)

    def forward(self, problem, coeff_hat, coeff_true, params=None, **hyper):

        return do_reduction(loss_vec, hyper["reduction"])

    # ------------- adaptive annealing (call once / epoch) ----------
    def anneal(self):
        pass
