{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5628e397",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:36.176415Z",
     "start_time": "2021-06-04T03:00:36.168869Z"
    }
   },
   "outputs": [],
   "source": [
    "from IPython.display import display"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1a486a4b",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:36.301047Z",
     "start_time": "2021-06-04T03:00:36.219274Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import numpy.linalg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b46197cc",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:36.435735Z",
     "start_time": "2021-06-04T03:00:36.302148Z"
    }
   },
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "matplotlib.use(\"pgf\")\n",
    "matplotlib.rcParams.update({\n",
    "    \"pgf.texsystem\": \"pdflatex\",\n",
    "    'font.family': 'serif',\n",
    "    'text.usetex': True,\n",
    "    'pgf.rcfonts': False,\n",
    "   'axes.labelsize': 12,\n",
    "   'legend.fontsize': 11,\n",
    "   'xtick.labelsize': 12,\n",
    "   'ytick.labelsize': 12,\n",
    "   'figure.figsize': [4.5, 4.5]\n",
    "})"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "637651db",
   "metadata": {},
   "source": [
    "# Read data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ace7d35e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:36.439550Z",
     "start_time": "2021-06-04T03:00:36.437050Z"
    }
   },
   "outputs": [],
   "source": [
    "def read_rust_output(name, max_sample=None,cols=None):\n",
    "    #data = np.genfromtxt('result/rust_gaussian_mixture/{}.txt'.format(name), delimiter=',')\n",
    "    data = np.loadtxt(f'../rust_experiment/out/{name}',\n",
    "                      delimiter=',',\n",
    "                      max_rows=max_sample)\n",
    "    if cols:\n",
    "        return data[:, :cols]\n",
    "    else:\n",
    "        return data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3e9e5f13",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:36.514230Z",
     "start_time": "2021-06-04T03:00:36.440689Z"
    }
   },
   "outputs": [],
   "source": [
    "unbiased_alg_list=[\"GD\",\"SGD\",\"SVRG\",\"SAGA\"]\n",
    "uldprocess_list=[\"LPMLikeRMM\",\"RMM\",\"OM\"]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "96f566c9",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-05-01T20:52:03.486115Z",
     "start_time": "2021-05-01T20:52:03.479942Z"
    }
   },
   "source": [
    "# Scale"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4f51cb1",
   "metadata": {},
   "source": [
    "## Gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6eef30f1",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:36.585051Z",
     "start_time": "2021-06-04T03:00:36.515793Z"
    }
   },
   "outputs": [],
   "source": [
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1d47dda8",
   "metadata": {},
   "source": [
    "trajectory mean error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "f6ee298d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:39.333985Z",
     "start_time": "2021-06-04T03:00:36.588969Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    for alg in unbiased_alg_list:\n",
    "        samples = read_rust_output(f\"{uldprocess}MS_{alg}_scale4\", cols=4)\n",
    "        samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 1],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((1e-5, 1e-1))\n",
    "plt.xlim((2e2, 1e6))\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "]\n",
    "leg = plt.legend(handles=legend_elements,loc='lower left',\n",
    "                 ncol=2,\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/gaussian_scale4.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/gaussian_scale4.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c6b0613",
   "metadata": {},
   "source": [
    "## australian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4e9789b4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:41.128264Z",
     "start_time": "2021-06-04T03:00:39.335318Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    for alg in unbiased_alg_list:\n",
    "        samples = read_rust_output(f\"australian_{uldprocess}MS_{alg}_scale\",\n",
    "                                   cols=4)\n",
    "        samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 1],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((5e-5, 5e0))\n",
    "plt.xlim((3e3, 1e7))\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "from matplotlib.container import ErrorbarContainer\n",
    "from matplotlib.collections import LineCollection\n",
    "\n",
    "line = Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='GD')\n",
    "barline = LineCollection(None, colors=\"black\")\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "]\n",
    "\n",
    "leg = plt.legend(handles=legend_elements,\n",
    "                 ncol=2,\n",
    "                 labelspacing=0.1,\n",
    "                 loc='lower left',\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/australian_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/australian_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7fc0e67e",
   "metadata": {},
   "source": [
    "## phishing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "7c3a2b3d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:42.793960Z",
     "start_time": "2021-06-04T03:00:41.130000Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    for alg in unbiased_alg_list:\n",
    "        samples = read_rust_output(f\"phishing_{uldprocess}MS_{alg}_scale\",\n",
    "                                   cols=4)\n",
    "        samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 1],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((1e-4, 1e0))\n",
    "plt.xlim((3e4, 1e7))\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "from matplotlib.container import ErrorbarContainer\n",
    "from matplotlib.collections import LineCollection\n",
    "\n",
    "line = Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='GD')\n",
    "barline = LineCollection(None, colors=\"black\")\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "]\n",
    "\n",
    "leg = plt.legend(handles=legend_elements,\n",
    "                 ncol=2,\n",
    "                 labelspacing=0.1,\n",
    "                 loc='lower left',\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/phishing_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/phishing_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "abaac18e",
   "metadata": {},
   "source": [
    "## mushrooms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "5aa83627",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:44.483347Z",
     "start_time": "2021-06-04T03:00:42.796201Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    for alg in unbiased_alg_list:\n",
    "        samples = read_rust_output(f\"mushrooms_{uldprocess}MS_{alg}_scale\",\n",
    "                                   cols=4)\n",
    "        samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 1],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((1e-4, 1e0))\n",
    "plt.xlim((3e4, 1e7))\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "from matplotlib.container import ErrorbarContainer\n",
    "from matplotlib.collections import LineCollection\n",
    "\n",
    "line = Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='GD')\n",
    "barline = LineCollection(None, colors=\"black\")\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "]\n",
    "\n",
    "leg = plt.legend(handles=legend_elements,\n",
    "                 ncol=2,\n",
    "                 labelspacing=0.1,\n",
    "                 loc='lower left',\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/mushrooms_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/mushrooms_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "459f8b53",
   "metadata": {},
   "source": [
    "## german"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "f82d2679",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:46.144862Z",
     "start_time": "2021-06-04T03:00:44.485612Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    for alg in unbiased_alg_list:\n",
    "        samples = read_rust_output(f\"german_{uldprocess}MS_{alg}_scale\",\n",
    "                                   cols=4)\n",
    "        samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 1],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((1e-4, 1e0))\n",
    "plt.xlim((3e4, 1e7))\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "from matplotlib.container import ErrorbarContainer\n",
    "from matplotlib.collections import LineCollection\n",
    "\n",
    "line = Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='GD')\n",
    "barline = LineCollection(None, colors=\"black\")\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "]\n",
    "\n",
    "leg = plt.legend(handles=legend_elements,\n",
    "                 ncol=2,\n",
    "                 labelspacing=0.1,\n",
    "                 loc='lower left',\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/german_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/german_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ad151712",
   "metadata": {},
   "source": [
    "# Effect of batch size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "55afa828",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:47.756148Z",
     "start_time": "2021-06-04T03:00:46.146675Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(5*fig_scale,3.5*fig_scale))\n",
    "#plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess !=\"OM\": continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg not in [\"SGD\",\"SVRG\",\"SAGA\"]: continue\n",
    "        if alg !=\"SVRG\": continue\n",
    "        for batch_size in [1,5,10,40,100,200]:\n",
    "            samples = read_rust_output(f\"australian_{uldprocess}MS_{alg}_{batch_size}_scale2\", cols=4)\n",
    "            samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "            if numpy.isnan(samples).any():\n",
    "                print(f\"{uldprocess}_{alg}\")\n",
    "            plt.errorbar(samples[:, 1],\n",
    "                         samples[:, 2],\n",
    "                         samples[:, 3],\n",
    "                         label=f\"b={batch_size}\"\n",
    "                        )\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "#plt.ylim((1e-2, 5e0))\n",
    "#plt.xlim((5e3, 3e5))\n",
    "plt.ylim((1e-4, 5e0))\n",
    "plt.xlim((5e3, 2e6))\n",
    "leg = plt.legend(loc='lower left',\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/batch_svrg.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/batch_svrg.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "05ac6111",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:49.159326Z",
     "start_time": "2021-06-04T03:00:47.757928Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "#plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess !=\"OM\": continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg not in [\"SGD\",\"SVRG\",\"SAGA\"]: continue\n",
    "        if alg !=\"SVRG\": continue\n",
    "        for batch_size in [1,5,10,40,100,200]:\n",
    "            samples = read_rust_output(f\"australian_{uldprocess}MS_{alg}_{batch_size}_scale2\", cols=4)\n",
    "            samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "            if numpy.isnan(samples).any():\n",
    "                print(f\"{uldprocess}_{alg}\")\n",
    "            plt.errorbar(samples[:, 1],\n",
    "                         samples[:, 2],\n",
    "                         samples[:, 3],\n",
    "                         label=f\"b={batch_size}\"\n",
    "                        )\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "#plt.ylim((1e-2, 5e0))\n",
    "#plt.xlim((5e3, 3e5))\n",
    "plt.ylim((3e-2, 5e0))\n",
    "plt.xlim((5e3, 1e5))\n",
    "leg = plt.legend(loc='lower left',\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/batch_svrg_small.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/batch_svrg_small.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0f6ec659",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:50.816704Z",
     "start_time": "2021-06-04T03:00:49.161152Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(5*fig_scale,3.5*fig_scale))\n",
    "#plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess !=\"OM\": continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg not in [\"SGD\",\"SVRG\",\"SAGA\"]: continue\n",
    "        if alg !=\"SAGA\": continue\n",
    "        for batch_size in [1,5,10,40,100,200]:\n",
    "            samples = read_rust_output(f\"australian_{uldprocess}MS_{alg}_{batch_size}_scale2\", cols=4)\n",
    "            samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "            if numpy.isnan(samples).any():\n",
    "                print(f\"{uldprocess}_{alg}\")\n",
    "            plt.errorbar(samples[:, 1],\n",
    "                         samples[:, 2],\n",
    "                         samples[:, 3],\n",
    "                         label=f\"b={batch_size}\"\n",
    "                        )\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((1e-4, 3e0))\n",
    "plt.xlim((1.3e3, 2e6))\n",
    "leg = plt.legend(loc='lower left',\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/batch_saga.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/batch_saga.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "952be718",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:52.243710Z",
     "start_time": "2021-06-04T03:00:50.818372Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "#plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess !=\"OM\": continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg not in [\"SGD\",\"SVRG\",\"SAGA\"]: continue\n",
    "        if alg !=\"SAGA\": continue\n",
    "        for batch_size in [1,5,10,40,100,200]:\n",
    "            samples = read_rust_output(f\"australian_{uldprocess}MS_{alg}_{batch_size}_scale2\", cols=4)\n",
    "            samples = samples[samples[:, 1].argsort()[::-1]]\n",
    "\n",
    "            if numpy.isnan(samples).any():\n",
    "                print(f\"{uldprocess}_{alg}\")\n",
    "            plt.errorbar(samples[:, 1],\n",
    "                         samples[:, 2],\n",
    "                         samples[:, 3],\n",
    "                         label=f\"b={batch_size}\"\n",
    "                        )\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation Number\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((1e-2, 3e0))\n",
    "plt.xlim((1.3e3, 1e5))\n",
    "leg = plt.legend(loc='lower left',\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/batch_saga_small.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/batch_saga_small.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c6a034fe",
   "metadata": {},
   "source": [
    "# step size dependency"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "20b0381c",
   "metadata": {},
   "source": [
    "## australian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "8e8e7081",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:53.824295Z",
     "start_time": "2021-06-04T03:00:52.245149Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 302.4x176.4 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 1.0\n",
    "fig_scale = 0.7\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(6 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    #if uldprocess != \"RMM\": continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg != \"GD\": continue\n",
    "        #if alg not in [\"SVRG\",\"GD\"]: continue\n",
    "        samples = read_rust_output(f\"australian_{uldprocess}MS_{alg}_scale3\",\n",
    "                                   cols=4)\n",
    "        samples = samples[samples[:, 0].argsort()[::-1]]\n",
    "\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"OM\": \"dashed\",\n",
    "            \"LPMLikeRMM\": \"dotted\",\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        coeff = {\n",
    "            \"OM\": 1.5,\n",
    "            \"LPMLikeRMM\": 1,\n",
    "        }\n",
    "        plt.scatter(samples[:, 0],\n",
    "                     samples[:, 2],\n",
    "                    15,\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     color=colors[uldprocess])\n",
    "        if uldprocess !=\"RMM\":\n",
    "            xx=np.log(samples[:,0])\n",
    "            yy=np.log(samples[:,2])\n",
    "            m = np.mean(yy-coeff[uldprocess]*xx)\n",
    "            nyy=m+coeff[uldprocess]*xx\n",
    "            plt.plot(samples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         linestyle=linestyles[uldprocess],\n",
    "                         color=\"black\"\n",
    "                    )\n",
    "            \n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Step size\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.ylim((None, 1e0))\n",
    "plt.xlim((None, 1e0))\n",
    "plt.gca().invert_xaxis()\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "from matplotlib.container import ErrorbarContainer\n",
    "from matplotlib.collections import LineCollection\n",
    "\n",
    "legend_elements = [\n",
    "    Line2D([0],[0],color=colors[\"LPMLikeRMM\"], label=r\"LPM\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=colors[\"RMM\"], label=r\"RMM\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=colors[\"OM\"], label=r\"ALUM\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"OM\"], label=r\"$O(h^{3/2})$\"),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"LPMLikeRMM\"], label=r\"$O(h)$\"),\n",
    "]\n",
    "\n",
    "leg = plt.legend(handles=legend_elements,\n",
    "                 #ncol=2,\n",
    "                 labelspacing=0.1,\n",
    "                 loc='lower left',\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/australian_step_scale_small.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/australian_step_scale_small.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "04714c52",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:55.742216Z",
     "start_time": "2021-06-04T03:00:53.825912Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    #if uldprocess in [\"ILSDELIKERMM\"]: continue\n",
    "    #if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg in [\"SVRG\"]: continue\n",
    "        #if alg in [\"GD\"] and uldprocess == \"RMM\": continue\n",
    "        #if uldprocess == \"OM\": continue\n",
    "        #if uldprocess == \"ILSDELIKERMM\": continue\n",
    "        #if alg in [\"SAGA\", \"SGD\"]: continue\n",
    "        samples = read_rust_output(f\"australian_{uldprocess}MS_{alg}_scale\",cols=4)\n",
    "        samples=samples[samples[:,0].argsort()[::-1]]\n",
    "        csamples=samples[samples[:,0]<3e0]\n",
    "\n",
    "        #plt.plot(samples[:,0],samples[:,1], label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 0],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "        if uldprocess in [\"OM\",\"LPMLikeRMM\"] and alg==\"GD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-coeff[uldprocess]*xx)\n",
    "            nyy=m+coeff[uldprocess]*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"blue\" if uldprocess==\"OM\" else \"green\"\n",
    "                    )\n",
    "        if uldprocess in [\"OM\"] and alg==\"SGD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-0.5*xx)\n",
    "            nyy=m+0.5*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"black\",\n",
    "                    )\n",
    "            \n",
    "#plt.plot(samples[:,0],np.exp(5+3.0/2.0*np.log(samples[:,0])))\n",
    "#plt.plot(samples[:,0],np.exp(1.0/2.0*np.log(samples[:,0])))\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Step Size h\")\n",
    "plt.ylabel(\"Trajectory Mean Error\")\n",
    "plt.ylim((1e-4,1e1))\n",
    "plt.xlim((3e-3,2e0))\n",
    "plt.gca().invert_xaxis()\n",
    "#plt.legend(loc='upper right', frameon=False)\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "    Line2D([0],[0],color=\"w\"),\n",
    "    Line2D([0],[0],color=colors[\"OM\"], label=r\"$O(h^{3/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=colors[\"LPMLikeRMM\"], label=r\"$O(h)$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=\"black\", label=r\"$O(h^{1/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "]\n",
    "leg = plt.legend(handles=legend_elements,loc='lower left',\n",
    "                 ncol=3,\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/australian_step_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/australian_step_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74055d30",
   "metadata": {},
   "source": [
    "## phishing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "0a688f3d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:57.563026Z",
     "start_time": "2021-06-04T03:00:55.743765Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    #if uldprocess in [\"ILSDELIKERMM\"]: continue\n",
    "    #if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg in [\"SVRG\"]: continue\n",
    "        #if alg in [\"GD\"] and uldprocess == \"RMM\": continue\n",
    "        #if uldprocess == \"OM\": continue\n",
    "        #if uldprocess == \"ILSDELIKERMM\": continue\n",
    "        #if alg in [\"SAGA\", \"SGD\"]: continue\n",
    "        samples = read_rust_output(f\"phishing_{uldprocess}MS_{alg}_scale\",cols=4)\n",
    "        samples=samples[samples[:,0].argsort()[::-1]]\n",
    "        csamples=samples[samples[:,0]<3e-1]\n",
    "\n",
    "        #plt.plot(samples[:,0],samples[:,1], label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 0],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "        if uldprocess in [\"OM\",\"LPMLikeRMM\"] and alg==\"GD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-coeff[uldprocess]*xx)\n",
    "            nyy=m+coeff[uldprocess]*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"blue\" if uldprocess==\"OM\" else \"green\"\n",
    "                    )\n",
    "        if uldprocess in [\"OM\"] and alg==\"SGD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-0.5*xx)\n",
    "            nyy=m+0.5*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"black\",\n",
    "                    )\n",
    "            \n",
    "#plt.plot(samples[:,0],np.exp(5+3.0/2.0*np.log(samples[:,0])))\n",
    "#plt.plot(samples[:,0],np.exp(1.0/2.0*np.log(samples[:,0])))\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Step Size h\")\n",
    "plt.ylabel(\"Trajectory Mean Error\")\n",
    "plt.ylim((5e-3,1e1))\n",
    "plt.xlim((5e-3,3e-1))\n",
    "plt.gca().invert_xaxis()\n",
    "#plt.legend(loc='upper right', frameon=False)\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "    Line2D([0],[0],color=\"w\"),\n",
    "    Line2D([0],[0],color=colors[\"OM\"], label=r\"$O(h^{3/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=colors[\"LPMLikeRMM\"], label=r\"$O(h)$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=\"black\", label=r\"$O(h^{1/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "]\n",
    "leg = plt.legend(handles=legend_elements,loc='lower left',\n",
    "                 ncol=3,\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/phishing_step_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/phishing_step_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb58d319",
   "metadata": {},
   "source": [
    "## german"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "bc23beef",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:00:59.560473Z",
     "start_time": "2021-06-04T03:00:57.564583Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    #if uldprocess in [\"ILSDELIKERMM\"]: continue\n",
    "    #if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg in [\"SVRG\"]: continue\n",
    "        #if alg in [\"GD\"] and uldprocess == \"RMM\": continue\n",
    "        #if uldprocess == \"OM\": continue\n",
    "        #if uldprocess == \"ILSDELIKERMM\": continue\n",
    "        #if alg in [\"SAGA\", \"SGD\"]: continue\n",
    "        samples = read_rust_output(f\"german_{uldprocess}MS_{alg}_scale\",cols=4)\n",
    "        samples=samples[samples[:,0].argsort()[::-1]]\n",
    "        csamples=samples[samples[:,0]<3e0]\n",
    "\n",
    "        #plt.plot(samples[:,0],samples[:,1], label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 0],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "        if uldprocess in [\"OM\",\"LPMLikeRMM\"] and alg==\"GD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-coeff[uldprocess]*xx)\n",
    "            nyy=m+coeff[uldprocess]*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"blue\" if uldprocess==\"OM\" else \"green\"\n",
    "                    )\n",
    "        if uldprocess in [\"OM\"] and alg==\"SGD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-0.5*xx)\n",
    "            nyy=m+0.5*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"black\",\n",
    "                    )\n",
    "            \n",
    "#plt.plot(samples[:,0],np.exp(5+3.0/2.0*np.log(samples[:,0])))\n",
    "#plt.plot(samples[:,0],np.exp(1.0/2.0*np.log(samples[:,0])))\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Step Size h\")\n",
    "plt.ylabel(\"Trajectory Mean Error\")\n",
    "plt.ylim((1e-4,1e1))\n",
    "plt.xlim((3e-3,2e0))\n",
    "plt.gca().invert_xaxis()\n",
    "#plt.legend(loc='upper right', frameon=False)\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "    Line2D([0],[0],color=\"w\"),\n",
    "    Line2D([0],[0],color=colors[\"OM\"], label=r\"$O(h^{3/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=colors[\"LPMLikeRMM\"], label=r\"$O(h)$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=\"black\", label=r\"$O(h^{1/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "]\n",
    "leg = plt.legend(handles=legend_elements,loc='lower left',\n",
    "                 ncol=3,\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/german_step_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/german_step_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d8bd4e95",
   "metadata": {},
   "source": [
    "## mushrooms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "b1b5a6ee",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:01.367611Z",
     "start_time": "2021-06-04T03:00:59.561719Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    #if uldprocess in [\"ILSDELIKERMM\"]: continue\n",
    "    #if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg in [\"SVRG\"]: continue\n",
    "        #if alg in [\"GD\"] and uldprocess == \"RMM\": continue\n",
    "        #if uldprocess == \"OM\": continue\n",
    "        #if uldprocess == \"ILSDELIKERMM\": continue\n",
    "        #if alg in [\"SAGA\", \"SGD\"]: continue\n",
    "        samples = read_rust_output(f\"mushrooms_{uldprocess}MS_{alg}_scale\",cols=4)\n",
    "        samples=samples[samples[:,0].argsort()[::-1]]\n",
    "        csamples=samples[samples[:,0]<3e-1]\n",
    "\n",
    "        #plt.plot(samples[:,0],samples[:,1], label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 0],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "        if uldprocess in [\"OM\",\"LPMLikeRMM\"] and alg==\"GD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-coeff[uldprocess]*xx)\n",
    "            nyy=m+coeff[uldprocess]*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"blue\" if uldprocess==\"OM\" else \"green\"\n",
    "                    )\n",
    "        if uldprocess in [\"OM\"] and alg==\"SGD\":\n",
    "            xx=np.log(csamples[:,0])\n",
    "            yy=np.log(csamples[:,2])\n",
    "            m = np.mean(yy-0.5*xx)\n",
    "            nyy=m+0.5*xx\n",
    "            plt.scatter(csamples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"black\",\n",
    "                    )\n",
    "            \n",
    "#plt.plot(samples[:,0],np.exp(5+3.0/2.0*np.log(samples[:,0])))\n",
    "#plt.plot(samples[:,0],np.exp(1.0/2.0*np.log(samples[:,0])))\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Step Size h\")\n",
    "plt.ylabel(\"Trajectory Mean Error\")\n",
    "plt.ylim((5e-3,5e0))\n",
    "plt.xlim((5e-3,3e-1))\n",
    "plt.gca().invert_xaxis()\n",
    "#plt.legend(loc='upper right', frameon=False)\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "    Line2D([0],[0],color=\"w\"),\n",
    "    Line2D([0],[0],color=colors[\"OM\"], label=r\"$O(h^{3/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=colors[\"LPMLikeRMM\"], label=r\"$O(h)$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=\"black\", label=r\"$O(h^{1/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "]\n",
    "leg = plt.legend(handles=legend_elements,loc='lower left',\n",
    "                 ncol=3,\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/mushrooms_step_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/mushrooms_step_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b18eb00e",
   "metadata": {},
   "source": [
    "## gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "7af800c1",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:03.109606Z",
     "start_time": "2021-06-04T03:01:01.369181Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAagAAAD0CAYAAADOibL4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABpl0lEQVR4nO2dd3gUVReH39n00EIvUhORKiUEESyABFCUKBCaWNBPEzWIPdjFghBQQSmSCGKnBSEBRUiUKp1Il5bQewKhhYQke74/7u6STpBNv+/z7ENm5s6dO8Punj3nnvs7hoig0Wg0Gk1xw1TUA9BoNBqNJie0gdJoNBpNsUQbKI1Go9EUS7SB0mg0Gk2xRBsojUaj0RRLHIt6AHlhGIYH4GvZjBGRuCIcjkaj0WgKkeLuQQUA0SISDowo6sFoNBqNpvAodA/K4hUFAIkiEpZhvz+QCHgAcSISA7QXkbGWJp7X67tatWrSsGFDO49Yo9FoNDfC5s2b40Wk+s32UxQhPp+sOyxGq7uIBFq2o4DuN9pxw4YN2bRp000PUKPRaDT/HcMwDtmjn0IP8YlINMpTysgAIDbDdqJhGN7ARovxAtDzTxqNRlOGKC5JEh5kNlpngSpAGDDAMIyzQGhOJxqGEYAKGVK/fv0CHaRGo9FoCo/iYqBywkNEElFGKlcs81hhAD4+PlpYUKPRaEoJxSWLLxHlRVmpgg7paTQaTZmmuBioOYBXhm0PSxafRqPRaMooRZFm7ovK0PMwDCNORKJFJNEwjCjLMYCQwh6XRqPRaIoXhW6gLFl80TnsDy/ssWg0Go2m+FJcQnx2Yf/p3ZCUVNTD0Gg0Go0dKFUGqtbJy5ysV+Xaju++g7AMSYDp6YU+Jo1Go9H8N0qVgTpeDkZ4XiUyMhKALZPe5cCUT6818PWFvn2vbc+ZA6tWFfIoNRqNRpMfSpWBuph4Oz9sWszSpUsB+CRgMNM++B8AIsLkusdZ3byCrX36Y49xoWdPm0HD1xdCMuRnrF0Lp08X2vg1Go1Gc41SZaBAcHT8lx49egCQMHMc0WPeA+By6mXCKj5NZP1BAMyaP4tqQak09b/C4MGDmfPrbE64pXPJzUF1lZYGnTvD+PFq22yGRx+FaEt+x8WLMHz4NQ/s/HkYMQI2bFDb587BBx8oI6fRaDSaG6ZUGajq1U8xb54nfn5+ALz3HowcqY6Vdy5P4qIRHF/5AACLli8iceFvnFi+lKSkJMJXzqOONGFKjTsA2HZqG48+dg9r7m0HwKlDu7gQMZcDg/opjys5GX76CfbuVRe4eBG++gp27lTbZ8/CRx/BM8+o7X37oH17WLNGbael6TkxjUajyYPiLHV0w9SvX99mnADuuy/z8V27lB0B6NdlAD9/1QlIwN3dnX73+vPrZH9ONEuGQZBmmJj5XRSVKifQ6QEYv3wWIW7bwfkU7oN78U7oeyx/9VW+6tmLpkB6ndqYkpIwDENdwMtLeV1iUV+6dAkqVgQPD7W9eDEMGQKrV0OrVhAfD1euQN26YO1Do9FoyjClykBdj3Ll1AugTx8/IiIiWbp0KT16zKR3bz96nAaTyR2AVjXa8MP30LKlKmlyet15uOwM5yqSZE7ijxU7WTXtRxZ7JNF0GIQs/ZaPR7qwZMIj3HtnRXaf2cvv0b8R+/d+evboqQznn39eG0zduvD448qQAfzwA7z2GnTsqLysNWtg/34VVnQsU/9NGo1GoxCRUvNq166dFBQRERHi7u4ugLi7u8ucOYtk8WKRw4fV8a8j1otLhUuyZIlZREQ6vvaa4HRRqLxZ3N3d5Znx78iTn/8gly+r9mazOfMF9uwRmT792vYLL4h4eIhY2332mchTT107fvHitWMajUZTjAA2iR2+0/VP83zi5+fHzJkzLR5XD/z8Hsx0/Dm/Owg8f227+kkHcNsL55JJIonF0ekc++1xgu+H5s2h2ycjiVvTmpif+1KlCqxzP0tM+WR2DRum+v/ySwgOvhbuu3ABEhKuXWDIEDh1CtatU9vHjkHt2mAqVdOKGo2mDKMN1A3g5+eXaY4rKxmnjv434C6i599DEkm4u7sz9tF7qPaSmdtuUwakxuUu/L3iLtzcVPsHA//i7Lq+0OtVZgyewa3/+x+NXLqzYFwDAH7p7YPX04/QwdK/DByIkVE1o1s3NZc1Z47avnQJype3161rNBpNoaMNVAGR3ePqlen4rDFdMX96zeFphit/XwF++oMkunJoVSdiD94H49Txp4POYdp7L0nn1Hbl2ftpbOrOezUiWbpkCR3vacUDD/ahCqhki1q1VJr7G2+oRA2zGRwcCuv2NRqN5qYpVQbq8GGIjIQ8nJxC5XoeV8ZoXHDgrQxe3s7mcU1/txx3313OdjxsRA+OHzYDat7wNpd7SdxfiT59UjG79GTyLY7UXlOX44/A1SuX+OMRP7xbeVIXVLLFnXfCzJnQo4dKbzeZdLagRqMp1pSqCYszZ2DwYGWkShpWjysoKIiZM2fSr19vata8dvyJvrV48+XKABiGwYY5XejRaQpmc2dIeRjOzKdBzc0A7Eg5wsO/f8yjk30AOHb+KLMa38V+Dxfib7+d49Wrc7VSJdi9W3V++jQcPHgtJV6j0WiKAaXKQOGYRFISWJSOShx+fn5MmjQpT68rIz169MDd3R3M4J76C2+9XBWAtrW8+eKTarwWoCzcRpdUBm+cx/OfulPzjl343XuZIW4BfBKpakLGT/4cadSIK6eOqY7Xr4d58/RCYo1GU6SULgPlch7HVnPp7Fs2Sm5k9bqshs0w4JUXKvHwQ64A3N+4BzNnGlR1W4L52z/ZvHkK4ac/IzoqGYBvqlbH0XSF2X95APD3yE95+9HtbNuTTGRkJNO7dmT9QD9Ee1gajaYwsUeuenF5mWgjIFLJbb9UumucdP7kDVl9YM3NpPOXKjKu5XJzqyWzZy8SEZEd+87JkMCjsn27avdB2G8CIh99tFqotUyCa/pLVdMxCRn3l4iI/PtwH1nfd+C1ji9eLOxb0Wg0xRjstA7KkFL0q9hkeIsQY9kSwKCu6xZkpB/3N+tBY4+m9GnhR+Mqja9JEpUxIiMjM2QW5h5KTE6GV14ZztSpE6FSGzC/wlP+//Ltt6MJuv1NpuwYw/79SghjXe2O7GrozeMrJ7N4cSR7f/iB5v7+9Bo0qPBuTKPRFBsMw9gsIj433ZE9rFxxeYG33Nf+IenqtlQqcF7ALCBiIk3qG3vE1bgkdWr/KuX8h0q30L7i1P0DcWq8TCIibua3Quklq3pGhOVBbd2eIm9/nCDp6SJiNkvPFt+Ig+mqhIcvlJWGIfOMh+Thyi/LggURImazJP3yg8jJk3leJygoyNa/RqMp2WAnD6rIjYo9XybaiPsod4nYrb7o9kb+K881+VPqORyxGatrRitV6pZbJxX6PiDO7b+Xb+YckH0J+27iv6R0kh/jkZAgsnq1WYKCgsQBpHb1aeLkvFeCgoIkffe/8j4jpbf3r6rx2bOyZ+QrcvHAXlv/ORlBjUZTcrGXgSpVIb4ajWvItEXT8GuSPXSVFJ/E1KfWsWl9Oivjm3FM6gJQmyO0avQVR+oc5khaM9J8ounduS6vdHyZO265A5NRuvJICpLIyEgGDx5MUlISbm41mDXrG3r0uI+HHozBya0hixfVJ2HeT/Tzr4vR0ZVla+7kgyH9SfjzH2ZdPkzCpVSCgoKYNGnSda+TnzClRqMpGnSIL4fXjYjFvvL4IrmDteLFbotndc27quRwUiq3mCQOj/eSMSvGSkpqSr77Letcz+NKSrks//vfZhk1VoX8Fj3TT6pzSqpV2Cju7u7y5wtPyLe1H5NN63aoE44eFTlwwCaMqz0ujab4g508qDLrHlwdtJg9NCWemnj0eIIetSJxQ6Wnn0+vybmdL+D041x2vDwXjw9cKPdCN4wXWmL0eI2EpITr9F52ud5aLjdnd6ZN8+btN9QarfunhtM/6B/u6v4nM2fOJLWeF0+f+JGZC9Xxfz94g4+9vmFdzBkATkydyrMWDcKkpCSW5mPRW2RkJMOGDVOFJjUaTcnBHlauuLxuxIOK2B0h7qPchZFkmrf6c9Yp6XnLNnHlss2zKs95ceaKmEiVSvUWCo8+KE2/aiE/bPkh39fT5I/UVJE161Lk0CHlMX0xdpqAyKw5V0VEZHa7rjLAaZpMN5qIu7u77H/gfpH+/a91sHevmhSzoD0ujabwQSdJ3JyBElFGKui3IJtxysrS8PPSveFeceGKzVhZ/3Ytd0AcHu0jb0a9KVtPbpWxq8fKv2f+vaHra/JHQoLY6mi99vVv4uR+TgYN+kQiIiLk3W7PSfMqK+TgQXX8ik9bSet8r+3c2ffcIw+qNQcCSFBQ0HWvp7MKNZqbw14GqlQlSfj4+MimTZsKpO9HA7exLQyOUZdEquBIKoMrTWbh86+RmNQALtSDBitpVLkRg1oOok/TPvjU8Smz660KEutb1jDg1a+WM3dKU3ZvrkW5cnB31zHs2jqIw4cbUr48HK5Sn+RLxzmems6D7u4cbNyY6s88A8OGqU7OnIFq1WzCuRkTPdzd3TMpdGg0mvxhrySJMjsHdaNsP36WnbQikSo04V/MGPx4/mVuG7eeu76fDt+tgCk7OLDkQUZHT+aOaXdw+5Tb6fJdF1LTU4t6+KUKw7gmxP7F8C4c2a2ME0CX/r607+ZA+fIW1fdbP6K1+3HmvhDErB9/5E9zYxbssfx/WMuSfPqp2k5L4+zEiXjoOS6NpnhgDzesuLwKsuT721PWCU6XVKjP6ZK8Pn69hL5zUBq5nxQQcSRFanDSdpwO44WRCCOR5pOaS6spreSLNV/IqUunCmyMmsyYzWaZ/HOsvDv6hIiIXEi+ICbP5VKv2TEREbl89pTcf/tIef05JfmUumObCMjTzk4CSBNXVzneoYPIxo2qwytXRM6csWUUiug5Lo0mJ9Al3wuXUc93ANYT+fsV/Hq5Wbbh6ZHw4oOxfLu0LqepiSOpNEw9TqNzdYg6fwtUOMau5S2g8e+8evpV3oh6g16Ne/Gs97P0btK7KG+p1GMYBi886mnbruBSgT1L7+FMgvKgEh3TWJ88kJTjlQDYU9nMHbWX49PmEkGei+nVsBbnJy3A7VICHgCrVql6WsuXQ+fO8O+/MHo05ZKSSAKMpCTWzZ+P34MPXrc4pF7LpdHkA3tYueLyKkgP6nqkpoq80f+AuFmy/xxIlQdYJP7GNwIihssFMbX/WghsLYxE6n1RT3af2S0iIttObhNzhl/lmsIlNVX9e/LiKenkt1PGfBkvIiJzty0QHK7IE0HK49q+bpG82eMD2b7Jojjy3XciIOsMQ5aBBDk7i4DIMdVeJk0ScXERiVf9ybRpIk2byqJZs8Td3V16gUxxdJSFc+eq48ePixw8mMlD02hKIhSmB2UYRkURuVDAtrJE4+gIY+c0ZIwZPn3uMCHTKrNYHgRJ5w7WUqFcOn9vDyB543M41NvMkUcG0nRyU26tciv7z+6nkUcjnvd5niGthlCnQp2ivp0yhaPlU1CzfA3+jqhh29+90QO8M/ok999VC4DfTicxZulIqj10iZbt4OtGboy/fyaBD5TnwN4/uP+2Blx1dMW5siosSZs28PLL2CbIatSAVq1Yunw5SUlJNAP6pqXx8bJlPOTvD+PHw1dfqbkxgClTYO1a+PFHIiMj2RweTidfX3o+8UShPBeNpqjJb5LENMMwGhbkQEoLJhO8G1afJ1+oQH3i8OA8G+jIxrMteTH5c0bdPpM7a99O7LurGN9zPBd23QEnWnMg8QDB0cHc8sUt1BhXg52ndwKQZk4r4jsqu1Qq78wnb9Tn7k7OALx6f3/WrLvKYwPKA3A0rhz7o/rxw9Fodvjs4Purzri+9yCbdqo6XFOunOXJCp04n6K2r/bqCbNn0+2BB3B3d+dzwNPdnR49e6oLPvoozJhxLQPk3Dk4dYrIyEg8+vQh6McfaTp06LVkjEWL4K+/Cu15aDSFTn7cLKAb0CbLvmfs4cLZ81WUIb6sRESIuLuriE9Vp3PSo8Y/ttBfZ2O5nJi5TMRsltatVRu3htsEv6eFt9XiYYcPHaTt1LbS9buuUveLujJk3hCZunGq7Dy9U4cDixHJySJX1RpiCY3cJO2675PDh9X23cNDBdTaYRGRO18dK+Ua7JRjx1RyRcvBz0rr3r9KikVJK3DiL9Lz6XWSlqa2nxk/Sx54erMEBQUJILc17CpNPUbY1nL91ai3zGgabBvL6idek6XB00RE9f/YcwEyM3xugT8DjSYrFOZCXWA/sATYZPl3KZBgjwHY81WcDJSIMlJBQWIr57Fx2UVp4HpCDNLFhSsSUHm2LK77jHz5+iGpXP+4ygA0pQg9XhHXj11tWYCMRJw/drb93WB8A0k3p4uIyLELx2x/a4oXly6JbNh01WbAXpv4lzS945BcuaK2Ww75XkC1ExG5rf8MwUi3GawGD88Qk2PqtUzB1iGCw2VbpmDVu6aLs9sl2/X6l/taPJzjJSIiQkxPm+RhtzAp53jM1v6OzpOkfbdttvYDP5otb4zdaduOWLdVjsdfKKCnoSlL2MtA5WuhrmEY/URkXpZ93UTkT/v5cjdPQS7UtSf7d6UwJvAgM1Z7YcaBxuxjnMfbjDL6sjG1M84Pv8Lc9x6jbtq9+D9+Hqdmv2G+bQH7iQLAwXDgsVaP0dOrJ88ufJZUcypPt3maR5o+QtdGXXF2cC7iO9Tkh4wfveut546MjGTJkqXcd9/99Ov3EAA7D5zmQqIjHdtWAeCXP7eSFF+JLas+45vJkxlW/n5WSiM6DDUxafRoPqo4jjWNu/HH3s6kX0miTe1lXKjYkkOHG+B+699c4SIeV5tw7nAj0sxpPPrhArrf7s2z/p55DU2jyYa9FurmW0nCMIyKgC9QBYgWkYM3e3F7U1IMlJX1K5MJ7HOGrWdV6Y96HGYswZwc8SAvj3mCv/+GwEDYqaajaNbyKs7N/8C5Uyj7k9dyLvmcrS+TYcIsZiq5VOLde9/l9U6vF8UtaYoBOaph9OwJy5apEsiNG0NsLGne7bn4xRRWVXfn3UED+DS5Ix+Xr8I7Pz1Jq9rudLq7Pp5t01i9rjlH92zEr9dRuvk3YlxIG65eOMf5gyep3rKJmnjVaDJQqEoShmF0A8YCXkBlYKxhGPfd7MXLOh3udWVLQj22/5NOq8pHOEJ9BjOb4JBB+Jg2s+Xh94l58D327Ujhs8+gWmVnds334/chv3HmjTMM9ZiBEdcd0h0wixmA8ynnGbdmHK8seYUNRzfw0C8PMT1mOqcvny7iu9UUFn5+fsycOZOgoKBrUk0uLnD//co4AXh54ZiYQOWh/Vm6dCmXrqQQJ8u5fPFXli5dSkNTZfbUH8CPI9SPoKv/xFA1rjxpx1TSzvbZU2jUuh73tlAZhpvWRdCkySqmfnsMgP3xB3j+k3Vs3n4JgOTUqyReSCOfv4c1GkV+4oBAv/zsK+pXcZuDuhGCgkQgXW7hkFTknK02lQtXZCgz5NeGL8uZFz+U86eTbefUb7dDzVs5JAudQsTrHT+pP76+GCMN23yV9W/Thya559t75Is1X8iZy2eK8E41xY18qWGkpIgcPizWCbTpX4ZIh2pvirNLF3F3d5df+/tJG2Jk3MexIiLyw6RRAiIffKqUU8b98aOASMeu30lERIR88ccccap2SH6cpebQwv76XWp5b5Sov9T7e9aaldKh/0pZt0EtUruUfEXS0nRyUEmBQq4HdS6f+zT/kR49wN3dxDHqk+buwfTpBi8POM7dNfexwHiEvgfHU33ie3StsYNv7prBybBIJozbhvOjg+HWxbDuFWJHRXDf1kMkvZPE1w9+Tad6nWzzUWYxs+bIGl5d+ip3Tb+riO9WU5zI0ePKirMz1KsHriplPmbvYdbHj+FqilrT9XelGvwTfZbX31XzVf7bDrOnXCuef0qpdNSdv5pO1UawdtUEBg8ezJG9B6jd7CB1aqlFaPEXLnE+3o20q0qBY8XOPayf78OFRLUd+PW3OLpdYdnydAAiNm5gZOhmLl4s0EejKWryY8WAfsDrwH2W1+voNHO7kzXrz8rVqyIzx5+QNhX2SR3nM5bSH+lSngvSk99lo+l2+X7VbzJhgohVlCAxUWTAAJHISJED8Udl2uZp0mJyC5tn1T6svTz080Py3T/f6SxAzQ1zXa8rNVVk3z7b5mYvL7kAssxS9mRFy5YiL754rf3Ro9fy9TNcw1r25JslK+WuAetsIh3th30lIPKvpcLN4599L827bZLTp9W2fk8XLRR2PSigLTAV+Bq4zx4Xt/erpBuo/GA2i2zddFUGe60Tdy7ZStXfxm6JvHuMrXDS2rUi1aur/+EaNUReeUXky4hl2dLXGYk0mtBIomOji/jONCWNG6mbFRERITXc3GwGbb+fn8jrr19r0KKFiJ+fbTPmxRflXheXXA3g4dNn5ZffDthkqu575TtxrxYvSUlq22vwRKneONaW0n8y8exN3avmxrCXgcpvmnmJkDoqaVl8N40IXzy1jbAf3dhjbgwY1OAUb92+iOFLHiK9Wk0WL4bvv4eFCyE1FXjxVqgaC0CtcrU4efmkrbv2ddozb8A86lWqVzT3oynV5CmQO3s2eHhAz55gNpPi4sKUtDRetRw+VqUKdT78UNXxEoFZs+COO1RWYg79f78+jSObb2fDH40REdw6/EzFhC6cjlUZs9Fbd9GpSWPcXZ0K5+bLGPbK4suv9zQHaGgPi1iQr7LgQWUko1pFHadTcmflf8UgXUDEnUsyokqopO7cIyKqSsRrn20SU6MVQoNl4thxsgx4fres2rFPfEJ9bN6U1wQvWXVolQ6RaIqU337+WRpYPC4PNzc5cu+9IrNnq4MJCepN//nnavvcOblwyy3yqLOzAFLFzU3WvfOOWON9KWkp8viHi+WZYBVyjL8cL9RfIY1aHxIRkeTUZPl87grZfySx0O+ztEIhK0kUmdQR4AF4A8GAb15ty5qBUpl/115BQeqzO+T2LeJEioBIAw7IuOqj5di4n0RElbl/YeEw6dTzmBiGiLOzyFNPiYQv2yOtv25tM1Run7hJQGSAzNo+S4J+C5KI3brOkaZwyTWEmJamJp9OnlTbx49LjJeXdLXMb7W2fiDmzFHH9+wR8fW11fW6FH9C3n0rUiZ/e1giIiKk7/B+QrmT0uWRgyIicvT8UXn6kyhZvy2+sG611FHYBsoqdbSRQpY6AgIAD8vfUXm1LWsGKqMH5e6eObkiNVVkXvA6ucdtgyr3Qbq8UOdXOfbHNambPXtEXnhBxM1N9TF1qsiGoxukyVdNss1TuX3ipo2UptiSMWmjipubrBg79lqZk40bRdq3F/nnH7W9cKEIyMqxY8Xd3V1uNxkSUL6zjBupPLTQVXMERIa/pQzgqtj1cu8Tf8naGO1h5ZfCNlA5rYPqdp1zPCxeT0CW/f4oRQp/wDvfA1VeVEhebcqagRLJPfMvI9+N2ClNnWPFIE2cSJGe/C6HR31vOx4fL/Lpp6oUkYjI6tUiwSG7pdaYBpmMlOcET1l/dL0O/2mKJflO2jh2TOTHH+W1Z58VQIaCpIKMeOopERFJn/6t7Gz2gBzdmSAiIu9PDhWMNPl5VrJERERIx6eHSI12S+WfrSrrUIs3Z6ewDVTFG+5YGaFMBspitEIzbOfpEWXpL0/jJGXUQN0IsVvOyyP1NgiYxUSaDCv3raTvi83W7vnn1TvDo9oVcbhvpPBGtUyGyv0Td6k/vr4M/324xJ2Ny3RuxO4IHRLUlAgyel0ebm7XDFt4uMhDD10rHPn663LeuarMnblA3N3dxaf+veLufES+/HKZiIg88MFEcat9QPao6V7ZfuiQnEy4lP2CZYjCNlCz/0uShCU8F5BlOzjD9lyrF2XxqDK+fDO087cYN8+8rqcNVN5YQ4LN2WpLUa9Mgvx+z6eZ1qCYzSLR0SK9eql3CEa69H12r8Rfjpcft/4oTh85ZTJYFUdXlJ4/9pTgqGBbGrv7KHdtpDTFnnx5XRs3inz7ra3syRyQf0FeeEGVPZnR5SXpUu0vuXhRNW/f8wvBSJf4eNV/x0eD5InX5kp6GQo8lIgkiRwMVFaPKvR6iQ8WTyzKYsyyeVGWa2wCNtWvX9++T7mUkTmpIl18y6+1SCqZpZPbZjnzz5Fs5+zapc6bMEFtp6SIjJ96Rl6Y/5q4fOxik1HKOmfFSOTxXx/X4Q9NqcHqcTmANMrocX34YaY1XSsaPyIjG3xua+9Tc5I4OZyTBQtU+8b+YdK62y5b+3mr/5Ht+xMK9V4KGnsZqPyug9oPxAJVgQTAANqJSNXrnBcAICJhlu1gIDHDdqglzBd+3UHkgzK3DuoGiYyEwYMhKQnc3WHmTPB0Pc7DD6URl1ofR1J5q+4PfPR3d6hfP8c+IiLgkUegShV49IlknDtM56ejH/Fhlw8J3xXOnwcyV2C5pcItVHKpxF317iLojiBa1miJg8mhEO5Wo7E/ea7lsrJ2LZjNDJs5k8mTJxNtePCXQz3OB97LxIkTea/8B2ys3pUlB7uSmp6KZ73FpJnaceLoLcyPmM9zE3fRybMV88N6F+7N2ZHCXgd1w0kScoMhPnu8dIjv+uSWVDHh0XXiwhUBkebskEOBo8RWOS8DZrPIsmUi/v4iDg4ihiHyQK80OXtWeUoP/fKQlB9VXtpObStDwofIAz89IKaR1zysip9WlOpjq0uPH3rIxPUT5dyVc3reSlMqySQHZfW40tNF3n9fZMECERFJvXhe1tJBZvWfIhEREVKxqqu0c1kitcstkIiICDlx/pjUu2O+DB+pJrjMZnOJiEpQGB6UYRgNUSneWyzbjYBGqPmgOOv+PM7P6kF5oMJ0gZbtKBHpfqNGNTe0B3VzXE5Ipn+TbSxLaIkJ4VXXKYz4tinlB+f8S+7oUfjmG1i9GqKjVdG9T77/m7VpU1mfsJiEKwkAtKvdjl/6/cL6o+uZu3Muf8T+Qao5NVt/TiYnfur7EwNaDCjQ+9RoCovrelxmMxw8CG5uDBs1ivDJk5kHjMWFekHPMPyxB3mxo4kmPZz4asl9rNkciV+XJjz7XCqjx7Xk0tVLzAtfwsY1y/L26gqZAi9YaBjGPiBQRP7K4VgjYKmINM5jgL5AIMqYhYhItGW/P5BobWfdbw+0gbIPh9ef4KUH9rLgXGdcSeLbci9S7pfpXO+9f+UKVKigZriGDRP8ntrH/rRlpJnTCLojCBGh/oT6XEy5SJtabTAw2HJyC4kpiZn6qVGuBk+1eYonWz9J02pNMa5XblajKQXkWGiyY0cl69SrF3h5seWHaUx40pFu7zbn8Y/vYORLT/HRV9Op4fwsFx1n8VnwSxxYWpf/ffEwTTrcAidOwP794OMDbm7KIBrG9Us43ySFYaDeEJFxhmFUQnlNAGTwpt4QkXE3OwB7og2UfXmxeTQz/21NAtVpQwzPVpjFC296wP/+BzVr5njO1q3wxRfw88+q0Orjj8N770HDhqrkxy/bf2HVoVWsPLyS3fG7M53rYDhQyaUS51POky6qrEIV1ypUdqvMiLtG4NfEj5rlc76uRlMayNcc15kzULEiuLjwxkP9OP1nc6KTIznONp7o1Jcf1sxjQehRHg6oy8SnXmP6d48zdX517nzkFnZ8NJqLH0Ww4NHbucu/Nx0vXuHKj4uoM3MKjpUrkLRuA+lbd1L+qccwnJ3g/Hll1Dw8bsioFfgcFBnmnVDlNr4mw3oodMHCUk9QkIgLSdKFv6QCiQIi1TklPxlDVC2PZcuurRXJwoED6nxXV5FNm9S+LNUU5PSl0/Lrrl/l8zWfS9BvQfLlui8zKVd4fekl1cZWyzSHVXNcTfH60kvu+fYembdrXoHev0ZT3Mla9mT+/AXyz7/H5dIFldM++utfpGnjdbJ3h5pP7t4rWEDEiebi7u4u/Tq+JiCyb6c6HtDuLQGRQ3FpIiLyTOt3xYkUeWromxIRESGfBIyRJ9vNkosX1Of+WMJZuZqaPX+egk4zB/reyHZxeGkDZV8ySinVdT4pXStssInR1uGIzMdP1fXIg3Pnrv09dKhIjx4iy5fnbNfSzeny75l/5aetP8nLi1+Wu7+9W8qNKicLdy+Ujcc2yjMRz4jjh47ZSoVM2zxN0svSIhONJgM3Uvak3/9eEGo+LFBRAOn6ZKA8/e5GSUxUx8f/8ps8+sQyOX9ebQ8f+o54e4wWKCfu7u7yWMP3xZlk249N//oh4mIk2bZffXmKPPfsioJPkjAMYxNKe8+KJxCXYdtHRNrftAtnR3SIz/5ERsLSparir58fHF57lCd7nWF5YhsAGjocIWzkCbqfD4f4eHj+eWjfPsdwwGefwbhxcPo0dOwIb70FDz2Ud+Qg3ZyOIDiaHImKjeKJ+U9kKhFixdHkSLva7RjeYTiDWgzCZMpvsWiNpuyQ4zxXHpPLw4YNY/LkybbtoKAgxo8eh1MFNwAmPzqGffsbMGHDYAD6VvqGNZcf5FT6LadF5Kbj8XkZqDmoBbK50V1EilW6lTZQhce+6EM80eci6y61AOA2Yz/TnQK5++oyKF8eJk+GgQPBxSXTeVeuwLffKkN16BB8/DG8+27+rxu5J5JB4YO4knYFB8OBii4VeaTJIyzat4gzSWcANW/1QvsXGNhiIC1rtrTbPWs0pYF8zXNlaHsjBu3PL7/i/Tc/Yk1yAiJy05kYeRmoRiJyINcTr3O8KNAGqvDZNj+WJ4ekseXKbTiQzlCPCIanj6fVxb9h+HD48sscz0tNVclJnTvDE0/AhQsQHAwDBqjkiryI3BPJ0til9PDqQa/GvXA0OQLg+aUnBxIP4OroSkpaCoLg4uBCD68eeLh64N/cH78mxSMNV6MpKdyIQcvocRWogSqJaANVdKz/cQ/j345n3tE7AKEx+/jo5bP4j78HNm2Cr7+Gl1+G22/P8fxnn4Vp09ThDz9UahU3mgmbkJTAvH/nMXPHTFYcXIEgOJmcbGuuTJh4vPXjfOv3rQ4BajQFQEaPSxuoLGgDVbQMGwbzJh+nPJfZjxfOXCWw5Rpe7PYvjb8JVhpL3brBK6/AAw9kcpXS02HOHBg5EvbuBW9vGDMGuv/HZdzHLhxj9s7ZrDq0igV7FmQ65mxyxr+5P+N7jqdG+Rr//YY1Gk02IiMjefjhh+0yB6V/RmrsRo8ecMG9DvtpTEOn4zxSdzNTdtzDbV++QKu0GDb2+RT27FGZER07qhW9FhwclE7gzp3w3Xdw7hxstKToiGRqmi9uqXgLr3Z8lafaPoW7k3umY6nmVH7Z8Qs1P6/JHd/cwerDqzMdj9wTybDfhxG5J/K/PAaNpkxjCQMesUdf/9mDMgyjoohcsMcg7IX2oIqerFl/G37YzRPPOrPnqlrr3cJ5H9OfXEkH7zR47jm1CDAkBO6/H9q0scX1UlOVV+XqquaqpkxRCRWdO/+HMVnmrDo36Mz5lPNMXD+Rbae3YTJMmMUMQO3ytQm+K5iGlRoyZP4QklKTcHdyZ2a/mXreSqO5QQpcSSKHC96XZVd/EXn+ZgdgT7SBKr6sDt3Js8Nd2X3VE4DmzvuZ9mUSHe8UpG1bDOByjYaUe/QR6NMH7rpLuVXA7NkqKnjihIoQfvyxcsD+KyLC6sOr2XZqGz51fHhlySusPboWgApOFbiYetHWNqh9EJN6TfrvF9NoyiCFaqAMw5iK0s9LyLC7u4j0uNkB2BNtoIo/f4ftIGC4K7tSvABo4hhLDU7ROG03/UwL6OkQhUNqCixZotywxERwdeWKuPL112pe6swZqFMHjh2zz5jik+JpPrk5Z5LO4GhyJM2cBoCBwWfdP+PVTq/a50IaTRmhsA1UNxH5M8s+nWau+c+snbaDZ4e5sDPlVgyEu/ibC1Sg29ON+OL+pfDww+DsDG+/DRMnqqSKPn24dG8vJsyoRIsWytG6elWFAt3cbm48KWkpzN01l0kbJrH+2PpMx1rXbE3b2m15++63aVw1uz5yxrR3HQ7UaAq/HlQbyyujFt/r9pCysOdLSx2VPKa8uFPuZqVU4LyAiDuX5JMuSyU53lI/e9UqkYAAkZo1Va6Ek5PIgw+KXLkiIiKjRok0aqRkmexVJmfD0Q0S9FuQxCbEyuQNk+WWz2+xSSvV+byOfLziY0lJVdplEbsjxH2Uuy5zr9FkgEKuqHsWJXtkAGL5t5HkUW6jKNAeVMkkMhKWLrjMpZWbmR3bnmTcqG6c4eGGWwkc7orPy3crN2n9epg/X9X0eP99AJYtvMSwN8uza5dysr78Ehrb+V05cf1EPlj+AeeSz9n2GRh0qteJam7ViNgbYduv56w0muIR4msrIv/c7ADsiTZQJR8xC39O3MXEcclEHvMGoJ5xjLd8NxC4oBcmd9drjVetgl69SH37AyY6vMzITxxJSYFJk9TCX3tiFjNrjqzh520/89P2n0hJS8lWdNHVwZXZ/WfrMJ+mzFPoWXxZLt4GqCI5FDMsSrSBKl0s/zaO119OJeZiYwQTbiQxqM5KHnmpAUsPN+Ph1gfpvugl5YI1a8aJj6cxIqITw4bBHXdAcrKSArR3bTazmIlPiudQ4iHeiHqDFYdW2I5VcqlEnQp1aFe7HR92/ZBGHo1yLLio5600pZnC9qAqAm8Dlay7ABGdZq4pBE4fTubVB3YRvqs5KbhiYKYHSzjofBtj53rhZ1qkdP8OHIDAQJg6FVBeVFycyrFo3rxgxmYWM+uOrOOztZ+x/dR2DiQesBVbBKhVrhbpkk6zas34X9v/MaTVEH7b9xuD5w3Wa600pZbCNlBjuKZsfta6X4f4NIWJ2Qz9W+xi+e6anKUqTlwlsN7vfBXXGyP1qspBr15daS6JMHWKmbffc+DiRbUm+M034ZZbCnaM6eZ0dpzewcHEgxy7eIxZO2ax6vCqTG0cDIdMRkzPW2lKG0U2B2UYxn0i8pf135sdgD3RBqr0ExmpJJEaJm3nIJ4kUY77K6xm7Cep3D6867WGP/0En31G/KdhvBt5B9OnK+m/77+HQYMKd8wXky8yfct0ft7+M7vjd3Pp6qVMxx0NR1rVbMVzPs/x6O2PUs65XOEOUKOxM4VuoAB/EXne4k3FA146xKcpCqxySvd1FQ5FbuWDHzy5SAW6uq9n/vpbqNSyHixapNymY8fgqac48MI4xnxTlbffhgYNlCSgiws0bFg09/DFmi+YsXUGxy4cIzE5EeHa59DJ5ESAdwCPtX4M71reODs66zkrTYmiqJMkngWiRS/U1RQD9q4/R++uF9l7pS41OMPHPf/m6R+64OjuDB99pEr5mkzwzTfw1FOA0qtdsgSGDlWVfT09i/YedpzawXdbvmPBngUcSDxg0wg0YcIwDFtIUM9ZaUoC9jJQ+VIzNwyjomEYUw3DWGLZtYlrCRMaTZFyW4fK7Emqz8bIU3hVTSRwSV88ajozrc9vMGYMf03cyfZ6D7Bxr+Ute/UqX08289xz8OOPcNtt8PTTsH9/0d1Dy5ot+aznZ+wfvp/099M5+dpJ5vjPoaFHw0zzVUmpSby25DWbHJNGU5rJb4jvdeAbwNOaGKHnoDTFEREYds9Wpv7dEjMOeBoHaOKwn8Vp3XF3h5kzwW/LRxARAePGcbzpfYwdC6Gh8M47N1Z+vrCI3BPJgDkDSDGn2PY5mhx5qPFDfHLfJ7So0aIIR6fRZKdQPSjgHxE5D9x4PFCjKUQMAyavbs2RuFTurLqXOGnI4jRfOvI3tyb9w9KlQNOmEB8P3bpRJ+AhJjy7kwMH4KWXVB/h4SoRo7j81vFr4secAXMIah/EzH4zCWofhKujKwv2LKDl1y255fNb+DMu0zp6XdNKUyrIrwf1LOCJUjOPAboDsSIyrWCHd2NoD0qTlbEvH2Pcl87EUx0DM11d1/HjQg/q3O0JX30Fn34KFy/CF1/YLNSkSUqj9uJFuOceVerDz89W/aPY8MnKTxizegyXUy8DUN29On2b9aWnZ08eW/CYXmelKTKKoh5UW2Ag4AHMzSp9VBzQBkqTE5GR8MvIvfy5tSrx5qoYmHnPZzGvz+lAhYqGKjD1+OPQrh0kJICLC+fTyzN9urJhhw5Br17w229FfSc5s/XkVl5c/KJtvVVF54pcuHqtlqheZ6UpbAo7xIeI/CMib4rIc8XROGk0ueHnB7NibuNMelW+fX0Xt7ke5qNND9LI0+DxNts4PugVZZwAXn+d5PqN+e2Rb2jcKI39+2HuXJWxDnDpksr6O3So6O4nK61rtWblUys59soxHrv9MSq7Vc50/GLKRcxmc5596JCgpliSm8w51ymnATxjDzl1e750uQ1Nflk/K066Vt0iIOLGZRnjGyUXj52XlSFrJJGKIiB7jNtk4xuzRdLTbef9/ruIg4N6DRggsnZtEd5ELpjNZnn1j1fF8UNHW5kQY6Qhbb5uI2uPZB+wLhmisTcUdLkNS4mNjBV0rYqX1nIblUWkaoFZzv+ADvFpbpRvX9jIL3Mc+TOhLRW4QGvXPexKbshdrGUU73A7O2DkSPjgA9s5hw8rfb9vvoHz5+HOO9XC4QoViu4+cmPD0Q08u/BZtp/eblsMXNWtKgNaDOCjrh9Rzb0aw34fxuSNk23n6JCg5mYp8DkowzAqoRIjAOJEZfFlPN5PRObd7ADsiTZQmv/K+u//ZfAz5TiQVh8DM22J4bhTA34L+gPvV7tAvXqwfbuK8XXsCKg/Z8yAUaNUYuDy5fDrr9ChQ8Fr/t0oaeY0JqydQMSeCNYeXWtbW9WmVhv8m/kzatUorqRd0UkVGrtQ2FJHDVHJEYjIlpu9aEGhDZTmZpn2+Are/KkFCVTDwMwDNf9hxiovajT2gAED1ISUn5+ySi1bZjr34kWoUQNSU+GRR+CFF6BrV/uX+7hZ0sxp9J7Zm6jYKJuhcnVwpaJLRZ5u+zRD2wylkUcjnB2d8+xHyy9pcqPIpI4sxsofiBG9UFdTSgkb9Cdvz2lDglTFIJ0Ha//DjKW3UC3iWxg7VlmjIUPgww8z6STFxqpFv9Onw9mz0KSJCgXec08R3kwupKanMnvnbEavHs2uM7uyHTcZJso7ladOhTq0qNGC7p7deaDxA9SvVJ/IPZG6ZIgmV4oizbwNMAhlnKJQqebaQGlKLyKE9o/m7XntOEsVTKTzcsf1fPKLF25ff6Fy0N95h8hW77J0KfTooZwrUMUS586Fr7+GH36AW29VEcLUVPD2Ltrbyol9Cfs4fvE4bk5u/HXgLz5e+TFJqUk5tjUs09EZBW71vJUmI4VioCze0nOALxALhEkxTjHXBkpTIJjNTO4TxUcL23JaalDL4TRD79rPG5/XYm1sDQY8XR7/pO/p7/ArdZ97iDZvPwh16mTrxhoh7NABnn9elf1wcSmC+8knZjFz6tIp9sTvYUnsEi5evUjcuTi2n9rOsYvHMhkok2Gia8OujPEdg3dtb0xGvlewaEohhZEksQlllGaLyK85HH9dRD672QHYE22gNAWKCCvHree9jxxZedkHF5Lxv20bM/d68wzTeZtPacBh1bZtW+jdW2X/mdSXdWKi8qamTLlW7mP6dBUpLImE7wxn8qbJnLl8hn/j/7UpsJdzKke6pNOmVhte7/g6Dzd9GEeTo56zKkMUhoGaCsy1bGZtZAAjRKTHzQ7AnmgDpSkUzGbG9/yD71Y2YtvVZlTnJHU5RqxTcxZ8HkvXy4tUParUVFi/Xp0zYQLUrw/duyPlKxAVBe+/r2zYO++oasEixU9O6UY4fek0S+OWMmb1GHae2ZnpWCWXSly+epk0SdNzVmWAwjBQjSSPek/XO14UaAOlKUwk3cxfn6zhfyNv4RCNMDBzd9XdTJpTg1b3VVMGyskJ0tOVcTp+XG137gwPPYT06Uta7Xo4OcGcOcrZ+vBD8Pe3OV0llqtpV5m8cTJhm8PYf3Y/aZK5PIizgzM9vXoysMVAunl2o1b5WkU0Uk1BUKQFC4sr2kBpigLz1TQmPvAbY5Z14KTUBKCx6xHGfJxK39e9VKO0NFizRnlWixbBv/+q0r4HD0JKClG/XuTlT6qxaxe0aqXkAXv3Ln4p6v+VyRsm89IfL2WqbZWRii4V+fS+T7mnwT1cvnqZNrXa4ObkVsij1NgLbaByQBsoTVGz5OXfeX1yI3akNQUMqprO8crAY7z1U8tMXtGfofuJXleejn1q4ScR0KcP6Xfdy2yvt/lg5X3sP+DIgAEwe3aR3YrdyTgH5VPbh62ntrJgzwIW7F5A/OV4zGTWC3R1dKWCcwV6Ne7FJ/d9Qt2KdYto5JobRRuoHNAGSlNc2PfjOoa9YCb6UgfMOFDFlMjYl44xZFRzlkYZDB4MSUng7g4LvjxE9+PfK2u0axdphhM/NBlFlbcDeeTxiiQlwcaNKjJYWhERYs/FsuLgCsasHkNcYpwt6QLAwXDgtqq30aZmG0yGiT7N+nBn3Tu5pWIxk+zQANpA5Yg2UJrixqWtsbz24G6WnWjCPvOtVDado6HrKf5Nqkcy5QAIClI1qADYsUMZqrVrISoKDIOv+q/ipfB7uKdjGi++4sgjj6iprNJMVn1AFwcXUtJTsrWr5FKJJlWbMOORGTSv3rwwh6jJg0Itt2Ep+a7RaG6Q8q29CD36IHsu1+PPN/6gjnGSf5KaYsaBVmyhmlMiPTLmwrZsqSagoqNtE1DPHn6P8bzMkbVHGDAAGtZP5+OPVeZfaaWHVw/cndwBcHdyZ07/OaS8k8Lc/nPxb+ZPqxqt8HDx4HzKeTYc30CbqW1oO7UtDSc0pNnkZsz/dz5X068W8V1obpb8avHNAaZaNjeJyIW82hcV2oPSFHvMZv5+cyGh0x2Ye7YbybhR3fEsIwLO8cpEr5yz90Rg40bSPxvP4rmXmGR6keTGrVi+W2W+7dunlCpKS0KFlfysm9oTv4dJGyax5dQW/j78d6bFw66OrjzW6jGC2gfRplabQhq1BopWi68NSlkiLqcFvEWJNlCaksTJRZsY3D+VFckdEEy4cYUnuxzk89+a4e6euW1kpCrp0afFXrptCiElcDgud7Tm1IZD1Lu7Pi1bGgwbBoMHg1sZTH7LGhI0MGzGys3RjbHdx/KCzwskpSVR3rl8UQ2zzFDYIb42ltcYYBpQFThgGEZbwzDuMwyj4s0OJB9jCDYMw6Ogr6PRFBa1HvJh2ZWOxEf9w+NVfycdE1OXN6NCuXQevHU3h2LV2qHISGV4Jk8Gv9dvI/Lh6bjc0RqAChM/ZWLq86TGHeZ//4O6dSE4GE6eLMo7K3yyhgR/HfArU3pNwauyF1fSrvDi4hdx+cSFSmMq0fX7rizcs5DU9NQiHrXmeuQ3xHcWmA2E56TFZxjGfQUpHGsYhicwAqVekZhbO+1BaUoyaYeP80mPlXy5pyeJVAaENpUP0rJzVX5acO03YKakitOnYcIEZNJkVl5sw6Rao4hM6MSevSYaNoSEBKhcueQv/M0PuYUET186zXvL3mPWzllcSLk2O1HJpRJ317+b6u7V6dOsj1a2sCOFXQ8q1+KEFq9qaVYDZfF2AoBEEQnLsN8fSETVl4oTkZh8XN8X8EaJ1Sbm1k4bKE2pIDmZmY/M4p2lnTkgDTEw08LYzQmpxmXXmsyefU013UZionKxJkzgrH8AVb4eBcBDDyndv+efh6FDoUqVwr6Z4sWKgyv49p9vWbx/MWeSztj2uzi48NUDXzGo5SAquhR4QKjUU9gGquKNJkZkMCo2A2UxWiEiEmjZjhKR7tfrR0SiDcMIRhsoTVnCbGbf5CVM+zKJqbHduIAHrlzh+W77GBRcn/bdPbInRly+DFevQp8+kJjIHKchTGQYqze54eamQoXDh0Pr1kVyR8UGs5jp9XMvlsQuse1zMBwQhB6ePXj7nre5u/7dGKUt86SQKNQ5KOAbS+mNfCMi0ShPKSMDUArpVhINw/AG5Vllefla2py1/N0elZyh0ZQNTCYav/gAIfv7cWT1EYbVnkcbp51M+rMpHXp64GJKpVONfYRPOnkt5bxcORXTW74cXn2VAf9+yKrtldny7GSeeDSVWbOU0hIo9aXk5KK6uaLFZJh4of0LtnkrZwdnKrtWxixm/oj9g3u/u5dKYyoxbs24Ih5p2Sa/HlQ3ICFjuXfDMJ4RkWnXOS8AIIMHFUxmjyoUVfgw+jr9eADfAFEZw4UZrhEAUL9+/XaHDh267v1oNCUWEc6t3snXw3fyxZZuJFAVMHAmhbtqxzEipAo9H69py/rza3eMHlFvwMyZUL8+50OmwgMPUKmSWg88bBg88ww895ySBixrZJ23WntkLe/+9S4rDq2w6QbWr1SfJ1s/ScsaLXE0OfLXgb90yZDrUNghvv0oz6cqkIAqt9FORKpe57z8GKgoEQm/mZuwokN8mjKF2cyusQv5eJwri8924DyVAAM3ruBFLMepSbJ7dWbOBD+PlfDii/DUU/DyywBs2ACjR6ssQYAHH1TzVI88UjaSKvLCbDbzw9Yf+Hzt5+w8szPT+ioAZ5MzMx6ZwaO3P1pEIyzeFHmShGEY3a5XXTcHAxUAeIjIWMv2XGB0fhIl8oM2UJoyi9nMpg8iGTWxIlHn23OZCoDQhn+4Y3BjQn+poGJ6AI6O8NNPEBMDH3zA4fOVCA1VxROrVIGdO9Wi3337wMtLG6tLVy/x0YqP+Gr9V9nklvo27csbd71Bg0oNqOpeFWcH5yIaZfGi0BfqWtY6+QJVgGgROZiPc7IaKA9uMEniRtAGSqOByF/T+GHAIo6l12AzPpgwc2/NvXz5a12adbKk8b3zjnKfatSAkBB4/HHSzCaOHoWGDeHKFahZUxmsIUPg8cehadMiva0iJ3JPJAPnDiQ5PRkTJjCwCdo6GA6kSzrV3avj6+nLG53eoE2tNmU2yaKwPahuQH+uJTi0B6bmtfbJktgQiEonD7HOM2VIMwdsyRR2QRsojUZhnYO622M786aeJjzhPpy4yoie23jt+1Z41HSBTZtU2G/dOrjzTlWLvm1bAFJSIDwcfvxRadaazdCuHXz+eelWVb8eWeesTl86zcrDKxm/bjzrjq7LpMDuZHKiVc1WVHatzFNtnypT4cDiEOLLdW1UUaENlEaTM7+/sIhps8sz/2wXynGJu+vE8cPa26hR1xl++AFGjIBvvlELrI4dg4sXbS7TyZMwa5aKCk6dCj4+sGWLEl7v25dsskxlmR2ndvDFui/4Y/8fnLp8KlvJkHsa3MMzbZ+hX/N+uDq6FuFIC5bCNlDZlCIKWj3iv6ANlEaTByL88/U6+r5Yh4PmBphIp4/nNr7deDuropJZvLIcPXoa+G14F0aNgubNoV8/ZYVat86kRvvaa/DFF2o6KyhIZQGW9RBgVrLqA2bllgq3MOmBSXRp1IVKLpVKVTiw0D0ooBFgTWawLsDNM828sNEGSqPJB2YzX/eK5K0lXTiPBw6k0cbYwmbxxt3dxPxJx+hxeT78+iusWKHie7ffrtwmS8aE2QwrVyqP6tdfITVV2bJwu+Tjlg4i90QyeN5gklKTcHdy55e+v1CnYh2mbZ7GrB2zuHT1EmbMtvmsau7VuN/rft7v/D5eVbyKevg3RVEkSbRFzSkJuWjyFTXaQGk0+cd8NY2xnX/j43W+JFEOR1Kpz2GaVj/LyGm34NO7Dkb8GTWhdfo0vPWWOvHBB6FRI2WROnfm1BkT06crbyo4WBmvzz+HQYOgXr2ivceiJq+SISlpKaw7uo7vt37Pj9t+JM2cZjvm7uTODL8ZDGg5oLCHbBd0Rd0c0AZKo7lxIuckEzroT9ZIJxLxQC1zhBoO8TSreBxXFzPDXnOh67ONKeearvSS/vhDpfq5u6v89P79wcEBgH/+UQkVhqFs2fPPQ8+eOl39eny98WteXPyibYEwQHX36vRt1pdPu31KFbeSI6RY2CG+NlYVCcMwGgGegOg5KI2mdGDN+uvR+iRXVm/m1BkHNm935vejtxNPdQAcSKOO4ykqOSVz922n6d/+IF1Wf4Jp9y747jt48klbf4cOQVgYTJumnK9GjWDJEmjcuIhusASQdc6qToU6nLh4wrZIuHXN1kx5cAqd6nUqqiHmm8I2UH2zFifMj9RRYaMNlEZjZ8xmYudtYfeGC6xdnsxPMc05ZK6H1cty5zIDaq1k8rZ7ca9eDubOVZ7Vo4+CoyNXr8L8+TBnDpw5o7yoQYPg0iWlZ+tVsqda7ErWOauZ/WZyX6P7eCbiGebvns9VsyphX9WtKi91eIn3Or9nO+96lYcLmwI3UIZhVEKJuwYClYDzYNP7OAuE6oq6Gk3Z4+rJs0x8fAPzo8uxgQ6k4owDafSstY3Jt46n4eqfVA36d95Rq3ydnDKd36+fSqwAlXvxyCPg7w+tWhX+vRQ38jI2fx34ixHRI9h0XH3H3Vv/XlrVasU3m74hxZxiM2rFwUgV+kLd4pgUkRVtoDSawmHYMFV+ypkkurKc9XS0FVnsWmETYbU+4NZ9i8HTEyZMgN69M51/8CAsWKC8q9WrYeBA+OUXdWzdOmjf3jalpcnCnvg9TN00lQV7FnAw8WCmY70b9yZicESRp6wXtoFqCwSIyPOW7TaoNPODNzsAe6INlEZTOFjL0CclqTyJmT+bubIwmne+b8zB9LqYcaB7xQ086PgHw75th+nh3qpWlZMTOGfWqztzRoX8GjWC3buhWTOoVk2tGfb3h+7dVYagJjPp5nSenP8kP+/4OdN+k2Gi4y0dGXj7QJ5o9QSVXCsV+tgKPUkCOCAi5zPs0wt1NZoyjC2xokfmCr8n1h9myku7+Wz93STjzu1u+wh+9hwDXBfiPG2KsjqDB8M992Rzky5fht9/V57Vb7/BhQtQp47yttq3L9z7KylE7olk0Z5FXLp6iY3HN3L4wmGupl+1HXcyOXFXvbt4scOLPNLkERbtW1Tgc1bFIUki276iRhsojab4kLDtGKMe380f/9bn39TGuJFEW8cdDJUZPJk+Dec6NVTm36ef5nh+SooyVj/+qJIEK1ZUhioxUdm48uUL825KFocSDzF5w2RmbJlB/JV4234Dw5YV6Oboxiz/WQVipIpCScIXiLLs6g5s1ll8Go3mephT01kYvIr/TWhpK7BoYMbTOMDDVVfzyl+9qXt7FZg4Ebp0UZkTuWBNsChfXmUDPvUUdOyYSYVJkwPrj65n6qap/LLjl0zelYPhQOMqjRneYTiB7QIx2WmxWlEpSQxA5ZfOFpF/bvbi9kYbKI2meGKds6qTtIcGHGGf6TaOmOsimAChipFIZ1nGq3zO3S3Oq8aDBmXLQxeBNWvg229VReDLl1UpkB9+KJr7KmlE7olkUPggrqRdwcFwwCzmTMUYq7pV5YnWT/D2PW9Tzb3af75OYXtQFYGxQCMR6WkxVpKxBHxxQBsojaZ4Ys36sxIUBJ+9f4Fv/reWH/+sw9Yrt3EVFwCaGnvoIn/SlN0Efu2N63NDc+zz0iW17Kp2bbj/fpVsERioCgbfc4/2qnIjayr7gt0LGLVyFNtOb8vkXVVyqUTz6s253+t+TiedvqE5q8I2UK8D3wCeVs+pOKaeawOl0RRPsmX9zcycWIHZzF+f/M3mv5OJWl+JP897Y8aRmqZTfPHSEQb3ScaoUzvPlb2rVyvh9TNnVHmrESPUNbTEUv45fuE4P2z7gdk7Z7P15NZM3pWBQa/GvfjhkR+o4p637FKRrIPKInmks/g0Gk2+yS3rLyeOr9zHlDcO8Me2OmxObkkDDhJiepuBL9eGd9+FypVzPO/KFZVQMW4cHDigKoZs2ADlytn/fko7aeY07p1xL2uPrs2038nkRNdGXanuXp2eXj0ZcvuQbHNXhW2gnkXp7yWgSm50B2J1koRGoylI0pNTmfRINK8s6Ylg0JydLCj/BI0/eVKp0GZZU2UlLU2V/ti8WRkrgEWLVDXgChUK8QZKOBnll1xMLtzneR+3Vr6VpXFL2ZOwx9auimsVfD19+ajrRzSp1qTIkiQGokq4zy1u4T3QBkqjKU1k9Lhud95D34fT2XK1GQZCf+bw/Y+OuD7mn6++jh6FBg2gUiU1/zV8OFSvXsA3UErISX4p3ZzOd1u+46v1X7E7frdNJxDA1dGV5M+ST8s5qXmz19blNjQaTbEjtzmrBS9G89SkdiRSGVeuMGbIDl7qHadkKO64I88+16+HkBC1lsrVFZ5+Gt57D2re9Neo5sTFE3yw/AOWH1zOvrP7IBTkuNx0mkqeBso6z2QYxjN59BFdXCSPcjNQvXv35sSJE0UwIo1G8184exYuXry2XaECVLHOywucO3GFhMuNOH9hEfU5zBz86fBoY7Xot0GDPPvevVuF/ebMgb17VRagiM76swe2kiGFZKCmishzhmHMAWbn0qwyQHGYj8rNQPn4+KA9K42m5JCYCHFxqjqvyaQ0Zz08MrfxbtWWinHfsOJyOxxJY6TpY15z/BLX14fBm29ed7Lp4kXVRAQeegjatlUVgStWLLDbKvXY5qwmJdnFQOWZgCkiz1n+HCEi83J6YS0Mo9FoNHbCw0MZpRo1cjZOACZnB5Zf8mHVp6t5oMp63jV/hNfVXYz/NAm2b7/uNaz268oVZZRGjVJZ7BMnwtWreZ+ryRm/Jn7M7DcTrnDaHv3la4WAiBzIuG0YRhvDMO6zbG4C5tpjMBqNRmPFwwPq18/ZOGXk7rfuITL+LiYNWk0iHrzKeIa9aJCUeBXGj4e//87zfOsc18aNSmVp+HCVnr5jh91upUzh18QPEjlij77yZaAMw6hoGMYYwzC+Ngzja+A5oD+AiPyTUeVco9FoshIeHk5YWBgxMTHZ9icmJhIdHc3YsWOJjo7+T/1HLjQIjrwbD87SmeVMjulIqxrHmf7+Ibj7bpVxcfhwnn34+MCffyqBWk9PlXcBKtyoKRryu8b6bZRQbDgQBoRa/tVoNJo8iYuLw9vbG19fX0JDQ7MdnzNnDj4+PgQHBzNixIj/dI2lS1XG33HqsYIuvHzH3ySkVuKZS+O50yWGC79GQ5Mm8P77SsAvFwwDHnhA9VeuHKSmquTA3r1h587/NDTNTZDfMmBR1nVPGTL77rveSZrsxMTEMGLECDw8PBg4cCAAs2fPpnv37gQEBADqV2VcXByenp628zw9PfH29i6SMV8P48OCmYaUD0rPEoiSTFhYmO29GBMTQ0BAAB4Z4m7R0dF4enri6elJXFwc3bt3JzY21nbc09OTxMREwsLCMhmg8PBw/P2vrWNKTEzEx8cn0/acOXNsn4u86NEDZsy4lpbe9Z27eK1SLL6+CaxPaUsNjjC9yTiGjPtUSaBb3aPrYDbD//4Ho0erkvRDh8LIkVCvXr5O19wk+VapsoT2AHpYtPn6F8yQSjfe3t54e3vTvn17/P398ff3Z+7ca1N4YWFhbNy4keDgYNvx2bNnc/bs2SIcdfElJiaG7t27079//2zhoYzHrCGmwMBAEhMTiYmJoX///vTvn/1tHBgYSPfu3bOFo8oi/fv3x9fX1/YKCAjI9sxiYmJsBsxqqLLi4eGBr68v4eHhtn1Z39OjR48mJCQk0znW/q+Hn5+aRwoKurZmqm5nL3an3sqHd/5OKk48tudduriuJanyLeqk4GAljZ4HLi5K0y82Fl56SRnBBg2UQoWm4MlvksSf1nLvIvImcB6lbq65SeLi4gCVCp+YmMiIESMyfUgB3nrrraIYWokgo8H39fXNdqx79+50794df39/AgIC8PLyYsSIEXh7exMYGEhcXByJGSYZrH9379692HqsGYmLgxYtVEn0Fi3Utr0IDAxk4MCBmQyOh4dHpiUbYWFhmbygrJ4/XJtn8vb2Zvbs2bZ2Gb2l8PBw3nrrrWxGKyAgwHbO9fDzg0mTsuv8vb+2F/t+20dD02FWJLahWuU05r/+N/z0E9x1FwwYoBZE5UHVqvDFF0rf74MPVEo6qJIfa9fmearmJshXiM8wjIoicsG6LSLfFNyQCpaXX36ZLVu2FEjfbdq0YcKECTd0TmhoKCEhIXh7e9tCJVkpCV+UJQUPDw/bjwJQX8IZw0hxcXG0a9cuk9EqzvTurRaems3qX3vNlVjDaznNGWUkKioqUwjO6sVGR0cTFRVFSEiILfS3adMm24+v6Oho23nR0dGMHj2a2bNn4+npme0HWpwdrK5nr6YcSDUzou0fjNvWg76fd+KBGgsZ2y+SxvM/x2ner5iefUYt9LWtCM5OgwbKQIF65u+9B/v2qfIeb76p5q/0gl/7kd8Q3zTDMBoW5EDKGhs3brTNNVkpKV+KJZXExETbl6aVAQMGXPdLuDizZ4/6ogT17549ebfPL9HR0dk8Uuv+jJ5PVqKiohgxYgS+vr4279Tq5QYEBOTYp6+vL5s3b2bu3LnZjBNAlSpV7PPZMJkI2Xo/O2bvpI5xksWn2zFw3gB80tYQanqeK3MXKlcU1Ord63dHTAxMmAAHD8KDD0Lr1rB8+c0PVaPIb5JEKEok1oZhGM8UB/WIG+VGPZyCwjoHldFj8vX1zRbfDw8PZ8SIEfj7++f44dVcn6ioKNtzzjjfB8qjqlKliu2HgqenZ4lSHWnS5JoHZTKpbXtw9uxZquTgSYSEhOT5PswY4ktMTMyUTGElOjqaAQMG5HssHh4enD17Nse+/gvNB9zOkb5mhjWPZuY+by5Sga/Snmdnt3eZVLGikkLv2hUeflhVWnR1zbWv8uXV3NQLL6i5r7Fjrwmsx8eDm5su9XEz5NeDCgVCDMPYaBjGEsMwlgL629IOZAzfeXh4EBwcTFjYtQx+qxHr3r17UQyvxJIxYcI6P5XTr3dQYb7Q0NBcv1CLMwsXQtOm4OCg/l240D79Wj2gjISFheU5N5dxXikmJgZvb+8cExx8fX1v6DnnNK91s5gcTdz/mS+VXZJpzi5205x54UL42zHIuURled54Axo3VvXl09Ly7M/JCZ54QglYdOqk9r3zjgoJfvghnDtn1+GXGXI1UBZD9IxhGN1QUkc9RaS95d8eQP5/AmlsxMTEEBMTw8aNG3NclGj9dRoWFkZ4eDhjx47F29s7x1+zmpyJjo7O1/Oyho38/f0zZZeVJDw91ZxTWpr6117f456enowYMYKwsDCio6MJDw/H09OT4ODgTO0yPmdrirmVqlWr2mcwBYSfH0yYU4d7g1ozvt9qajqfo/9obxrVSWaJ71hYtgzq1FF55q1aXXehL2Sef3rySejYUaWlN2yo5qsSEgrsdkonIpLjC3gjt2OW4xXzOl4Ur3bt2klO5LZfU/LZvHmz+Pr6ir+/v8ydO1dCQkLEw8NDzp07Zzvm6+srmzdvznaet7e3hIaGiohIcHCwiIjExsaKv7+/+Pv7ZztHk525c+cW+HMKCQnJcb+9P9epl1PknfZ/CJgFzHJXpe1yZn+iyLx5In36iKSlqYaxsSJmc7773bJFxN9fBESef96uQy62AJvEDt/peRmgvnmeeJ3jRfHSBkqjKXxyMyD2YO7cuXLu3LkcjxXU53rrj1vE0+GggIgDqfLWvaslPV0dWzTnslxyqSLn6zUXmTpV5PLlfPe7Y4fIkSPq7/XrRV59VeTEiQK4gWKAvQxUXnNQYy1hvpxeeg5Ko9EAKkRaEIuarXOChT0v2Oqx1sSmNeCrXn/gSBqjV95FLad4JgTuYsiTjjyfMp7Yo67w3HNQt65ayXv8+HX7bdFCNQe1PnjCBCVo8dJLcOxYwd5TSSXXelCGYUwlb5Xy/nKtHEexoKTUgwoLC7PF7jdu3EhgYKBtErikyRwBBbfwI5f3pkYDhfO5Tjp5gYG372RR/J0A3M429uFFMuX4vM/fvOrwJfz6K6xerSacrlxRWX/5+Ezs368klH74QWVgvvqq2i4NGIaxWURyX4+QT/JKM98kFv29XAZws9cuk1h/aVpX32fMlAoLCyM2NjZTGm///v0JDAws3EGWIKzahqCeVWJiIgkJCbZnGBMTw2jLpz5rirlVScLaNj/tivUPhQLiZrX4bkRTr7jhXqsiC890ZNO0f+gTUJ3t0poKnOcO02rq9GwFgXOV91S7tjrh5Zdh0yblFg0cqLSScuHWW2H6dJU8MWYMVKqk9ovA6dO6FD2Q5xzU1/aIIRbmqyTMQUVFRUlAQIBt+9y5c7aXh4dHtvabN2+WqKiowhzijaM+U/Z/5ZOQkBBbsoOISEBAQKZ5kaioKPH29s40l3Hu3Ln/3K4s4e/vL7Gxsbbtc+fOia+vb6Y2WZ9N1uMiIqGhoXZPpiiKz/WbPkvlbud1AiJOpEgLl32yc/HBaw1mzBBp1ky9f2vWFPnggxueaJo9W8TdXeTDD29oiqtYQSHMQcVY0sxLnWp5ly5d+O677wBITU2lS5cu/PTTTwAkJSXRpUsXm/7X+fPn6dKlC7/++isA8fHxdOnShYWWBScnT56kS5cu/PHHH/m6tnV9iZeXl80zsuqb5SZzlNv6HU3uJGTJ57VKGlmxShplJb/tigtx5+JoMaUFjh850mJKC+LO2U+Mz15afHBjmnrFmdEbu7MqpQM75v5Lc5dYdqV40vKBevS5ZQOzXl6L+YmhKt9/6VJVYOrDD1nRYxSRkaifXfko1du+PfTqpSSVmjSBn3++phZS1sjVQInINyIyTUT+KswBlQWioqIIDQ3Fw8ODRhbZfy1zdHNs3ryZmJgYwsLC8PLyyqZ2kF9Jo5ImfdR7Zm92x+8mXdLZHb+b3jN726Vfa1guo/HJiYwqHZBZiy9rbSd7aOoVF1r4N2NLcjOOrj/OOx2Xsfx4YwZ/2ZGKDpd4xWcVyR06ExmwiFaue3li++sMHgyrx6xW66peegn++SfXvhs1grlzYcUKVfL+scdUtLAskl+po1LF8gxiWU5OTpm23d3dM21XqlQp03a1atUybdeqVSvT9vWwrrC3KhtUrVqV8PBwLXN0k7Rr1w5vb2/i4uIyzX9Yya+kUUmTPtoTvwezqJ/XZjGzJ94+Ynw3o8VnFYjNqs5h1dQraWodeVHnjrp8vKYuw3ee4sX7V/Pr0TuYEHMvkyqlcrf7Oo4le3KWGpAEq7ZW5O5u3WDqVPjqKyXcN3QoBASoIlZZuPdeVYb+xx+hcmW1LzkZTp1SChVlgXzXg9LYh02bNmVKybWm0WqZI/vg7+9PWFhYjh5pfiWNSpL0UZNqTTAZ6mNsMkw0qWYfMb6C0OKzauqVRqq3qMmsI3dz6SK8ecdfuHOF5Ul3cpbqNGcHLZ130+LR1qo+x4kTMGWKEu379NNrArV796oSvhkwmZQihbWEyFdfqbDfO+/AxYuFfJNFgDZQhUyVKlXYtGmTrYBeYmKi7Zeqljn6byQkJGQySNZnbN2XX0mjkih9tHDwQppWa4qD4UDTak1ZONg+YnwFocVXEJp6xQ3n8s6MXn8f56Ui3w5dQV3TcXbRgh1XmzCifyx7Fsepch7PPw8bNsCuXcpQmc1w//1wyy0q33zfvhz7HzwY/P2VXbvtNpUFmJ5eyDdZiJSIEJ9hGAHAJsBTRErGN0cuXC+mXxJTcYtyvVJMTAyJiYm2Krne3t6EhITYUsWrVKnC6NGjOXv2LAEBAfj7+9tCgVFRUbY+gHy1K25p5p6VPdn5gh0KQGXtN4MWn7Vku6enZ7awX0nW4itonprRmadmwF+fbWb4uxX5N6URzXqZ6FNnHYMHmfH/vBNUq3bthIkT4bvvVNXF8eNVcakPPoAOHWxN6tVTdRaHD1cZ7c88A3//rfRsSyX2SAUsyBfgD/ha/vbIq21JSDPXaEoTN6LFZ+9U/ZL2uT6x9ZS83WmZVCBRQKSp837545ONYk6/pusXESHy5tAT8u/gkSK1aolERqoD586JnD+fqT+zWWTWLCWbJCKye7dIhw4io0eL/PtvId1ULlDQWnw33bGqHxUMBGTZ7w/4Wv71zkc/oUBARkOV20sbKI2m8MmP4clLU++/UlI/18c2n5CHaq6XWsZxAREvxwMy7PblMu/nK+Lurr6V3d1FIsNTrgnUvv22SIUKIsOHi+zdm2O/f/8t4uMjtmWEt90mEhwscupUId6cBXsZqIIM8WVL9TEMwwPoLiKBlu0oID8ZAJtEJMbSPnuNihJGTlJHcXFxBAYG4uvra0tzjouLo3///gwcOBBfX988FROslEipJE2JxqrFl9t7rKg09YordbxrsfBkLa5eTOHnl1bx8ozWTNrekKlDUvFhDbu5jcSkaixZ5kzvfpaT+vZV5T6+/lplSjzwgIrx9ehh67dTJ5X1d+QIREZCRISKFr71ljoeFaVyMO67L88ajMULe1i53F4ozycgy3Zwhu25WLwolIeU8WUN6wVnaBOV1/VKgge1efPmTKoHISEhtpX6ISEhtrIPVubOnZupbV6KCaGhodnO9/f3L3AliiIWkrARFRWV6fmIZC7HkfU5ZDxmDVNZ1SSsoStr6Y2sBAQE5FjGQ1N4FKfP9c2QeiVV3rzzLynPRQERgzTpxGqZ9/OV7I1PnFASE7VqiQwYoPaZzSLx8Tn2nVGJont39bkqX16kXz8lelFQ3hWFoCRREHgAiRm2zwJVAEQkPMvL6imFAT6GYfiTg4K6YRgBhmFsMgxj05kzZwp29Hbg7NmzbN682bYdEBBg86YCAgIypZnnJ83ZqpiQmJjIiBEjsnlUb1l/PpUBrAugM+Lt7Y23t7etqm5ux6y//n19fXnrrbdsSRJW7zZjlqD177wy2jSZsWal5rQ/MTGR6Ohoxo4dm2MRz9KOo6sjo9d25XyqOyM6rqAil1jDXQweYjCy8zLMaRlkJGrVgvffh0OHVFIFwL//qhW999wDn32WKQMw4/KqhQth8WIYMgTWrYOnnoJHH712fN++4qfPXBzSzD3yOigiiSISlsVoZTweJiI+IuJTvXr1fF2wS5cu13199tlnmdpbpZGsUkc5vfJDblJH1n99fHwyrcbP+qWam2KClkpSpd2tGX32pKTJHxVH/P39s8lPWZkzZw4+Pj4EBwdnU58oS5gcTYxZ05mzqRV4q+MyBIMPV3aluvN5loZkKWfi7KyMEiiV2ffeg0uXVJn6226D5s1h27ZMp7i4qEz2qVNVGPCff2DUKHUsIQGaNoX69VUVkUWLICmpEG76OhS2gUoks0GqApQe/ZN8kpPUkZX+/fvnKbVjVUyoUqVKpg98WZdKshpz60Jde1LS5I/sjbXsu9XLyfpei46Otq2Zsv74yg/h4eH4+/vb1NETExMzqVQkJiba/f+yJGByNPHpmq6cPXGVvnXWcl4q0PPNNvzvtlUcWZe9cFTk5lsYFj+SyA//gYMH1RxVvXrX5Ca++UapVfz2m5KiQFUDadPmWga7i4taU9Whg9L+690bqlaFBQsK5ZZzxx5xwtxeZJ+D8gBCM2znOad0o6+SMgeVkZCQkEzzTCIiHh4esnnz5kwq0ta2GedYrKXNRZTKNFkmbubOnSuenp7Z5qXsTXGYg7I+w9jYWPH29s50LDg4ONdMs5yOZfz/sM5b+fr6SmxsrMTGxsq5c+ckNDS0TCic20vNXESyvQ+zzhcGBwdny/TLSwW9OH2uC5KE/Wfl1XbLxZEUMUgXv1pr5dKpSyKi0tIzZv5FROTQwciRauIJRMqVE+nbV+S773K9XnKySFSUyEsvqer2IiILFog8/rgqX58fKO5zUIZh+KIy9Ppb/kZEEoEowzB8LfvKnMBcblJHGfH19WX06NHZQnZ5KSaUdamkuLg4wsPDbQt3rydMag2jVq1aNdfQU0aKq/xRXFwcLVq0wNHRkRYtWthVkNWeauY5jTujtxQeHs5bb72VTQqptKig3wxVvCrz+abOrJmxlzqmk0SevJPbal8gbMgKli66agvFJSUpEfVsfPABxMfDH3/AE0/A+vWqSqKVYcPgo48gOhouXsTFBXx9VcVf63/lkSOqLmObNipxcOnSwpmvKjADJSLRItJfRLpLhrkjscwlWV8Fdf3iSl5SR1YCAwOzGRXrF29sbKzNwFkVE6xfGGVVKik6Otqm/mB95SVVFB0dbXsmWcuVZzVAxV3+qHfv3uzevZv09HR2795N797FU83c+uPBakCjo6NtCSbR0dGMHj2aZ599NsdQamlSQb8Z2g9tydH0OqyavI26bmcJ/KUz336TRlfTMsCMu3umrPPMuLhAz55KA/DIEZg/X+1PT1f150eOhO7dwcMD2rZV8T4rIgwbpk4bPRp27FBd9euX04XsjD3csOLyKgkhPo19iYqKEk9Pz0xhuYCAAPH09JSoqKhMqeRz586VkJCQTKFRax+hoaEyd+7cTP1s3rxZvL29baEoa4gqNjbWln5e1GnmDg4OAtheDg4Odul37ty5OabXR0VFZQrhZW2TMSTo7++f6+LcrOG9vAgICMixn7L8uU5PM8vwNsvFgVQBERNpUtM4KT2rbpDxfn/JiS0nb6zDxESRJUtE3n9fxNdXxPr/c/SoSO3aIk8/LbJnj4ioEOCMGSLWj8rlyyJffKG6sEJxV5Ioipc2UJqyRvPmzcVkMgkgJpNJmjdvbpd+Q0NDM1V+tpJ17VdWA5Vx/i+3uaioqKgbUpUIDg7ONh8roj/XIiLnDpyTJzxXiafjQXEiJcMcrllcSZJO5bfKd/9bKbt/2y9pKUqVIiJCJCgol/mqrOzfLzJ4sIibm4jJJDJkiMiuXZma/PqrumaFCiKvvSZy+LD9DFRxSDPXaDT/kYULF9K0aVMcHBxo2rSprdLzzVIQauYZ+76RebyyoIL+X/Fo6MH3sXcTm9qAq+LM3qhDfHjfcu6ttJVyRhKbLzVm6PR7aPqgF04uBi2c9vJln2Vsm7ycr/r8xfjB6zj89+HMa60y4uUFv/yisgNfe02FBlu3htOnbU369IFNm+ChhzLPW9mDEqFmXtrISeooaxw/Li4uR2Xz/EoZ5dWHpvTg6enJzp1azVyjaOzbgPd9G/C+ZducZmb3H3EsnX6Y0N/rcznVhWXSGcEEZvhzFrw6C0BwJBVXkqloukQVp4vUcLtIF+8LtL3Lndt71KHB2LFqndXy5dfWYIWEwP33065da375Rc1RTZigXnbBHm5YcXmVhBBfXlJHVoKDg7OlSovcmJRRbn1oNPbkRtTM/yu5pfMXp891SSEiQqSq6yVpynbpbFouQ+qvkIdqrhcf9x3S0PGwVDbOigtXxCA9y7KPdKllOimzhv99TX391CmRihVVg4cfFsnwPkCH+EomeUkdWclJEeFGpYwKSlVBo8mIv79/gcoThYeH6yiAHfHzg29nl6NbUEtend+Znw7dy8KTd7DxcgsOpNbjrLkyyeKKWUycP3aJ/csOs276TvrWWc8Zc1UGfdWJNuX2Muq+P0m85KhCfyNHwooV0K6dWuF78KDdxqsNVCGTl9QR5K6IcCNSRgWpqqDRZCVrqr690CroBYOfn1I5t5aRz42Kdcrj1aU+HZ5uwbxjHbmYkMr0p1YjAu8u60YVLw/uaXCYLY39lVH65BOVg16xot3GWibnoHLSzRswYAAvvPACSUlJ9OrVK9vxoUOHMnToUOLj43NcG/L8888zcODAfF0/KiqK6OhooqKiaNSoEefOnbMds34oAwMD6d+/P8HBwbb9+SW3PjSagqCgEhg8PDzKjI5kcSYyUi3M7dHDjae/vZuhYWYm+K9g3MJmrL7YirZDoJHDEUYOvZsn9r8JDg52u7b2oAoZ6y9NX19fQkJCeOuttzItAM1NEcHX1zfbr9Tw8HC8vLyyCWzeqKqCRqPR5ERkJAweDJMnq38jI5VW4KsLOnMivQZ/fr6FNm57OJBejyend6ai42Vea/uX/QZgj4ms4vIqCUkSWbXFQkNDbUkOWdeHZNWJCw4OzrbA0dfXN1OSxPX60GhKC8Xpc11aCQqSTMkSQUE5tzu04YQ8UnudOHLV0lYnSZRIcpM6io6OJjAwMNOEc2JiIqGhobZ915Myyk8fGo1Gk1969LhWUyovKaX67Wsx/3gHLl82eOuuFXa7viFSzCpU3QQ+Pj6SUcgyw35y2q/RaEou+nNdOFybg7p+YoUVwzA2i4jP9VvmTZlMktBoNBpN/vDzy79hsjc6xKfRaDQauxEZCdCwnj360gZKo9FoNHbBmvUHVWvYoz9toDQajUZjF5YuxVZA0R5oA6XRaDQau5Ax688eaAOl0Wg0Grvg5wczZwIknL5e2/xQJrL4ateubatTo9FoSge1a9cu6iFockBl/B08Yo++yoSBslcRN41Go9EUHjrEp9FoNJpiiTZQGo1GoymWaAOl0Wg0mmKJNlAajUajKZaUKrFYwzAuAnsy7KoEnM/SLL/78tp/vWM30ua/tLXnuTdKNSD+OtcurGd8o/ddWp7xjT7LwnrGN/uMivszLunfE/Y4P780EZEKN92LPWp2FJcXWWqQAGE5tMnXvrz2X+/YjbT5L23teW5JfsY3et+l5Rnf6LMsrGd8s8+ouD/jkv49UZjPOOvz/a+v0h7iyym/PL/78tp/vWM30ua/tLXnuTdLUT7jG73v0vKMb/RZFtYzvtlnVNyfcUn/nrDH+YVKaQvxbRI71CDR5I5+xgWPfsYFj37GBYu9nm9p86DCinoAZQD9jAse/YwLHv2MCxa7PN9S5UFpNBqNpvRQ2jyoXDEMw8MwDH/DMAKKeiylFcsz9jYMI9gwDN+iHk9pxPKMfS3vZc+iHk9pxfIe9ijqcZRGDMPwNAxjs2EYodd7D5cZAyUiiUAM4FG0IynVDADiRGQsMKKoB1NK8QTiUO/lwCIeS6nE8qXpVdTjKOV0E5FAEYnLq1GxF4u1/IoJABJFJCzDfn8gEWVw4kQkpijGVxqw1zO2nmsYhjfqC1RjwY7POCZDX6EFNNwSh52/JzyBWPuPsmRj52fsY+kvz/YlwYPKlgliubHuIhItIuFASKGPqnRh72c8UES0B5UZuz3jDNEAf3sOsIRjl+drGIaviEQXwPhKA3Z5xiISl6F9nlGAYu9BiUh0DnHKAWT+hZNoGIa35ddl1g9ton7D5Y09n7Hl2GjDMDyv576XJez1jA3DCBCRMMvfI4CxBTrwEoId38NnLfOn7VGh1PCCG3XJwt7vYcu+POegir2BygUPlEtp5SxQBcBilXPDF2ivvzzzhQc3+IwtH+xAYCDqw629qLzx4Mbfx5ssIVRfdOTgenhwg883Qwg10NpWkyce3Ph7eI7lPezDdb4jSqqBygmP6zWwWG29/uG/45HXQcsvUO2t3hweeR3MEK/Xc3z/DY/rNbCEUPsX+EhKLx55HcwQor7ue7gkzEHlRCKZH0IV1C92jf1IRD/jgiYR/YwLkkT08y1oEinAZ1xSDdQcMqeBeugsPrujn3HBo59xwaKfb8FToM+42If4LPMa3QEPwzCs2R+JhmFEZVgMqmPxN4F+xgWPfsYFi36+BU9RPGMtdaTRaDSaYklJDfFpNBqNppSjDZRGo9FoiiXaQGk0Go2mWKINlEaj0WiKJcU+i0+jKWoski1VUKvkEwHPDMK4HpaFhwV+LTv07QvMFZHK9uhPoylotAel0eSBRXusvUX/LhxlODwyNBlQWNcyDOOmFLYtSh+bbmqQGk0hog2URpM3nkCCdcOyCDHjSnl71mS63rXa2fFaGk2xR4f4NJq82QTMNQwDINxSKiAcbCEzD0tYzlbXxlK1OQ7wRmk/+gBzuabv1h0YnUNoMK9reVv68LL074HSMusPbBaRsKzXzS30aOkLIFBEdNFDTbFFe1AaTR5YvuS7oYxKrKVUtYflWDSqhEB4BuPkDXhZjoUBIZa/44BNlr9nA9/c4LUyelPWqsWbAB+Lccp23evcVwyqNIJvXu00mqJEGyiN5jqISIyIdBcRA6XWnteX/0AgwWIwPMlQ78bq0ViMQ46GIT/XylDf7Bvg2etdNweshi4hjzYaTZGjDZRGkwdZPQxLpeBsX/4ZCrl5ADEWQxMjIt3tfa0Mbc9a6hd53sh17Zl1qNEUJNpAaTR5Y51jAmwlrjMmLpy1/Gs1JHNRITpre+8Mf3tY/vUk57pZ17tWRkK4VuzNOj+V43U1mpKKTpLQaPJBBsPhSeYqoKEZkhNsZbEzeENnM7T1NQwjEWVIniUXcrqWNXSXIUFiE+Bj2V9VREbkcV2y9BGMKmXeHZV0sUl7VZriiFYz12gKAcMwNouIThPXaG4AHeLTaDQaTbFEGyiNpoCxhN2s4TmNRpNPdIhPo9FoNMUS7UFpNBqNpliiDZRGo9FoiiXaQGk0Go2mWKINlEaj0WiKJdpAaTQajaZY8n8jzGywknrnLQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    #if uldprocess in [\"ILSDELIKERMM\"]: continue\n",
    "    #if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        #if alg in [\"SVRG\"]: continue\n",
    "        #if alg in [\"GD\"] and uldprocess == \"RMM\": continue\n",
    "        #if uldprocess == \"OM\": continue\n",
    "        #if uldprocess == \"ILSDELIKERMM\": continue\n",
    "        #if alg in [\"SAGA\", \"SGD\"]: continue\n",
    "        samples = read_rust_output(f\"{uldprocess}MS_{alg}_scale4\",cols=4)\n",
    "        samples=samples[samples[:,0].argsort()[::-1]]\n",
    "\n",
    "        #plt.plot(samples[:,0],samples[:,1], label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        linestyles = {\n",
    "            \"GD\": \"solid\",\n",
    "            \"SGD\": \"dotted\",\n",
    "            \"SAGA\": \"dashed\",\n",
    "            \"SVRG\": \"dashdot\"\n",
    "        }\n",
    "        colors = {\n",
    "            \"RMM\": \"red\",\n",
    "            \"LPMLikeRMM\": \"green\",\n",
    "            \"OM\": \"blue\",\n",
    "        }\n",
    "        plt.errorbar(samples[:, 0],\n",
    "                     samples[:, 2],\n",
    "                     samples[:, 3],\n",
    "                     label=f\"{uldprocess}\\_{alg}\",\n",
    "                     linestyle=linestyles[alg],\n",
    "                     color=colors[uldprocess])\n",
    "        if uldprocess in [\"OM\",\"LPMLikeRMM\"] and alg==\"GD\":\n",
    "            xx=np.log(samples[:,0])\n",
    "            yy=np.log(samples[:,2])\n",
    "            m = np.mean(yy-coeff[uldprocess]*xx)\n",
    "            nyy=m+coeff[uldprocess]*xx\n",
    "            plt.scatter(samples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"blue\" if uldprocess==\"OM\" else \"green\"\n",
    "                    )\n",
    "        if uldprocess in [\"OM\"] and alg==\"SGD\":\n",
    "            xx=np.log(samples[:,0])\n",
    "            yy=np.log(samples[:,2])\n",
    "            m = np.mean(yy-0.5*xx)\n",
    "            nyy=m+0.5*xx\n",
    "            plt.scatter(samples[:,0],\n",
    "                         np.exp(nyy),\n",
    "                        10,\n",
    "                         #label=f\"{uldprocess}\\_{alg}\",\n",
    "                         #linestyle=linestyles[uldprocess],\n",
    "                         color=\"black\",\n",
    "                    )\n",
    "            \n",
    "#plt.plot(samples[:,0],np.exp(5+3.0/2.0*np.log(samples[:,0])))\n",
    "#plt.plot(samples[:,0],np.exp(1.0/2.0*np.log(samples[:,0])))\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(\"Step Size h\")\n",
    "plt.ylabel(\"Trajectory Mean Error\")\n",
    "#plt.ylim((None,1))\n",
    "plt.xlim((1e-5,1e-1))\n",
    "plt.gca().invert_xaxis()\n",
    "#plt.legend(loc='upper right', frameon=False)\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "legend_elements = [\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"GD\"], label='FG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SGD\"], label='SG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SVRG\"], label='SVRG'),\n",
    "    Line2D([0], [0], color='black', linestyle=linestyles[\"SAGA\"], label='SAGA'),\n",
    "    Patch(facecolor=colors[\"LPMLikeRMM\"], label='LPM'),\n",
    "    Patch(facecolor=colors[\"RMM\"], label='RMM'),\n",
    "    Patch(facecolor=colors[\"OM\"], label='ALUM'),\n",
    "    Line2D([0],[0],color=\"w\"),\n",
    "    Line2D([0],[0],color=colors[\"OM\"], label=r\"$O(h^{3/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=colors[\"LPMLikeRMM\"], label=r\"$O(h)$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "    Line2D([0],[0],color=\"black\", label=r\"$O(h^{1/2})$\", marker='o', linestyle='None',\n",
    "                          markersize=4),\n",
    "]\n",
    "leg = plt.legend(handles=legend_elements,loc='lower left',\n",
    "                 ncol=3,\n",
    "                 labelspacing=0.1,\n",
    "                 frameon=True,\n",
    "                 fancybox=False,\n",
    "                 prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/gaussian_step_scale.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/gaussian_step_scale.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6678a33e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "06aa5afc",
   "metadata": {},
   "source": [
    "# Explore how many segments is enough"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "6b4fd4af",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:04.261159Z",
     "start_time": "2021-06-04T03:01:03.111154Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess not in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg not in [\"GD\"]: continue\n",
    "        samples = read_rust_output(f\"{uldprocess}MS_{alg}_scale3\",cols=4)\n",
    "        samples=samples[samples[:,0].argsort()[::-1]]\n",
    "\n",
    "        #plt.plot(samples[:,0],samples[:,1], label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        plt.errorbar(samples[:,0],samples[:,1],samples[:,2], label=f\"{uldprocess}\\_{alg}\")\n",
    "\n",
    "#plt.yscale('log')\n",
    "#plt.xscale('log')\n",
    "plt.xlim(0,100)\n",
    "plt.xticks(np.arange(0, 100, 10.0))\n",
    "plt.xlabel(\"Segments\")\n",
    "plt.ylabel(\"Trajectory Error\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/segments_rmm.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/segments_rmm.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "db7747d0",
   "metadata": {},
   "source": [
    "# Posterier"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "32db5d64",
   "metadata": {},
   "source": [
    "## australian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "1fb3964a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:05.366804Z",
     "start_time": "2021-06-04T03:01:04.262819Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "#plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        #if alg in [\"GD\"] and uldprocess == \"RMM\": continue\n",
    "        #if uldprocess == \"OM\": continue\n",
    "        #if uldprocess == \"ILSDELIKERMM\": continue\n",
    "        #if alg in [\"SAGA\", \"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"australian_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,0], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "        #plt.errorbar(samples[:,1],samples[:,1],samples[:,3], label=f\"{uldprocess}\\_{alg}\")\n",
    "#plt.plot(samples[:,0],np.exp(5+3.0/2.0*np.log(samples[:,0])))\n",
    "#plt.plot(samples[:,0],np.exp(1.0/2.0*np.log(samples[:,0])))\n",
    "\n",
    "#plt.yscale('log')\n",
    "#plt.xscale('log')\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Potential\")\n",
    "plt.ylim((None,300))\n",
    "plt.xlim((None,4000))\n",
    "#plt.gca().invert_xaxis()\n",
    "#plt.legend(loc='upper right', frameon=False)\n",
    "leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "#leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "#leg = plt.legend(loc='lower left',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/australian_mp.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/australian_mp.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "d0d0d39c",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:06.498876Z",
     "start_time": "2021-06-04T03:01:05.368237Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "#plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"australian_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,2], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Accuracy\")\n",
    "#plt.ylim((None,1))\n",
    "plt.xlim((None,4000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/australian_ma.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/australian_ma.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "53022277",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:07.578639Z",
     "start_time": "2021-06-04T03:01:06.500404Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "#fig_scale=2.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "#plt.figure(figsize=(6*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"australian_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "        np.mean(samples[:,4:],1)\n",
    "\n",
    "        biacc=np.mean(samples[:,4:],1)\n",
    "        plt.plot(samples[:,3],biacc, label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Posterior Predictive Distribution\")\n",
    "#plt.ylim((0.35,None))\n",
    "plt.xlim((None,4000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/australian_ppd.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/australian_ppd.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d0f1c8b6",
   "metadata": {},
   "source": [
    "## phishing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "b7417e9a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:09.170695Z",
     "start_time": "2021-06-04T03:01:07.580217Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"phishing_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,0], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Potential\")\n",
    "plt.xlim((None,24000))\n",
    "leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/phishing_mp.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/phishing_mp.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "1ff34a24",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:10.759007Z",
     "start_time": "2021-06-04T03:01:09.172683Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"phishing_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,2], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Accuracy\")\n",
    "plt.xlim((None,24000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/phishing_ma.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/phishing_ma.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7dc2b0b3",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:12.386684Z",
     "start_time": "2021-06-04T03:01:10.762134Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"phishing_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "        np.mean(samples[:,4:],1)\n",
    "\n",
    "        biacc=np.mean(samples[:,4:],1)\n",
    "        plt.plot(samples[:,3],biacc, label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Posterior Predictive Distribution\")\n",
    "plt.xlim((None,24000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/phishing_ppd.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/phishing_ppd.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e6d93b07",
   "metadata": {},
   "source": [
    "## german"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "2ab015ef",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:13.483799Z",
     "start_time": "2021-06-04T03:01:12.388378Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"german_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,0], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Potential\")\n",
    "plt.xlim((None,4000))\n",
    "leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/german_mp.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/german_mp.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "6d030b04",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:14.548200Z",
     "start_time": "2021-06-04T03:01:13.484893Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAARgAAAD0CAYAAABAfznBAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAxv0lEQVR4nO2de1zU15n/34ebKKIDincRwWvUJCJobjaJQi7b9JaAtmnTNm0D2e5vt+1uKjG7bbfb7brYdrvdpNtA0jbdpJdE0ssmJttATFKb1ETAqNHEC+NdVG6j3ARm5vz++H6/44BcBpwvwwzP+/XixcyZ7+U5o98Pz/Occ56jtNYIgiDYQVSoDRAEIXIRgREEwTZEYARBsA0RGEEQbEMERhAE24gJtQHBYvLkyTotLS3UZghCRFBVVVWvtU650utEjMCkpaVRWVkZajMEISJQSh0LxnUkRBIEwTZEYARBsA0RGEEQbEMERhAE2xCBEQTBNkRgBEGwDREYQRBsI2LmwQiC0Dcer4d3694lPiae+Y75xEXHDct9RWAEIYxoutjEjtodnGw+ydSEqcxImMGC5AVMiJvQ6/FnWs/w6w9+zYs1L3Ku/RwAMVExLJu8jNw5ueTOyWVawjTb7BWBEYQRyvmO87R1tdHS1cKbp96k/Fg5e+v3orm8SNys8bO4atJVLJ28lJRxKXS4O9hTv4f/rflftNasnrmar2d8HYVif8N+3jz1Jpt3bmbzzs2kJqZy7ZRrAbjQeYG2rrag9UFFSkW7rKwsLUsFhFDT5e1i97nd7Kjdwe663UwZN4WFSQtZPWs1cyfOHfh8TxdvnX6Lp/c/zdtn3u722eLkxaxJXcONM24kw5FBXXsdJ5pP8EHjB+xv2M/+hv2cajnlO35M9Bjunn839y+5n+njp192r6Pnj/LGyTeoPFvJvvp9xETFMD5uPONjx/P0Xz1dpbXOutLvQwRGGNG0dLZwquUUrV2tXDvlWqLUwOMS7e52alw1HGo6hFd7mZk4k9TEVKYnTEcpNWRbtNa0drUSpaKIjoqm09NJh6eDk80nOeQ6ROWZSraf2k5zZzNRKor5jvk0Xmykrr0OgFtn38qdc+9EoWh3t1PbWsupllPUt9dT315PXVsdTR1NAEwdN5V7FtzD1HFTiYuO45qUa5idOHtAG5suNnG+4zzxMfFMiJvAuNhxQ+qrUiooAiMhkjAiae1q5ZtvfpNXjr3ia1uUvIivZX6N62dcf5lQtHW18erxV3nl6Cu8efpNurxdl10zITaB1MRULnReoL69nutnXE9RdhGzEmd1O67xYiOvHn+Vbce30eHpYELcBFq6WjjQeABXh6tPm5PGJLFm9hpumX0LK6ev9OVFzraepexQGb/+4Ne8duI13/EKRcq4FKaNm8aM8TO4NuVaUsalMM8xj5tn30xsVOygv7ek+CSS4pMGfZ5diAcjjBi82kvTxSaONx/nW299i+MXjvPZJZ9lyaQltHW1UbKnhFMtp0iMS2SeYx6zE2czZdwUGtob+OPRP9LmbmNawjRyUnPImppFhiOD2OhYTrec5uiFoxxqOsTxC8dxxDtIiEngBecLeLWXG2bcgNvr5kLnBU42n6ThYgMAcybMYfLYyYZHEB3PwuSFzJkwBwCP9hAbFUt8dDxTE6YyzzGPGeNn9OthtbvbOX7hODFRMcRFx/m8k5FIsDwYERgh5Git+f3h3/P9yu9zofMCAMnxyXzvQ99j5fSVvuM6PZ1sdW7lvfr3OOw67Asv4qLjuCPtDj4+7+MBh1FgeBY/qv4R+xv2MyZmDONjxzMrcRapiancNPMmFiQtuKKQKpwRgemBCEz4Ud9ez966vWw5uIXtp7aTOSWT29NuZ9LYSWRNzWLS2EkDXsPj9eDFO6RwQugbycEII4oubxevHn+VffX7OHbhGBfdF0kZl8LksZNJjEtkbMxYTrWcwnneSW1LLXVtdTR3NQMwNmYsD698mE8t+lTA3odFdFQ00UTb0SUhCIjACFfE+Y7z/PbQb3nm/Wc413aOuKg4ZifOZlzsOI6cOUJ9ez1urxuA+Oh40iamkT4xneumX8fM8TNZlrKMRcmLGBszNsQ9EexABEboFa/2sq9+H9Xnqpk4ZiIzEmbQeLGRg00Hae5sZsKYCTS0N/DSkZdod7ezatoqvnX9t7hxxo1ER13yKLTWdHg6aO1qJSk+adAeihDeiMAI3TjdcprfHPgNW2u2+qaW+xOjYkiIS6C5s5nYqFg+nP5h7l10LwuTF/Z6PaUU8THxxMfE2226MAIRgRnlaK2pPFvJ27Vvs+vcLirPGonym2fdzFfnfJXrZ1xPW1cbp1tPkzQmibkT5xIXHYdXe31DtYLQFyIwo4guTxcvHXmJ3XW7mTl+JvEx8ZQdLOOw6zBRKoqFSQv5wtIvsG7Buu5Ty8dC6oTUbteKUlES7ggDIgITwWitabjYwP6G/eyp28Mfav7AmdYzJMQm0NrVCsCCpAV858bvkDsnl4TYhBBbLEQaIjARQmtXK7879Duqzlb5kqrO807f1HaFYsXUFXzzum9y08ybaO1qpeFiA6mJqaN2MtmoQmuoOwCuY6CiISkNHKlwdi84X4eLF+Dse+A6DpMXBO22IjBhjNaavfV72ercyv/W/C8tXS3MmTCHhNgE4qPjWZu6lgxHBouTF7N40uJuHsr4uPGMjxsfQusFW+i6aAhFWwO0u6D1HDQegZpt0HSkx8EKrNIPUTEwaR5Mmg/1B4NmjghMmODxejjdcpp2Tzv1bfVsP7Wd1068xqmWU8RGxZKTmsN9V93HspRloTZVsIuLF+BUFZyuhrP7oOEwxMRDdJzheXg6DWHxdHY/b8xEmJkJN30NpiwGrweajkKjEybOgqs+CmN7LJD82+B4tSIwYcCJCyd46E8Psb9hv68tLiqOVdNXUXh1IWvnrO2zopkQJNwdsPvXcLjCeK+i+vlRA3weyDF+n2tthDFH/oTP45iYCpPnG2LivgizV0LsWEMoZmVD4gyInwAJkyHeYVzPnznXD8vXJgIzgunydvHykZfZ9PYmlFI8vPJhUsamkBiXyDUp1wy51ocQAK31hpi0NcCF07B3C7ScNfIWsQmgvb386D7aA/y8l0p1PhxzYPU/QNqNMGP55R7HCEUEZgRyru0czx96nrIDZZxrP8eyycv43s3fY+b4maE2LXJpqDFE5OifjWRoq98kw6gYmH87ZH8BMtZe7g0EC637FqG4BPvuayMiMCOIXed28fT+p9l2fBse7eHGGTfyjeu/weqZq7tNvxeCgNcLe56Ftx+Hiy4jJ6GiYNrVsPAOSJoLGbcav6PjIG4YvEWlTBGJnPlFIjAhxqu9vH7idX723s/YXbebiWMmct9V95G/IP+yyW3CFeDuhMqfwnu/NUZZrMLW05YZOYvln4Hl90GifRX2RyMiMCHifMd5XjvxGr/Y9wsOuw4zc/xMHln1CB+f93FZWRxMOtvgvTLY/h/GMO2M5ZD5WRgzAaZeBYs/BlGR4zGMNERghpl9Dft4tPpRdtTuwKM9ZEzMYNPqTdyRdgcxUfLPccVoDfWH4IMXjZ/T74L2GKHPp8tgXk5Y5jLCFfkfPUy0drXyw6of8tyB50iOT+b+pfezZvYalkxeEhlrelwnjETkuOTu7V6PMZTq6QRPl99rdx/tXeDt6r3d97uXdneHMeJzdh+cP27ce+YKuOmrkH4LpK0WYQkBIjDDQH17PV+u+DIHmg5w7+J7+Ztr/4bEuMRQmxUcju+A175rztHAmHNhiYq3yxx+tQEVbSRfo+MgOgZixkL8RJi1Am78O1hwBzgG3uZDsBcRGJs50XyCwvJC6tvr+fHaH3PTzJtCbdKV43FDzauw7/ew+1fGpK41/wTRY4wZpdFxEB1r/sT5/TZfR/XRftl5fu1RPa4no2phgQiMjbxx4g0e+fMjKKV44rYnuCblmlCbdGV4PXD8L/B/G+HMHogdB6v+2hCXMbKuSbgcERgb8Hg9PPbuYzy590kWJS/iBzf/IHyHnOsOQuXP4FSl8brjPIyfBvf8FBZ/BGLGhNpCYQQjAhNk2rraKNpexOsnXuee+fewcdVGxkSH2UPo9cLJnfDWfxkjMdFxMHsVLL0b5q6G+bfBmAjJIQm2IgITJDxeD9tPbefRXY9y2HWYjSs3cu/ie0NtVuA0nzGW9B/5k7GwrrnWWIV7cxFkPwDjU0JtoRCG2CowSqk8wAU4AKfWurrH5w5go9a6aLDnjhS01rzgfIHHdj1GbWstKWNTeGzNY6yetTrUpvVPWyPs/o1RgOhUNZx8x2gfN9lYULfww7DwTmNFriAMEdsExhSPXK11ofm+HMjtcVg6UGCKCUAysAkoDeDckHOm9Qzf/su3+fOpP3P15Kv5evbXuWX2LSO3ELany0jS7vsd7HkOOluMGa3J6Uaidv7tMHWpzGwVgoadHsw6oMbvvUspldnTE9Fa+9adK6XytNZlSqmCQM4NFV3eLn71/q/48bs/BhjyroTd0NoYpdEe87e3+2vrM//XXv9j/D/zdr+W+yLs/4Px03HBGP1ZdJcxCW3qkuB8KYLQC3YKjAMjxLFoxPBQfPgLhunFVAR6rnlOAVAAkJpqzyjNoaZD7KjdQZSKwu11c7DpIFVnqzjVcoqbZ93Mw1kbmNXmggMvQ1e7MarS1gjtTcbCuY5mo/JY3QfGHJG2BuOh7yki/dUCCQax42DJ3cZK4Yw1xqxbQbCZ4U7yOnprNMOpdK21azDnaq1LMcIpsrKyrvgJ1Vqz7cQ26tvqiVZRvHH4BV6v39XtmElxE1gS4+DrCUtZc+IIquoWQzT6I3YcpCw0FtolpBj1RZQyZqNGRfv9NiuYdWsz26OiemmL7n58t3Oj/NpiYNpSY6arIAwjdgqMi+6ikAw4+zh2I/DsEM8NCp2eTv7lL//CH2r+4Gub4PHw5QvN3NPcyhht6NcErxcFRjI0OR0W3GkM3aYsMkoWui8a0+XHJhkV0MYkwvipsg5GGJXYKTDPAcV+7x395FBygJIhnnvFdHg6KHilgOpz1fy14xrW7d5K1+T5JK18kPgFdxgewOl3DcGInwCpNwQ2bCsjMMIoxzaB0Vq7lFLlSqkcs8knGEqpKmCtf0iktXYGcq4dVJ+tpvpcNY8svp9PvfRtWHoPfOy/IdZvP+UFt9lpgiBEJLbmYLTWZX20r+jvfX/n2kGXtwuApedqDG/lzu91FxdBEIaETHjAmIULEH34VWMafMKkEFskCJGBCAzg0YbAxLTWw9XrQ2yNIEQOIjCAW7sBiIkeYxQqEgQhKIjA4BciJc2R3IsgBBERGMDtNTyY6KS5IbZEECILERjA474IQIwIjCAEFREYwN18BoDoSRkhtkQQIgsRGMDTYgpMcnqILRGEyEIEBvC0nAUgetK8EFsiCJFFQAKjlHrIbkNCiae1DoDY+KQBjhQEYTAEulRgpVJqjfm6Umt9wS6DQoG7rR6iIVr22hGEoBKQwGit11mvlVLXmosQnVrr39pm2TDiaauHxHiilQiMIASTgARGKXWt+fKTGKUVyoFXlVLLgSTC2avxenG7OwARGEEINoGGSNswCkKVaa0f7vmhGT5tC6Zhw4b24FYQjUJJUShBCCqBCswDWuvne/tAKfXvwCvBM2mY8XrwANEiLoIQdAIdpnYqpX5ivVFKLVdKpQForR/WWoen9wKgPXiUIlpG7AUh6AT6VGnAFxpprXdh7GkU/pgeTMyVbDkiCEKvBPpUpWutz/docwTZltCgPbjFgxEEWwg0B6PMEKncfJ8LVNlj0jDj9YoHIwg2Eeg8mOeVUk7AKvdWaoZJ4Y+VgxGBEYSgE3DRb1NQdoFvst2asE7uWng9uBEPRhDsINCJdhOARwBra0CFkfgNf4GxcjAiMIIQdAL1YB7hUv6l0SZbQoNvHowIjCAEm0CfqnKt9ata61eBJDNcioylx74cjCwTEIRgE/Cfbb+JdreZ5Rvy7TFpmPF6JQcjCDYR0FNlei9/bb5+GDgPbLbTsGFDPBhBsI2Ak7z+q6W11k/YZ9Iw45vJKwIjCMEm0LjgSWvtUcQhHowg2EagAlNCj6UBSqkvBd2aUOD10KUgJkpyMIIQbAIdpi4BapRSyRjD1ApYATxpl2HDhvbgQTFGPBhBCDqBCkxRz3owSqm1Ntgz/Hi9eBQSIgmCDQQ6itRbsamdQbYlNJgejCR5BSH4BDqKtKZHkwMoBG4PtkHDjtcsmSk7CggCDS0dVB1rCtr1Ag2RNgO/wci9AGQDzqBZEUpMDyZaBbzuUxAiAq01NXWtVB1rpPJoE5XHmjhS3xrUewT6VOVrrY/4N0RODsaDR0FMlAiMENlc7PKw99R5Ko82UXWskapjTTS1dQGQNC6WFXOSWJc1m6y0JFYWB+eegdaD6SkuE4C5wTEhxGgPbhQxEiIJEUZDSweVx5qoOtZE5dFG3jt1gU6PF4D0yQnkLJ5KVloSK+Ykk5GSYMuuGoHmYA4DNVwKkZowhq7DH6/XyMFIiCSEMUa40+ILdar8wp246CiWzZrI/TemsWJOEivmJDFp/JhhsWswIVJkVLDriZWDEQ9GCCOscGfn0UaqjjZRdbwJV7dwJ5n12bPJmpPE0pkTiY8Nzf/vgP9sK6V+Yi14NHd6dGmtj9pk1/Bh5mBkHowwkqk3R3d6DXdSErjtqqlkzUlmRVoS6ZPtCXeGQqAC03PbknfNoeuj/Z2klMoDXBjD2k6tdXUfxxVgjkpprSvMthIuhWE5Wmt7Vm/7cjASIgkjB601+2svsHVPLX/cd4aaukvhztWzJnL/TWmGoMxJIjkhLsTW9k2gT1W61vrdHm2O/k5QSjmAXK11ofm+HGM3gp7HbcHYOdJlvq6w7glsASqsa9iC5cGIwAghRmvN+7XNbN17mpf2nuFIfSvRUYobMiaRnxX6cGco2LltyTqMxLCFSymV6e/FKKUyAUxxSdda+xexKgYqgeQAbRwa2ti2RARGCAVaaz4408xLe2vZuqcWZ30rUQpuyJhMwYfSuX3JtBHtoQyEnduWODDCI4tGLheLLPB5Ow6lVLHWusj8LB0jbOrZ7sMMrQoAUlNTA+nK5WgvHqWIiYod2vmCMEi01hw828LWPad5cW8tzjpDVK7PmMSXVqdz+5KpwzbKYzeBDlMvBwr8krzLlVJpQ0jyOnp7r7V2AdVKqWLTk3FqrUv97v+E1e5/snlMKUBWVpYepC3GNTxu3EpyMIL9HDzbzIt7anlpby2Hz7UQpeC69El84ca53LF0GpMjRFT8GcxT1W1v6gCSvC66C0oyly8vcAKTepyTboZO6X6JXdt2MvBoNyAhkmAPh842s9UMfw6da0EpWDU3mc/dsJQ7lkwjJTHyRMWfQJ+qub2ERI4BznkOI4/iO76XUaQKuid+0zHyLlZ4ZJHc03sJFh6PMXcgWkIkIUgcPtfM1j1n2Lr3NAfPGqKyMi2Z73xsCbcvncaUxPhQmzhs2JbkNRO35UqpHLPJJzZKqSpgrd8xBeZHm/zCpTylVDqG2Ni2g4HHawiMhEjClVBT18LWPYancuBsM0pBdloy3/7oEu5cOo0pE0aPqPhj697UWuuyPtpXBHBMr+3Bxu21QiTxYITB4bREZW8tH5wxRCVrThL//JGruHPZdKaOUlHxZ0h7UwMMMck74vB4JQcjBM6Z8xd5vvokL+6p5f1aY6ONrDlJfOsjV3Hn0ulMmyii4s+VPFVFwF8Hy5BQYQmMDFMLfaG1pvp4E0+9dYyX99bi9mpWzEnim3ddxZ3LpjF94thQmzhiGZTAmGuQHsSYRKeJAIFxe60kr3gwQnc63B5e3F3LU28dZe+p8yTGx/D5G9K47/o5zJmUEGrzwoIBnypzP6QHAWtd0U6MWjDpdho2XPg8mOjwnS0pBJezFy7yyx3H+NU7x6lv6WTelPH868eX8onlM0kYI3+IBkO/35ZSqhKYiLHocIXW+rxS6h6t9Xn88jHhjFtLklcwwqBdJ1w89eZRXtpbi0dr1i6awudvmMuN8yaNmNXJ4cZAcrwWsIaZ5wLvYoRGEYPHY3kwIjCjkQ63h5f21vLUm0fZffI8iWNi+NwNaXxWwqCg0K/AmJ7K8wBKqblKqXuAuWbJzByt9W+HwUZbueTBSIg0mjh34SLPvH2cX719nPqWDjJSEvjOx5Zwd+YsCYOCyGCGqY8AR8C3NmkjEPYC4/F6AIiOlv9Uo4Fdx5t46i0jDHJ7NWsWTuFzN6Rx07zJREVJGBRshvRUmWuRHh74yJGPtRZJZvJGLp1uLy/treXnbx1l9wkXiWNiuO86IwxKmyxhkJ0M+anSWr8aTENChW8mr5TMjDjONV/klzuO86t3jlPX3EF6SgL/YoZB4yUMGhZG/bfs0WaIJEW/I4Z3T7h46s0jbN1bS5dHc+vCFD5/41xWSxg07IjAmDmYGNm2JKzpdHt5+b1afv7mUd494WL8mBg+c90cPnt9GnMlDAoZQ36qlFITtNYXgmlMKHB7JQcTzjS0dPDMjuM88/YxIwyanMC3P7qEe1ZIGDQSGMy2JWt6NOUTCUsFrBBJcjBhxfn2Lp7c7uRnfz5Ca6eHWxam8Pkb0vjQ/BQJg0YQgZbMfBxjmUCDX3OGHQYNN5KDCS/aOt089dZRSt5wcr69iw9fPZ2v5cxn3pTEUJsm9EKgHsyWnqNGSqlhqddiN755MOLBjGg63B5+884JHt12mPqWDtYsmsLf5y5g6cyJoTZN6IdABabBXEnt9Mu73AN83xarhhErRJIczMjE7fHy212n+FHFIU652lk1N5nHP5NJVpq9u9kIwSHQp2obxipqpZTSgMJYmxT2AuORHMyIxOvVvPReLf9RfhBnXStXz5rIv9+zjJvmTZaFh2FEoAKT30uItNwGe4Ydjzb295UczMhAa83rB+r43h8PsL/2Agumjufxz6zg9iVTRVjCkEBr8vYUl2uBJDsMGm6sHEyslGsIOTucDXzvjweoOtZEavI4frj+Gj56zUyiZVQobAl0FGkC8AhGbRgwQiSNETqFNV0SIoWc3SdcfP+VA2w/VM/UCWP47ieWsi5rNrHRUaE2TbhCAg2RHuHSliW2bYIWCmSYOnQcPNvMD145wB/3nSVpXCz/9OHFfOa6OWG1ubvQP4EKTLkVJiml1mitt/Uy8S4s8WijfpZ4MMPHsYZW/rPiEL9/9xTj42L4Ws4CvnBTGonxEqZGGoOZyfsTc2/q28ytXTOIgBDJI8PUw8aZ8xf5r22HeG7nCWKiFQUfSufBD2WQlCDFviKVwSR5XzVfP6yUegDY3P9Z4YEbcxRJPBjbaGzt5CevH+Z//nIMr9bcuyqV/3frvFG72+FoYjBJ3s0Ye1TfjrF/dERMoZRhavu4cLGLJ7cf4afbnbR3ebg7cxZfWTuf2cnjQm2aMEwEGhcUYGy0lg6+inYRkoMxBEbKNQSP9k4Pv/jLUR5/owZXWxd/tWwaf5+7QNYLjUICfap2mVuWRNSOAmAMU0eDTOIKAp1uL7/ZeZxHtx2mrrmDWxam8NBtC2W90CgmUIFJV0rlYKxJSgZygRoiIcmLRoKjK6PneqGVacn8+N5MVs6V9UKjnUCTvE+YSwPWY2wbe9nq6nDFozXR4r0MiZ7rhZbNnMi/3b2MD82X9UKCwWC2LdlFhOzm6I9He4mRqeiDQmvNtg/O8f1XDvK+rBcS+qFPgVFKPaS17nO1tFLqS1rrJ+0xa/hw45UQaRC8dbie771ygF3HXaQmj+M/11/LR66ZIeuFhF7pz4N5RClV6Pfe+h9klWtIAsJeYDxaE408HANRfbyJ7//xAG/VNDBtQjz/9oll5GfNkvVCQr/0JzBzMYelMQpNnff/0NxGNuzx4BWB6Yf9py/wH+UHqHj/HJMS4vjGXVfx6VWpsl5ICIg+BcYUlF0ASqk0pdRcs/1d8/fzw2Gg3bi1JkYE5jJq6lr4YflBXtxTS2J8DA/dtoD7b5wr+zYLgyLQUaSj1mulVBqQB1RrrcN+mNqNJkaJm29xsqmNH1Uc4vnqk8THRvM3t2ZQsDqDieNkIaIweAaz2PFa4JMY4lIOVNtk07BizIMRgTl34SKPvXaYX79zHKUUn79hLl++NYPJ48eE2jQhjOlXYExv5UEgB2NiXanWOiI2vbcwBGb0hkhNrZ08/qcafvHWUbo8mnVZs/nbNfOY4RgbatOECKC/YepKDFF5tjdRGWgYO1xwa03MKJy70Xyxi5/++Qg/3X6Elk43H7tmBl/NWUCabLMqBJH+PJhKYAv0uqujAm5jgF0FlFJ5GBu2OTBGonoNq5RSBYATQGtdMZhzr5TRFiK1d3r4H3MhYlNbF7cvmcrf5y5k4TRZiCgEn/4EplhrfaSvD5VSzv4urJRyALla60LzfTnGGqaex20BHtBau8zXFYGeGww8jI6lAtZCxMe2HeZccwcfWpDCQ7ct4OpZjlCbJkQw/Q1T9ykugXyOsWapxu+9SymV6e+JmJXxMMUlXWudH+i5wcIDET2K1HMhYnZaEo9+ajmr0ieF2jRhFGDnpAYHRohj0Qj0XF6bBT5vx6GUKtZaFwV4rhVaFQCkpqYOyUh3BIdIb9XU843fv0eNuRDxu59Yys0LUmS9kDBsDPesKUdv77XWLqBaKVWslEqnd3qei9a6FCgFyMrKGlKtGjcwNsI8mMbWTr679X2erz5JavI4Hv9MJrcvmSbCIgw7dgqMi+6ikIyZyPXDCfj76i6M5QmBnBsUPBE00U5rTVnVSf7tpfdpvujmb27N4G/XzB/2af0f+chHqK2tHdZ7CkNj+vTpvPDCC7Zd306BeQ4o9nvv6CWHUkH35G06xuhVZQDnBgUPEBMBIVJNXQv/+Lu97HA2smJOEpvuXsaCqaEZGaqtraWysjIk9xYGR1ZWlq3Xt01gzMRtuVkJD/wEQylVBaz1O6bA/GiTGS7R17nBxg1Eh7EH0+H28N+v1fCT12uIj43i3z6xjE9mzyZKyicIIwBbczBa67I+2lcEcEyv7cHGo8JXYP5S08A//m4vzvpWPnrNDP7prsVMSZStQISRQ3g+WUHEQ/gJTGNrJw9t2c2nnthBl9fLL76wkv/61HIRl16orq4mNzeX/Px8ysrKKCsrIz8/n9LSUt8xZWVlbN682fd5WVkZ1dUDR+QVFRXdrtPzfhUVFX1+Zl2/oqKCFStW+O6Zn59Pfn4+PSksLCQ3Nzcgu0YSo37tvRuICZNN17TWPF99iu9u3U/zRTdfvsVI4o6NCw/7Q0FmZiaZmZlMmjSJvLw8APLy8nzCUFpaSk1NDcXFl6Lw/Px8CgsLe72eP+Xl5VRUVFBQUOBr879fTk5Ot+P9P8vMzAQgJyeHjRs3+mwrLCykqKgIl8uFw+EAwOVyAZCbm+s7L1wIrz/dwcbrDZsQyVnXwr1PvM1DW3aTnjKerX+3mg13LBJxGSROpzEYmZWVhcvloqioqJu4AGzcuDGga2VnZ+NyuXwCECwKCwt57rnnfO+dTicrVqzo54yRy+j2YLQHN2pEbxvb4fbw+OtOfvzaYcbERvHdTyzlU9mpYZPE/fYL+9h/+oIt175qxgS+9ZElgzqnpKSE4uJiMjMzqaioID398mlXgXgJFRUV5OTk+LyhDRs2DMqO/li3bh1r167t5hmFKyP/T7edeD14FMSM0G1j33Y28Fc/2s4PKw5y+9JpvPoPN/PpVXPCRlxGEjt37qSsrMznwQBX5HlYIUxhYSHPPvtsECy8hMPhIDk5GafTidPp7FUEwwXxYFAjbqJdU2snm15+n+cqTzIraSw/vz+bWxdOCbVZQ2KwHoZdZGdnk5eX1+1hzcnJuSyhWlZWRlFREXl5eRQXF/vyIWB4PxZOp5OyMmOg0+VyDSgElsczadIkGhoaBrS3sLCQkpIS1q9fLwITtpgezEgJkbTW/G7XKf516/tcaO/iwZsz+MpaSeIGE//wx+FwsGHDBkpLS33hSF5eHiUlJeTmGvM/e+ZnAF9i10rCWt5RX2FSRUUFycnJvuv7J5D9k7nWe+u4oqIi1q9fP+S+jgRGt8BojzlMHfoH+Eh9K//4u728VdPA8lQHm+5exqJpE0JtVthTXV1NdXU1DofD50X4U1xcTGlpKaWlpb6wJDMz0ycIPamoqKCwsJDi4mLfyI/L5aKsrMx3nnU/KyTbtGkTR44YxQfS09MpKiry3Q/wXae6uppNmzbR2NhIQUEBeXl5ZGZm4nQ6KS8v9x0TTiNJSuvI2M8+KytLD3p6emsDy7fczP2Ts/i7u56yxa6B6HB7KHnDyWOvHWZMTBRFdyzi3pXhk8TtjaysLFkqECb09W+llKrSWl/xOoJR7cForxu3Ct0o0jtHGnnkd3s5fK6FD189nW/ddRVTJshkOSFyGNUC4/V2AcMfIrnaOtn00gc8W3mCmY6x/Pzz2dy6KDyTuILQH6NaYNyeTgBioobna9Ba84d3T/OdF/fjau+i8OZ0vrJ2PuPiRvU/gxDBjOr/2R6fwNjvwWit2fTyB5T+ycm1sx08c/cyFk+XJK4Q2YxqgXF7DYEZjhDpsW2HKf2Tk/uum8M/f3QJ0WGcxBWEQBnVAuPxuAGIVvZ+DT9/8wg/KD/I3ctn8u2PLgnrESJBGAwjawrrMOMxk7x25mCeqzzBt1/Yz+1LprI572oRF2FUMaoFxu0xR5FsysG8tLeWh5/fw+r5k/mvTy0nJnpUf90ho7S01FfnpaioCKfTSUVFBRkZGd1m1Vqrljdv3uyr3ZKbm0tpaSmbN2+mqKjosmtLLZn+Gd0hkjVMbYMH8/qBc3zlN7tYnppEyX0rGBMT+tnCoxHrobJmy1qLHXNycigsLOy2Lig9Pb1bbZbc3FwcDodvGUFhYSGbN2/2LQmQWjIDM6r/pHp8Sd7gCsw7Rxp58Jkq5k9J5Gefz5Zh6BDS2NhIVVWV731BQYFvin5BQUE3L6LnuqDesARJaskExqj+n2+FSMHMwew56eILT+1kpmMsT39xJRPHxgbt2mHJyw/Dmb32XHvaMrjz3/s9JCcnh+LiYjIyMnyvLRFxOBxkZWX51ihVVFT4vAGLqqoqqqurqaysJCMjw+e9VFZWSi2ZABjVHozbl+QNjggcOtvM5372DhPHxvLMl1YxafyYoFxXuDLKy8spKSnB4XAwd+7cbp/l5+d3K8PQkxUrVvgWMfqHU1JLJjBGtQfjG6YOQpL3eEMbn37ybWKio/jll1YxfeLYK75mRDCAh2E31urjnJwcXz2WsrIyn6dSUFBAUVHRgKuU8/LyeOCBB9i4cSMOh0NqyQTIqPZgPEHyYM6cv8i9T+6g0+PlmS+uIm1yQjDME4JAZWVlt9ETh8NxWZ4lJyeHTZs2XfYwNjQ0dPNUkpOTqays9HkgVi0ZC6uglX8tmZKSkm7iYiV28/LyfD+W2PRGz1oy/n3pr5ZMf9ccTka1B+MOwihSQ0sHn/np27jauvjll1axcFpodlMUescSBafTSWNjIy6X67IRmsLCwm6lNMHwfKwkrOXdFBcXs2XLFuBSbkdqyfTPqK4HU7XrST6/50c8cfVXuW75Fwd9zwsXu7j3iR0cOtvCL76wkuvSJw180ihA6sGED3bXgxndIZIvBzN4D6a908MXn9rJB7XNPP6ZFSIugtALo1pg3NoQmMHmYDrcHgqerqTqWBP/+clrpZaLIPTB6M7BWEsFogP/GtweL1/59btsP1TP5nuu5q6rZ9hlniCEPaPag/H4PJi4gI73ejVFz+/l//ad4Rt3XcW67Nl2micIYc/oFhgrBxM9cIikteZfXtzP89Un+WrOfL5409wBzxGE0c6oFpjB5GB+8MpBnnrrKF+6aS5fWTvfbtMEISIY1QLj8VqjSP0LzONv1PDYa4f5ZPZs/vHDi1FKarqEE72Va/Cnt9IJFoGWY+jvGr0xWso1iMDQf4j0zI5j/PvLH3DX1dP57ieWibiEGf7lGvLy8pg06fLpBNZapZ6Ulpayc+dONmzY4Dv/2WefpbGxMeBr9EVvx1slGbKzs/ss15Cdnd1ruYbMzEzfhEH/2cdSriGEeLweoO8Q6fe7TvGNP7zHmkVT+OH6a6WObhjSX7kGi95KJwy2HMNgyy+MlnINo1pgrBxMbx7MK/vO8A9bdrNqbjL//elMYqUaXViSk5OD0+nsVr3Of/1Oz9IJFv2VY+jpXfR1jb4Y7PGDYd26dYPypOxmdM+D8YVI3Yep3zxcz//71S6WzpzIk5/LJj5WqtENleJ3ivmg8QNbrr0oeRFFKy8vY9kTq3pceXk5c+fOpampyfeZf+mE/Px8X22WwXgWfV0jWMcPBv9yDWCsXwrlso1R/WfZ08soUtWxJh74n0rmTk7gF/dnM37MqNbgsMfKwViLEzdu3NhtpbFVOsFa3OhfUrNnUrSsrIyMjIzLavP2dY2ioiIKCwsvK6HZ1/F9YSV8B1uuIZAKfXYzqp8eXw4m2igMtf/0Be7/+TukJI7h6S+uxDEusAl4Qt8E4mHYifXX20pw+pdrsEonWO937txJWVkZGzZs6FaOwaoOl5eXR0lJia8cw0DX6Jm/Gej43uhZrsFfrPor11BUVMT69esD/6JsYlR7MG5tCEx0dBw1dS189mdvkzAmhme+uEo2oY8QrHINZWVllJaW+so1WKUT/IeDXS4XJSUlvjZLIKxh7s2bN3crxxDINfwZ6Pjq6mqqq6t9orN582by8/N9uSD/cg1lZWW+XA5cKtdg5XR6lmvYuXNnSIapbS3XoJTKA1yAA3BqrS/roVKqBLCyUjla6839tffFUMo1lL74RR5teIcXc7byyf85RKfby3MPXk9GyvhBXUfojpRrCB/sLtdgW4iklHIAuVrrQvN9OZDby6HpwBagwjp2gPag4TE9mAd/uZuWjjh+U3CdiIsgBBE7czDrgBq/9y6lVGYvXkwxUAn0LAPWV3vQuOjuIkprzjZ7eOpL2SyZMdGuWwnCqMTOHIwDIzyyaKR3sUg32x1KqeIA2n0opQqUUpVKqcq6urpBG1hT10w08Oins1kxxzYdE4RRy3CPIjl6NmitfTONlFJPKKXStdbOvtp7ObcUjBzMYI154Ja/5wZnJTcumD7YUwVBCAA7BcZFd0FJBroJhJkETvdL4Db21x5srllwC9csuMWOSwuCgL0h0nNAht97Ry/5FyfgP56XbHopfbULghBG2ObBaK1dSqlypZS1cMOXR1FKVQFrtdbVSqk8pVQ6Rs4l3zy313YhPJg+fTpZWVc8wikMA9On25seGNXblgiC0DuybYkgCCMeERhBEGxDBEYQBNsQgREEwTYiJsmrlKoDjoXajgCYDNSH2gibifQ+Rnr/ABZqrROv9CIRUw9Ga50SahsCQSlVGYzs/Egm0vsY6f0Do4/BuI6ESIIg2IYIjCAItiECM/wEt4z8yCTS+xjp/YMg9TFikryCIIw8xIMRBME2RGAEQbCNiBmmDiVm/eECwNWjUFavRc8H2z4SMG1LBlYAW7TWFX7tLiKnj04gCy4VQ4ukPsIl+4bl31BrLT9X+APkABuAAr82B1Di9758KO0j4QfIBDL93jdFYB8dQFUk99HPvnKMnTps75+ESEFAG38JXD2aey16PoT2kUAy4L+zQ+MQ+zJi+6i1dmmtVwCYdYisiWYR00eTLAyBsbC1fyIw9uGg96Lng20POVrrnlvHJGvDLXYQIX20MAuk5XGpyJmDCOmjKQQ9Z+g6sLF/IjDDiyNI7SHD3OGhvwqDjiC1hwTTG63GyKn1hSNI7cOO1toVwGGOILVLktdGXPRe9Dx5kO0jBjO596y+lNRzEWF9BENklFJblFJW6Ovw+zgs+6iUKsAIbdOBbGCSUsqJzf0TD8Y++ip6Ptj2EYHpXldro15yuvkfNWL6aO6x5b//lrWTRUT0UWtdqrUu01qXYQhCuTYK6dvaP5nJGwTMuL0QQ9mL9eXDf4DP/R50e6gxxeVVLj10yVrrJPOzSOmjA3N4GmPUDH1pn/SI6CP4/i2LMUSmWGvttLN/IjCCINiGhEiCINiGCIwgCLYhAiMIgm2IwAiCYBsiMGGCOTRcbG6pm6OUylRKbQjCNauCMZXdHIXp7z5bzHvlmT8blFI1fZ0zwL1yhnqu3zUcV3K+EBgiMGGAKQAlWusicy5DBcYEp/VXcl1zHkS3IcYreHDXDXCfcqDSmothDgEXmvNpBoXZ/yudvHaZvVcqWsLliMCEB0/QfbGh9ZDZsRn3iiGeVzjwIZdQSjnMPjiGeL8rpTd7h9p3oQ9EYEY45l94h+kF9KTEPCZPKVVjhg5bLPfffJ9jhlYOv2taYUoOkO7XnglU+b0vMM/foJRymK+bzPAsRyll3T8HcJjXHDDcMidqpQOYM4PzrOuan2+xZtX21Qd/my3Pwy/ky/H7/LLze7O3l75boaj1PVnXuqz/Qt+IwIx80rm8FARgPJzmb2v6dyNQ5LegLd/0EsqBjeB7kLL9Qq3GHtdz+h2XYR5TyqUZypXmsRUYS/VzrNfmNfubFp9uiktuj36UYYRqlt0lWuuivvrQy3fgNF87gWd7HHLZ+b3Z20vf081V5GVAvp/HdVn/++nvqEcEZuTTiJ+XAb6/2nmqu8eQrLWu9vd0epRYcJi/1wM7/dpdfdx3PdBgPWw9bLDu0TCYjmBUPysDLPGwPDQwvLHLwpY++hAwQzy/EGNFtUUNRlExi6H2f9QhAjPC0ZfKFDp6tLmAjX4eQ2PPc82wIKe3zwLAgbm40fzxeR39LfkPJGlrFney7LZCpQogR3Uv9nSlfRjw/EEkmX01TwIseSAgAhMuPICR6A0YZSzPb/BfiGZ6I89iLNe3cPRxiS34hTIB5FasBzjgUSErv+TXVAnkWQ9wP33oictPgLOtaw5wfn/2bsFc8Oh3zRGzYDGcEIEJA8ywYpP/PBiMB2QT+JKWWeYDZVEBZPTIEViV6KyEcCbGX2b//Ey6UqrAfCit43J6fL7BFIdczPwEUNLj/j78js3ynweDkRfxT16X0D1k67UP/nb6nbfO73spNG3q9XzrHH97e+m7y0ryYuSEnAP0X+gFWU0tCIJtiAcjCIJtiMAIgmAbIjCCINiGCIwgCLYhAiMIgm2IwAiCYBsiMIIg2IYIjCAItvH/AXRekptDayyLAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"german_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,2], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Accuracy\")\n",
    "plt.xlim((None,4000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/german_ma.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/german_ma.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "ad91b83f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:15.641936Z",
     "start_time": "2021-06-04T03:01:14.549478Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"german_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "        np.mean(samples[:,4:],1)\n",
    "\n",
    "        biacc=np.mean(samples[:,4:],1)\n",
    "        plt.plot(samples[:,3],biacc, label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Posterior Predictive Distribution\")\n",
    "plt.xlim((None,4000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/german_ppd.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/german_ppd.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2e611aa7",
   "metadata": {},
   "source": [
    "## mushrooms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "047e10bc",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:17.148454Z",
     "start_time": "2021-06-04T03:01:15.643813Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"mushrooms_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,0], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Potential\")\n",
    "plt.xlim((None,8000))\n",
    "leg = plt.legend(loc='upper right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/mushrooms_mp.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/mushrooms_mp.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "a3cad36d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:18.692017Z",
     "start_time": "2021-06-04T03:01:17.150163Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAARgAAAD0CAYAAABAfznBAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAArYklEQVR4nO2de2xcV37fP2eGM+TwOSJFWVzLeozsSPY+YlOUd5smu90Vuc1rEaBLShu0m8ZtVkzaFGmARLQcpGmBIF66LRCgLRJytwjQIkFtcdM/nCIP0oumKbJOTHE3qdfWbqSxHrYpiSI1Gr5n5s7pH+feyzvDeZHDK86Ivw8wmLl3zr33N0Pe7/x+v3PO7yitNYIgCH4Q2G0DBEF4dBGBEQTBN0RgBEHwDREYQRB8QwRGEATfaNhtA3aK/fv366NHj+62GYLwSHD58uV7Wuvuas/zyAjM0aNHmZ6e3m0zBOGRQCl1YyfOIyGSIAi+IQIjCIJviMAIguAbIjCCIPiGCIwgCL4hAiMIgm+IwAiC4BuPzDgYQXjYZHWW+dV57qzcYW5ljrnVOe6t3uPuyl3m1+aJBCN0N3dzoPkA3ZFuupu7eaz5MXpaewgFQtu/cGoFVhcga4FSZp8KgApCIGierRSs3IPlOVi+B41t0H0CokdMm4eECIzwUElbaa4nr3M9eR0raxEMBGlQDeY50EBTsImuSBddTV20hFpQzg1UIYupRT5Y+oC5FXOzz63OMbcyx/zaPMvpZdYya6xb66xb66xl1sjqLPua9rE/st+9bleki8ZgI5lsxn2ks2nWrXXurNxhdnmW2aVZZpdnSWfTOddXKPd8a5k17t66y5q1ltMmoAL0tPRwuO0wT7Q9weH2w3Q2dRIOhglZGcJrScKrCUIr84SX5ggt3iacnCW8fI/wyn3IrLEUCLBoP5YCKm87wGJAsRgIsBII0Kg1TdksEa1pIkhzU5SG5k4yTVGspg4y4WasbArLStFCgGhDc9V/ZwcRGME3VtIrTN+Z5rvz3+Va4hpX71/lRvIGGZ2p6HhXbCJd7G/aT3dzN/sj+9kf2U93pJvWcCs3kzfNuRNXuZq4yp2VO5vO0xZuM+1DrTQ2NLIvtI+mYBNNDU0oFAtrC9xZucN357/LwtoCWZ0talN3pJuelh6e7nqaM4fP0NPaw8HmgxxoPsD+yH46I5053onWmqX0EnMrc9xdvcvt5dvcWrzFreQtbi3e4k/i/4tkZrn8lxEGwkHYt79kMwW0BsK0Bhtpa2ihOdRCEs1aZpXV9BJrmXVWdYpMapaG9Q8JPtA0aE0DoDQsBxRrgZ3LnPgqMEqpQSABRIG41nqmQJvzwALQCUw7bSo5Vqgt0tk0b997mzc/fJM3Z9/kb+f+lozOoFA83vo4T+57ks8e/ixPRp8k1hEzXoI2HoKVtcjoDKuZVeZX581jbZ57q/e4t3qPm4s3mbk7Q2I9sem64UCYWDTG6YOnOR49zpH2I3RHNsSoqaFpo7HWkFqG+b+D2b+BD78Dd65CpBN6+rEOfoxE9BDp1DINqSVC60s0rC/SYD8H15dMOBLYD4FuUFFQrRCIQDACBCE5Cw9uQeIm6sEt2h68T9uD94k9eB9WE5BNg5WGzBqkV3gQCJDoPErq8edIt3+EVHMX6cg+Us1R0o3tpHSGVDZF2kqTslJoNK3hVtpCbbSGW2kNtdIWbqMt3EZLqIWAqlAgMutw/zo8eB9CEQi3QLiVtdQSEZ6t9t8B8FFglFJRYEBrPWxvTwIDeW16gVP5bSo5VvCHtJXmg6UPuLl4k5vJm9xdvctKeoXVzGrOI2WlzCNrntNWmmQqyZq1hkLxTNcz/MxHf4ZP9XyKH+z+QZpDO+N2p620KzrJVJJDbYc41HqIYCBoxCNxE278JXz3z8zNnFqG9DKsJU0uYnkOMqsbJ2zsgIMfM4JwdZKgztJVyoDGdpP7SFfgdThE9kHHIYgehoOfgGDIfoThsY/REfsMHR2HtvmNVEFDo8nLdJ/I2d1UpPm2LrGD58rnLHDNs51QSvXmeSL9BdrEiuzPP1aogkw2w43kDa4sXOF797/H9+9/nxsPbjC7PIulLbddOBCmOdRMpCFCpCFCU0MTkYYI7eF2QsEQ4UCYcNA8WkItPHfgOZ4/+DwdjR2+2B0KhuiJdNOzfB8e3IObf2N+gR/chA9mIPmBbXgbtHRBuBVCzeYm3/8D0LIfWrrNzf6RZ2HfsY1EaWoF7r4Dc9+DsH1MZB80RaGpwyRKnQRpasUkUZfmYGXeTqjeg/VFaHsMOg5D9AnoeAIaW335LuoBPwUmiglxHJwwyEucXM8kZj8qOdYJr84DHD58uDprH0G01txfv8+txVu8v/i+if0Xb7k5i3VrHYBQIMTx6HE+vv/j/HjsxznSfoTDbYc53H6YfY37tpxorcJgSC2ZG3Vl3jzWHmw8FmdNWHP77VwvJNQM7Y/DE5+EIz8Eh/8eHHgGtppLCDfDoT7zqKRt+LARKqEoDzvJG/VuaK0nlFIDttcSLXhEkWPt48eBcYC+vr49uTxCYi3BlftX+HDpQ24v3+bOyh3uLN9xezuW81z5A80HONZxjC+d+BInOk9wovMExzqObb/bVGs7l7BqYvrMKizdNaFK4qbxKNaSkF6xw5VV+7FijsusmXyElTKPEglWGtvhsY9B3wvQ8ywcOGk8hMi+DS9EqCn8FJgEuaLQifFYctBaDyulYlrrGfuXcpoNL6bksXuJ1cwqd1fuciN5g3fm3+Hd+Xd5d+FdZpdn3TYKRVeki4PNBznSfoRP9nySQ62HeKLtCQ61HeLx1sdzE56lyGZhLQErC8b9X7xtPz40z8kPzWNx1ohFMSKdEIlCqMX+1W8xIUqoCRoiJg/Q0AiBBpOTaGqH5v0mlIl02iFKh9nf0FjVdyg8fPwUmNeAUc92ND+HYnsuw1rrEfv1tNY6oZQqe+yjRlZn+XDpQ+IP4sQTca4nr7seyd2VuyRTSbetQnGk/QjPdj/LT5/8aU52nnR7TkJB2xPJZo0Y3L8B967DtW8ZD8LxFDLrZju1ZD8vG6FwvIu1JHhyMS6BELT1QPtHoOcTcOLHoLnThCkNjdDQtJHj6DhkBEXYs/gmMLZQTCql+u1drmAopS4DZ7TWcaXUW3abXqfXqNSxNY2Vge/8Pneu/gkroSZaGvfREukk0thOIBhGB4LM6wy3dIqbep1b1jI31xe4vvwh7yVv5gzI6mzqpKelhyfanuDUY6c42HKQA5FuDrV8hBMdx2gJhI1QOD0j1980PSF3r2wkKr15CpS5+YNhaAibZ7tbknCLEYxQs/1oMonN5i7jSTR3QutBIyzNnRKOCBWjHpWVHfv6+vSulczUGr7/pzD1Gyze+x6fOXKIdN5NGMma3MKqJ/EY0JqejMWRdJrj6QwxHeS4aiSmg3QEwsZbyKY3PIzUUukcBRgR6D5pkpxdx6HzmBke3vGEERZBqACl1GWtdQXZ7tLISN5qSa/CH5yD9/4cOo9z7yf/I+m3f5svnfgST+17itXUEsvrD1hJL2Nl0xyKHOBwqIMnAo08noXQWtJ0ba4vwnrSdH86A7GyaSMyXk/DyVcEGszr5i4TkrR0Q3uPyVkIQo0gAlMtt/7KiMunL8BnLpBceAfehk8f+jQ/cuhHdts6QdhVpFxDtVj2ZLenPg/BEMl1k4xtb2zfRaMEoTYQgakWR2CCxhl0envawyIwgiACUy1WyjwHTQJVBEYQNhCBqRbXg7EFRkIkQXARgakW14MxA9ySqSSRhkh1FcsE4RFBBKZanIpmgQ2BkfBIEAwiMNVSIESS8EgQDCIw1VIgRBIPRhAMIjDVku/BiMAIgosITLW4AiMejCDkIwJTLU6IFLAH2kkORhBcRGCqxUqZ8Egp0tk0K5kV8WAEwUYEplqyGbeLejG1CMgoXkFwEIGpFiu1kX+RUbyCkIMITLU4IRIyD0kQ8hGBqRYr4wrMg/UHgAiMIDiIwFSLldpcqkFCJEEARGCqR0IkQSiKCEy1WOlNpRo6wv4smyoI9YYITLVk0xuD7JxSDUEp1SAI4HPRb6XUIBsrPMYLLZ5mr30UtTcTWuspe/8YMGbv79dav+KnrdsmL0RqC7ftskGCUDv4JjBKqSgw4CymppSaJHehe6dNVGs9YW+PAlP22zHgEjDlnKMmyQuRJP8iCBv4GSKdBa55thNKqd4C7S7ay8bmMwqcotZXdfQOtJOJjoKQg58CE8WERw4LmEXsXbTWCWAEuKyUuqS1HvG8HbPbR23PZhNKqfNKqWml1PTc3NwOmr4FrHSuwEgXtSC4POwkb7TAvhjGU3HCKAC01uNaaydv01/Iy7Hb9Gmt+7q7u/2yuTTeECmVlB4kQfDgp8AkyBWUTiDubWAngadtIRkCZpRS/UqpQaXUBU/TBR/trI68uUjiwQjCBn4KzGvAcc92tEAvUie5YdQkRoTibCR7ATq11jniVDNkjQcjpRoEYTO+9SJprRNKqUm7Gxo8yVql1GXgjNZ6XCl1QSmVsN+KO0JiezExTAg15JedVWOZBeqlVIMgbMbXcTBO93OB/ac8rwuObyl2bM1hh0hSqkEQNiMjeavFHmgn85AEYTMiMNViZYwHIwIjCJsQgakWCZEEoSgiMNWgtduLJB6MIGxGBKYashnz7AmRZKCdIGwgAlMN7ppIJkSSUg2CkIsITDW461KHpVSDIBRABKYaPMvGykxqQdhMRQKjlPoVvw2pS0RgBKEklXowzyulPmc/5C5y8IZIMtFREDZR0VQBrfVZ57VS6ll7flFca/2HvllWD7gejMnBnAif2F17BKHGqEhglFLP2i+/BPRjZj2/oZR6DtiHKbmQ9MXCWia7ESI9WH8gIZIg5FHpZMdvAq8CE1rrF/PfVEp9zm6zt7BDpDQBU6pBQiRByKFSgfmK1vobhd5QSn0V+LOdM6mOsEOkRSxARvEKQj6VJnnjSqnfcTaUUs8ppY4CaK1f1FrvPe8FXA8mmTXPIjCCkEulAqMBNzTSWn8bUwhqb2N7MEltnjsaZZqAIHipVGBiWusHefuiO2xL/eEIjHgwglCQSnMwyg6RnKr/A8Blf0yqI5wQyVoDRGAEIZ9Kx8F8QykVB87Zu8btMGlv4wrMOiC1YAQhn4pr8tqC8m1wB9t9bs8mdx3scg3JzCogHowg5FPpQLt24CXAyWIqTOJ3bwuM68Gs0hRsImwvwCYIgqFSD+YlNvIvtbsI2sPGERhZD0kQClKpwExqrd8AM2pXa/1Ne/RuSeyVGxOYHqd4gYXXsOc1Re3NhNZ6qtJjdx3LDpHSMopXEApRcT0Yz0C7z9vlG0ouhqaUigIDWuspe42jTQvY222iWusJu81ApcfWBK4HsyQejCAUoCKB0Vq/obX+Bfv1i8ADoOCCaR7OAtc82wmlVG+BdhcLLGxf6bG7iyMwqSXxYAShABUneb2zpbXWX6vgsCi5604vYNaidrGXlx0BLiulprTWQ5Uea9t1HjgPcPjw4QpM2mGcgXbpJU6IByMIm6g0RPq6M/eoSqIF9sWAUwBKqckC7xc9Vms9rrXu01r3dXd374B5WySbBpRUsxOEIlQqMGPk3eBKqZ8rc0wi75hOIJ53jkFMLZm47b3M2EnfssfWBFaKTDDMcnpZQiRBKEClvUhjwDWlVCcmXFEYr+PrJY55jdzkbLRAT1An4N03iRGS6QqO3X2sNIuhRkAG2QlCISoVmJH8ejBKqTOlDrDzK5O2RwIewVBKXQbOaK3HlVIXlFIJ+6241jputyl4bE1hpUk2mHWQRGAEYTMVz0UqsPutCo6bKLL/lOd1wd6oYsfWFFbKFRgp1SAIm6m0Fyl/UF0UGAb+4U4bVFeIByMIJak0RHoF+B+Y3AvAaWox6fqwsVIkg0EgKwIjCAWoVGCGtNbveXeUy8HsCbJpkgFbYKQXSRA2UelI3nxxaQeO+WJRPWGlSQbMVygejCBsptIczFXM0H0nRLqP6bre21gpHgQCUqpBEIqwlRBJKtjlY6VJBhTt4bbdtkQQapLtzKZ2Ktod9cWiesJKk1Ra8i+CUITtLlvyHWTZEtOLpCT/IgjFkGVLqsFKkZQuakEoiixbUg3ZDEmynJAQSRAKIsuWVIOVIoklHowgFKHSburngPNOVTtnbWqt9XU/jat1MlaKZSQHIwjFqLgXCVmbehOLWVPRTnqRBKEwlQrMMUnybiapzaoC4sEIQmEkyVsFSW0BIjCCUAxJ8lZBEtuDkRBJEAqyrbWpASTJC0mygHgwglCMrSR58xnZMSvqkWyWpD31UwRGEAqzJYGx5yD9rlJqAbM42t4l6ynVICGSIBSkbIhkT2r8ecBZK/otTC2Yvd1NbaVIBgI0qiCNwcbdtkYQapKSHoxSahrTc3QPOKW17gOmtNYP9nyS10qTDAZoD4i4CEIxynkwZwBn6ZBjwHcwM6sFu5pdR0Nkty0RhJqlpMDYg+u+AaCUOqaU+iJwzC6Z2a+1/sOHYGNtYqX4xPo6R9uf3G1LBKFm2Uo39XvAe+DOTboIlBQYe2nYBGbUbzx/dUalVBS4qLXe1COllBpjoyxnf7H1k3aNbJoXHizC4/3l2wrCHmVb3dR2/uXFUm1s8RjQWk/Zi6gVWp0xBpxXSl2zH/eVUhc8710ChmtOXAAsMw+JQMUaLQh7jm3fHVrrN8o0OYspFO6QUEr15nsxWut9zmul1KBnRcdRzBrVndu10VeslHmWYt+CUJRqBtqVI4oJjxwWyBMLr9jY4dSU5+2Y3T6qlCq4NrVS6rxSalopNT03N7dDZleICIwglMVPgSlEtNBOO5yKaa0Tzj6t9bjW2snb9CulNo27sdv0aa37uru7fTK5CJaZh0Qw9HCvKwh1xLYFxu5JKkWCXEHppPhysxfxeC9KqUFPLgaM91NbuB6MCIwgFGMry5Z8zvugcNLWy2vAcc92ND//4qGf3HAqTm641Km1rq21sCVEEoSyVFoy83cxAjDv2X28cGuD1jqhlJpUSjn9uK4gKaUuA2fyQqK45/WM7cXEMLmYoUrsfKhkJUQShHJU2ot0Kb/XSCk1Uayxg6dHKH//qVLbpY6tGcSDEYSyVBoizdszqb15ly/6YVDd4AhMQDwYQShGpR7MNzGzqJVSSgMKMzfpP/hlWM3jDLSTEEkQilKpwAwVCJGe88Ge+sEVGAmRBKEYFYVIBcTlWWBf4dZ7BOmmFoSyVNqL1A68BHQ4uzBlG77pk121j3gwglCWSkOkl9hYsqT2Br3tBuLBCEJZKu1FmtRav2GHSvvs2dR7O0TKigcjCOXYykje37Fffl4p9SvU4uC3h4lbrkE8GEEoRsVJXmfhe631i8ADoPZqtDxMrBSoIAQe9nxRQagfKro7lFLt9nIlf2rvmmYj4bs3sdISHglCGSpN8p7HLLQWA1PRzp7wuHex0pLgFYQyVOrff9suAC4rCjhYKREYQShDpR5MzJ4VPa+U6gQGMOUw9/A4mJSESIJQhkqTvF/D1HfZj6m1O6W1/rqfhtU82Yx4MIJQhq0sW/JtYG+v5ujFSkkXtSCUoagHY491KYpS6ud23pw6QkIkQShLKQ/mJaXUsGdb2c9OuYZ9wN4NkywJkQShHKUE5hh2tzRmVcYH3jftZWT3LuLBCEJZigqMLSjfBlBKHVVKHbP3f8d+/sbDMLBmkW5qQShLRUlerfV157VS6igwCMxorfdwN3UaGsSDEYRSbGWy47NKqa9ilhMpuaLAniArUwUEoRwlPRjbW/l5zLpF14Bxe7KjIN3UglCWogKjlJrGiMqrhURFKfUrWuuSRb/t9aYTmBUenWVgve9HgYta65GtHrvryFwkQShLKQ9mGrgEZlXHvPcU8HlKrCpgi8eA1nrY3p7ETDHwEgPO22ICZnnZl4HxCo7dXWQ2tSCUpZTAjGqt3yv2plKq3FKuZzEekENCKdWb74lord3KeEqpQa31hFLqfCXH7ioiMIJQlqJJ3lLiUsn7mNAm4dlewHgo3nO4gmF7Mc561GWPtY85r5SaVkpNz83NlTFnh7FSEKx4poUg7Ekedjm2aKGddjgV865VXcmxWutxrXWf1rqvu7t7J+yrHBloJwhl8VNgEuSKQidQLKy6yIb3stVjd4dsRgRGEMrgp4//GjDq2Y6WyKH0A2PbPHZ3sFIQkBCpEF/4wheYnZ3dbTOECujp6eH111/37fy+3SFa64RSatIuVAUewVBKXQbOeEMirXW8kmNrBgmRijI7O8v09PRumyFUQF9fn6/n9/UnWGs9UWT/qVLbpY6tCbIW6KwIjCCUQdbc2A7usrEy0E4QSiECsx1k2di6YWZmhoGBAYaGhpiYmGBiYoKhoSHGx8fdNhMTE7zyyivu+xMTE8zMlE/5TU1N5Zwn/3pTU1NF33POPzU1xalTp9xrDg0NMTS0eU3D4eFhBgYGKrKrlpAs5XaQhe/rht7eXnp7e+nq6mJw0AwYHxwcdIVhfHyca9euMTq6keYbGhpieHi44Pm8TE5OMjU1xfnz5wter7+/P6e9973e3l4A+vv7uXjxomvb8PAwIyMjJBIJotEoAIlEAoCBgQH3uHpBPJjtkJUQqV6Jx01fQl9fH4lEgpGRkRxxAbh48WJF5zp9+jSJRMIVgJ1ieHiY1157zd2Ox+OcOrUpTVkXiAezHdwQSTyYcvy717/LOx8mfTn3Mx9p5ze+8NEtHTM2Nsbo6Ci9vb1MTU0Ri8U2tanES5iamqK/v9/1hi5cuLAlO0px9uxZzpw5k+MZ1SviwWwHWfi+7njrrbeYmJhwPRigKs/DCWGGh4d59dVXd8DCDaLRKJ2dncTjceLxeEERrBfEg9kOkuStmK16GH5x+vRpBgcHc27W/v7+TQnViYkJRkZGGBwcZHR01M2HgPF+HOLxOBMTZiRFIpEoKwSOx9PV1cX8/HxZe4eHhxkbG+PcuXN1LTDiwWwHSfLWLd7wJxqNcuHChZyeIEeEBgZMdZDR0VHGxsZyxMVJ7A4ODroPR2wKMTU1RWdnp3t+b0+QN5nrbDvtSp2zXhAPZjvIOJi6YWZmhpmZGaLRqOtFeBkdHWV8fJzx8XE3LOnt7XUFIZ+pqSmGh4cZHR11e34SiQQTExPucc71nJDs5Zdf5r33TPGBWCzGyMiIez3APc/MzAwvv/wyCwsLroD19vYSj8eZnJx029RTT5LS+tFYz76vr08/tOHpN74Fv/ej8OX/Ccfza3EJfX19MlWgTnD+VqlMlmtzS1y5neTK7CIv/cQzl7XWVc8jEA9mO2QlRBLql7SVZS1tsZa2uL+c4kd/+/9wbW6JtGWcjXBw5zInIjDbQbqphTogqzXr6Q0xWU1brKWzZLJZt816JktPRxOfPXmAkwfbeKannWP7Wwj91s7YIAKzHdxuavn6hN1Ha00mq3NEZC1tsZ7OojFeSUApGhsCtDc10BQK0hQK0BQKcrCjid974XnfbJM7ZDuIByPsEtmsZj1jserxTPK9klAwQCQU9IhJkMaGAEqpEmf2BxGY7SDd1ILPaK3JWJrVjC0iqSxrmc1eSVPI9krCRkiaGgI07GAOpVpEYLaDdFMLO0g2q1nLbIQ2ziOT3ejhDQdNSNPeFHLDm93ySraCCMx2kJG8wjbQWpO2dI6IrKazpDL5XkmQ9kiIplCQSChIYyhAQ6B2vJKtIAKzHaSbuq7wDmp76623GB4eJh6PMzw8TH9/vztKNx6PMzQ0xLlz5+jv72dkxCw4OjQ0RCKRYH5+ftPMa2cwnXc4fywW49lnn7O9EuOZrNqCYtleyZt/8b+5/f4NfuaFn6MjEiISCvDu23/Dr//aS+4cJ++gwJmZGUZGRohGo1y8eNGdrDkyMsLFixeJxWK8/PLLAFy6dCnHRufzOpM8HyYiMNtBQqS6wRmW74yWdSY79vf3Mzw8nDMvKBaL5dRmGRgYIBqNurOah4eHeeWVV9yZ0+Pj41y9epXf/K2vuh7JC1/+aQb/8QuEDsRwAhzHKzFCYnIl//3bf8k333iDf/Orv+Re/1PPn37kasnUp9+12zghksymrnkWFha4fPmyu33+/HnXmzl//nzOPKT8eUH5aK25fXeOheV13rkxy69eGOGf/utf48rtJNfnl7mdXOOf/ctfJhQMcKC9iSNdzZx4rI2PfqSdJw+0cmhfM12tjbQ0NvDJ55/fE7VkxIPZDtJNXTl//CLc/n/+nPvgx+HHvlqySX9/P6Ojoxw/ftx97YhINBqlr6/PnaM0NTXF4OCgnSsxCdf/+62/5vEnP8rly5dp6X6cn/2FX+L9+6v81bf+mieOHCVq50qcxycOfbqs2Xuplox4MNvByphnCZHqgsnJScbGxohGoxw7diznvS9+cZD/8ju/y/zSOvPLKa7dXeKdD5Ncub3I/ZUUR09+jCef+Tjd+ztJLyc50tXCiYNtRIMpGhsCPO7xSoKBynp09lItGV89GHu96QRmlcZ4scXT7MXu4wBa6yl73xgbi7H1a61f8dPWLWGlTHhU412ENUEZD8NvnNnHZ86c4dP/4LO0tEf5+n/7AwZ+4qdYS1v80E+e48KLI0z9xZscecrUrok2h2kKBehqaWR/R4QTB9s58cI/Yd++f8Vv/ttfpzESZWBggLNnz+ZcS2rJbMY3gbHXmx7QWg/b25PAQIF2l4Cv2IutXWJjCdkYcAmYcs5RM1gp8V5qGCu70RU8+ed/ya2FFZ58+uNYWpNpiJANNbOWztIUChJtDvO5z53htf/6n5i4dClnXMnig/uEGzac/M7OTqanp+nr68upJeOEI4ODg4yNjeXUksnHqSXjhGlOpb1iYVJ+LRlvMfJStWRGRkY4d+7c1r+8HcZPD+YscM2znVBK9Xq9GKVUL7grOca01t7yYqPANGZd6trCSovA1ABaa1JWNmeA2mraIpXZGDYfbmnn7e/McPuDmywn7xO21vjn534qJ5z5xX/xC8Tj8RxxmZmZcZOwjhc0OjrqdgE7+RypJVMa3+rBKKUuAAmt9bi9PQZcckIge995jFfzFYzHck5rPeJ5bwoTXrn7865xHjgPcPjw4VM3btzw5bNs4o9+Gd59HX716sO5Xp3hRz0YK7shJN4JfVn7/1cB4QYziS/iSbqGgqrmR7vuJsX+VkqpuqwHEy20ba9RPaOUGrU9mbgjTABKqa85+70H223GwRSc8tPwHJwcjLDjaK1JZWwhyWRZS1msZXK9kmDAjCvpbAm7w+abGoIEKkyyCg8PPwUmQa6gdGIncj3Ega68Y2J26BTzJHYX/DFxm0iItCM4XsmqZ1ZwIa+kORSkszksXkkd4qfAvIbJozhEC/QiTZGb+I1h8i4xcsWoM9972VWstIyB2QKOV+INbdbSFikr1yuJuF6JXa9EvJK6xzeBsRO3k0opZ8yzKzZKqcvAGU8bZ1TQy55waVApFcOIzebFencTKyUCU4QHK2nWM1nuLa0X8UpM4aPmcAOdYRPeRBqCNIhX8kjiaw5Ga11w3QWt9akK2tTumg1WGoJ7exC0ldW8d2+ZK7eTvDtrCkVfub3IB4lV1pfW+TCxSkNOriRIJBSgUbySPcXevku2yx7zYBIrKd6dXdwQk9uLfO/2Iut24rUhoDje3Urf0X18uecI//mPwzzd005DQLySvY4IzHbIZh5JgclYWa7PL/PO7CJXZjfEZPbBmtumq8WIx5c/dYSne9o52dPGkwdaaWwIum2+HgoSqqGqaoXKNXhHuE5NTRGPxwvO3ylWjiF/PEmpcxSiUHtvSQYp17CXsVIQiuy2FVVxfznFu7eTxjOZTfLu7STfv7PkdgeHgsYr+VSsi5MH21wxOdDWtMuWb41i5Rq8TE5OuiNsvYyPj3Pt2rWcEblDQ0M5o2nLnaMYhdp7SzI8KuUaRGC2g5WCxvbdtqIi0laW9+4t8+5sMifMuZNcd9vsb23k6Z42fvaHjrpicry7NWeYfL1SqFxDPqdPn2ZiYmLTjTkyMsL9+/dz2l68eJGFhc2jJgqdoxRbbV8pTrkG53M65Rp2uixEpYjAbAerNkOk+aV1rtxezBGTv7uz5HYHh4KKJw+08fef3M/TB41HcvJgO91tjbtsuX+UKtcAxUsnTE9PF5woWMgL2Gr5hb1UrkEEZjvs8mTHtGUv8zm7mBPm3F3c8EoOtDVysqedH37KiMnTPe3Eulseem5k9K9HubJwxZdzn+w8ycjzm2aQbMIJRyYnJzl27FiOV+ItnTA0NOTe7Fv5xS92jp1qvxW85RrA5It2cxlfEZjt8BAF5t7SutsN/O5skndvL3L17mLOMp9PPdbKjzzVzdM9dq7kYBtdrY+uV7IVnAl+/f39bsmDiYmJnJxModIJ/f39DA3lDr/KL8fgUOwcUq5BBGZ7+DCS11l83Om5ccKce0sbXsnB9iZO9rTxmR/YEJNj+x++V7IVKvEw/MT59XZCm2g06oZIpUonVFKOodw5pFyDCMz2yFY3F+nu4prrkThicvXukrsOTrghwInH2vjsiW639+bkwXY6W2ov71PrODVc4vE4CwsLJBIJtzxmqdIJlZRjqOQcXqRcQx3T19enH1qsOXoUPj4EP/7vSzZbz1hcvbuUIyZXbie5t5Ry2/R0NLlhzdM97Tzd08bRrpaaWp1vq/hRrkHwh0etXMOjgZXOKdegtebu4nqOR3JldpFrcxteSWNDgBMH2zhz8jFOenIl0WbxSoRHFxGYLZK2sgStNN+fW+PSH73jisrC8oZX8ng0wsmDbQw8syEmR7taKi4KLQiPCiIwW+Te4hqPZVL86fcW+H11gxMH2/n8M4+5HsnJnnY6IlIrRhBABGbLHGxv4vIPj/GPjp7kF49/QrwSQSiBCMwWUYEAfQO73/0nCPVA/XZVCIJQ84gHI+w4PT099PVV3cMpPAR6enp8Pb8IjLDjvP7667ttglAjSIgkCIJviMAIguAbIjCCIPiGCIwgCL7xyEx2VErNAX4vTr0fuOfzNfyiXm2vV7uhvm0/obVuq/Ykj0wvkta62+9rKKWmd2KG6W5Qr7bXq91Q/7bvxHkkRBIEwTdEYARB8A0RmK0xvtsGVEG92l6vdoPY/ugkeQVBqD3EgxEEwTdEYARB8I1Hppu6WpRSg0BCaz3l3QaiQFxrPbOd/T7bPAY4C+70a61fqRfb7eueB+IA9fC9K6WiwEWt9aa1WGrZbo+N/fb14GH9r2ut9/zD/qImMTepsz3meX9yO/sfgt2TwLW8a9eL7ZeAqPO6HmwHeoH79nd+zX59odbt9lxz0LM9+jC+c/FgDH2Ym9XhLOYfyCGhlOq121W8X/v/qzQKTAOdnn01b7t9XbTWCaVUTGvtLKFY87Zrrfc5r5VSg1rrCdsTq2m7bS4qpWa01nHPPl+/8z2fg7G/tPxRi1GMC+iwgLmJt7rfb2LO9ZVSzjKCxWzZ6n4/6QM35Kgb2703kR0mTNmbW7Wv2H7f0FongBHgslLqkt4I87ZqY7H9BdnzAgPul1+O6A7t3zG01uNaaycG7ldKFVuIuJgtW92/U0TBfO+27b11ZLsjjLEy/zfF7Njq/p0kBpwCUEpNlmhXzJat7t/bAmO7tjH71+g0MGD/oyfI/dI6McnIre73DaXUoFLKu6Dxgv1czJat7veTeN41Eph//mK2bHW/31xkw3uhhB1b3e8b9v/4tP2DNATM2EnfrdpYbH9B9rTA2B7AhNZ6AvMlTdrx6WvAcU/TqP1Lu9X9fhIn95+8s45snyL3nzSGCVPrwXYA58Z0qAe7O8m1eRLzP+Sr7TKSFzcPM4r5wke11nFPVxxQsBu1ov0+2z1ov4wBE07yro5sd2L3BVvk68X2y1rrU3n76sHuC55rxrdr41ZsF4ERBME39nSIJAiCv4jACILgGyIwgiD4hgiMIAi+IQJTJyilYkqpUXv8S79SqjdvHMx2z3nZGbpf5bmiZa5zyb7WoDOGRyl1rdgxZa7Vv91jPeeIVnO8UBkiMHWALQBjWusRe9zOFKaL91w157W7tXO6GKu4cc+Wuc4kZqDXhP14BRguMYK3KPbnr3Zg2iZ7qxUtYTMiMPXB14Bh7w77JtuRyu95nCrfpCDD5ZtsoJSK2p8hus3rVUshe7f72YUiiMDUOPYvfDRvBqzDmN1mUCl1zQ4dLjnuv73db4dWUc85nTClHzNIz9nfC1z2bJ+3j7+glIrar+/b4Vm/XY/GrTNin7NsuGUP1IqBmUBoH3ffOdb+DKOlPoPXZsfz8IR8/Z73Nx1fyN4Cn90JRZ3vyTnXps8vFEcEpvZx5uhswhmi7ZnqsACMeCbhDdlewiRm/oxzI532hFoLeeeLe9odt9uMY0Y4u16T/TqhlOp3XtvnLDXk3Zn3NZD3OSYwoZpj95hntu+mz1DgO3CKVsWBV/OabDq+kL0FPntMaz1l2zbk8bg2ff4Sn3fPIwJT+yzg8TLA/dUeVLkeQ6fWOqfWh9baGwZE7edzwFue/Yki1z0HzDs3W54NzjXmt/JBMMPTJzBlA5zP4px3jAJhS5HPUDHbPH4Y8ArlNcz8I4ftfv49hwhMjeP8wnrDA3tfAlO+0bkRFvKPtcOC/kLvVUAUmLFFa0Zr7XodpcoUVJK09ZRpgI1QaYqNkhNubqnKz1D2+C0kmd2aJxWW9xAQgakXvoJJ9FaMMqUo5r0T0Wxv5FVMaQqHaJFTXMITylSQW3Fu4Ip7hZz8kmfXNKasY8J+v9hnyCfhEeDTzjnLHF/K3kuY8pgOp8nrbRMqQwSmDrDDipe942AwN8jL4CYt++wbymEKOJ6XI+i0PQcnIdyL+WX25mdiSqnz9k3ptOvPe/+CLQ4D2PkJYCzv+i6etn3ecTBslAxwGCM3ZCv4Gbx2eo476/lehm2bCh7vHOO1t8BnTzhJXkxOKF7m8wsFkNnUgiD4hngwgiD4hgiMIAi+IQIjCIJviMAIguAbIjCCIPiGCIwgCL4hAiMIgm+IwAiC4Bv/H5XtIrYtVsNqAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"mushrooms_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "\n",
    "        if alg == \"GD\": alg=\"FG\"\n",
    "        plt.plot(samples[:,3],samples[:,2], label=f\"{alg}-ALUM\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Mean Accuracy\")\n",
    "plt.xlim((None,8000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/mushrooms_ma.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/mushrooms_ma.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "818ee127",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-06-04T03:01:20.203001Z",
     "start_time": "2021-06-04T03:01:18.693024Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n",
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale=1.0\n",
    "pad = 0.05\n",
    "plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "\n",
    "for uldprocess in uldprocess_list:\n",
    "    if uldprocess in [\"LPMLikeRMM\"]: continue\n",
    "    if uldprocess in [\"RMM\"]: continue\n",
    "    for alg in unbiased_alg_list:\n",
    "        if alg in [\"SGD\"]: continue\n",
    "        if alg==\"SVRG\":\n",
    "            alg2=\"SVRG2\"\n",
    "        else:\n",
    "            alg2=alg\n",
    "        samples = read_rust_output(f\"mushrooms_{uldprocess}_{alg2}_plot\").transpose()\n",
    "        samples=samples[samples[:,3].argsort()[::-1]]\n",
    "        np.mean(samples[:,4:],1)\n",
    "\n",
    "        biacc=np.mean(samples[:,4:],1)\n",
    "        plt.plot(samples[:,3],biacc, label=f\"{uldprocess}\\_{alg}\")\n",
    "        if numpy.isnan(samples).any():\n",
    "            print(f\"{uldprocess}_{alg}\")\n",
    "\n",
    "plt.xlabel(\"Gradient Evaluation\")\n",
    "plt.ylabel(\"Posterior Predictive Distribution\")\n",
    "plt.xlim((None,8000))\n",
    "leg = plt.legend(loc='lower right',frameon=True,fancybox=False,prop={'size': 11})\n",
    "leg.get_frame().set_edgecolor('black')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/mushrooms_ppd.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/mushrooms_ppd.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0802c7fb",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:machinelearning]",
   "language": "python",
   "name": "conda-env-machinelearning-py"
  },
  "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.7.10"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {
    "height": "calc(100% - 180px)",
    "left": "10px",
    "top": "150px",
    "width": "384px"
   },
   "toc_section_display": true,
   "toc_window_display": true
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
