import numpy as np
from typing import Optional

from loguru import logger

from molecule_movement.matching.AbstractMatching import AbstractMatching
from molecule_movement import Matching, Goal, Obstacle, Molecule, MoleculeExperiment, Pair

INF = np.iinfo(np.int64).max
#INF = -1


class GreedyMatching(AbstractMatching):
    def __init__(self, molecules: list[Molecule] | list[MoleculeExperiment],
                 goals: list[Goal],
                 obstacles: Optional[list[Obstacle]] = None,
                 respect_obstacles: bool = False):
        super().__init__(molecules, goals, obstacles, respect_obstacles)

    def compute_matching(self, seed: Optional[int] = None) -> list[Matching]:
        logger.trace(f"Computing schedule using {self.cls}")
        self.matching = list()
        self._compute_distance_matrix()
        while len(self.matching) < len(self.goals):
            row, col = self._flattened_index_to_col_row(np.argmin(self.distance_matrix))
            self.distance_matrix[:,col] = np.array([INF] * len(self.molecules))
            self.distance_matrix[row] = INF
            self.matching.append(self.molecule_goal_paths[Pair(self.molecules[row], self.goals[col])])
        return self.matching

