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

class RandomMatching(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)
        if respect_obstacles:
            logger.warning(f"Called {self.cls} with respect_obstacles = {respect_obstacles}. This will be ignored.")

    def compute_matching(self, seed: Optional[int] = None) -> list[Matching]:
        logger.trace(f"Computing schedule using {self.cls}")
        permutation_generator = np.random.default_rng(seed=seed)
        permuted_goals     = permutation_generator.permutation(self.goals)
        permuted_molecules = permutation_generator.permutation(self.molecules)
        return [self.molecule_goal_paths[Pair(m, g)] for m, g in zip(permuted_molecules, permuted_goals)]

