from typing import Optional, Callable
import numpy as np

from shapely import Point

from molecule_movement.sampling.Sampler import PolarSampler, normal_dist_pdf, gaussian_mixture

class CircularSampler(PolarSampler):
    def __init__(self,
                 mean: float,
                 scale: float,
                 angle_distribution: Callable[[float], float],
                 radius: float,
                 x_offset: float,
                 y_offset: float,
                 seed: Optional[int] = None,
                 min_distance: float = -np.inf,
                 rejection: Callable[[Point], bool] | bool = True,
                 mean2: Optional[float] = None,
                 scale2: Optional[float] = None,
                 alpha: Optional[float] = None) -> None:
        if mean2 and scale2:
            radius_distribution = gaussian_mixture(mean1=mean, scale1=scale, mean2=mean2, scale2=scale2, alpha=alpha)
        else:
            radius_distribution = normal_dist_pdf(mean=mean, scale=scale)
        super().__init__(angle_distribution, radius_distribution, radius, x_offset, y_offset, seed=seed, min_distance=min_distance, rejection=rejection)


