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
from .ShortestPathObstacles import shortest_path

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


class RRTMatching(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)
