import numpy as np

from Algorithms.GenLBINFV import play_GenLBINFV
from Algorithms.utils import convert_action_list, convert_loss_list, convert_matrix


class play_LBINFV:
    def __init__(
        self,
        supplier,
        demander,
        action_list,
        cost_matrix,
        regime,
        m_estimation,
        loss_list,
        time_horizon=2000000,
        change_dist_ratio=1.0,
    ):
        assert np.sum(supplier) == np.sum(demander)

        self.action_list = convert_action_list(
            action_list=action_list,
            supplier=supplier,
            demander=demander,
        )
        self.cost_matrix = convert_matrix(
            cost_matrix=cost_matrix,
            supplier=supplier,
            demander=demander,
        )
        self.regime = regime
        self.m_estimation = m_estimation
        self.n_i = np.ones_like(self.cost_matrix)
        self.loss_list = convert_loss_list(
            loss_list,
            supplier,
            demander,
        )
        self.time_horizon = time_horizon
        self.change_dist_ratio = change_dist_ratio

    def run(
        self,
    ):
        result = play_GenLBINFV(
            action_list=self.action_list,
            cost_matrix=self.cost_matrix,
            regime=self.regime,
            m_estimation=self.m_estimation,
            n_i=self.n_i,
            loss_list=self.loss_list,
            time_horizon=self.time_horizon,
            change_dist_ratio=self.change_dist_ratio,
        ).run()
        return result
