#!/usr/bin/env python3
import argparse
from pathlib import Path
import numpy as np
import matplotlib.pyplot as plt
from math import gamma as math_gamma

# --- parameter sets: (shape α, scale θ) ---
PARAMS = [(1,1), (1,2), (1,3), (2,1), (2,2), (2,3)]

# Your color list (in this exact order)
REF_COLORS = ["#E69F00", "#56B4E9", "#009E73", "#F0E442", "#0072B2", "#d86a12"]

# Font sizes
TITLE_FONTSIZE = 18
LABEL_FONTSIZE = 16
TICK_FONTSIZE  = 13
LEGEND_FONTSIZE = 13

def gamma_pdf(x, alpha, theta):
    # f(x) = x^{α-1} e^{-x/θ} / (Γ(α) θ^α), for x>0
    return (x ** (alpha - 1)) * np.exp(-x / theta) / (math_gamma(alpha) * (theta ** alpha))

def style_axes(ax):
    # Remove upper and right spines
    ax.spines['top'].set_visible(False)
    ax.spines['right'].set_visible(False)
    # Horizontal dashed grid only
    ax.grid(axis='y', linestyle='--', linewidth=1, alpha=0.5)
    ax.grid(axis='x', visible=False)

def make_plot_for_alpha(alpha_val, params, color_map, out_path):
    x = np.linspace(1e-6, 20, 4000)
    fig, ax = plt.subplots(figsize=(8.5, 5.0))

    for p, color in color_map.items():
        alpha, theta = p
        if alpha == alpha_val:
            y = gamma_pdf(x, alpha, theta)
            ax.plot(x, y, linewidth=2, color=color,
                    label=fr"$\alpha={alpha},\ \theta={theta}$")

    ax.set_title(fr"Gamma density ($\alpha={alpha_val}$)", fontsize=TITLE_FONTSIZE)
    ax.set_xlabel("x", fontsize=LABEL_FONTSIZE)
    ax.set_ylabel("density", fontsize=LABEL_FONTSIZE)
    ax.set_xlim(0, 20)
    ax.set_ylim(0, 0.5)

    style_axes(ax)

    # Ticks & legend font sizes
    ax.tick_params(axis='both', which='major', labelsize=TICK_FONTSIZE)
    leg = ax.legend(title="Parameters", fontsize=LEGEND_FONTSIZE)
    if leg and leg.get_title():
        leg.get_title().set_fontsize(LEGEND_FONTSIZE)

    fig.tight_layout()
    fig.savefig(out_path, format="pdf", bbox_inches="tight")
    plt.close(fig)

def main():
    parser = argparse.ArgumentParser(description="Plot Gamma densities (custom colors, clean axes, horizontal dashed grid) and save as PDFs.")
    parser.add_argument(
        "--outdir",
        type=Path,
        default=Path("."),
        help="Folder where the PDF plots will be saved (default: current directory).",
    )
    args = parser.parse_args()
    outdir: Path = args.outdir
    outdir.mkdir(parents=True, exist_ok=True)

    # Fixed color map: each (alpha, theta) gets its specific color in the given order
    color_map = {p: REF_COLORS[i % len(REF_COLORS)] for i, p in enumerate(PARAMS)}

    make_plot_for_alpha(1, PARAMS, color_map, outdir / "gamma_alpha_1.pdf")
    make_plot_for_alpha(2, PARAMS, color_map, outdir / "gamma_alpha_2.pdf")

    print(f"Saved: {outdir / 'gamma_alpha_1.pdf'}")
    print(f"Saved: {outdir / 'gamma_alpha_2.pdf'}")

if __name__ == "__main__":
    main()
