{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "toc_visible": true
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "# Figure 4: Classifier two-sample test basic visualization"
      ],
      "metadata": {
        "id": "K4t90XSUHvEb"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "rn0KdSQg292I"
      },
      "outputs": [],
      "source": [
        "import torch\n",
        "import numpy as np\n",
        "from torch import ones, zeros, float32, as_tensor, tensor, eye, sum, Tensor, manual_seed\n",
        "from torch.distributions import MultivariateNormal, Normal, Categorical\n",
        "from typing import Any\n",
        "import matplotlib as mpl\n",
        "import matplotlib.pyplot as plt\n",
        "import seaborn as sns"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from labproject.data import toy_mog_2d"
      ],
      "metadata": {
        "id": "fgwRepKG_Rub"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "## 1-d densities and optimal classification\n",
        "\n",
        "We plot two different univariate Gaussian distributions. The optimal classifier takes the central gray line as the decision boundary, resulting in the shaded misclassified regions but still guaranteeing a classification accuracy over 50%."
      ],
      "metadata": {
        "id": "NYMG64oaIgvS"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "x = np.arange(-7.74, 8.26, 0.01)\n",
        "gaussian = lambda x, mu=0.0, std=1.0: np.exp(-0.5 * ((x - mu) / std) ** 2) / std / np.sqrt(2 * np.pi)\n",
        "with mpl.rc_context(fname=\"matplotlibrc\"):\n",
        "    fig, ax = plt.subplots(ncols=1, nrows=1, figsize=(1.4, 1.2))\n",
        "    # plot pdfs\n",
        "    plt.plot(x, gaussian(x, mu=-1.0, std=1.5), color=\"#2b7cba\")\n",
        "    plt.plot(x, gaussian(x, mu=1.0, std=2.0), color=\"#d52221\")\n",
        "    # shade classification areas\n",
        "    plt.fill_between(x[:len(x) // 2], gaussian(x[:len(x) // 2], mu=-1.0, std=1.5), color=\"#2b7cba\", alpha=0.2)\n",
        "    plt.fill_between(x[len(x) // 2:], gaussian(x[len(x) // 2:], mu=1.0, std=2.0), color=\"#d52221\", alpha=0.2)\n",
        "    # hatch misclassified areas\n",
        "    plt.fill_between(x[:len(x) // 2], gaussian(x[:len(x) // 2], mu=1.0, std=2.0), color=\"#d52221\", facecolor=\"none\", alpha=0.7, hatch=\"///\")\n",
        "    plt.fill_between(x[len(x) // 2:], gaussian(x[len(x) // 2:], mu=-1.0, std=1.5), color=\"#2b7cba\", facecolor=\"none\", alpha=0.7, hatch=\"///\")\n",
        "    # bounds\n",
        "    plt.ylim(0)\n",
        "    plt.xlim(-7.74, 8.26)\n",
        "    plt.axvline(0.26, color='grey', linewidth=1.0)\n",
        "    # labels\n",
        "    plt.text(-6.7, 0.125, \"$p_1(x)$\", color=\"#2b7cba\")\n",
        "    plt.text(3.4, 0.125, \"$p_2(x)$\", color=\"#d52221\")\n",
        "    # clean axes\n",
        "    plt.xticks([])\n",
        "    plt.yticks([])\n",
        "    plt.gca().spines['left'].set_visible(False)\n",
        "    plt.gca().spines['bottom'].set_visible(False)\n",
        "    # legend\n",
        "    legend_elements = [mpl.patches.Patch(facecolor='none', edgecolor='gray', hatch='///',\n",
        "                         label='misclassified')]\n",
        "    plt.legend(handles=legend_elements, handleheight=0.8, loc=(0.10, -0.18))\n",
        "    plt.savefig(\"svg/fig1_panel_a.svg\", bbox_inches=\"tight\")\n",
        "    plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 146
        },
        "id": "RN0g70TDrDHr",
        "outputId": "b6a6970d-5dd4-4234-de47-7a76a77758a2"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 140x120 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Classifier problem and training depiction\n",
        "\n",
        "We plot samples from a multivariate Gaussian and a mixture of Gaussians to depict the training task of the classifier."
      ],
      "metadata": {
        "id": "iHhOGKRKJBhH"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# generate samples from mixture to compute single-gaussian approximation\n",
        "n_samples = 5000\n",
        "toy = toy_mog_2d()\n",
        "samples_mog = toy.sample((n_samples,))\n",
        "samples_np = samples_mog.numpy()\n",
        "samples_normal_approx = Normal(samples_mog.mean(dim=0), samples_mog.std(dim=0)).sample((n_samples,)).numpy()\n",
        "\n",
        "# subselect samples to plot and prepare plot params\n",
        "n_plot = 10\n",
        "samples_to_plot = samples_np[0:10,:]\n",
        "\n",
        "al=0.4\n",
        "ms=6\n",
        "mec='k'\n",
        "\n",
        "densities = [samples_np, samples_normal_approx]\n",
        "samples_plot = [samples_np[:20], samples_normal_approx[:20]]\n",
        "titles = [r'$p_{true}(x)$', r'$p_{1}(x)$']\n",
        "cmaps = ['Blues', 'Reds']"
      ],
      "metadata": {
        "id": "1vCSJcDk3dcP"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# plot densities and samples\n",
        "with mpl.rc_context(fname=\"matplotlibrc\"):\n",
        "    fig, axs = plt.subplots(ncols=1, nrows=2, figsize=(0.8, 1.8))\n",
        "    for i_a, ax in enumerate(axs):\n",
        "        density, samples, cmap, title = densities[i_a], samples_plot[i_a], cmaps[i_a], titles[i_a]\n",
        "        sns.kdeplot(x=density[:,0], y=density[:,1], fill=True, thresh=0.05, levels=10, cmap=cmap, ax=ax, alpha=al)\n",
        "        ax.plot(samples[:, 0], samples[:, 1], 'w.', ms=ms, mec=mec, alpha=0.8)\n",
        "        ax.set_xticks([]); ax.set_yticks([])\n",
        "        # ttl = ax.set_title(title, fontsize=12);\n",
        "        ax.set_xlim([-7,4]); ax.set_ylim([-6,4])\n",
        "\n",
        "    for i in range(2):\n",
        "        axs[i].set_ylabel('dim2')\n",
        "    axs[1].set_xlabel('dim1')\n",
        "\n",
        "    fig.tight_layout(pad=4.0, w_pad=1)\n",
        "    plt.savefig(\"svg/fig1_panel_b1.svg\", bbox_inches=\"tight\")\n",
        "    plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 246
        },
        "id": "5wg7XbqU3iHi",
        "outputId": "4c1cac7f-3f5a-4cfe-afe9-12c1836783ed"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-9-06f4992e5502>:15: UserWarning: Tight layout not applied. The left and right margins cannot be made large enough to accommodate all axes decorations.\n",
            "  fig.tight_layout(pad=4.0, w_pad=1)\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 80x180 with 2 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAGEAAACuCAYAAAAmuGPCAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAgHUlEQVR4nO2dd3xUVfr/31MyqSQhZVJIIQFUiktTpKw0kZpCSELagNjWtXx3Xb+uiux+f379abCsruKqa0FAZiAQ0gOirIIoijQFCysCElIIk0J6mUzmfv8YZjLphRlyYefzeuX1Sm7uPefc53Of5znnOc85RyIIgoAdgwrpYDfADjsJooCdBBHAToIIYCdBBLCTIALYSRAB5LauQBAEGhoaAHBxcUEikdi6ymsONteEhoYG3NzccHNzM5NhR3vYzZEIYCdBBLCTIALYSRAB7CT0EVqtliNHjqDVaq1ets27qNcDcnJyeP755zEYDEilUtasWUN0dLTVyrdrQi/QarU8//zzREdHk5GRQXR0NKmpqVbVCDsJveD8+fPo9XqWLVtGYGAgKpWK1tZWCgsLrVaH3Rz1gEadgW+Pf09RURH//Oc/iYyMZN++fchkMoKDg61Wj8TW05v19fW4ubkBUFdXh6urqy2rswoadQbAaIriYqK44YZRnDx5krq6Oqqqqnh+7Uvcf+8qq9Vn1wQLNOoMaLVaCgvPExwcQmHheQwGA8899zzOzs4cOnSIv/zlL4wZO9aq9dpJoO3Lz8vN4eUX15p7Qap7HkBAwma1mhUqFSdOHMfJyYmgIOuZIrCbo3amJyY6kqVLo0lKTmHrFg25ubncff8DfPDuOxgMrTjI5Tz+xFNERhm7p84K6/RrRK8JJiF1h4EKomO5J385iyAYSEhMJig4hITEZDIys/ANGYkmPZOCgkIChwUxMnTYgOrrCaLtojbqDL0SYLpvIGWbcLqgmM8PHKQZOQYkqDVqzv76K5otagxI8A8MotXRnVtumYyPr9L8nLW0AESqCd0J1tJpKpXKdvf3VSiWZaftyOSNV16k1WBAL8CEabezPTObjKwsBKSkPPgoIUEB1Dfpr+yFeoHoSOiOgI5O889PrjbbZsvnuiOjY7mnC4p57eUXiImJJj4hCc2WLWzLyCLlyZdo0TUTHhaKh5cP5yob8HVRoNMLeLo4WOkt20O05sgSpwuKeWFtKpFRUaRtTycyKooXX1jL6YLiTvd2NGMd/65qaKGqoYWfTp+h1WAgOj4Rr4AgImMTkAgGKqvraPYMQ69wvyrvBiIjoSstqGpoobioEDCQkpJC2PBQUlJSEIRWSoqLzELtqqyO5Znuq2xoBndfdILAti1bOHeugIy0LbQaJOA4FF83BQB1Oj2+Lgr83Z3alWNNfwAiNEeWMAlt+PAQJBIpm9VqkpJS2LpVgwEpzl5KFHIJOr1AVUNLt+bCVI62rhm5FIpqmvip1oHwO1exedt6MjIykcllxKx6BAcPbwAuNbYw3d8TAJ3etjnTohondPXlKuQSSmua+Ozjnaz/x6sgGH3C7x/9MzPmLjTf6+XiaP7dRIalhlQ2NFNU00RxTTOl1c2U1zRTfqkBd6Gekl9+xm2okoWzJnO8qJoWmRQfd0emh3ni66LAy8WxHcHW1gTRkmBJAEBZg45LFWVoL5SgDAhkqLev+V5fF6P5MJkNyy+3sqEZoEsCKi6UEzTUuV0bPJXetMikTB3hhdLN4aqQ0OfScnJyeOONNzhz5ky762+//bZVG9QVyhp0ALQ4ejJ0+BhaHD3R1rWgrWtp9//SmiZKa5pQyCUo5BIzAWUNOjMBh0+VU36pAeemeoKGOjMl3Mv8A3DhMulXE30iYfXq1bz++uucOnWK6dOno9FozP977733rNKQjloAmLUAMAu8ok5n/jFdP1vZSFmDrhMZpmtnKxvNGnCDryuUFVF2/mdu8uraCIzyc7PKO/UVfXLM+fn5fPvtt8jlch555BHmz5+Pq6srS5cuxVbWTCE3Zuq5OsnNwjUJfoSPC2fKG8x/e7sp0Na1oHRzMN8LcLayETeFvJ0JunjoY07uTcPVUcYP+TA/9h4mTpvDobOVzJoUzu6fLgLGntEULw+bD9SgH70jmUwGwI033kh2djaLFi3Cz8/P5mmN5yob8HZVmDXBW1JPzp6jeCoDcfP0xtNVQUWdzkyEJdwUcirqdO2c8L69aagS44hbnsiO7WlkZG5gxOjfABKOF1W3e76+SY+/u5PNe0d9MkcLFy5k8eLFfPfddwBMnDgRtVpNVFQU586ds0pDLJ2dp4tDuxevqDd+3ce/+IT/fXgFe955lqzUh/jp639RVd+mJRV1OoZ5OJl/Kup0/HKxjvJLDQS4O1Hyy8+4OsqIW55IcEgIc++4k+amegrPnjLXNTrY0/y7q5O8nUk0YSDxqp7QJxJefvll7r333nbX5s2bx/79+1m8eLFVG9QRpp5PdWU5eza/QdSSxWzWbGFZzFKOZr1PXVUFVfU6Rvi4AHCiuMb8U1WvMxNQpa3AbaiSVgPs2J7G5k0buP/uFbQ0N5KrfoNzJ77stg0KuaTLAaG10OfeUVxcHBMmTKCmpobz589z/vx5XF1dSU1NtVnjLEeq+/PTaaqpZM7smbjIBCIiIpFgwMtQzRh/N44WVJnJGOHjYtaQAHcnxgd5ADBr/Ajmx97Dtu3ppD77DJGREaRnZBMTs4yT+7ZRX11hrs9NIedcZfcJzNbUhn6NmB977DHWr1+Pt7e32SFLJBLOnj1rtQZZwmSSLlWUcWB3JgqFggMHvmLRokVoNBpaWwUUjo6c/vE4gQHDKNE58fnxM5ScOYkEcPENY/rYcD4/1ta+idPmoHB0JG/zOlbe8ztCw8JZGufMzvw8aisuQoj15wt6Q79IyMvLo7i42Dz4sjacFVLzF+bp4mA2AbrKi7gqFNz78MNs3riBrKwsSkqKCZ04k7f/9zEkCAhIGHPLb/nm03wa62txVDgid3JB8bsnwHWkeRwAEBx+IxKZA5kZO1iyNJ7sHdswSCQM8fajrqqC6sIy5OHDUboF2OQ9O6JfJIwfP57m5mabkdAV/N2dqBgWjICEyvIy/vbaOj7cuIGaz7+kouDfJC5fTnJKMhvWv8emD9bj4e7Bww8/zKJFi9mi0ZD/4RtMVT3DoXbKKiHst/Got21jy9ZtgMDCpN9RcuoEH+36AAcpIJGieuhPxERZL9OuO/SLhJiYGEaNGsW4ceOQy9se/eyzz6zeMBN0egFvH18e+OPjvLvuFXZkGidcJs9fyo+f7yR2eSK+AcFMmDwF9aaNDHEfgmrFSgL8A1gSsYSPPt7DjX4Kwm4Kb1furEnh7Pdz4ZNt76NwcGDXtg/QNdWzcuVdJCQlk5mehuYff0PpMYSZU2/BY6hvNy28cvSLhDVr1vDaa68RGhpqq/Z0aZL83Z2Yu2AJ06ZP4+jJM0jdjbNqJ/btIjM9jbiEJI4e/obWVgM1NbVs/nATCxcsIC83l4pyLV8d+Y4at5B29dRXV7A7fRPL45ezbHkiGWlqNrz/DnfOX0BY2HD8lUrKL5bw2vN/5R0nJx557EkS45bZ5J37FcCbNGkSx44d61cF/c226CmS6urU1mPR1rVweO9u8jf+A7lEoLkVwidM4/i+nTTX1+Ds7IyziyvjJ07mu5/+TeJf38bN09tcbtGp79nzzrNotm4jKCSUs2fPsDxyAQsWR5CychX3rUwmMjKSBx58iMz0dLJzcsnMzm03rToo2RbTpk0jJiaGJUuWoFAozNdXrlxplcZ0RFd98+FeLpyrbGC0nyujE2O5YfwtVJSW4O0fyJiwINKyppK97v/x1Jq/MvuOeTQ1NpKSuBxDXTmew9ocrWx4KAISsyblZ+3AwdmVLw58xf59+2hpaWHlqru5cdQoEpNTyM7Opqio0EzCoE30NzQ04OnpyYEDB9pdtxYJXQXxLMPZQKe++9TRoTDaaB5PXqznNxMmsMfdk5LiQvS6JjLT05BIZcY5Y7e2D8fbLZB7//A4m958lZycbASkRP7uCebOnE5d0RlefPYvfJSfj4e7B1u3aJDJZFZP+jJBNPMJXRFgCkVDW7ja21VBR5jCGiZ8+a+P2PbO6yAYQCIl4YE/8tt5izo9p61rQSlr4Ocz51A4OqJramL0iDC8fXw5tv8TXvvbSzZN+jKhTyRERESQn59PWFhYlwG7ngZrfSGhJwJMwu8YnBvtZyzHRMBwL5e2Opv0VJSXUVpShH9gEN4+bT0bVyej8ltq1KmDn/Hmqy+BIIBEwuNPPMW8hZGUl2mpqSglKCjYJr7AhD6RsHbtWoYNG9Zt2Pquu+7q9tmBkGAyQWUNOr47XUhjxUVqHYYSHOgPGEPXYCSiol7HcC+XdiHnjhPzlugYkKsoL+O/ViUQszSaFSoVGo2GnJxcNm7N6DLbztoEQB99wqlTpzh16hRnz57l9OnTLF68GLlczu7duxkzZkyPJPSG7iZzyhp0ZGTlsGvjGzhIoVEvMDPh90yft9gcuu4IS+F3FX5WyCWdCLpwWotMIpCSoiI4JJSk5BRysrOpqSiFDiTYggDoIwkbNmwAYM6cORw/fhwfHx8AqqqqrLp2C9rM0KWKMvZsfpPlsTEsi08kY3sa6TveJWT0RBrlQwA3TgJKt/YZFpbCt5wXrmpoafc/06SRX0AQIGXrFg0rVCq2be3aCduKAOhn3lFxcTFeXm0xGBcXFy5cuGD1RpU16Pj232dAMLAsPhEf/yCWxiUgNRgo+rXAnBdkQsfJF08Xh07pL6Zrpus6vYBOLzAydBhPrX6a/Lw84uLiyM3N4/EnnkKpVKLVajl69Ai1VeVWf0dL9KuLGhERwR133EFsbCyCIJCWlkZCQoJVGtJxTBAcHEqrICFjexpL4xLIy9yGTC5jiLdfj+X0JVWx4z2RUdHcNnUaRUWFZiecl5vD315aa7MVm5bodxc1IyODffv2IZFImDdvHlFRUT3e35tjNvmEjg5ZW9fCZx/ls0fzFlKDAZlcxuKUh3AIuw1PDyc8XRV4uynapaVA30joDbVV5URERBAdHY1KpUKtVpObm0teXl67XpK10O8MvNjYWGJjY63eEMvQtQnjb5+Pd/jNFP1awBBvPxw8vLlQ00SLTIogleCokDLWxbVdGVcCk93/8bxxmZRKpSI0NBSVSkVWVhaFhYXiIOFqoU6n51JjC43yIdw0cZL5uik7zt/DkXAvY+KWZfadCV050oKi0k6p9V3dFxISglQqRa1WmzXB2is2LSE6Eiy7kG4KY/M8nY1f+KXGFqaO8KJOpyfcy7lbM9SVYPuzKl+pVLJmzRpSU1PJyspCJpPx9NNP20QLQARhi95Gy6bcIcAs/Ga9gSB3pz4ToNVqB2TjjYtSCgkODrYZASCy1HiTME3C9XVRcFuQB0o3B5RuDgxzd8TXRdEvAsC4Kr+jje/LqnylUsnkyZNtSgCIgISOgrMkwmSafF0UZuH7d0NAT7C08QUFBTa38f3FoJsj6H5xiAmm0W13o2HofUSbk5NDamoqra2tZhtvq35/fyEKEqDnPB4TId19+X0NKVwtG99fiIYEE/qTVGXLeM7VhOjeoq+CvV4IABGOE6BNwB214noSvCVESYIJ16vQO+I/4y1FDjsJIoCdBBHAToIIcFW27jehvr7e1tWJEr0dWWBzEiy36/fz63lq8npFb4NUuzkSAWwetjAYDJSXG7MV/lNPEuntvW1Ogh29w26ORAA7CSKAnQQRwE6CCGAnQQSwkyAC2EkQAezHPooA9mMfRQC7ORIB7CSIAHYSRAA7CSKAnQQRwE6CCGAnQQQQdQae1dBU1/3/nK7ulsxd4fomoSfhd3fPIJBy/ZDQF4H3tZyrTMS1SYK1BN5T+VeRCPGSYGtB96X+q0SEOEmwEQFCTdtGIRJ3H5vUMRCIjwQrEmApdADkl1f+65v7RshV0gZxkdBPAjoJuSPknbdb6HT9MiGDSYS4SOgj2gm/O0EDwoVfu/2fJCCs7fm+ENERViRGPCT0QQtMwteWlXO+tJyQoGEofR17FDauHp2v1Vebn5EEhJmJNJXfJ39haq8VyBDHEtpeCLD88nM+2Uvq39/AIAhIW/Wsvk9F9NzbOwlbOPtTl2VJwsd0aKDxCBezZuiN+2r0y3FfIRGiJ8FMgNwRbVk5kcl3EbFkMfGxy0jPyGRnfj45767Dt+ai+RntpWoKmyEkwA+l19C2sirabxVnJmSQiRh8c9RHAgDOFxVTX1/P9NtnIcgdmT5zFhq1mo8z0pl/y3j8Rt5Ezt4vWLtBg6FFj8Sg56HZUxk7c7aREO+2bZqFigtmbZGEjzGbKLN56s1PWBGDS0I/CABwrqugrKKCPf/6F/fecw9vvfU22ktVvJr7L97ctZcHp03grX0HiY6NRxUfy/tp6Ty5fj0Bnx1EIYXVi+cQdcvNAEjHGjeyMpFh0oquiADbjitEGcruigDhwq80NDXh7ubGnk8+IT4+ji+++AKVagVbN35AVEQkf9/zJTqJHFVyMsOGhzH7jjvw9BzKc889T/TyJF7c8xXlrkZhGn48huHHY0gua4fZh7h6tDl6uWMnp20LDN6xj731hjoQABAyYhRenh7MnzOLu1KS8fTwIDoyglGjbkCVnIxMJqelrhb1ZjUnf/iJ3Nw8XJ2duXXMTaRERqDX6Ti7by/6CxVIg0YCRjKEUqOv6JIIi7bYiojBOfaxL2bI9LdJGK4e+NZcZPWyBez99FM2rV9PddUl9n7yCUW/nEa9WY2D3IH7Fy3g/Q83syAuns1qNcNCQrhY34gmJxeZTE7IxKkA6A5/046MHjUCzERotWUcOXoMrbasz+/UG/rUO7r55pvNxz7+/PPPzJ8/n9dff52lS5cyceJEvv32226f7bJ31E2DO5ohSwJMwhFKL6CtrqWwsorvv/+Fd4+coNXRCRoa+K2fH/tKLlCh1yOVSpkzYzpfHjqMTqfDWy7nT5MnsmiUUeieM6Zi+OV7ABS33oah6DTSsZPMPSiTs4a2XlNOXh6p697GgBSpVMKaJx4nOjKi7QUG2EO6+sc+9sMMAZ0IAPBq0OHl5ML4W8czzSeQktpaXMbezB8++ICopCRmzp3LV199xc68PNb9/+d49KknWXHjaIZNuoVKb2+8zp2h6sBBMxG6w98gD/DG8OOxdkTg6mEmQltWTuq6fxIVvZQVK1ag1mhIffkVRo4YQWNjIyHBwSiVDIgI0Rz7KNSUd+kHzH9fJkB/wXggXY22nhptPb6uLgS6eVJ0+Aj6lhYSIyMJDAhg0aLF6PSt5H76Ka2CwKZfz/DfGzaQsPYFtn1/Etn4SVQdOIh01OXekoWPkHgHdBrsnS8qxiAIqJKTjPvopaRQUVFJ0l138/s//ImI2Hhy8vIH9O5X99jH3syQBbQVlzhyppCLR79ua+xlQdVojYvSZeMnUVZnHFiNmDkLqVzOjl0f0VxXh1qjpri4iE8/2gWtBmLjl5O+I4NlKhXrf/yBH/d8CkDVgYOA0UeYygfjgO/IiR/QNuoRLvxKSNAwpBIJ6i1bKSgo4J/vvENNbS1xcfFk7EgnOjqa1JdfQavV9l0el9HvEXNNTQ1VVVXtroWEhHR9Mx18QnlplyPmjlqQrfmQtR9swSCARN/Mw4mx3EQzgXrwnzSVqgMHkY2fROmBr3GdMgWAU/sP8FXBOXac+gnkDrTqdCycPgOlpxcf7t1D2gcbGB4czMVLl1ienMTT437DHTHRtB43HtTkrjS2Sx7gTe6R71n7yRcISJE6OLD6nmSWpqwkZ9du1v79DVqR0NjUCALs2plPaGgoBQUFxMbF88677zJ58uT+iHTwj33sqAUXfzjG2vfVRC2LRZWUxPvr1/PE6+8SMNQDhcHAky0yZgKlB9o05NR+4xk/kYmJzKip4eKlSvyGenHi7GnW79pJeU0167dvRxUTQ96uXUgFgfCZMyk98DX+M6ZR+tWXnMGXYbVlKEbeyNpde4lOTEYVF4s6I4sX1muYPn8x0YsXMm3izRRVN+Lk5MTdDzyIWqNBlZKCWqNBJpMOaIdJcRz7aNEbOn+hFINEiiopiUBfL2bPu5PtWVk898z/cPzED7yUlcvouXMAGa5TppgJ8J5m7Hp6ubvj5e5OZU0Nmz75mPjEBHx9fHn1jXVkZmYwRCIl4aax+Li7w5QpbFFr2Hj2DEKrHplgIPboCQSpHFViAqGBAaiSksjOzKCwuASlrw9KXx/8RhgHfGueeJzUl18hKysbmUzK03/+7wFtcCi6Yx9DRoxCKgH11q0si1hCXl4ebi6uTJk0kXGjbiArK5OS2lomLVjUThs6orSyAmRSEuPiCQkOZsJvfsPd99/HIzFxjKqu5dT+A3hNuJn3f/iBmITlqGKXkZafz/YtGgxSUKdtM2uCTCIheFiguWxTTCk6MoJpt91GYVERwUFBKJUDO5VQdMc+Kn28Wf3gfaxd9xYZ27dRrC3nztkzaWxqQpOXj6FZR2VjI6VffQnIuGHmDLM2WMLfyxtaDaTtSCcxLp49n32Ki0LBDUHBeI1xp+Lrg5RUlCNxdSFpaQyhQUGkLF9OVvp2VPNmsT1tK9k7diBTKHjqofvx1dcCPuaYkrm9St/2wh/ATFy/HPPw4cN59tlnOx37OGvWrG6f6c0xWzpl4cKv5nmBi0e/pkgn4YfTZ3lbsx2DgyM1NTVIDa24untAfQOrxoxlblg4xU2Xj46/bJJM2PfdMT7c8zGCVIrEYGDlnQu4ubHtODCvCTdz/z/WER0VZdaE3LSt5L7yHIaSXymSyAm5ZRpKH2+or24X6u4xoNdPEvqlCV5eXjY7XdCM+mpw9UA51AMlMHnMIhb9dirffvIRa3I+Y1lUNCnJyWxWa9iUm8t4P3+Gubh06R9mT5hEcGU1ZfV1+Lq64XmZgBtmzjBXd8+IkWzKyyM3Owu5gwN/vn0KyqGeGOqH4OcfgMTHu1MTrY2re+yjkxvQheLpm0HuiCQgrG3aMXyMecCk9BrKUFcXpDI5KbHLCFX6sEKVQnZWJi0jw6GklPpDh8ym6cxne9HW16F0dcPT2ZkpC+Z1qrL+0CEA5oaFMzc8lJLaWm4M80M5xLVTCMPWGPRjHyXuPp0Ha5e1AYzxfol3ACHeQ5G0GP1CSmQEmpxcJHo9w7y88A0Lo/TA19QfOsTPFwr54MxpDHo9tOi5b9w4hl0WeEf4z5hmHieMmj8Xwy/fm+NIA8YAwhZXf3pT1rm6vgTuJN4BZG/axAu79tEqgKy1lScS4pmpb0U23jhBU1ZdTcLaF4hJWE7S0hi279pJTkYG6j/+EV8PD8qqqymqqCDocvzIBNNAradAntkfQM8+wVYkWP3Yxy7CF30lovSrzymWu+FXXGgePZvw3YVSnvr6IOnpOwgNDqagsJD4+DhenD6Nktpa1h37DsFBjqRFzx8mTSBplapTJBVA4m8Ma3cVSbU2AdBHczRjxgw+/PBDnnnmmQFV0heYzVJH/1BfbfYPQsUFlB5DUALSuXPRHf4GzxltPaIxVdVI9n+JZssWFsyexQdp29A3N+N76ySefutdYlQppCxfjmb7dt5M28qcYwcJmjsXQ9HprjXA1LYOCQBWf/e+aMLdd98N0O2xjzt37uz22f7MJ0A30VSTfzj7ExLvAAw/Gu24NGgkusPftHs+74efeXr3XqpaWnFycsLNQc6qOTPZ/s0RdmzcQGhwEAWFRcTfcy9vJi5icpgxzGD6+qHnLAxrdk1NEN2xj4BZG8zo4KilYycZ54iLTqO49bZ2j94+8kbcPj9I8oo4UuJi2Z6ZTVpaGkglaDIyUa1QocnORtrSTLCXZ9df/2XhQz+04GqlvFjt2Ecnt261oWNvyWSWtOfPcb7OQHBLrdEcXc6WMGmFCefOnkfm5MTdyYmEBgejSownOzeHhEmjSc/OJDs3B6mhldW/vwe/G0d2OZNmqteM3vKQrjD5SzTHPnaChTbkfvszqS+/igGQSqWsfvA+TOccSvwDzPPDAMMDwpCm70adnYsqMQF1di4yBwdW3HsPK+6FwlItQQoB5VCjZpmF39H0WLYD2xEAg3nsYx9zT7Vl5USu/B1RS5eiWh6Heus28rKzyHn/Hyh9vLtMd8w9cJi12/IwIEGKwOqESKJm3Gr+f7tUyK6Eb2F6es03uqZzUfuYnXB4/2c8+NT/sCM93Tx5ErdsGW+v+ROTx97UdcIvoC2voPBCKcEB/sbYT7tG9Wx2oI/JXlbKzB68DLwe/IIlQm+62TitqNmCKjkJ9dY0ZA4KQsbfCvradgK1hNJZjjI8yPhHF/dckfBN7bcSxJEQDD0SkpOXT+rLr9Cqb0EmkbL6T/9F9OKFV964gQgfrL5oRDwkmNANGVptGYVFRQR5OKP07UJgPSwW6YSBCh9ssmpHfCSAdZZNdUXKlQgfbLZsavBT462AjgI1hz+g00yYmFZtmiBOEvrotLuDSdCWZFyx8G24eFCcJMAVEwFX4Gwt6/2PW0LbEf0RwJUQ1rGeq7y3hSgXiQwIAxWcCLbauX5IgP4J1MlNFASA2M3RQGASrI0XgFsT1x8JJohU4F3h+jJH1yjsJIgAdhJEAPuxj1cB9mMfRQD7sY/XAOzHPl4F2I99vAZgN0cigJ0EEcBOgghwXZCwatUqUlNT+7e7wGWUlJQQGBjY+402xHVBAkBgYCC7du3q1zM7d+5k9uzZA8untSKuSRIEQeCxxx5j1KhRzJ4927wR1vDhwwGjZjz00ENMnDiRkJAQ1Go1sbGxjBgxgkcffdRcznvvvUdmZuYgvEEHCNcg0tPThZkzZwo6nU7QarWCv7+/sGHDBiE0NFQQBEG46667hKioKEEQBGHjxo2Ch4eHcPHiRaGmpkYYMmSIcOnSpXblDbYYrklN2LdvH7GxsTg4OODr69ulL1iyZAkAoaGhjBs3DqVSyZAhQ/Dy8uq0Qcpg45okQSKRtAsMOjg4dLrHcomv5e4DYsQ1ScK8efNIS0ujubmZqqoqdu/ePdhNuiKI+xPpBtHR0Rw+fJhx48bh7+/P6NGjB7tJVwR77EgEuCbN0fUGOwkigJ0EEcBOgghgJ0EEsJMgAthJEAHsJIgAdhJEADsJIoCdBBHg/wBVV5SpBnvu3QAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# plot densities again in small as target classes\n",
        "with mpl.rc_context(fname=\"matplotlibrc\"):\n",
        "    for i in range(2):\n",
        "        fig, ax = plt.subplots(ncols=1, nrows=1, figsize=(0.3, 0.3))\n",
        "        density, cmap = densities[i], cmaps[i]\n",
        "        sns.kdeplot(x=density[:,0], y=density[:,1], fill=True, thresh=0.05, levels=10, cmap=cmap, ax=ax, alpha=1.0)\n",
        "        ax.set_xticks([]); ax.set_yticks([])\n",
        "        ax.set_xlim([-7,4]); ax.set_ylim([-6,4])\n",
        "        _ = ax.spines[\"left\"].set_visible(False)\n",
        "        _ = ax.spines[\"bottom\"].set_visible(False)\n",
        "\n",
        "        plt.savefig(f\"svg/fig1_panel_b2_{i}.svg\", bbox_inches=\"tight\", transparent=True)\n",
        "        plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 103
        },
        "id": "PF7ela0w9gU1",
        "outputId": "2977120e-56da-4301-dab0-3ea0575f07e0"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 30x30 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAACsAAAArCAYAAADhXXHAAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAB8klEQVR4nO2Xv2vbQBSAv5QMlkxqSyjEyEPlqIQMXbp2CBQ69j/N2jEQ8FC6delQTNw40IiYCDlOiOUh4A7JyZLsDH7yuRjum3T6wfv07uneaWc2m83YEt78b4FVMLK6MLK6MLK6MLK6MLK62CrZ3U0EuX14Wji3v7d66EqyeYnXgt8+PBGNUgbjRwCCRh3fsUTxxLLlbKmxklbj74OYs4sRAKFXI2jUpSFlskokGqWF875jFa6dX8Wc/vhLFN0D8PXkkM/vxK7yzKqpvbybC3fGFkGjzmD8yNnFiG/dP9z87gHQOj4i9Gpy0yqyAJd3Kd1eko37rk3opfTjaUF0XaxlNRgmk+z4OpkwTCYLor7/lk5T9mEp1rrODl9EVY2WyZeMBJHs/t4uvmPRaVq0XbtwLYruF7LaOj6SG+aoVAZBo07opYCXTT8slzsovZSEHcmveH6hz09tP54W7rt+kW+7NqFXo9O0+BR4wIY6mBI9v4rp9hKGyYQD16bt2nx575Tuno/zzUAiKpJV9OMpP3/dAM912j45zKR8x1raMKqy1o1Mvu8vk5NmVCF+OvRqfPzQysog352qSr3Gyh9YvvernRTMs6pLFCqsBjDfyKgp1ykKQllFeVuom0qym2ar/sGMrC6MrC6MrC6MrC6MrC7+Adzg1c2P36szAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 30x30 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAACsAAAArCAYAAADhXXHAAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAABt0lEQVR4nO3XT2vCMBjH8W/LwFHEixdBocjsoYLga99L2CsYCHpwoxQm9LKLiGyXdof+MbapmNQ4hPxOtdbw8TFPEp0syzIeJO5/A1RisaZisaZisaZisaZisabyZGTU76/mveGk87BOp4OMDHUpHcH62BZomkSNe+5oenrRAaw3DQSoiMs+VtLHUwSw+CUV4epYCTT7WMF23fqRjBwMtSorRrvB6tB0+wnAcbMDwAvH1bMuOdiZLUiT6LzKCtVVwxZVlUGPmx1xvD89W1z7/gDvElgh12NrDVVCD69vxPGe6PBTvfd++AVg2e9BDD7k4GCuDNTDFkmTSNpIJVB6L4YwHMN2XVVXJ3fbwcq53CWdsWUjLfs9vQEUNpbrp8FwUg3szBZnU8H3BxDLPzbtP+dNJqwOjXFvji3ijqakSZSDyX8aj7yJRLDvD6prLxzjBi8QzLXnqxZWBAMQzCtwKKleiYRTY1XLlvEdTAQX1xnFsiTuYsIyJVZTFwq6B5mWs0FbGhuA5mHG6KmrdZe6O7aeS0vQDQ7ecEtsmTr6RlAwgTWYh/rDaLGmYrGmYrGmYrGmYrGm8gfVtbbbNezMRgAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Intuition on C2ST score interpretation\n",
        "\n",
        "### C2ST = 0.5\n",
        "\n",
        "C2ST = 0.5 when the distributions are not distinguishable by the classifier."
      ],
      "metadata": {
        "id": "s_oAeWI3Js6T"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "np.random.seed(0)\n",
        "from scipy.stats import multivariate_normal\n",
        "rv1 = multivariate_normal([0.0, 0.0], [[0.6, 0.3], [0.3, 1.0]])\n",
        "rv2 = multivariate_normal([0.0, 0.0], [[0.57, 0.285], [0.285, 0.95]])\n",
        "x, y = np.meshgrid(\n",
        "    np.linspace(-3.5, 3.5, 1000),\n",
        "    np.linspace(-3.5, 3.5, 1000),\n",
        ")\n",
        "pos = np.dstack((x, y))\n",
        "with mpl.rc_context(fname=\"matplotlibrc\"):\n",
        "    fig = plt.figure(figsize=(1.6, 1.6))\n",
        "    plt.contour(x, y, rv1.pdf(pos), colors='#2b7cba', linewidths=0.5)\n",
        "    plt.contour(x, y, rv2.pdf(pos), colors='#d52221', linewidths=0.5)\n",
        "    plt.scatter(*rv1.rvs(size=25).T, color='#2b7cba', s=1.0)\n",
        "    plt.scatter(*rv2.rvs(size=25).T, color='#d52221', s=1.0)\n",
        "    plt.xticks([])\n",
        "    plt.yticks([])\n",
        "    plt.gca().spines['left'].set_visible(False)\n",
        "    plt.gca().spines['bottom'].set_visible(False)\n",
        "    plt.text(0.0, 2.8, \"C2ST = 0.5\", ha='center', va='center')\n",
        "    plt.savefig(\"svg/fig1_panel_c1.svg\", bbox_inches=\"tight\", transparent=True)\n",
        "    plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 160
        },
        "id": "I7THB5Bj3z69",
        "outputId": "53c995cc-2165-414d-edc5-bba5cbc79197"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 160x160 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "### C2ST = 0.7\n",
        "\n",
        "C2ST is around 0.7 or 0.8 when the distributions are distinguishable but still overlapping."
      ],
      "metadata": {
        "id": "KYCgsPfSKDEi"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "np.random.seed(0)\n",
        "rv1 = multivariate_normal([-0.5, 0.1], [[0.6, 0.3], [0.3, 1.0]])\n",
        "rv2 = multivariate_normal([0.5, -0.1], [[0.55, 0.15], [0.15, 0.95]])\n",
        "x, y = np.meshgrid(\n",
        "    np.linspace(-3.5, 3.5, 1000),\n",
        "    np.linspace(-3.5, 3.5, 1000),\n",
        ")\n",
        "pos = np.dstack((x, y))\n",
        "with mpl.rc_context(fname=\"matplotlibrc\"):\n",
        "    fig = plt.figure(figsize=(1.6, 1.6))\n",
        "    plt.contour(x, y, rv1.pdf(pos), colors='#2b7cba', linewidths=0.5)\n",
        "    plt.contour(x, y, rv2.pdf(pos), colors='#d52221', linewidths=0.5)\n",
        "    plt.scatter(*rv1.rvs(size=25).T, color='#2b7cba', s=1.0)\n",
        "    plt.scatter(*rv2.rvs(size=25).T, color='#d52221', s=1.0)\n",
        "    plt.xticks([])\n",
        "    plt.yticks([])\n",
        "    plt.gca().spines['left'].set_visible(False)\n",
        "    plt.gca().spines['bottom'].set_visible(False)\n",
        "    plt.text(0.0, 2.8, \"C2ST = 0.7\", ha='center', va='center')\n",
        "    plt.savefig(\"svg/fig1_panel_c2.svg\", bbox_inches=\"tight\", transparent=True)\n",
        "    plt.show()"
      ],
      "metadata": {
        "id": "Zz0BfSyi9jPq",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 160
        },
        "outputId": "dba96e86-b8fa-4428-c1aa-8420bd145de9"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 160x160 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "### C2ST = 1.0\n",
        "\n",
        "C2ST is 1.0 when the two distributions are completely non-overlapping and the classifier can classify every sample correctly."
      ],
      "metadata": {
        "id": "eSoq2UB6KNPB"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "np.random.seed(1)\n",
        "rv1 = multivariate_normal([-1.5, 0.3], [[0.5, 0.2], [0.2, 1.0]])\n",
        "rv2 = multivariate_normal([1.5, -0.3], [[0.5, 0.05], [0.05, 1.0]])\n",
        "x, y = np.meshgrid(\n",
        "    np.linspace(-3.5, 3.5, 1000),\n",
        "    np.linspace(-3.5, 3.5, 1000),\n",
        ")\n",
        "pos = np.dstack((x, y))\n",
        "with mpl.rc_context(fname=\"matplotlibrc\"):\n",
        "    fig = plt.figure(figsize=(1.6, 1.6))\n",
        "    plt.contour(x, y, rv1.pdf(pos), colors='#2b7cba', linewidths=0.5)\n",
        "    plt.contour(x, y, rv2.pdf(pos), colors='#d52221', linewidths=0.5)\n",
        "    plt.scatter(*rv1.rvs(size=25).T, color='#2b7cba', s=1.0)\n",
        "    plt.scatter(*rv2.rvs(size=25).T, color='#d52221', s=1.0)\n",
        "    plt.xticks([])\n",
        "    plt.yticks([])\n",
        "    plt.gca().spines['left'].set_visible(False)\n",
        "    plt.gca().spines['bottom'].set_visible(False)\n",
        "    plt.text(0.0, 2.8, \"C2ST = 1.0\", ha='center', va='center')\n",
        "    plt.savefig(\"svg/fig1_panel_c3.svg\", bbox_inches=\"tight\", transparent=True)\n",
        "    plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 160
        },
        "id": "QPqZNHiqsUvO",
        "outputId": "0be24fd1-cfd7-4a85-e5b3-1697ab8f00b2"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 160x160 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Construct figure with svgutils"
      ],
      "metadata": {
        "id": "msndPseMKXo7"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "import time\n",
        "from svgutils.compose import *\n",
        "import IPython.display as IPd\n",
        "\n",
        "def svg(img):\n",
        "    IPd.display(IPd.HTML('<img src=\"{}\" / >'.format(img, time.time())))\n",
        "\n",
        "svg_scale = 1.25  # set this to 1.25 for Inkscape, 1.0 otherwise\n",
        "\n",
        "# Panel letters in Helvetica Neue, 12pt, Medium\n",
        "kwargs_caption = {'size': '10pt', 'font': 'Arial', 'weight': '800'}\n",
        "kwargs_text = {'size': '7.75pt', 'font': 'Arial'}\n",
        "\n",
        "f = Figure(\n",
        "    \"16.6cm\",\n",
        "    \"4.2cm\",\n",
        "    Panel(SVG(\"svg/fig1_panel_a.svg\").scale(svg_scale).move(5, 15), Text(\"a\", 0, 25.0, **kwargs_caption).move(10, -10)),\n",
        "    Panel(SVG(\"svg/fig1_panel_b1.svg\").scale(svg_scale).move(10, 5), Text(\"b\", 0, 25.0, **kwargs_caption)).move(130, -10),\n",
        "    Panel(SVG(\"svg/fig1_illustration.svg\").scale(1.5).move(10, 5)).move(220, 20),\n",
        "    Panel(Text(\"?\", 0, 25.0, **kwargs_text)).move(338, 49),\n",
        "    Panel(SVG(\"svg/fig1_panel_b2_0.svg\")).move(315, 49),\n",
        "    Panel(SVG(\"svg/fig1_panel_b2_1.svg\")).move(315, 61),\n",
        "    Panel(SVG(\"svg/fig1_panel_c1.svg\").scale(svg_scale).move(10, 15), Text(\"c\", 20, 25.0, **kwargs_caption).move(10, -10)).move(320, 0),\n",
        "    Panel(SVG(\"svg/fig1_panel_c2.svg\").scale(svg_scale).move(10, 15)).move(405, 0),\n",
        "    Panel(SVG(\"svg/fig1_panel_c3.svg\").scale(svg_scale).move(10, 15)).move(500, 0),\n",
        ")\n",
        "\n",
        "f.save(\"fig/fig1.svg\")\n",
        "svg(\"fig/fig1.svg\")"
      ],
      "metadata": {
        "colab": {
          "resources": {
            "http://localhost:8080/fig/fig1.svg": {
              "data": "CjwhRE9DVFlQRSBodG1sPgo8aHRtbCBsYW5nPWVuPgogIDxtZXRhIGNoYXJzZXQ9dXRmLTg+CiAgPG1ldGEgbmFtZT12aWV3cG9ydCBjb250ZW50PSJpbml0aWFsLXNjYWxlPTEsIG1pbmltdW0tc2NhbGU9MSwgd2lkdGg9ZGV2aWNlLXdpZHRoIj4KICA8dGl0bGU+RXJyb3IgNDA0IChOb3QgRm91bmQpISExPC90aXRsZT4KICA8c3R5bGU+CiAgICAqe21hcmdpbjowO3BhZGRpbmc6MH1odG1sLGNvZGV7Zm9udDoxNXB4LzIycHggYXJpYWwsc2Fucy1zZXJpZn1odG1se2JhY2tncm91bmQ6I2ZmZjtjb2xvcjojMjIyO3BhZGRpbmc6MTVweH1ib2R5e21hcmdpbjo3JSBhdXRvIDA7bWF4LXdpZHRoOjM5MHB4O21pbi1oZWlnaHQ6MTgwcHg7cGFkZGluZzozMHB4IDAgMTVweH0qID4gYm9keXtiYWNrZ3JvdW5kOnVybCgvL3d3dy5nb29nbGUuY29tL2ltYWdlcy9lcnJvcnMvcm9ib3QucG5nKSAxMDAlIDVweCBuby1yZXBlYXQ7cGFkZGluZy1yaWdodDoyMDVweH1we21hcmdpbjoxMXB4IDAgMjJweDtvdmVyZmxvdzpoaWRkZW59aW5ze2NvbG9yOiM3Nzc7dGV4dC1kZWNvcmF0aW9uOm5vbmV9YSBpbWd7Ym9yZGVyOjB9QG1lZGlhIHNjcmVlbiBhbmQgKG1heC13aWR0aDo3NzJweCl7Ym9keXtiYWNrZ3JvdW5kOm5vbmU7bWFyZ2luLXRvcDowO21heC13aWR0aDpub25lO3BhZGRpbmctcmlnaHQ6MH19I2xvZ297YmFja2dyb3VuZDp1cmwoLy93d3cuZ29vZ2xlLmNvbS9pbWFnZXMvbG9nb3MvZXJyb3JwYWdlL2Vycm9yX2xvZ28tMTUweDU0LnBuZykgbm8tcmVwZWF0O21hcmdpbi1sZWZ0Oi01cHh9QG1lZGlhIG9ubHkgc2NyZWVuIGFuZCAobWluLXJlc29sdXRpb246MTkyZHBpKXsjbG9nb3tiYWNrZ3JvdW5kOnVybCgvL3d3dy5nb29nbGUuY29tL2ltYWdlcy9sb2dvcy9lcnJvcnBhZ2UvZXJyb3JfbG9nby0xNTB4NTQtMngucG5nKSBuby1yZXBlYXQgMCUgMCUvMTAwJSAxMDAlOy1tb3otYm9yZGVyLWltYWdlOnVybCgvL3d3dy5nb29nbGUuY29tL2ltYWdlcy9sb2dvcy9lcnJvcnBhZ2UvZXJyb3JfbG9nby0xNTB4NTQtMngucG5nKSAwfX1AbWVkaWEgb25seSBzY3JlZW4gYW5kICgtd2Via2l0LW1pbi1kZXZpY2UtcGl4ZWwtcmF0aW86Mil7I2xvZ297YmFja2dyb3VuZDp1cmwoLy93d3cuZ29vZ2xlLmNvbS9pbWFnZXMvbG9nb3MvZXJyb3JwYWdlL2Vycm9yX2xvZ28tMTUweDU0LTJ4LnBuZykgbm8tcmVwZWF0Oy13ZWJraXQtYmFja2dyb3VuZC1zaXplOjEwMCUgMTAwJX19I2xvZ297ZGlzcGxheTppbmxpbmUtYmxvY2s7aGVpZ2h0OjU0cHg7d2lkdGg6MTUwcHh9CiAgPC9zdHlsZT4KICA8YSBocmVmPS8vd3d3Lmdvb2dsZS5jb20vPjxzcGFuIGlkPWxvZ28gYXJpYS1sYWJlbD1Hb29nbGU+PC9zcGFuPjwvYT4KICA8cD48Yj40MDQuPC9iPiA8aW5zPlRoYXTigJlzIGFuIGVycm9yLjwvaW5zPgogIDxwPiAgPGlucz5UaGF04oCZcyBhbGwgd2Uga25vdy48L2lucz4K",
              "ok": false,
              "headers": [
                [
                  "content-length",
                  "1449"
                ],
                [
                  "content-type",
                  "text/html; charset=utf-8"
                ]
              ],
              "status": 404,
              "status_text": ""
            }
          },
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "qyUBQm0hsbza",
        "outputId": "9cd377f5-9d8a-4f0f-affc-616b15817939"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ],
            "text/html": [
              "<img src=\"fig/fig1.svg\" / >"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "S2mgqStGtPJZ"
      },
      "execution_count": null,
      "outputs": []
    }
  ]
}