{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d35813e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.image as mpimg\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "import os\n",
    "from pathlib import Path\n",
    "os.chdir(Path.cwd().parents[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dc5e551e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def vis_images(*paths, titles=[], scale=4):\n",
    "    \"\"\"\n",
    "    Display an arbitrary number of images in a square-ish grid layout.\n",
    "\n",
    "    Parameters:\n",
    "    *paths: variable number of file paths to images\n",
    "    \"\"\"\n",
    "    n = len(paths)\n",
    "    if n == 0:\n",
    "        print(\"No images to display.\")\n",
    "        return\n",
    "\n",
    "    # Determine grid size (close to square)\n",
    "    n_cols = math.ceil(math.sqrt(n))\n",
    "    n_rows = math.ceil(n / n_cols)\n",
    "\n",
    "    # Create subplots\n",
    "    fig, axes = plt.subplots(n_rows, n_cols, figsize=(n_cols * scale, n_rows * scale))\n",
    "\n",
    "    # Flatten axes array for easy iteration\n",
    "    if isinstance(axes, plt.Axes):\n",
    "        axes = [axes]\n",
    "    else:\n",
    "        axes = axes.flatten()\n",
    "\n",
    "    # Display each image\n",
    "    for ax, path, title in zip(axes, paths, titles):\n",
    "        img = mpimg.imread(path)\n",
    "        ax.imshow(img)\n",
    "        ax.set_title(title)\n",
    "        ax.axis('off')\n",
    "\n",
    "    # Hide any unused subplots\n",
    "    for ax in axes[len(paths):]:\n",
    "        ax.axis('off')\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c40ba706",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds = [\n",
    "    \"./ckpts/1752567036.6695304/run_iter=300.png\",\n",
    "    \"./ckpts/1752566951.7877476/run_iter=30.png\",\n",
    "    \"./ckpts/1752610090.6529822/run_iter=650.png\",\n",
    "    \"./ckpts/1752525499.4329767/run_iter=200.png\",\n",
    "    \"./ckpts/1752523819.479008/run_iter=200.png\",\n",
    "    \"./ckpts/1752523675.4143364/run_iter=250.png\",\n",
    "    \"./ckpts/1752521366.505088/run_iter=100.png\",\n",
    "]\n",
    "titles = [\n",
    "    \"Catint\",\n",
    "    \"BindBio\",\n",
    "    \"Bindint\",\n",
    "    \"HOMO\",\n",
    "    \"Catbio\",\n",
    "    \"Conserved\",\n",
    "    \"Repeat\"\n",
    "]\n",
    "vis_images(*ds, titles=titles, scale=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "70faf916",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "language_info": {
   "name": "python"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
