{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Figure: Examples ShapEval"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1800x300 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PDF saved as /home/tim/Documents/XX_Perturbation_SHAP/perturbation_shap/figs/results/shapeval_example.pdf\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import random\n",
    "from PIL import Image\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Computer Modern Roman\"],  # Use preferred LaTeX font\n",
    "    \"font.size\": 14  # Adjust font size as needed\n",
    "})\n",
    "\n",
    "\n",
    "\n",
    "# Specify the directory containing the images\n",
    "image_dir = \"/home/tim/Documents/XX_Perturbation_SHAP/perturbation_shap/data/grayscale_shap/train\"  # Replace with your path\n",
    "output_pdf = \"/home/tim/Documents/XX_Perturbation_SHAP/perturbation_shap/figs/results/shapeval_example.pdf\"  # Name of the output PDF\n",
    "\n",
    "# Get a list of image files in the directory\n",
    "image_files = [f for f in os.listdir(image_dir) if f.lower().endswith((\".png\", \".jpg\", \".jpeg\", \".bmp\", \".gif\"))]\n",
    "\n",
    "# Select 9 random images (or fewer if there aren't enough images)\n",
    "random_images = random.sample(image_files, min(len(image_files), 9))\n",
    "\n",
    "# Create a PDF to save the plot\n",
    "with PdfPages(output_pdf) as pdf:\n",
    "    # Create a 3x3 grid plot\n",
    "    fig, axes = plt.subplots(3, 3, figsize=(18, 3))\n",
    "    axes = axes.flatten()\n",
    "\n",
    "    for i, ax in enumerate(axes):\n",
    "        if i < len(random_images):\n",
    "            # Load and display the image\n",
    "            image_path = os.path.join(image_dir, random_images[i])\n",
    "            img = Image.open(image_path).convert('RGB')\n",
    "            ax.imshow(img)\n",
    "            ax.set_title(random_images[i])\n",
    "        \n",
    "        # Remove axes for any empty subplot\n",
    "        ax.axis(\"off\")\n",
    "\n",
    "    # Tight layout for better spacing\n",
    "    plt.tight_layout()\n",
    "\n",
    "    # Save the figure to the PDF\n",
    "    pdf.savefig(fig)\n",
    "    plt.show()\n",
    "    plt.close(fig)\n",
    "\n",
    "print(f\"PDF saved as {output_pdf}\")\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PDF saved as /home/tim/Documents/XX_Perturbation_SHAP/perturbation_shap/figs/results/shapeval_example.pdf\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import random\n",
    "from PIL import Image\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Computer Modern Roman\"],  # Use preferred LaTeX font\n",
    "    \"font.size\": 14  # Adjust font size as needed\n",
    "})\n",
    "\n",
    "\n",
    "\n",
    "# Specify the directory containing the images\n",
    "image_dir = \"/home/tim/Documents/XX_Perturbation_SHAP/perturbation_shap/data/T_grayscale/train\"  # Replace with your path\n",
    "output_pdf = \"/home/tim/Documents/XX_Perturbation_SHAP/perturbation_shap/figs/results/shapeval_example.pdf\"  # Name of the output PDF\n",
    "\n",
    "# Get a list of image files in the directory\n",
    "image_files = [f for f in os.listdir(image_dir) if f.lower().endswith((\".png\", \".jpg\", \".jpeg\", \".bmp\", \".gif\"))]\n",
    "\n",
    "# Select 9 random images (or fewer if there aren't enough images)\n",
    "random_images = random.sample(image_files, min(len(image_files), 3))\n",
    "\n",
    "# Create a PDF to save the plot\n",
    "with PdfPages(output_pdf) as pdf:\n",
    "    # Create a 3x3 grid plot\n",
    "    fig, axes = plt.subplots(3, 1, figsize=(12, 4))\n",
    "    axes = axes.flatten()\n",
    "\n",
    "    for i, ax in enumerate(axes):\n",
    "        if i < len(random_images):\n",
    "            # Load and display the image\n",
    "            image_path = os.path.join(image_dir, random_images[i])\n",
    "            img = Image.open(image_path).convert('RGB')\n",
    "            ax.imshow(img)\n",
    "            ax.set_title(random_images[i])\n",
    "        \n",
    "        # Remove axes for any empty subplot\n",
    "        ax.axis(\"off\")\n",
    "\n",
    "    # Tight layout for better spacing\n",
    "    plt.tight_layout()\n",
    "\n",
    "    # Save the figure to the PDF\n",
    "    pdf.savefig(fig)\n",
    "    plt.show()\n",
    "    plt.close(fig)\n",
    "\n",
    "print(f\"PDF saved as {output_pdf}\")\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "perturbation_shap",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
