{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d65a6785-f209-4e2b-a8d7-1a76086f5edc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import jax\n",
    "import matplotlib as mpl\n",
    "import jax.numpy as jnp\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from approxml.mnist import load_model, get_loader, visualize_images_grid\n",
    "from approxml.simulators import gan_simulator\n",
    "from functools import partial\n",
    "import pickle\n",
    "\n",
    "LATENT_DIM = 50\n",
    "N_RUNS = 20\n",
    "N_ITER = 500\n",
    "N_PROP = 250\n",
    "N_SIM_DST = 250\n",
    "N_PARAM_DIM = LATENT_DIM\n",
    "N_DATA_DIM = 256\n",
    "PRIOR_SIGMA = 1e-1\n",
    "\n",
    "gen, gen_state = load_model(\"./saved_models\", \n",
    "                            \"generator_1.eqx\", \n",
    "                            \"generator_state_1.eqx\", \n",
    "                            jax.random.PRNGKey(42), \n",
    "                            LATENT_DIM, \n",
    "                            (16,16,1))\n",
    "\n",
    "gan_simulator = partial(gan_simulator, \n",
    "                        generator=gen, \n",
    "                        state=gen_state,\n",
    "                        latent_dim=LATENT_DIM,\n",
    "                        sigma=PRIOR_SIGMA)\n",
    "\n",
    "mnist_loader = get_loader((16,16,1),\n",
    "                          36)\n",
    "images_batch , _ = next(iter(mnist_loader))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "97da97a0-8830-4fad-8c1c-a4e59a283262",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running obs_idx:  1\n"
     ]
    }
   ],
   "source": [
    "obs_idx = 1\n",
    "print(\"Running obs_idx: \", obs_idx)\n",
    "obs = images_batch[obs_idx].reshape(1, 256)\n",
    "obs = jnp.array(obs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "eaade71c-8027-4017-b9b8-d91de7335a12",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 120x120 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(<Figure size 120x120 with 1 Axes>, array([[<Axes: >]], dtype=object))"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "visualize_images_grid(obs, 16,16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75f62859-c735-46e6-bdd7-253e0a43f58e",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_sim = 5\n",
    "obs_idx = 2\n",
    "\n",
    "with open(f'./results/3_mnist_sm_obs_idx_{obs_idx}.pkl', 'rb') as f:\n",
    "    res = pickle.load(f)\n",
    "sims_sm_list = []\n",
    "key = jax.random.PRNGKey(0)\n",
    "for i in range(n_sim):\n",
    "    key, subkey = jax.random.split(key)\n",
    "    sim = gan_simulator(subkey,\n",
    "                    res['res_list'][i]['theta_values'][-300:,:].mean(0),\n",
    "                            1)\n",
    "    sims_sm_list.append(sim)\n",
    "\n",
    "sims_sm_list = jnp.array(sims_sm_list).reshape(n_sim,256)\n",
    "\n",
    "with open(f'./results/3_mnist_aml_obs_idx_{obs_idx}.pkl', 'rb') as f:\n",
    "    res = pickle.load(f)\n",
    "\n",
    "sims_aml_list = []\n",
    "key = jax.random.PRNGKey(0)\n",
    "for i in range(n_sim):\n",
    "    key, subkey = jax.random.split(key)\n",
    "    sim = gan_simulator(subkey,\n",
    "                    res['res_list'][i],\n",
    "                            1)\n",
    "    sims_aml_list.append(sim)\n",
    "\n",
    "sims_aml_list = jnp.array(sims_aml_list).reshape(n_sim,256)\n",
    "\n",
    "with open(f'./results/3_mnist_det_obs_idx_{obs_idx}.pkl', 'rb') as f:\n",
    "    res = pickle.load(f)\n",
    "\n",
    "sims_det_list = []\n",
    "key = jax.random.PRNGKey(0)\n",
    "for i in range(n_sim):\n",
    "    key, subkey = jax.random.split(key)\n",
    "    sim = gan_simulator(subkey,\n",
    "                    res['res_list'][i],\n",
    "                            1)\n",
    "    sims_det_list.append(sim)\n",
    "\n",
    "sims_det_list = jnp.array(sims_det_list).reshape(n_sim,256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c61014a9-2c00-4d1b-bb61-46f1f30055f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def visualize_model_image_rows(\n",
    "    images_list,\n",
    "    model_names,\n",
    "    img_side = 16,\n",
    "    normalize_range = (-1.0, 1.0),\n",
    "    cmap = 'gray',\n",
    "    figsize_scale = 1.2,\n",
    "    target_width = None,\n",
    "    save_path = None,\n",
    "    title = None\n",
    "):\n",
    "    n_rows = 3\n",
    "    n_cols = max(arr.shape[0] for arr in images_list)\n",
    "\n",
    "    if target_width is not None:            \n",
    "        cell_inch          = target_width / n_cols\n",
    "        fig_width_inches   = target_width\n",
    "        fig_height_inches  = cell_inch * n_rows\n",
    "    else:    \n",
    "        fig_width_inches   = n_cols * figsize_scale\n",
    "        fig_height_inches  = n_rows * figsize_scale\n",
    "\n",
    "    fig, axes = plt.subplots(\n",
    "        n_rows, n_cols,\n",
    "        figsize=(fig_width_inches, fig_height_inches),\n",
    "        squeeze=False,\n",
    "        gridspec_kw=dict(wspace=0.05, hspace=0.05),\n",
    "        constrained_layout=True\n",
    "    )\n",
    "\n",
    "    vmin, vmax = normalize_range\n",
    "    def _prep(img_flat):\n",
    "        img = (img_flat - vmin) / (vmax - vmin)\n",
    "        return np.clip(img, 0.0, 1.0).reshape(img_side, img_side)\n",
    "\n",
    "    for r, (model_imgs, label) in enumerate(zip(images_list, model_names)):\n",
    "        num_imgs = model_imgs.shape[0]\n",
    "\n",
    "        for c in range(n_cols):\n",
    "            ax = axes[r, c]\n",
    "\n",
    "            if c < num_imgs:                  \n",
    "                ax.imshow(_prep(model_imgs[c]), cmap=cmap, vmin=0, vmax=1)\n",
    "            ax.axis('off')\n",
    "\n",
    "\n",
    "    if title:\n",
    "        fig.suptitle(title, fontsize=10, y=0.99)\n",
    "\n",
    "    if save_path:\n",
    "        fig.savefig(save_path, bbox_inches='tight')\n",
    "        print(f\"Figure saved to {save_path}\")\n",
    "\n",
    "    plt.show()\n",
    "    return fig, axes\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1649169f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Figure saved to ./mnist_half_image.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "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AKiEEg8AAACVUOIBAACgEko8AAAAVKI3rg2PRqM42+/3o1y3241nfuxjH4tyMzMz8cyXX345zl5//fVR7v3vf38889lnn42z3/jGN6Lc1q1b45m33nprlDty5Eg8s0Sn02llbttK1sLc3FyU6/Xypf2Zz3wmyt14443xzP3798fZ3bt3R7lrr702nvnII4/E2f/+7/+OcldffXU88/Of/3yUO378eDyzRK1rYTgcxtkTJ05EuTVr1sQzP/GJT0S5r3/96/HMHTt2xNm3vvWtUS5dM03TNHffffeyZ3ft2hXP/O53vxvljh49Gs/k1RYXF6NcyTfKBz/4wSiXvpOaJt/PpmmaD33oQ1HujW98YzzzwQcfjLN///d/H+WuvPLKeOYzzzwT5Q4fPhzPLFHre6HkG2lhYSHKtfGNdMMNN8QzS45pz549Ue6qq66KZ5asha997WtR7pprroln3nPPPVHuueeei2eWqHUtvJZ/4gEAAKASSjwAAABUQokHAACASijxAAAAUAklHgAAACqhxAMAAEAllHgAAACohBIPAAAAlVDiAQAAoBJKPAAAAFSiN64Nd7vdOPvcc89FuU996lPxzA9+8INR7vd///fjmS+99FKcHY1GUe473/lOPPPLX/5ynD158mSUe/e73x3P/MlPfhLlFhcX45mrwcRE/lvasWPHotyf/dmfxTM/8pGPRLl9+/bFM/v9fpy97777otwdd9wRz7ztttvi7O7du6Pc6dOn45mPPvpolLMWXq1kLRw5ciTK/cVf/EU888Ybb4xy73vf++KZ6XOxaZrm4YcfjnJf+tKX4pnf+9734uymTZui3K/+6q/GMw8dOhTlFhYW4pmrQck30osvvhjlPvnJT8Yzb7rppij3m7/5m/HM9FuuaZrmgQceiHJf/OIX45m33357nJ2ZmYlya9asiWc++eSTUW5ubi6euRqUrIX9+/dHuc9+9rPxzPe+971R7ld+5Vfimc8880ycffDBB6PczTffHM+85ZZb4uzatWujXMkz3FpYHv6JBwAAgEoo8QAAAFAJJR4AAAAqocQDAABAJZR4AAAAqIQSDwAAAJVQ4gEAAKASSjwAAABUQokHAACASvTGteHhcBhnR6NRlLvlllvimbfeemuUW7t2bTyz5JhOnz697DNLshs3boxyzz33XDzzwIEDcbYN6X2y0pRct36/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buvWrfHMH/zgB1Gu5F4sWTdptuS7pyR74YUXRrk//dM/jWfeddddUe6pp56KZ64GJc+wdN2ce+658cxHHnkkyqXfMk1Ttr7TuSXvmpLtv+51r4tyf/InfxLPfPDBB6Nc+k5erfwTDwAAAJVQ4gEAAKASSjwAAABUQokHAACASijxAAAAUAklHgAAACqhxAMAAEAllHgAAACohBIPAAAAlVDiAQAAoBK9cW14OBzG2YWFhSg3NTUVz/z4xz8e5f72b/82nvn6178+zm7evDnKveENb4hnTk9Px9njx49HubVr18Yzn3zyySjX7/fjmatByVqYn5+PcoPBIJ75yU9+Msr90i/9Ujzz/PPPj7MnTpyIcpdddlk8Mz1PTdM0c3NzUW779u3xzAcffDDKleznajAajeJs+hzpdrvxzE9/+tNR7pvf/GY88/LLL4+zvV72Sr7ooovimSXn9NChQ1GuZC2k74X0Pb9atLEWSp43N91007Juu2nKvpEuueSSKLdv3754ZsnxP/7441GuZC18+9vfjnLeC6/WxjdSyXvhL//yL6PcLbfcEs/cuXNnnE2PqeQbqeT5cvDgwSi3adOmeOajjz4a5ayFn80/8QAAAFAJJR4AAAAqocQDAABAJZR4AAAAqIQSDwAAAJVQ4gEAAKASSjwAAABUQokHAACASijxAAAAUAklHgAAACrRG9eGu91unB0MBlHuM5/5TDzzve99b5T7yEc+Es88cOBAnH3++eej3D//8z/HM+++++44u3v37ih39dVXxzMfeuihKDccDuOZJTqdTpQbjUatbH+pJiby39LSc1eyFv7gD/4gyr3pTW+KZ95xxx1x9uGHH45yn/vc5+KZBw8ejLO/+Iu/GOXe/OY3xzMfeeSRKGctvFrJeyHd989+9rPxzI9+9KNR7sYbb4xnPvDAA3H2Jz/5SZT72te+Fs989NFH4+wll1wS5a677rp45p133hnlrIVXK1kL6bn7+Mc/Hs98z3veE+V++Zd/OZ75zDPPxNn7778/yn3+85+PZ5a8Fy688MIol56npsmfBek3b6la10Kvl1eVkydPRrm/+qu/imf+zu/8TpR7+9vfHs8s+UZKv+1vvvnmeOZ9990XZ/fs2RPlfu3Xfi2e+eSTT0Y574WfzT/xAAAAUAklHgAAACqhxAMAAEAllHgAAACohBIPAAAAlVDi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",
      "text/plain": [
       "<Figure size 975x585 with 15 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "mpl.rcParams.update({\n",
    "    'figure.dpi'     : 300,\n",
    "    'pdf.fonttype'   : 42,\n",
    "    'ps.fonttype'    : 42,\n",
    "    'font.family'    : 'serif',\n",
    "    'font.size'      : 7,\n",
    "    'axes.labelsize' : 7,\n",
    "    'xtick.labelsize': 6,\n",
    "    'ytick.labelsize': 6,\n",
    "})\n",
    "\n",
    "fig, axes = visualize_model_image_rows(\n",
    "    [sims_sm_list, sims_aml_list, sims_det_list],\n",
    "    ['SM', 'KDE-SPSA', 'Inv.'],\n",
    "    target_width = 3.25,             \n",
    "    cmap         = 'gray',\n",
    "    save_path    = './mnist_half_image.pdf'\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6880f04c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Figure saved to ./mnist_full_image_5.0.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 2250x675 with 30 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_sim = 10\n",
    "sigma = 5.0\n",
    "\n",
    "with open(f'./results/3.2_mnist_sm_prior_sigma_{sigma}.pkl', 'rb') as f:\n",
    "    res = pickle.load(f)\n",
    "    \n",
    "sims_sm_list = []\n",
    "key = jax.random.PRNGKey(0)\n",
    "for i in range(n_sim):\n",
    "    key, subkey = jax.random.split(key)\n",
    "    sim = gan_simulator(subkey,\n",
    "                    res['res_list'][i]['theta_values'][-300:,:].mean(0),\n",
    "                            1)\n",
    "    sims_sm_list.append(sim)\n",
    "\n",
    "sims_sm_list = jnp.array(sims_sm_list).reshape(n_sim,256)\n",
    "\n",
    "with open(f'./results/3.2_mnist_aml_prior_sigma_{sigma}.pkl', 'rb') as f:\n",
    "    res = pickle.load(f)\n",
    "\n",
    "sims_aml_list = []\n",
    "key = jax.random.PRNGKey(0)\n",
    "for i in range(n_sim):\n",
    "    key, subkey = jax.random.split(key)\n",
    "    sim = gan_simulator(subkey,\n",
    "                    res['res_list'][i],\n",
    "                            1)\n",
    "    sims_aml_list.append(sim)\n",
    "\n",
    "sims_aml_list = jnp.array(sims_aml_list).reshape(n_sim,256)\n",
    "\n",
    "with open(f'./results/3.2_mnist_det_prior_sigma_{sigma}.pkl', 'rb') as f:\n",
    "    res = pickle.load(f)\n",
    "\n",
    "sims_det_list = []\n",
    "key = jax.random.PRNGKey(0)\n",
    "for i in range(n_sim):\n",
    "    key, subkey = jax.random.split(key)\n",
    "    sim = gan_simulator(subkey,\n",
    "                    res['res_list'][i],\n",
    "                            1)\n",
    "    sims_det_list.append(sim)\n",
    "\n",
    "sims_det_list = jnp.array(sims_det_list).reshape(n_sim,256)\n",
    "\n",
    "mpl.rcParams.update({\n",
    "    'figure.dpi'     : 300,\n",
    "    'pdf.fonttype'   : 42,\n",
    "    'ps.fonttype'    : 42,\n",
    "    'font.family'    : 'serif',\n",
    "    'font.size'      : 7,\n",
    "    'axes.labelsize' : 7,\n",
    "    'xtick.labelsize': 6,\n",
    "    'ytick.labelsize': 6,\n",
    "})\n",
    "\n",
    "fig, axes = visualize_model_image_rows(\n",
    "    [sims_sm_list, sims_aml_list, sims_det_list],\n",
    "    ['SM', 'KDE-SPSA', 'Inv.'],\n",
    "    target_width = 7.5,             \n",
    "    cmap         = 'gray',\n",
    "    save_path    =  f'./mnist_full_image_{sigma}.pdf'\n",
    ")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sm_approxml",
   "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.13.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
