# =============================================================================
# Visualization Utilities
# =============================================================================

from pathlib import Path

import matplotlib.pyplot as plt
from matplotlib.backends.backend_pdf import PdfPages

from problems import BiLevelBaseProblem
from utils import RFFModelList


# -----------------------------------------------------------------------------
# Model2DPlotter
# -----------------------------------------------------------------------------

class Model2DPlotter:

    def __init__(
        self,
        local_path: Path,
    ) -> None:

        self.local_path = local_path
        self.pdf = PdfPages(local_path / "model.pdf")


    def plot(
        self,
        problem: BiLevelBaseProblem,
        model_Y_upper: RFFModelList,
        model_Y_lower: RFFModelList,
    ) -> None:

        fig, ax = plt.subplots(2, 3, figsize=(15, 10))


