from mcmcs.base import BaseMCMC
from mcmcs.hamming_ball import HammingBallMCMC
from mcmcs.swendsen_wang import SwendsenWangMCMC
from mcmcs.bit_flipping import BitFlippingMCMC
from mcmcs.true_sampler import TrueSampler
from mcmcs.ising_mh import IsingMH
from mcmcs.potts_mh import PottsMH

from typing import TYPE_CHECKING

if TYPE_CHECKING:
    from omegaconf import DictConfig
    from targets.base import BaseTarget


def create_mcmc(cfg: "DictConfig", target: "BaseTarget") -> "BaseMCMC":
    mcmc_cfg = cfg.algorithm.mcmc
    if mcmc_cfg.name == "hamming_ball":
        return HammingBallMCMC(target.ndim, target, mcmc_cfg.L or min(10, target.ndim // 8))
    elif mcmc_cfg.name == "swendsen_wang":
        return SwendsenWangMCMC(target.ndim, target)
    elif mcmc_cfg.name == "bit_flipping":
        return BitFlippingMCMC(target.ndim, target, mcmc_cfg.p)
    elif mcmc_cfg.name == "true_sampler":
        return TrueSampler(target.ndim, target)
    elif mcmc_cfg.name == "ising_mh":
        return IsingMH(target.ndim, target)
    elif mcmc_cfg.name == "potts_mh":
        return PottsMH(target.ndim, target)
    else:
        raise ValueError(f"Unknown MCMC sampler: {mcmc_cfg.name}")
