{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "from mpl_toolkits.axes_grid1.inset_locator import mark_inset, zoomed_inset_axes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "tasks = [\"twomoons\", \"gmm\", \"invkinematics\"]\n",
    "budget = 1024\n",
    "estimators = [\"ac\", \"nsf\", \"cmpe\", \"fmpe\"]\n",
    "\n",
    "sampling_steps = [2, 5, 7, 8, 10, 20, 30, 40, 50, 100]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "colors = [\"#4477AA\", \"#EE6677\", \"#228833\", \"#CCBB44\", \"#66CCEE\", \"#AA3377\", \"#BBBBBB\"]\n",
    "\n",
    "plot_settings = {\n",
    "    \"ac\": {\"name\": \"ACF\", \"color\": colors[0]},\n",
    "    \"nsf\": {\"name\": \"NSF\", \"color\": colors[1]},\n",
    "    \"fmpe\": {\"name\": \"FMPE\", \"color\": colors[5]},\n",
    "    \"fmpe10\": {\"name\": \"FMPE 10#\", \"color\": colors[2]},\n",
    "    \"fmpe30\": {\"name\": \"FMPE 30#\", \"color\": colors[4]},\n",
    "    \"cmpe\": {\"name\": \"CMPE (Ours)\", \"color\": colors[3]},\n",
    "    \"cmpe10\": {\"name\": \"CMPE 10#\", \"color\": colors[3]},\n",
    "    \"cmpe30\": {\"name\": \"CMPE 30#\", \"color\": colors[6]},\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_dict = pickle.load(open(\"./computations/eval_dict_speed_performance_ik.pkl\", \"rb\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/8n/pc0r4zbs3pn15xp3s0d7hk6h0000gn/T/ipykernel_17457/3658602096.py:123: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n",
      "  f.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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z0doaChcXV3xxhtvYMuWLcWO0TGkV69eAMCNQ9OnX79+8PX11dkeHBzM/X/69Ok6+z08PLh0RcehadjY2GDy5Mk6262srPDxxx8DALZv316uczNkypQpkEgkOttDQ0P11vXAgQPIzs6GlZUVJk6cqJNOJBJhypQp5aqLvb09AODx48dlTluettu0aRMAYPTo0XBwcNCb7+DBgwEAiYmJUKlUOmk1eeszaNAgAMDBgwe5bRcvXsTt27cB6L9OeDwePv/8c4N5VpSmjRUKhd5xc/ps374dWVlZCA4ORvPmzfUe065dO3h5eSEtLQ0XLlzgtv/4448AgC5duqBr166lKi86OhpqtRpubm4YNWqUzn4bGxtMmzYNALBjxw6t16Uwfe0LAH369AGge21v27YNANC2bVsEBQXppPP19cWAAQP05lmRa5cQUoACPqJFLBZj0aJFuH//PlavXo13330X9evX51YUOHfuHIYMGYIBAwboHXiem5uLJUuWIDAwEK6urhCJRNwDBi1atAAAPHr0yGD5zZo107vd1dUVQEGAoS8gBMBNspqWlqZ3f+vWrSGVSvXuCwgIAACkp6fj7t27ButXVm3atNG7vU6dOgB06/rnn38CAPz8/GBra6s3bYcOHcpVl+7duwMAli9fjqFDh2L//v14+fJlqdKWp+1OnjwJAJg3bx7c3Nz0/mjaJycnhwuQ7t+/zw3g7969u8G0kyZN4o7X+OOPPwAUXAsNGzbUW19/f38IhZUzQUH9+vVRv359yOVytGvXDkuWLMGNGzeK/RKhaaeEhASD5+rm5sadZ+HzPX36NID/XtvS0LRRhw4dDE4e3alTJwBAdnY2bt68qbPfyckJ3t7eetMaurY15WquF30M7evWrRsAYOfOnejduzd27NhR6oCaEFKAAj6il6urK8aOHYuff/4ZSUlJePz4MdatW4e6desCALZu3YrvvvtOK83jx4/h5+eHKVOm4MiRI/j7778hkUhQo0YN1KxZEy4uLgAK/ogYYmgSY80fppo1axpczkpzjEKh0Ltf84eopH1///23wePKys7OTu92zVPOSqVSa/s///wDwHA7AEDt2rXLVZdhw4ZhzJgxYIxh8+bN6N69O2QyGVq0aIGZM2cW23tSnrbT5Jeeno6nT58a/NHIycnRSgcAz549M5hOE1Bo0hUuv7g2kkgk3LVo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",
      "text/plain": [
       "<Figure size 600x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "point_kws = {\n",
    "    \"nsf\": dict(marker=\"^\", markersize=5, capsize=4, markeredgewidth=0.5, markeredgecolor=\"black\"),\n",
    "    \"ac\": dict(marker=\"D\", markersize=4, capsize=3, markeredgewidth=0.5, markeredgecolor=\"black\"),\n",
    "    \"fmpe\": dict(marker=\"V\", markersize=5, markeredgecolor=\"black\", markeredgewidth=0.5, capsize=4),\n",
    "}\n",
    "\n",
    "\n",
    "line_kws = dict(marker=\"o\", linestyle=\"-\", markeredgecolor=\"black\", markeredgewidth=0.5, markersize=5)\n",
    "\n",
    "n_test_samples = eval_dict[\"gmm\"][\"ac\"][\"posterior_samples\"].shape[0] * 4  # (hack to get speed per 1000 samples)\n",
    "\n",
    "\n",
    "# less space between subplots\n",
    "f, (ax1, ax2) = plt.subplots(1, 2, figsize=(6, 3), sharey=True, width_ratios=(0.90, 0.10), gridspec_kw={\"wspace\": 0.15})\n",
    "task = \"gmm\"\n",
    "for ax in (ax1, ax2):\n",
    "    # AC and NSF -> single point with error bars\n",
    "    for estimator in [\"ac\", \"nsf\"]:\n",
    "        c2st_mean = np.mean(eval_dict[task][estimator][\"c2st\"])\n",
    "        c2st_std = np.std(eval_dict[task][estimator][\"c2st\"]) / np.sqrt(1)\n",
    "        ax.errorbar(\n",
    "            eval_dict[task][estimator][\"time\"] / n_test_samples,\n",
    "            c2st_mean,\n",
    "            yerr=c2st_std,\n",
    "            label=plot_settings[estimator][\"name\"],\n",
    "            color=plot_settings[estimator][\"color\"],\n",
    "            **point_kws[estimator],\n",
    "        )\n",
    "\n",
    "    # CMPE: line with error bars\n",
    "    cmpe_times = [eval_dict[task][f\"cmpe{step}\"][\"time\"] / n_test_samples for step in sampling_steps]\n",
    "    cmpe_c2st = [np.mean(eval_dict[task][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "    cmpe_std = [np.std(eval_dict[task][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "    ax.plot(cmpe_times, cmpe_c2st, label=\"CMPE (Ours)\", color=plot_settings[\"cmpe\"][\"color\"], **line_kws)\n",
    "    ax.fill_between(\n",
    "        cmpe_times,\n",
    "        np.array(cmpe_c2st) - np.array(cmpe_std) / np.sqrt(1),\n",
    "        np.array(cmpe_c2st) + np.array(cmpe_std) / np.sqrt(1),\n",
    "        alpha=0.3,\n",
    "        color=plot_settings[\"cmpe\"][\"color\"],\n",
    "    )\n",
    "\n",
    "    # FMPE: Line and point with error bars\n",
    "    c2st_mean = np.mean(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    c2st_std = np.std(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    # ax.scatter(eval_dict[task]['fmpe']['time']/n_test_samples, c2st_mean, label='FMPE', color=plot_settings['fmpe']['color'], **point_kws['fmpe'])\n",
    "\n",
    "    fmpe_times = [eval_dict[task][f\"fmpe{step}\"][\"time\"] / n_test_samples for step in sampling_steps] + [\n",
    "        eval_dict[task][\"fmpe\"][\"time\"] / n_test_samples\n",
    "    ]\n",
    "    fmpe_c2st = [np.mean(eval_dict[task][f\"fmpe{step}\"][\"c2st\"]) for step in sampling_steps] + [\n",
    "        np.mean(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    ]\n",
    "    fmpe_std = [np.std(eval_dict[task][f\"fmpe{step}\"][\"c2st\"]) for step in sampling_steps] + [\n",
    "        np.std(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    ]\n",
    "    ax.plot(fmpe_times, fmpe_c2st, label=\"FMPE\", color=plot_settings[\"fmpe\"][\"color\"], **line_kws)\n",
    "    ax.fill_between(\n",
    "        fmpe_times,\n",
    "        np.array(fmpe_c2st) - np.array(fmpe_std) / np.sqrt(1),\n",
    "        np.array(fmpe_c2st) + np.array(fmpe_std) / np.sqrt(1),\n",
    "        alpha=0.3,\n",
    "        color=plot_settings[\"fmpe\"][\"color\"],\n",
    "    )\n",
    "\n",
    "    ax.set_ylim(None, None)\n",
    "    # ax.set_title(task)\n",
    "    # log x axis\n",
    "    # ax.set_xscale('log')\n",
    "    # x labels as decimals\n",
    "    # ax.xaxis.set_major_formatter(plt.FuncFormatter(lambda x, _: '{:.16g}'.format(x)))\n",
    "    # larger tick labels\n",
    "    ax.tick_params(axis=\"both\", which=\"major\", labelsize=\"x-large\")\n",
    "    # minor grid every 0.01 units in y and x\n",
    "    ax.xaxis.set_major_locator(plt.MultipleLocator(0.05))\n",
    "    ax.xaxis.set_minor_locator(plt.MultipleLocator(0.01))\n",
    "    ax.yaxis.set_minor_locator(plt.MultipleLocator(0.05))\n",
    "    # 0.01 grid\n",
    "    ax.grid(which=\"minor\", alpha=0.2, zorder=-1)\n",
    "    # 0.1 grid\n",
    "    ax.grid(which=\"major\", alpha=0.5, zorder=-1)\n",
    "    ax.set_xlim(0, 1.0)\n",
    "    ax.grid(zorder=-1, alpha=0.5)\n",
    "    sns.despine(ax=ax)\n",
    "\n",
    "\n",
    "# add a zoom-in to the plot\n",
    "# between top center and top right\n",
    "axins = zoomed_inset_axes(ax1, 2.5, loc=\"upper center\", bbox_to_anchor=(0.5, 1.0), bbox_transform=ax1.transAxes)\n",
    "# show zoom-in\n",
    "axins.errorbar(\n",
    "    eval_dict[task][\"ac\"][\"time\"] / n_test_samples,\n",
    "    np.mean(eval_dict[task][\"ac\"][\"c2st\"]),\n",
    "    yerr=np.std(eval_dict[task][\"ac\"][\"c2st\"]) / np.sqrt(1),\n",
    "    label=\"ACF\",\n",
    "    color=plot_settings[\"ac\"][\"color\"],\n",
    "    markersize=9,\n",
    "    marker=\"D\",\n",
    "    capsize=6,\n",
    "    markeredgecolor=\"black\",\n",
    ")\n",
    "axins.errorbar(\n",
    "    eval_dict[task][\"nsf\"][\"time\"] / n_test_samples,\n",
    "    np.mean(eval_dict[task][\"nsf\"][\"c2st\"]),\n",
    "    yerr=np.std(eval_dict[task][\"nsf\"][\"c2st\"]) / np.sqrt(1),\n",
    "    label=\"NSF\",\n",
    "    color=plot_settings[\"nsf\"][\"color\"],\n",
    "    markersize=12,\n",
    "    marker=\"^\",\n",
    "    capsize=6,\n",
    "    markeredgecolor=\"black\",\n",
    ")\n",
    "axins.plot(\n",
    "    cmpe_times,\n",
    "    cmpe_c2st,\n",
    "    label=\"CMPE (Ours)\",\n",
    "    color=plot_settings[\"cmpe\"][\"color\"],\n",
    "    marker=\"o\",\n",
    "    linestyle=\"-\",\n",
    "    markersize=8,\n",
    "    markeredgecolor=\"black\",\n",
    ")\n",
    "axins.plot(\n",
    "    fmpe_times, fmpe_c2st, label=\"FMPE\", color=plot_settings[\"fmpe\"][\"color\"], marker=\"o\", linestyle=\"-\", markersize=8\n",
    ")\n",
    "axins.fill_between(\n",
    "    cmpe_times,\n",
    "    np.array(cmpe_c2st) - np.array(cmpe_std) / np.sqrt(1),\n",
    "    np.array(cmpe_c2st) + np.array(cmpe_std) / np.sqrt(1),\n",
    "    alpha=0.3,\n",
    "    color=plot_settings[\"cmpe\"][\"color\"],\n",
    ")\n",
    "\n",
    "# add grid to inset axis\n",
    "axins.grid(zorder=-1, alpha=0.5)\n",
    "\n",
    "# sub region of the original image\n",
    "x1, x2, y1, y2 = 0.00, 0.01, 0.68, 0.73\n",
    "axins.set_xlim(x1, x2)\n",
    "axins.set_ylim(y1, y2)\n",
    "axins.set_xticks([0.005])\n",
    "axins.set_yticks([0.65, 0.70])\n",
    "# 0.01 grid\n",
    "axins.grid(which=\"minor\", alpha=0.2, zorder=-1)\n",
    "axins.set_xticklabels([])\n",
    "axins.set_yticklabels([])\n",
    "axins.tick_params(axis=\"both\", which=\"both\", length=0)\n",
    "axins.grid(zorder=-1, alpha=0.5)\n",
    "mark_inset(ax1, axins, loc1=4, loc2=2, fc=\"none\", ec=\"0.5\")\n",
    "\n",
    "ax1.set_xlim(0, 0.21)\n",
    "ax2.set_xlim(1.1, 1.2)\n",
    "ax1.set_xlabel(\"Sampling speed [seconds]\", fontsize=\"xx-large\")\n",
    "ax1.set_ylabel(\"C2ST\", fontsize=\"xx-large\")\n",
    "\n",
    "ax1.spines[\"right\"].set_visible(False)\n",
    "ax2.spines[\"left\"].set_visible(False)\n",
    "# ax2.spines['top'].set_visible(False)\n",
    "# ax.yaxis.tick_left()\n",
    "# ax.tick_params(labeltop='off') # don't put tick labels at the top\n",
    "# ax2.yaxis.tick_right()\n",
    "ax2.set_xticks([1.15])\n",
    "ax2.tick_params(axis=\"y\", which=\"both\", length=0)\n",
    "\n",
    "d = 0.5  # proportion of vertical to horizontal extent of the slanted line\n",
    "kwargs = dict(marker=[(-d, 1), (d, -1)], markersize=12, linestyle=\"none\", color=\"k\", mec=\"k\", mew=1, clip_on=False)\n",
    "ax1.plot([1, 1.01, 1.02], [0, 0, 0], transform=ax1.transAxes, **kwargs)\n",
    "ax2.plot([-0.15, -0.08, 0], [0, 0, 0], transform=ax2.transAxes, **kwargs)\n",
    "\n",
    "\n",
    "lines, labels = ax1.get_legend_handles_labels()\n",
    "lines = [lines[0], lines[1], lines[3], lines[2]]\n",
    "labels = [labels[0], labels[1], labels[3], labels[2]]\n",
    "# legend below plot with 1 row\n",
    "f.legend(\n",
    "    lines,\n",
    "    labels,\n",
    "    loc=\"lower center\",\n",
    "    ncol=4,\n",
    "    bbox_to_anchor=(0.5, -0.25),\n",
    "    fontsize=\"x-large\",\n",
    "    frameon=False,\n",
    "    markerscale=2.5,\n",
    ")\n",
    "f.tight_layout()\n",
    "f.savefig(\"./figures/speed_performance_c2st_gmm.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/8n/pc0r4zbs3pn15xp3s0d7hk6h0000gn/T/ipykernel_17457/977356485.py:120: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n",
      "  f.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "point_kws = {\n",
    "    \"nsf\": dict(marker=\"^\", s=55),\n",
    "    \"ac\": dict(marker=\"D\", s=40),\n",
    "    \"fmpe\": dict(marker=\"V\", s=55),\n",
    "}\n",
    "\n",
    "\n",
    "line_kws = dict(marker=\"o\", linestyle=\"-\", markersize=4)\n",
    "\n",
    "n_test_samples = eval_dict[\"twomoons\"][\"ac\"][\"posterior_samples\"].shape[0] * 4\n",
    "\n",
    "\n",
    "# less space between subplots\n",
    "f, (ax1, ax2) = plt.subplots(1, 2, figsize=(6, 3), sharey=True, width_ratios=(0.90, 0.10), gridspec_kw={\"wspace\": 0.05})\n",
    "task = \"twomoons\"\n",
    "for ax in (ax1, ax2):\n",
    "    # AC and NSF -> single point with error bars\n",
    "    for estimator in [\"ac\", \"nsf\"]:\n",
    "        c2st_mean = np.mean(eval_dict[task][estimator][\"c2st\"])\n",
    "        c2st_std = np.std(eval_dict[task][estimator][\"c2st\"]) / np.sqrt(1)\n",
    "        ax.scatter(\n",
    "            eval_dict[task][estimator][\"time\"] / n_test_samples,\n",
    "            c2st_mean,\n",
    "            label=plot_settings[estimator][\"name\"],\n",
    "            color=plot_settings[estimator][\"color\"],\n",
    "            **point_kws[estimator],\n",
    "        )\n",
    "\n",
    "    # CMPE: line with error bars\n",
    "    cmpe_times = [eval_dict[task][f\"cmpe{step}\"][\"time\"] / n_test_samples for step in sampling_steps]\n",
    "    cmpe_c2st = [np.mean(eval_dict[task][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "    cmpe_std = [np.std(eval_dict[task][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "    ax.plot(cmpe_times, cmpe_c2st, label=\"CMPE (Ours)\", color=plot_settings[\"cmpe\"][\"color\"], **line_kws)\n",
    "    ax.fill_between(\n",
    "        cmpe_times,\n",
    "        np.array(cmpe_c2st) - np.array(cmpe_std) / np.sqrt(1),\n",
    "        np.array(cmpe_c2st) + np.array(cmpe_std) / np.sqrt(1),\n",
    "        alpha=0.3,\n",
    "        color=plot_settings[\"cmpe\"][\"color\"],\n",
    "    )\n",
    "\n",
    "    # FMPE: Line and point with error bars\n",
    "    c2st_mean = np.mean(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    c2st_std = np.std(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    # ax.scatter(eval_dict[task]['fmpe']['time']/n_test_samples, c2st_mean, label='FMPE', color=plot_settings['fmpe']['color'], **point_kws['fmpe'])\n",
    "\n",
    "    fmpe_times = [eval_dict[task][f\"fmpe{step}\"][\"time\"] / n_test_samples for step in sampling_steps] + [\n",
    "        eval_dict[task][\"fmpe\"][\"time\"] / n_test_samples\n",
    "    ]\n",
    "    fmpe_c2st = [np.mean(eval_dict[task][f\"fmpe{step}\"][\"c2st\"]) for step in sampling_steps] + [\n",
    "        np.mean(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    ]\n",
    "    fmpe_std = [np.std(eval_dict[task][f\"fmpe{step}\"][\"c2st\"]) for step in sampling_steps] + [\n",
    "        np.std(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    ]\n",
    "    ax.plot(fmpe_times, fmpe_c2st, label=\"FMPE\", color=plot_settings[\"fmpe\"][\"color\"], **line_kws)\n",
    "    ax.fill_between(\n",
    "        fmpe_times,\n",
    "        np.array(fmpe_c2st) - np.array(fmpe_std) / np.sqrt(1),\n",
    "        np.array(fmpe_c2st) + np.array(fmpe_std) / np.sqrt(1),\n",
    "        alpha=0.3,\n",
    "        color=plot_settings[\"fmpe\"][\"color\"],\n",
    "    )\n",
    "\n",
    "    ax.set_ylim(0.50, 1.0)\n",
    "    # ax.set_title(task)\n",
    "    # log x axis\n",
    "    # ax.set_xscale('log')\n",
    "    # x labels as decimals\n",
    "    # ax.xaxis.set_major_formatter(plt.FuncFormatter(lambda x, _: '{:.16g}'.format(x)))\n",
    "    # larger tick labels\n",
    "    ax.tick_params(axis=\"both\", which=\"major\", labelsize=\"x-large\")\n",
    "    # minor grid every 0.01 units in y and x\n",
    "    ax.xaxis.set_major_locator(plt.MultipleLocator(0.05))\n",
    "    ax.xaxis.set_minor_locator(plt.MultipleLocator(0.01))\n",
    "    ax.yaxis.set_minor_locator(plt.MultipleLocator(0.05))\n",
    "    # 0.01 grid\n",
    "    ax.grid(which=\"minor\", alpha=0.2, zorder=-1)\n",
    "    # 0.1 grid\n",
    "    ax.grid(which=\"major\", alpha=0.5, zorder=-1)\n",
    "    ax.set_xlim(0, 1.0)\n",
    "    ax.grid(zorder=-1, alpha=0.5)\n",
    "    sns.despine(ax=ax)\n",
    "\n",
    "\n",
    "# add a zoom-in to the plot\n",
    "# between top center and top right\n",
    "axins = zoomed_inset_axes(ax1, 2.5, loc=\"upper right\", bbox_to_anchor=(0.8, 1.0), bbox_transform=ax1.transAxes)\n",
    "# show zoom-in\n",
    "axins.scatter(\n",
    "    eval_dict[task][\"ac\"][\"time\"] / n_test_samples,\n",
    "    np.mean(eval_dict[task][\"ac\"][\"c2st\"]),\n",
    "    label=\"ACF\",\n",
    "    color=plot_settings[\"ac\"][\"color\"],\n",
    "    s=180,\n",
    "    marker=\"D\",\n",
    ")\n",
    "axins.scatter(\n",
    "    eval_dict[task][\"nsf\"][\"time\"] / n_test_samples,\n",
    "    np.mean(eval_dict[task][\"nsf\"][\"c2st\"]),\n",
    "    label=\"NSF\",\n",
    "    color=plot_settings[\"nsf\"][\"color\"],\n",
    "    s=180,\n",
    "    marker=\"^\",\n",
    ")\n",
    "axins.plot(\n",
    "    cmpe_times,\n",
    "    cmpe_c2st,\n",
    "    label=\"CMPE (Ours)\",\n",
    "    color=plot_settings[\"cmpe\"][\"color\"],\n",
    "    marker=\"o\",\n",
    "    linestyle=\"-\",\n",
    "    markersize=8,\n",
    ")\n",
    "axins.plot(\n",
    "    fmpe_times, fmpe_c2st, label=\"FMPE\", color=plot_settings[\"fmpe\"][\"color\"], marker=\"o\", linestyle=\"-\", markersize=8\n",
    ")\n",
    "axins.fill_between(\n",
    "    cmpe_times,\n",
    "    np.array(cmpe_c2st) - np.array(cmpe_std) / np.sqrt(1),\n",
    "    np.array(cmpe_c2st) + np.array(cmpe_std) / np.sqrt(1),\n",
    "    alpha=0.3,\n",
    "    color=plot_settings[\"cmpe\"][\"color\"],\n",
    ")\n",
    "\n",
    "# add grid to inset axis\n",
    "axins.grid(zorder=-1, alpha=0.5)\n",
    "\n",
    "# sub region of the original image\n",
    "x1, x2, y1, y2 = 0.00, 0.04, 0.58, 0.7\n",
    "axins.set_xlim(x1, x2)\n",
    "axins.set_ylim(y1, y2)\n",
    "axins.set_xticks([0.01, 0.02, 0.03])\n",
    "axins.set_yticks([0.60, 0.65])\n",
    "# 0.01 grid\n",
    "axins.grid(which=\"minor\", alpha=0.2, zorder=-1)\n",
    "axins.set_xticklabels([])\n",
    "axins.set_yticklabels([])\n",
    "axins.tick_params(axis=\"both\", which=\"both\", length=0)\n",
    "axins.grid(zorder=-1, alpha=0.5)\n",
    "mark_inset(ax1, axins, loc1=4, loc2=2, fc=\"none\", ec=\"0.5\")\n",
    "\n",
    "ax1.set_xlim(0, 0.9 / 4)\n",
    "ax2.set_xlim(1.1, 1.2)\n",
    "ax1.set_xlabel(\"Sampling speed [seconds]\", fontsize=\"xx-large\")\n",
    "ax1.set_ylabel(\"C2ST\", fontsize=\"xx-large\")\n",
    "\n",
    "ax1.spines[\"right\"].set_visible(False)\n",
    "ax2.spines[\"left\"].set_visible(False)\n",
    "# ax2.spines['top'].set_visible(False)\n",
    "# ax.yaxis.tick_left()\n",
    "# ax.tick_params(labeltop='off') # don't put tick labels at the top\n",
    "# ax2.yaxis.tick_right()\n",
    "ax2.set_xticks([1.15])\n",
    "ax2.tick_params(axis=\"y\", which=\"both\", length=0)\n",
    "\n",
    "d = 0.5  # proportion of vertical to horizontal extent of the slanted line\n",
    "kwargs = dict(marker=[(-d, 1), (d, -1)], markersize=12, linestyle=\"none\", color=\"k\", mec=\"k\", mew=1, clip_on=False)\n",
    "ax1.plot(1, 0, transform=ax1.transAxes, **kwargs)\n",
    "ax2.plot(0, 0, transform=ax2.transAxes, **kwargs)\n",
    "\n",
    "lines, labels = ax1.get_legend_handles_labels()\n",
    "lines = [lines[0], lines[1], lines[3], lines[2]]\n",
    "labels = [labels[0], labels[1], labels[3], labels[2]]\n",
    "# legend below plot with 1 row\n",
    "f.legend(\n",
    "    lines,\n",
    "    labels,\n",
    "    loc=\"lower center\",\n",
    "    ncol=4,\n",
    "    bbox_to_anchor=(0.5, -0.25),\n",
    "    fontsize=\"x-large\",\n",
    "    frameon=False,\n",
    "    markerscale=2.5,\n",
    ")\n",
    "f.tight_layout()\n",
    "f.savefig(\"./figures/speed_performance_c2st_twomoons.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# TODO: Repeat this with correct reference samples\n",
    "\n",
    "point_kws = {\n",
    "    \"nsf\": dict(marker=\"^\", s=55),\n",
    "    \"ac\": dict(marker=\"D\", s=40),\n",
    "    \"fmpe\": dict(marker=\"V\", s=55),\n",
    "}\n",
    "\n",
    "\n",
    "line_kws = dict(marker=\"o\", linestyle=\"-\", markersize=4)\n",
    "\n",
    "n_test_samples = eval_dict[\"twomoons\"][\"ac\"][\"posterior_samples\"].shape[0] * 4\n",
    "\n",
    "\n",
    "# less space between subplots\n",
    "f, (ax1, ax2) = plt.subplots(1, 2, figsize=(6, 3), sharey=True, width_ratios=(0.90, 0.10), gridspec_kw={\"wspace\": 0.05})\n",
    "task = \"invkinematics\"\n",
    "for ax in (ax1, ax2):\n",
    "    # AC and NSF -> single point with error bars\n",
    "    for estimator in [\"ac\", \"nsf\"]:\n",
    "        c2st_mean = np.mean(eval_dict[task][estimator][\"c2st\"])\n",
    "        c2st_std = np.std(eval_dict[task][estimator][\"c2st\"]) / np.sqrt(1)\n",
    "        ax.scatter(\n",
    "            eval_dict[task][estimator][\"time\"] / n_test_samples,\n",
    "            c2st_mean,\n",
    "            label=plot_settings[estimator][\"name\"],\n",
    "            color=plot_settings[estimator][\"color\"],\n",
    "            **point_kws[estimator],\n",
    "        )\n",
    "\n",
    "    # CMPE: line with error bars\n",
    "    cmpe_times = [eval_dict[task][f\"cmpe{step}\"][\"time\"] / n_test_samples for step in sampling_steps]\n",
    "    cmpe_c2st = [np.mean(eval_dict[task][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "    cmpe_std = [np.std(eval_dict[task][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "    ax.plot(cmpe_times, cmpe_c2st, label=\"CMPE (Ours)\", color=plot_settings[\"cmpe\"][\"color\"], **line_kws)\n",
    "    ax.fill_between(\n",
    "        cmpe_times,\n",
    "        np.array(cmpe_c2st) - np.array(cmpe_std) / np.sqrt(1),\n",
    "        np.array(cmpe_c2st) + np.array(cmpe_std) / np.sqrt(1),\n",
    "        alpha=0.3,\n",
    "        color=plot_settings[\"cmpe\"][\"color\"],\n",
    "    )\n",
    "\n",
    "    # FMPE: Line and point with error bars\n",
    "    c2st_mean = np.mean(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    c2st_std = np.std(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    # ax.scatter(eval_dict[task]['fmpe']['time']/n_test_samples, c2st_mean, label='FMPE', color=plot_settings['fmpe']['color'], **point_kws['fmpe'])\n",
    "\n",
    "    fmpe_times = [eval_dict[task][f\"fmpe{step}\"][\"time\"] / n_test_samples for step in sampling_steps] + [\n",
    "        eval_dict[task][\"fmpe\"][\"time\"] / n_test_samples\n",
    "    ]\n",
    "    fmpe_c2st = [np.mean(eval_dict[task][f\"fmpe{step}\"][\"c2st\"]) for step in sampling_steps] + [\n",
    "        np.mean(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    ]\n",
    "    fmpe_std = [np.std(eval_dict[task][f\"fmpe{step}\"][\"c2st\"]) for step in sampling_steps] + [\n",
    "        np.std(eval_dict[task][\"fmpe\"][\"c2st\"])\n",
    "    ]\n",
    "    ax.plot(fmpe_times, fmpe_c2st, label=\"FMPE\", color=plot_settings[\"fmpe\"][\"color\"], **line_kws)\n",
    "    ax.fill_between(\n",
    "        fmpe_times,\n",
    "        np.array(fmpe_c2st) - np.array(fmpe_std) / np.sqrt(1),\n",
    "        np.array(fmpe_c2st) + np.array(fmpe_std) / np.sqrt(1),\n",
    "        alpha=0.3,\n",
    "        color=plot_settings[\"fmpe\"][\"color\"],\n",
    "    )\n",
    "\n",
    "    ax.set_ylim(None, None)\n",
    "    # ax.set_title(task)\n",
    "    # log x axis\n",
    "    # ax.set_xscale('log')\n",
    "    # x labels as decimals\n",
    "    # ax.xaxis.set_major_formatter(plt.FuncFormatter(lambda x, _: '{:.16g}'.format(x)))\n",
    "    # larger tick labels\n",
    "    ax.tick_params(axis=\"both\", which=\"major\", labelsize=\"x-large\")\n",
    "    # minor grid every 0.01 units in y and x\n",
    "    ax.xaxis.set_major_locator(plt.MultipleLocator(0.05))\n",
    "    ax.xaxis.set_minor_locator(plt.MultipleLocator(0.01))\n",
    "    ax.yaxis.set_minor_locator(plt.MultipleLocator(0.05))\n",
    "    # 0.01 grid\n",
    "    ax.grid(which=\"minor\", alpha=0.2, zorder=-1)\n",
    "    # 0.1 grid\n",
    "    ax.grid(which=\"major\", alpha=0.5, zorder=-1)\n",
    "    ax.set_xlim(0, 1.0)\n",
    "    ax.grid(zorder=-1, alpha=0.5)\n",
    "    sns.despine(ax=ax)\n",
    "\n",
    "\n",
    "# add a zoom-in to the plot\n",
    "# between top center and top right\n",
    "axins = zoomed_inset_axes(ax1, 2.5, loc=\"upper right\", bbox_to_anchor=(0.8, 1.0), bbox_transform=ax1.transAxes)\n",
    "# show zoom-in\n",
    "axins.scatter(\n",
    "    eval_dict[task][\"ac\"][\"time\"] / n_test_samples,\n",
    "    np.mean(eval_dict[task][\"ac\"][\"c2st\"]),\n",
    "    label=\"ACF\",\n",
    "    color=plot_settings[\"ac\"][\"color\"],\n",
    "    s=180,\n",
    "    marker=\"D\",\n",
    ")\n",
    "axins.scatter(\n",
    "    eval_dict[task][\"nsf\"][\"time\"] / n_test_samples,\n",
    "    np.mean(eval_dict[task][\"nsf\"][\"c2st\"]),\n",
    "    label=\"NSF\",\n",
    "    color=plot_settings[\"nsf\"][\"color\"],\n",
    "    s=180,\n",
    "    marker=\"^\",\n",
    ")\n",
    "axins.plot(\n",
    "    cmpe_times,\n",
    "    cmpe_c2st,\n",
    "    label=\"CMPE (Ours)\",\n",
    "    color=plot_settings[\"cmpe\"][\"color\"],\n",
    "    marker=\"o\",\n",
    "    linestyle=\"-\",\n",
    "    markersize=8,\n",
    ")\n",
    "axins.plot(\n",
    "    fmpe_times, fmpe_c2st, label=\"FMPE\", color=plot_settings[\"fmpe\"][\"color\"], marker=\"o\", linestyle=\"-\", markersize=8\n",
    ")\n",
    "axins.fill_between(\n",
    "    cmpe_times,\n",
    "    np.array(cmpe_c2st) - np.array(cmpe_std) / np.sqrt(1),\n",
    "    np.array(cmpe_c2st) + np.array(cmpe_std) / np.sqrt(1),\n",
    "    alpha=0.3,\n",
    "    color=plot_settings[\"cmpe\"][\"color\"],\n",
    ")\n",
    "\n",
    "# add grid to inset axis\n",
    "axins.grid(zorder=-1, alpha=0.5)\n",
    "\n",
    "# sub region of the original image\n",
    "x1, x2, y1, y2 = 0.00, 0.04, 0.7, 0.75\n",
    "axins.set_xlim(x1, x2)\n",
    "axins.set_ylim(y1, y2)\n",
    "axins.set_xticks([0.01, 0.02, 0.03])\n",
    "axins.set_yticks([0.69, 0.75])\n",
    "# 0.01 grid\n",
    "axins.grid(which=\"minor\", alpha=0.2, zorder=-1)\n",
    "axins.set_xticklabels([])\n",
    "axins.set_yticklabels([])\n",
    "axins.tick_params(axis=\"both\", which=\"both\", length=0)\n",
    "axins.grid(zorder=-1, alpha=0.5)\n",
    "mark_inset(ax1, axins, loc1=4, loc2=2, fc=\"none\", ec=\"0.5\")\n",
    "\n",
    "ax1.set_xlim(0, 0.9 / 4)\n",
    "ax2.set_xlim(1.1, 1.2)\n",
    "ax1.set_xlabel(\"Sampling speed [seconds]\", fontsize=\"xx-large\")\n",
    "ax1.set_ylabel(\"C2ST\", fontsize=\"xx-large\")\n",
    "\n",
    "ax1.spines[\"right\"].set_visible(False)\n",
    "ax2.spines[\"left\"].set_visible(False)\n",
    "# ax2.spines['top'].set_visible(False)\n",
    "# ax.yaxis.tick_left()\n",
    "# ax.tick_params(labeltop='off') # don't put tick labels at the top\n",
    "# ax2.yaxis.tick_right()\n",
    "ax2.set_xticks([1.15])\n",
    "ax2.tick_params(axis=\"y\", which=\"both\", length=0)\n",
    "\n",
    "d = 0.5  # proportion of vertical to horizontal extent of the slanted line\n",
    "kwargs = dict(marker=[(-d, 1), (d, -1)], markersize=12, linestyle=\"none\", color=\"k\", mec=\"k\", mew=1, clip_on=False)\n",
    "ax1.plot(1, 0, transform=ax1.transAxes, **kwargs)\n",
    "ax2.plot(0, 0, transform=ax2.transAxes, **kwargs)\n",
    "\n",
    "lines, labels = ax1.get_legend_handles_labels()\n",
    "lines = [lines[0], lines[1], lines[3], lines[2]]\n",
    "labels = [labels[0], labels[1], labels[3], labels[2]]\n",
    "# legend below plot with 1 row\n",
    "f.legend(\n",
    "    lines,\n",
    "    labels,\n",
    "    loc=\"lower center\",\n",
    "    ncol=4,\n",
    "    bbox_to_anchor=(0.5, -0.25),\n",
    "    fontsize=\"x-large\",\n",
    "    frameon=False,\n",
    "    markerscale=2.5,\n",
    ")\n",
    "f.tight_layout()\n",
    "f.savefig(\"./figures/speed_performance_c2st_twomoons.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
