{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "92be371d",
   "metadata": {},
   "source": [
    "# Very Simple IEMM Example\n",
    "\n",
    "This notebook demonstrates the basic usage of the IEMM (Imprecise Ensemble of Maximum Margin) library with a simple 2D clustering example."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b347674f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import required libraries\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from evclust.ecm import ecm\n",
    "from iemm import IEMM, Loss"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "629f8c2c",
   "metadata": {},
   "source": [
    "## Load and Prepare Data\n",
    "\n",
    "We'll use a simple synthetic dataset with 2D features for easy visualization."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "dda95b81",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset shape: (200, 2)\n",
      "Feature names: ['x', 'y']\n"
     ]
    }
   ],
   "source": [
    "# Load the synthetic dataset\n",
    "df = pd.read_csv('data/easy_synth_data.csv')\n",
    "features = df.iloc[:, :-1].values\n",
    "feature_names = df.columns[:-1].to_list()\n",
    "\n",
    "print(f\"Dataset shape: {features.shape}\")\n",
    "print(f\"Feature names: {feature_names}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b285fb89",
   "metadata": {},
   "source": [
    "## Create Initial Clustering with ECM\n",
    "\n",
    "We use the Evidential C-Means (ECM) algorithm to create an initial credal partition."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "99b5158e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of data points: 200\n",
      "Number of focal sets: 3\n",
      "Focal sets F: [[1. 0.]\n",
      " [0. 1.]\n",
      " [1. 1.]]\n"
     ]
    }
   ],
   "source": [
    "# Apply ECM clustering\n",
    "number_clusters = 2\n",
    "model = ecm(x=features, c=number_clusters, beta=2, alpha=1, delta=3, disp=False)\n",
    "\n",
    "# Extract mass functions and focal sets\n",
    "mass = model['mass_n']\n",
    "F = model['F'][1:]  # Remove the first element (empty set)\n",
    "\n",
    "print(f\"Number of data points: {mass.shape[0]}\")\n",
    "print(f\"Number of focal sets: {mass.shape[1]}\")\n",
    "print(f\"Focal sets F: {F}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1d5f7bbd",
   "metadata": {},
   "source": [
    "## Visualize the Initial Clustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "71667e2f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the data points\n",
    "plt.figure(figsize=(6, 4))\n",
    "for i in range(len(features)):\n",
    "    plt.scatter(features[i, 0], features[i, 1], color='black', linewidth=0.5, s=50)\n",
    "\n",
    "# plt.title('Initial ECM Clustering')\n",
    "# plt.xlabel('x')\n",
    "# plt.ylabel('y')\n",
    "# remove ticks\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.axis('equal')\n",
    "\n",
    "# save figure\n",
    "plt.savefig('figures_simple_example/initial_points.pdf', bbox_inches='tight')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2cb5a90b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeQAAAFICAYAAACBcI1sAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjUsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvWftoOwAAAAlwSFlzAAAPYQAAD2EBqD+naQAAgUVJREFUeJztvQd8VOeV/v9IQmVGQgUJmybAxjZgugrujjHYGATYTrLelN1NNvml2rEdOy4YMB1s3Num7Ca/zX9LdvPbjW2QwLjH3UYSvbmAhAoCJFSQRg1p/p/nlUYazdy5c2c05c7ofHcVee57NXNVmOee857nnBi73W6HIAiCIAhhJTa8Ly8IgiAIAhFBFgRBEAQTIIIsCIIgCCZABFkQBEEQTIAIsiAIgiCYABFkQRAEQTABIsiCIAiCYAJEkAVBEATBBAwzclJ3dzeqq6sxfPhwxMTEBP+qBEEQBCFKYP+tc+fOYcyYMYiNjR2cIFOMs7OzA3l9giAIgjCkqKiowLhx4wYnyIyMHU+WmpoauKsTBEEQhCinqalJBbUOLR2UIDvS1BRjEWRBEARB8B1vW75S1CUIgiAIJkAEWRAEQRBMgAiyIAiCIJgAEWRBEARBMAEiyIIgCIJgAkSQBUEQBMEEGLI9CUKwYBe43Xu/wutvlMBma4PVmoSbb8rFnFmTdDvaCIIgRBsiyELYaGxqwRNP/Rl1Z5vQ1tbZd/xExSlkjkjFA/ffgbTU5LBeoyBEw01veWkp9u3YiQ6bDQlWK2YuWogJOTly02syYuxssmmgy0haWhoaGxulMYgQsDeJR9f+EVXVdR7PGTsmE+tWf0/eNATBT2yNjSjc/Biaa+vQ2dbWdzw+KQkpWZlYsvxhWNPSwnqNQ4Emgxoq73RCWGCampGxHlzfu+9YyK5JEKLtppdiXF9ZNUCMCR/zONd5nmAORJCFsMA9Y+c0tRZcf+314pBdkyBEE0xTMzLWg+sndu8J2TUJ+oggC2GBBVyGzms1dp4gCAPhnrFrZOwK1/du3xGyaxL0EUEWwgKrqQ2dZzF2niAIA2EBVyDPE4KPCLIQFmhtSkqK1z2H67fcnBeyaxKEaILV1IE8Twg+IshCWKDPmNYmPbg+a+bFIbsmQYgmaG1iNbUeXJ+1eFHIrknQRwRZCAu0MtFnTGuTa6TMxzzOdbE8CYJ/0GdMa5MeXB8/Z3bIrknQR3zIQlih5YLWJlZTs4CLe8ZMUzMyFjEWhMEhPmRzYFRDh6QgUwRKd5dhx869sNk6YLUmYNHCWciZM1FEQBCEqILvd7Q2sZra0amLaWpGxvJ+FxqMauiQa53Z2GjD5i1bUVt3boAPtvxELbIyh2P5g8uQliZFDoIgRAcU3Ym5OepDMDexQ+1OkWJcWXXWrSkFH/M416VzjSAIghBqhpQgM03NyFgPru/eUx6yaxIEQRCEISfI3DM20q5x+2vSSk4QBEEILUNKkFnAZei8VmPnCYIgCEKgGFJFXaymNnSexdh5ghBqWN9w4OBBvPvue2htbYXFYsENN1yP6dOmBaVilq93+MB+fPDuW2hrtSHJYsW1N8zH1OkzpEJXEALMkBJkWptYTa2XtmZTisW3iFFeMB9N587hpZd+g/r6erS3t/cdr6ysQkZGBu6886dIHT48YK93rqkJv3/pOTSo1+v3sJ6srER6RgZ+eOc9GB5CGyRvDr7ctwe73nwd7TYbEq1W5C+4GZfMFPuOEB0MKUGmz5jWJlZTe4Lrc2ZPCOl1CYIRMaIY19TUuK1RnHmc6w89eH9AxImvRzE+VXNS4/Xa1HGu3/3QCt3X4/Mc3b8XH7/9JtpbbUi0WHHVjQswecYsn66zpakR//XMk2g6W4cOpwYXpytOIHVEJr71y18hOVUaXAiRzZASZL4B0Ges5UNmZOzwIcvdtmA2mKZmZKwH1w8ePIQZM6YP+vWYpm4w8HpHDu7H5TNmaa43NzXhjy88jcazZ9HhFGHXVFYgbcQIfO8X9yHFQIRNUacY11ZXua1RnHmc6/+4aq382w0z/F1VlJRiP5uQtNiQkGzFjMWLkJ2bI78bAwwpQSZs+rFp/R3K2sRqahZwcc+YaWpGxvJHI5gR7hk7p6m14Po77/41IILMPWPnNLUWFNn333lLU5D5xkwxPnOyWvPreJzrP1v+qNd/c0xTMzLWg+tf7duLS2fP0T1PCB6tDY3YvnEzWmprB7TpPFtWjuSsLCxesRyWdMli6DHkBJnwDSA35yL1IQiRAAu4AnmeN1jAZew87ddjmpqRsR5c//zAPkyZqV+zwT1j5zS1Flzf9eZOEeQwwRswinFDZaXbGsWZx7l+++ObJOjRQX4yghABsJo6kOd5g9XUxs7Tfj3uGTunqbXg+sdvv+H1NVjAZYSa8jJ8sbtEOu2FAaapGRnrwfWK0t0hu6ZIRARZECIAWpsSExN1z+H6vBu+FpDXo7UpMVF/lm5CYhKumzdfc40FXEZoMyC2rKY2Qmd7O4r+77/gj+seVUVgQujgnrFzmloLru8v2h6ya4pERJAFIQKgz5jWJj1GZGRg2rTLA/J69BnT2qRHxogMTJk2Q3ON1dRGSDIgtrQ2JSTp3xygd2hdZ2+R15+ffkIi5RDCAi5D5xnMdgxVRJAFIQLgvht9xqNGjXKLlPl49KhR+PmdPw3Y/hyfhz7jC0eNVpGwM3x84ejR+OHP7/H4erQ2uX6dK1y/6sabvF4Lfca0Nnkjxum/G8/W4di+vfAXivmxkmK8vGkD/nvlI+ozH4vIa8NqakPnGcx2DFWGZFGXIEQibPpBnzGtTaymdnTqYpqakXGgi2XY9IM+Y1qbWE3NAi7uGTNNzchY7/XoM6a1SavK2kH6iBG4bPpMr9fB16HPWMuH7IiMY1wEmZHyrjdewyV+FHnZGhux9fHNOFdXNyANW1tejuGZmVj20HJY06Ra2Blam1hNrZe2jk9KwoyCxSG9rkgjxm7v/YsOwHBlQRAEbz5kRsYU438w6EN2wOiU1qZtv/+t2i924CrGDkaOHYfvr17v0zXzNf688hGcrXL3PDsYMXYs7tgg1cKuP7eXH3pEs8raQca4cbhtiFZZNxnUUImQBUEIChRb+oxpbWI1NQu4uGfMNDUjY1/fmHk+bU2jx09A5RefB6wYzJmy3aUqMtaD6+V7duOinFyfnz9a4e+GPmMtHzIj45SsLCxasXxIirEviCALghA0+AZMn7E3r7Ev5C24GacqTnhNj+bfdItPER7F+K1/+Z2b59k1+ubr7nlthwiyC2z6QZ8xrU2spmYBF/eMmabOzpkjYmwAEWRBECKKSbPmIG1EpmYrTQdcv3imdktPrT3jV7c47Rk7FNje/8lVlKVaWBuK7oS8XPUh+I7csgiCEHFv+nfc9wCyxoxVkbAzfMzjXDcSkTEyphhzz9gt4nbanHYttJFqYSEYSIRsIvjmUFJ6AkU798Nm61DzmwsWzkBuzviQpXvUNezmNexzuoaZyJ0TumsQBG9wstP3Hl2nrE2spu4bx3jTLSoyNvq3amTP2BWK/uxbFvl55YLgGRFkk9DQaMOGx7ajrq4ZrU5TqMrL65CZmYKVDy9Gepo1+Newpcj9Gk70XsODBUG/BkEwCkWXtiZ/rE0O9u58zWuHKRUlO4XIwzOzMEF6ZgtBQEIeE8ColGJcWVU/QAgJH/M414PZlEBdw5Yi/WvYUiSNEYSowmifbEdkPGLsOCx76GHJFglBQf6qTADT1IxK9eB66Z4TwbuG3eG/BkEINUatUQlWCxb85Ke4Y8NGaQoiBA0RZBPAPWPXqNQVrhfu2B/Ea9hn7Bpe2xe0axCEUDNr4S1uhWGucH3Bj36ibE4SGQvBRP66TACLpwJ5XlCvoTV41yAIoWbinBzVDlMP2TMWQoUIsglgJXMgzwvqNViCdw2CEGoY8d764HLVDlPLQsU941sflD1jITRIlbUJoLWJ1dR6KWNLUjyWLJoRxGuYqaqpvV7DLd6HAQiCEVgg+Pn+3fjs7dfR1mpDksWKuTfejMtmhLarE/eE/3b9JtUOkx24OMuZ4yNpbWJkLGIshAoRZBNAnzFtRaxk9kRWZgpyZo8P3jXMGY/0dCtaazwPds/IsAb1GoShQ3NTI/7jhSfUmETnwRM1lSdUl63v/uIBpKSGrniKoss9YmmHKYQTufUzAXwzoM943NgMFYU6w8fZYzOw4uHFwb9Tt8eqaXau878cx+zd8uciBCYyphifOVk1QIwJH/M418ViJww1JEI2CWy4sWXj15WtiNXUji5ZTFMzKg22GBfvPoH6BltfFwT3oZwxar10TwXyciYE9VqE6IZpakbGenD9ywN7cdlMKaYSeuANWmVxKQ46Da6YVrAY4/JyomZbQQTZRPCPKi9novoINUU7D/TuH3uaLuuwPe0XQRYGBfeMXSNjV7j+yduviSBHtHiW4BDFs6UFCcnJuFyJp3/WsdaGRuzcsAnNtbU439r/t1NXXq5GOy5c+YiaNhXpiCALCputf+C7Hi0GzxMET7CAy9B5Jp2oRLGpKC3Bge2M1FqQYE3G9MUcMSg+ZdLa0IA31m90E8+zZWVKPG9atQKW9HSfft47N2xCQ0Wl2xqfn8e5vmzL5oj/+YsgCwqrNdHQeckGzxMET7Ca2tB5Jpyo1NrYgB2besXGqQd2XXmP2Cx6ZAUsacbFJtqgeFKM9cST60ueeNyweFYWl6qftx5cryzdjfERPvYxsm8nhIBRsHC6W0GZtu0peNYrYWhAa1NCon53LK5feeMtMJvYUIwbKisHiDHhYx7n+lAuRmOa2pB4lpQafs6DRdsHRNpacP1g4XZEOiLIgiJvznhlrdKjx3qVHbJrEqIT+oxpbdKD65dMnwUzwTS1EbGp2G1cbKKNQwbF81BhkeHn7DC4dcG96khHBFnot149tEhZrDxZr7ge6Xs0Qvjh3xB9xiNHj3WLlPmYx7lutr817hm7RsaucP3AduNiE20YFcXOFuP1AQlGB4AkJyPSkT1kYaD1asPtytrEamoWcHHPmGlqRsZme4MUIhc2/fjR8nXK2sRqahZwcc+YaWpGxmb8W2MBl6HzfBCbaMOoKMYnG68PmFawWFVT60XewyxJmLZkMSIdEWRBw3o1QaxNQkj+1mhrihRrE6upDZ3ng9hEG7Q2sZram3hevqTA8HOOy8tRBXNahWIOuD4uZ07E+5ZFkAVBEAxAaxOrqfXS1sOSkjDtlsU48dkuHC4q6hOCqQUFfntwIwl+j4bEMzfH8HPGxsYqn7GWD5ni7vAhO/9sI9W3HGO3u/dkcqWpqQlpaWlobGxEampqaK5MEEwI77p3H/wcO9/9FLbWNlgtSVh4wxWYM+2yqH+zHerwd//K8odUNbUn0kaPRrw9Bi11Z3G+tbXv+DCLBSlZmViwcqVPHtxo8iE7xNNXH/KAiLd0t6qmdjQbYZqakbHzvz2et/XB5bo3BenZ40LqWzaqoSLIgmCQxnPNePylf0ddfSPa2vvnQiclJiAzIw0P3fl3SBuuX6kuRDaefMiMjCk2cR3n0VR9UlcICrZsifqbNyWeJaWqmpoFXNwzZpqakXGwv/cTnxXjvX/6tde0+fV3/TxkvmURZEEI8BvMyi2/Q1XNGY/njB01Ehse/HHUv9kOdVSnrt2lqpqaBVzcM56+uADo7MJHv/nNgMjYFUbK1951J7Lz8kJ6zUOJHavX4dSRo17Pu3DqFCxasyok12RUQ2UPWRAMwDQ1I2M9uL7n4BfImTE5ZNclhB7ecE3IzVMfzuxcvUZXjAnXDxUWiiAHkY4I9i3LrbwgGIB7xs5pai24/tq7n4TsmoRIFYKha4sKBQkR7FuWCDkK6OruRnFpJQp3HEKLrQPJamzj5cjLGYc4SZ8GBBZwBfI8IXDp4+N7S7H7je1ot9mQaLVizk2LcdGs0FtbjAvB0LVFhYJpEexbFkGOcBoaW7F28xuorW1Ga9v5vuNl5WeRlZWC1ctvQnqaJazXGA2wmjqQ5wmDx9bUiL88tQnnztai06nA6kxFOYaPyMLX738E1tTQWVtobTqrhEB/D/nyJUtgdrq7ulFdXIwjhf375FOWFGBMXh5i48x9kz/OT9+yGTD3T1bwGhlTjCsqGwaIMeFjHuc6zxMGB61NrKbWg+u33HBlyK5pqEfGFOOz1ZUDxJjwMY9zPZSDHno8uPo9uikEY3OMe3DDZVt67VcP4uMX/wlnDh9B44kT6jMf8zjXzUxsr2+ZFe2MhJ3hYx539S2bBfNdkWAYpqkZGevB9dLdnu8UBWPQZ0xrkx5cnz3t0pBd01CGaWpGxnpwvWzf7pBdE9/g6TPuEYKBWSk+Ts/OxoKVK0wpBM6R8TtrN6CxosIt0udjHuc6zzMzlvQ05TOmtYnV1Bnjs9VnPuZxMzYFIZKyjmC4Z+waGbvC9a3bDyE/dzzMCiP4kt0VKNx5oH8PfOF05M7JNs0eON9E6TP25kPmeap5yOEj2Pn+h/3NQ667BnOmTjH1m3EkwT1j18jYFa6Xvr4dF88O3YxcNrygz7iqlB7cwr50L9PUjIzN/vtnmrrFy0QrrleXlmJcvrkrxWNjY5XPOJJmJIsgRzAULyPYbJ0w8x74usd3oLbOdQ+8To17fPShRabZA2fTD/qMaW1iNbVDbJmmZmTMNwDVPOSf/4C6Bop2e9/XllfXIDM9DQ/96AdDonkIb0qOHN6ND9/fibZWG5IsVlxz3UJMmTqwq5K/sIDL0Hmtobe28PujrSkSrU3cMzZi3TqytdD0ghyJiCBHMIwkjWC1DhynaKbImGJcUeW+J6X2wKsa1PoTG24zVaRMn7GW15giRDGuOnXabY3izONc33DvXaaPlAZD87lG/OGfH0djQx3a2/uj2JrqcqSlZ+IHP3oIKcMHlzJkNbWh8yzms7aYGaOWrE6Dk68E34jed4UhAK1NliT9eyquL1t8OcwI09SMjPXgOsdBRgJMUzMy1qOuvgF7DnvvIhSp8KaEYnz6VNUAMSZ8zONcH2yxFa1N8Un6Fe1cz7nZfNYWM2PUkhVvcPKV4BsiyBEMfca0NunB9Zw542BGuGfMSJi9Wz19cH3bawcQCXDP2DlNrUVbRwdee/9Dj+sUqtLD+/H4H17A6l9vUZ/5OJTVwoOBaWpGxno01Nfh6OE9g3od+oxpbdIjdUQWJkbIaEezQGuTa0GaK1yfssz81q1IRFLWEQzTuPQZa/mQGRk7fMhmSfdq7YEPbKQe4/Tf9r7/tRncK4+c5iHae3SNzefw5B9fwtnGerR19Av7iZpKjEjLwK++dyfSUoYj3PDm4NDR3Xjvo51oa7MhKcmK669eiMsnz1F7xq6RsSsdHW348P3XMHWa//YfpvzpM9byITMyphjffr85rS1mhj7j5KwsVU3tCa6PMbl1K1IRQY5wWPD05KYlytrEamoWcHHPmGlqRsZmFWNitcRrCDFcjtlh6TsvWpqHWDRFjmJcfabGbY3izONcX/uzB8MqMueaG/Hbf30cDY0D94era8qRnpaJ+Havs2oUra2Dbx/Jph/fWb1ZWZtYTc0CLu4ZM03NyFjE2HfY9GPe6pXK2sRqatcRkhRjrpu9OUikIoIcBVB0aWsys7VJi8mXXojDn/dMT/I8cywGUy8bhUiA1iZWU+ulrZMSEnDLdde4Hd9z9KCKjPXg+t7PD2LOlBkIB7xpoBifOl3ltkZx5nGr3VihocUSmPaRFF3amkJpbYp2aN265cktytrEamoWcHHPmGlqRsYixsFDBFkIG0e+OK0hxu5p6/2H3KNGM0KfMa1NWlXWDjIz0jF7qnuF9hsfvzsgTa0F11//+N2wCTLT1IyM9eiK7cawYfE4f96z1S4hIQnXXHdLEK5QCBQUXdqaxNoUWkSQhbBha+10EmPPaevj5WeVRcrM6fe+5iE/+kGPD7m+QRVwOUfGFGOua6VSbe363s++89qMnRcMuGfsbX+4vfs8hsXqR8npGZmYPHU2ooXuri5UF5fgc9UIpEVNEbpsyRKMyctFbFxcuC9PiCBEkAXT+6i7uu0o3VOJ/Bzzp+RV85B771LWJlZTs4CLe8ZMUzMy9rSvaU001vzEmmQJakp6/xe78fZnO9HaZoMlyYob5y7EjEt79mNZwOWVmJ5+zQnnY1Q1NQu4nCNjijF9yNGyv9vW0IB31q6DzWW/tb6sDFa13/ooktLTw3qNQuQggiwMHONYUo2tO46gpaUDyckJWLZoCvJyxwQlOl2ycBqOfH4a3hw93d12bN1xMCIEua95yLSp6sMoN111g6qm1ktbJyUk4uarbkAwaGpuxAt/2oKzLNZyEtHKUycwIi0Tv/j2g6qa2gjW5OH46T8+rKxNrKZmARf3jJmmZmQcLWLMyJhi3KRRkUxx5nGuL3zyCYmUI4Du7m5UFpfiYNF2Ndua4zQ5ypHTo0L1NyuCLPS1sFy98R2cqW0ZYJ86XlaPkVnJWLtiXsBbWOb19qo24rE12iY0Upk9eZqyNmlVWTvITM/ArMumBfy1+fOnGJ88o1Gs1dGmjnN96TW3qWpqvbR1YkISvnb1LeoNjLamwVibzA7T1IyM9eD6ydJSjM3P9+m57V1dOLmrGF+wqKqlBfHJybh02RKMzs9DjIh7wGltaMTODZvQrDId/X/fnKvMjA+nQ4ViIIUIsqAiY4rxiUr3LlMUZx7n+tOP3RLQSJnPddGETHz+VU+ldSDS25EKBYw+Yy0fMiNjivH9/3BnUO7UmaZmZKxHTW01/vft/0R7fBe6Ou2I7WZ22n3fPyM9E1MnR8/+sB7cMzbS9/no1m0+CTLT4B88uha2MwPT4I3Hy2AdmYVr160eMmnw7q5uVJWU4HBhETpbbIhPtmLqkgKMzeX+fGzAbkgpxlrzkynOPM51TokKdqQsgiyoNDUjYz24XrK7GnNzA9v167aCGXjhd+/pTq1S7T8XBT4yNBts+kGfMa1NrKZmARf3jJmmZmQcrDcD7hk7p6m1sNvtqGs6i9gYO2ISY9BtB4a12ftEmZExxfjH34+e/WFvsIDL0HkGB2E4ImOKcdMJD2nwExVqff4zT0Z9pNza0IC31tEPXeeyP1+O5KxMzH90pbJoDRamqRkZ68H1ytLdQZ8cJYIsqD1jI2McXy06EhBBVnvVpVXYuv0wmls64G20Kqc+5cw2Z/vPQEMxo60plNYmFnD5gp3/Rx1OScAo64WwWJJVmpqR8VARY8JqakPnGRyEQZimZmSsB9dPlpRizFzf0uCRFhm/tY5zmbWiVs5lrlTri5/YMuhImXvGzmlqLbh+sHC7CLIQfFjAZei8AIxxVHvVm95y26uOi4tRFbqMxAa0/8xMwZqHF5re8mQmmILb89VuvFH6OmztNlgTrbgp52bMnqTdvYrV1P4QExeLmxZ+AzMvjd59Yj1obWI1tV7amt2tJi9bavg5uWdsJA3+xStbo1qQq0pKVGSsB9c5dzp7kF5poxkMoxmRwSCCLKhqakPnDXKMo9qr3vSWxl51DLq6mH7rRlJSHEaNGo4UKyu8p6nIWMTYOI0tjXjyf57A2aY6tHX23/WfOH0CI1Iz8atvPoC05IHFKbQ2sZpaP23tGPfRD89/59MdQ1aQ6TOmtUmrytoB10f70PeZBVyGzvMhDR6JHDY6l3lb4aAF2WgGw2hGZDDIO52grE1GxjjeWjBlUK/DNLXnvWrmQOMQg3h8++s5WL9ikbI5iRgbR/XD/p8nUF1XNUCMCR/zONddq9rpM6a1yRsxAUh3RxO0MtFnnJqd7TYhiY95nOu+WJ5YTW3oPKsV1Z98iveWr8Jb99ynPvMx96CjgU6Dc5l92Z/3BK1Nw7z0oef6tCXBH+UpEbKgfMa0NmlVWTvgeu6cMYN6He4ZG9qr3s696uxBvdZQhGlqRsZ6cH3v8b2YM6l/LCHT2PQZv/CfW1BTVz1g28ARFcfAjhgNRfY33R0qePNRUVqMA68V9XlLp99SgOycvIDsd7PamT5jWptYTe14DaapGRn76j+mtYnV1HrRYVxSEmynTqPk2RfdqrAtrMJeH/lV2PEG5zL7sj/vCfqMaW3SqrJ2wPVxOcEf5SmCHImNO7Yf7W/csXjyoBt38GvpM9byITMydviQBxutGt2DNrqnLQyEe8aukbErXH+9+LUBgkxSU9Kw+IZb8X9f/Q26znchxs76aYcYQ1OMWVk974pFMCutjQ3YsXkDmutqcd6p5ajylmZmYdHylbCkDV64KLq0NfnqNdaCPmNam7SqrB3Yz59Ha22dW8aC4nyOVdir1mL+s5FdhT11SYGqpva2Pz9l6eDnMvPGjD5jLR8yI2OHDzkUBYsiyBFCQ0MbVm98G2dqbRqNO6xYu+JGpKcbG/+nBZt+0GdMaxOrqSme3DNmmpqRcSBSx0b3oI3uaQsDYQHXYM5747PtaI/r4M6BIr4jBrGqnFob7klPnzTbtJExxbihSsM+1NaqjnP9tk1bTFUZThGlz1jLh0wBYkq781wz7J2eM02trMIuLsWYKyK36Gtsbq6yNmlVWTvgKMixAZrLzKYf9BnT2sRqakdPcqapGRlLpy7BpXHH2zhR2eShcUeTWn/68cE17uDX0tYUaK+xg2WLp+J4eb1Xz/Gtiwe3Vz1UYTW1v+dRwMrrygZsFHcm2BHfAcTYBzYBiYmJwajMMbjzOw+bSsycYZqakbEeXK/YXYoJueaaaMR0M33GtDaxmpoFXNwzvvS2ZfjiL6/irBdbFEX8y1e3RrQgx8bFKp+xlg/ZMZd5/qMrAjoKkn/LtDUF29qkhwhyxDTu0I9+uF5SWo25eeb16+bljDW4Vz02pNcVLdDaxGpqvbR1UnwSbs5zH32471gpuuwuhvCYHlGO7QLinGqFLswag4d+sNG0Yky4Z+ycptaC6wd2FJpOkB2RMm1Nrtamw//xp4AWRZkZS3q68hnT2sRqasf+PNPUY6N0LrMIcgTAPWNjjTuOmlqQ1V71I/M1fch9e9WPzJfKaj+hz5hpZFZTeyIzNROzLprldvzN0h2wuwoyiQG6h/GjZz85FrFYdsPfmFqMffKW2oLrLWXVc82uYnz16ra+1o+Tbl2KUX72pI63Jge0KMrsxMbFKlvTYK1NkYIIclQ17jB/MZTaq968GCW7q1Q1taM4jWlqRsZmF2OmdksOfY7t732GlrY2JCclYfH1c5F7+WVhFynVD/ubD2j6kBkZU4zv/+YDHuYxGxOwuNg4zLg4+NWmg8Wwt9SgwPlDW30DPlq1Ru0FdzmlXBuO9fSkvnr9GiRl+FZUdsmt3quwmdK95NZlg7p2ITyIIEdV447IKIbq2avODqu1ifvyJfvKUPjmXrS0tiPZkoglC2Yhd+ZEjzcFDeeasfG3/4Hahka0tfff/JRV1yArPQ0rfvJdpA9PQThh04+1f79OWZtYTe3o1MU0NSNjz/OYjQnYuAsm9D0Hb04OfFWCd4q3o7WtBZakZMzLW4zpk3L9vjnhc355sAS7/lqEtlYbkixW5H+tAJdM8+05aW1iNbVe2npYkgXTFw2+StdTZEwxZtWzKxRnHuf6vOee8ilSZhU2rU1az+uA66PzhmazlkhHBDkCoLWJ1dRei6EKJof0uiKVhiYb1j3zKs6cbUJbe78V6+ixamSkJWPTQ9/EiPQUN6GgGFeecp9MRXHmca4/ft+P/BIjPn/pV/uwo+Qt2NpbYU20YFHufORMmunz86l+2JPmuFmb9FiQswgVp8u97j/fMrenDWRTSwNe+vNGnG2sRbvT11SeKsOItCzceccKpCb7Fv21nGvAn369AU31deho7xfSU1XlSM3IxLd/thLJw409J33GtDZpVVk7oJ0le05whKvGYE/qmuJSjPah+EpVYa9fraxNrKZ2LXZy+JAj2fI0lBFBjpjGHVbNKusBxVA5g2vcMRRgZEwxrjjp1ECjt4C4mxON6ptx58p/w4sb/h6ZTqLMNDUjYz24Xnr4S+RNu8yna2psacLm//csapvqBwhi+elKZKVmYPnf3Iu05FQEk5kX52BEahaq6zzbTLg+86I56uaBYnyy1v1cijOPc/2h7z1u+GaCz0kxrq1xf06KM49z/Qe/MmZT4jn0GWv5kBkZU4wXPbzS70jeMa9Y7Q33VkFzb9gxr5jHndPUWnD9q1e2+iTIfVXYzz6prE2spnbsTTNNzchYxDhyEUGOAHoad9yo6UMOZOMOX+nqtmNX8Um8WvQFWlo6kZxM3/KlyM8bjbhYz/7VcMI0NSNjhdYlxgDnu7qwcsv/4MUN/9D3M+WesXOaWguuF/31E58EmUJEMa6sO+n+fJ1t6jjXN/2D/+JhBD73L7+xHM/872acbap123+mGHOd5+37YpeKjPXg+oFjpZh5ibFiHKapGRnrwfWvDpXi0unGnpNNP+gzprWJ1dQs4OKeMdPUjIz9/XlyXvGHq9a4RaiOTlnXrF9juMrZaO9qzSrsK/Ij2tokmECQVVFMaQWKXtsPm60DVmsCCm6Zgdyc7LAXxQS2o1YVtqmipR6hWrp4CvJy/S9aYtMP+oxpbWI1NQu4uGfMNDUj41CLcX1DG1at/6DnBqG1/wbhWFmjiubXr7oWGYNoVBKw38OeCmx7/UDfz6ulbWCa2hNnG1pQur8M+bMuVo9ZwGUEm8HzHDBNzchYD67vPrYfuZe4V0cHktTkNKz6u03Yd3w33izZ3rf/vCB3sYqMHf8+uWfsnKbWguvv7CoyLMjcM3ZOU2vB9c/eLTQsyITXTFtToKxNjIwpxlp7uI5OWVxPSE4JaO9qYWgQUkHm6L0Nm7ejro6Wl/43xfLys8jMTMbK5YtVFW4k09DQqiLZWhdbD/eAs1Qky45aFv+LofLGhd3axMiYYnyiQqNRSet5dZzrzz0xPyiRMoV2F+cp7+jvKMYBGfk5/Tc8aszjkztQW9c8cMxjQnvPf3i5LKavt725p0+QWU1tBKvB8xxwz9hIu8vtJW8GXZAdAjZ7Uq768AQLuIzQarBym7CAK5DnBQumqRkZ68H1Ufn5KmLWS1vHWSyYdJtUQwv9xIYyMqYYV1Y1DBBjwsc8znXXSTSR2FGrorLRrQCLj3mc6zwvkmGa2kijkuIS9zTsYKHQ/vKRHXjuNx/j0NEzKK9oUJ/5mMe5rn4PT+5AhfpbG/h78OVHb2vtFW9AWZuSEvWr2Lle8LUrffp+WMBl6DwvTS5CCaupDZ1nsHKbsJo6kOcFC+4NGxkLWHf4sLI26cH1UVINLYRDkJmmZmSsB9dLd3uuijQ7TFMzMtaD60w7RzLcM3ZOU2vB9VcKvwjo61JoH93MFqLaNzw8zvXPSk+oyFgLe1ecy1Rfz1gtiX3/TZ8xrU16ZGWkIWfqJQafvfc1Eo1lS6xJ5skc0dqUGK+fCeD6vPwCw89Ja1OCl58F1+feEBybklGMziE+b7Mpn/Hw8dkqEnaGj3mc61KAJYQlZc09Y9fI2BWuF+7Yj7zcCYhEuGdspKPW1qLDYU87DwbuiwfyPKPs0p2n3APX/+uVUs+/B3sc0N17K6qTtrYkxWPpgtkDUrn0GWv5kBkZU4xX/Pi7PtdB0NrEampvdqPFuQtgFugzprVJq8raAdenX6wd/TELduRoCT78qAhtbTYkJVlx9ZWLlLVJq8raQWpGFiZdHt6IktXUhs5LTlZNP+gzprWJ1dQs4OJxpqkZGYsYC2ETZBZwBfK8iBYqg2MIzQqL1AJ5nlG4Z2zkhuf0mf5Uszsx6D6fhNiENt1t5KyM4ciZMXHAMTb9oM+Y1iZWU7OAi3vGTFMzMvanKJE+Y1qbtKqs+64lNQNzLp4Bs8Dvkz5jLR8yI2OHD1nr59Hc3IA//OsGNDbWod0pXV9TU658yyMuGI3mxoYBBV6MjCnG3/6Z9nOGElqbfOmURdGlrclXa5MwNAmZILOaOpDnRbRQGRxDaFZobWI1tV7a2mIZhtuWXBrQ121u6YC9W03n7f1g8pmjiOya83o9E4vujiQkWjtVtMYCrr7rTopXYvzovbdpVq5TEGhr8tVr7PFKYmOVz1jLh8zI2OFDDrcQuULxpM+Y1iZWU7OAi3vGTFMzMta6Xv6sKcanT2v4l9tbcaa9FSNHjkXB4p+j+L3+Tl1MUzMyNsPPwGinLNkbFkwtyLQ2sZpaL23NN8Mli8wTCfgKrU1GOmotK5iKSIY+Y9WopKIJ/VrmrIh2ZGVakJc7OmCv2dDYhpqaVpdcc68oq//v6hPlrIxUnG1y32d2xpKUgF/84wLEDetW1dQs4OKeMdPUjIxDaSNj0w/6jGltYjU1C7i4Z8w0NSNjMwiRFrwu2pqMWpuYpmZkrEdj41l0x8fgu3etgRlhxEufsZYP2dEpi+uSjhZMLcj0GdPaxGpqT2RlpSBnTvj6Gw8W+oxpbWI1dTR31KKViT7jR9a8h6pqG+xKlQfOy+3qikFTU3tAvMgs5lq18V20d3Dz1zUU7n1sZ7FWF6yWYfjuN3Lwp627VJW1J0ZmpiB/znglvA5rU7jFjbYmX61NytdfWYzth4vQ0mFDcoIVi6cWIHdcnumEnHvGzmlqLTo6WvHhR4WYOtW8033YKevGZ3v2hns6ZfXsDTNNLXvDQkQIMt8c6DPW8iGrNGFWClY8vMh0byIem37sOAJbSyesbPqxqL/ph6OjlqsP2dFRa82KG00/0cgIqcMTERsb1xshDxRJHquqbsbKdR/i+SduRFzc4LzIuwzMg+554Rj1M87PHYspl2Vp+pDV7yEzBWt+tSjifw8NrQ3Y+OYG1DbXou18v9CVnS1HVkoWHrnxEXxZ/wWKjmyDrcMGa4IVBVOWIncMxTr0osECLiO0GjwvnMjesBAMYuw94Y0uTU1NSEtLQ2NjI1JTB9dTVzXR312hqqkdnbqYpmZkbHYxpsd1jQexzeoVWzY2UZOESqtVNXVf44qCqWHpqBVIurrs+Ky4Bq8UfqUEsrauFd3dPX8+Wnu43Ee+/xe5uCJ/cKnr5evexqEj+s0YSGJiLH73bEFfcxn1e9hbga07+zt1LVs4HbmzsiP69+D4d/RQ0YOobPC8lzksbhjihgFtXf370pZhFmQmZ2HlvDVIt/g2/GGw/PPv16C8/IjX8yZOmIL/88PwpKxVj+riYnyxtX9+8aXLlmJ0nn/ziwXBFw0NeetMVRSTOyHirE18c6cYa6WjHU0/uP7UY4tM01Er0K0yV6z9qLdVZpfbOm/rXEWZRV8vb/ty0ILMTIQRRl0wfECnN/V7mDNBfUQbTFMzMtajs6sTnfbuAd0GWs+3orKxAhveWYMttzwV0kj5mqsLVDW1Xto6IcGCa65eElIBrqYAb9uG9nPnYDt9mm3a0N3R2Zf3YVU1m3hcu3YNEocPR81nxTjGoRK9qeqLb12KUXODJ9i8xlOfFeP4K9vQ2dyC+JRkXHTbUlwYxNcMNd1d3er38Pm2InTYbGqe9WVLCzAmLw+xcZF98+wLMlwigE0/qqqa8Kc/78e375gR8RGYa2RMMT5RcU5j1fG2ZdcU5UBYvLgtYISUANuszAz3jJ3T1FrEIKanKj3WPQlW11KL0upS5I3zP+Xa3d2FPSeK8ca+QrR2tMCSkIybZi7B7PE9KfGeecnFeKeUVdgtqgo7LsUCe7tNXZsW6elZmDw5NBXKHBLx3po1sNUOLM5Sxfu99YL8xLWmExV4b+UqxHfHoLW2bkBLzMZjx5VgX7VhLRIzApt1aK9vwCePrFYFZANe86vjqoDsyk2Bf81Qw9/DO2s2uP0e6svKYc3Kwrw1K9W+/VBABNkg2wx4YGmfeWXbIewqqVLTl/ztWW02mKY2tIfbGyk77yl3nbcrQfdnH5k9sz8rPommxk4l9HqbK0NtHjQLuIyh/XNnpFx4ZKvfgtxoa8BTRWtxlvvXnf1vohV1ZRiRkoWfzLsX/1/R82pyVLvTOn3K9vQ4pNgScL6jbUBkTDH+wfdD4zVm1EkxbqrQSPk76gR7/8fxE2yuPonY892I63XbOeiyteJceQXeu+8BzP/tS4hNSAjYNVKMmzUsVhRnHuf69S8+HbGRMiNjirHW7+E8b4QqKtT6wqe2DIlIWQQ5wGlT7qn29Kx+R01nioZImXvGWmlqz2/8/f9dc7oVv/jVu9i4+iqfKq6ZIl+5wTFNqhMxsdr71A5ow8qbMzqwxXsHjqHw3VK0tLYj2ZKIJTfkIG/6xab4nbKa2hie72JsnS1+R8YU4+p69zdRijOPb3j5YQw7d94tEnY0EbFfkI4JsRPQ1t4KS5JVpakZGYeqjoTpUUZk3hjgH7DbWTfY0+mtF+fvrv1MHd7+yV247uktAYlamaY2Msji1K4SjLpyLiIRI78HW20tTpaWYmy+eSvvA4UIcoDTpq49q6NhH9m3FpgD34A7OrpVqnvF2o/xwpM3GIqUGRlTjPunSTH1GgfE9twUOAtzT/W6FetX3BAwoWxoasHal/4XtfVNaHUa1VhWeVp5nFff+Q2kpyb7Zk366gCKSt7p8xgX5M5D7qTpfgsQrU2sptZLW9spJxrpagfWeP9G/zFNzchYj87uTsTEAcO6tH/ftvYWXLH4HzFzUniqlLln7G1IhNNuTB+O//T0V9x2phYfr1iNr73gOWrt2xN+eSvON7dgGPeEb1/mtifMPWO9aVGE63yeSBVk7hkbGdZxdGuhCLLQD61NZV6afjinVHt6Vh+JCkEORAtMNf2ptMZQgRfT1O4p8l5RVjnEbsTGxmDc2OH4+2/NUJFxoMSYkTHFuKLGvYEFxZnHuf7kQ39n6DXPnmvAyv94Bg3NTehmgZXCjrKaCmSlZWLlHXciPdl35wJ9xrQ26VVZK2K0BZnV1kum+Df6j3vGzmlq7dcFzsdTkLWXmcZ+p7gwbILMwiF/iDUwLUxFrcUlGHXFXM094U+5J3z6zACxbeKe8AUjcYXTnjALuIygdR5F35/iM1VlvqtYTbXiIA327ma7UHYoC0Za3OjvoaPFv2xOpBH+3FuENf3whUjvWe3gtiWTYLEM7h8jU94vbz02yGlSjEtiYbcPQ1dXHFKSLbii1/8dKJimZmSsB9dLDx73+lz15xpx9z+vV6Lc056zv+1nW2cnKmtPYsOfX/Jr5KgadrFgJcalZyNp2MBahaRhScryhLguj6FcVnIWcsb4VzzFAi4jqPSu3vO0h+9NllW8PmO3q4SDtxwPhfbYy1vdv7yrS4lxc/kJt8hX7QmXn1DrPI+wmtoIrudR9P96933Y/czzOHvwEM6VlavPfMzjXPdUXPX2vfej9NkXUHfoMJrKytVnPuZxrofr95CQ7F82J9IQQTYI3/TpM84el4ZYl81MvtdqtZCM9J7VDubmjVJp4cHSbPAGxeiNTKCnSRHuGTunqbXg+tZ3SnTPocgyMj6v3ly1uov1fNQ21qH02AG/rpU+4scLtuDOa+/ClAumYnz6ePX5zmt/gedue0GJNSNhZ/g4Oy0bK+at8dvyxGpqI3gIzvufJzF8b7KXLl2qWl3q4lK8RYyWJmpFrWpP+PQZ3a/jOveECa1NrqMbXeE60919l9zVhY9Xrla9trVEn8e57hB9569jO1Cuu6aQ+ZjHue76dYOF1iZvv4dhFgsmLwvv2M1QISlrH6DHlT5jWptYTe1oiqH1z7WnZ/UURAPc9924+mpNHzIj5+4uoL1DS3gGkmLwBsXojUygp0kRFnAZgb2v9Sj56iDqmz23UHXQ1tmBwuJ3kHfJTPjt68/OUx+u0GdMaxOrqVnAxT1jpqkZGbuKcbe9C8Und6Hoi1fR0tmC5PhkFFx6K/JG5yOWm8FO0NrEamrdtLUdGKZzX5MYb8G8vPC9ydLfSkuNZpW1E+ovuvdumwkHo2hFt9zrNbInXPaXV9WeMPeUaW3SqrJ2wDT3hfm5fY+ZprZ5KQTjek1xCUY7pdSZpjZSQMZ2oYHsTmbk92DNysLonKExrEME2Y9ImT5jWpuivWe1M6yQfuHJeWof+OWtX6lolwJ7+7JJOH/ejmf/abduJTaF+/ZlFxufJlXufZrU7QGeJkVYTW0EDqLQo6j43QFTpLTpuYFhoVcwoOjS1uTN2tTQVo/1H6xCre2MskM5KGs8hizrSKy6dj3SkzL6jtNnTGuTVpW1g/jYeMR1ef79jUjNwvSL+oUk1HA/9Po1azR9yLQtsTo8MTkF7WfPIqbLrqJ9x3wx9fVeotaLnaJWByzg8iW65jXSZ6zlQ+ZrUIyv3DhwkAX3jI2IPlPqzoLMPWMjxVXs3R1IQaaViT5jLR/yMIulz4c8FCxPRATZD3p6Vs9T1ibPPavnmcIeE+hImUVZroVZ9BmP/PNRD41DeriAtqScUYZeZ67TNCldm1POaFWRzV7X3Hd2tMekoOfnsk2p795nWptYTa2XtrYkxmPZPH0x8UVkWXUdLhgZU4wrmk64rVGceZzrT8x/ri9SptDfX7Ba04ecFG/x4kO2KDG+85urwt4ql80mbnrqKVSXluKLrf1DIi5dtgxjcnLw4YrVOHvKuzVKM2rNc//7YDW1r9E1C7zoM2YamxF2X6cuVmXn57oVWvF7MILreSzg8ufrAvV7oM/4ZGmpqqZmARf3jJmmZmQ8VMSYiCD7CZt+0Gfc07P6iFPP6ikR37Pav5T2VcrapJXSphhvWH2V4eYgFNINK6918iE73fBYemxOXOc0qVUb3sOZuoHnHCtvwMhMK9avvN7naVP0GdPapFVl7SBrRCpypl0UEJGNjYnFkrx5CBdMUzMy1oPrJSeLkT/mir5jadZ0rPnGk9h3ohSv79vaN7zi5pnLMHN8T0r8ob9/AgeOl6hq6p5OXckqTc3IONxi7ICCNjY/X324cl5LfFwa1Dj/RTui1qs2aI9fpIiymlovguVzTPz6rW7XyBS2EWsTbyiM4Hoeq6n9+bpAQdEdm583JKxNeoggu01xOuw0xWlq3xQnLaKxZ/XgUto39Ka0jzmltC9WkbGvnbr4fM9vmY/i0pN4ufALVcDFPWOmqRkZk3sefAMnKt2jaIozj1Osn9tyk0+RMn+n9Blr+ZAZGVOMV//8G15vuArybkDZqUq0dertNduRkZKGnIunI1xwz9g5Te2xq9cXrwwQZELRnT0xX314nJc8KT9s1qbBMsyT+LiIclxiItIvnaTS1IyMPdmD1J7wBSNVNbXRPWFfobWJrTy9ib5rSp3WJvbs1ktbM4XMEZNC8BBB7pvi9JZb+pm+454pTvMHDC0QfEtp+/18sTG4Im+M+nDlk11VKjLWg+vFpdW4Im+sT6/Lph/0GdPaxGpqFnBxz5hpakbGRrIfuZOmISstA5W1NR7PoTVp/Xd/GbZoscvehTOtpw2dy0KvocYkPXHrvceLtVgw5/57BuzHeoJCTZ+xlg/ZEV1zfTB+X/qM2VebVdGesI4ciVEuKXX6jC1evo7rnPcsRNH4RTNGxvc/vF23QItWp6ceWzyk0tCDH9N4Cq9sO47mlvNISR6G25ZehLl5F/oUKTuPe2xpOY9kPs+SScqGtXL9X3HQwEjGaVOysHnNDQgHDS3nlM+4trF+QKRM2xwj4w3f/SUyhqeF59ra67Hm4xU42VAFu5tbwJ2pmdOw9mubYWbY0rNidwkO7CxEh60FCdZkTF+4BNlzmCL3XeRo8Xn37vt0RWr4+PG44fmnfBJR1alrV4mqpnbsCTNNrbUn7A/0GdPaxGpqV9GnGDOlrtXakz5jWptYQOZaXEUxvmb9miEz5CHQGNXQIS/In+6qwAu//ki3AxcLte6582rk52aH9NoikfqGdjyy+lOcqW1120semWXBprVXICM90eC4R+09ae4hx8R2oKLKcxGZg4nj0/D8lpsQLtT872MHUbjrXdjaW2FNtGBJ/g3IuXhaWCPj+//6C1Q0nwC62JGUNcWeb5ToXb4r7z63lLWZaG1swI7H16G5rhbnnQrqhiVZkJKZhUUPPQpLmu9i0mZA3JJCOG2pfxSjU4HXbe5tN1WnruISVU3d16nr9mUqMvbWqYvWJlZTO76OaWpGxpE6wMIMiCAbZOW613H4iH5RC7l8ygVY/2j43tgjAUa0d933Pk5UNHs8Z3x2Cl58+jrdSJnPw4EUelXbSZZudHTqT98Kd4RsVj49+TFe2PM0WrtalY8ntlNfkLNTxw+osjZjZPzKygfQUOU5kk0fm43bNjzhd6Tsj7gFmv5RjAPT3Zy8EpsQj+k/+zHG3fg1EU4TYlRDh/westEpTrTUCPowTX36jE1nvhBQUdWMf/vTUfz9tyd7FGUj4x67u2KQEB+Ljk7PbSdZkX1bELzKkc6246/0iDGJAbrj7Yjt/WfgLMwxMbEYN3yc8iGbVYwJ09SMjPXgesWeUkzI8b3AjALHPWIj+8TBon8U4wnNCrPu9g7se+4lHPvLq1ExI3moMuQF2egUJ/pbBX3+38tfobVNvy8z2zb/zyvH8Omu0x7T10bGPXZ0ABYrU77dXrzKY3yrtN9Xhm1v7UVLaweSLQlYOn8W8mZOjKr6Abexi72izB9lDD/YCjYGGJk8wtSRsQPuGTunqbXg+oHXtvklyGagZxSjcyZP42bWbnebkezvkAkhPAx5Qaa1ydsUJ3/bYPINnk0rthZ97uRTvqy3aUX0vME70sxfHfe+p+sQ5fKKZrXXrJW+ZgGXd2KQNWI44oadd/MhO7zK61dcb9jy1NBkw+pnt6K2/hxa2/qzJscra5GVMRxr712G9NTB9/M2A5pjF/ljigPscWpooyIr5QLTizFhAVcwJzyZAe4Ze+vA5TojOWPyZZr736wcZyX2VRskkjYbQ16QHVOc9KqsuZ4zxzfrTENDGx7d8K6bWBzvbVqxbuUNSPexaYXZ09VdXb5NLTpd24pdJadw5dyBHbxYTW2EtOGJ2LiW7Tyr8Qq9yr03PUxTMzI2Ksa8caIYV5w867ZGceZxrj+98o6ouJFaetFtqi1mX9paA0ucBcsuvl1zv7akehe2f86e1zYkx1ux+LJbkTsmf8D+LM/bV1aMN/dtg63dBmuiFQtmLsXMiXl+D7XwBKupDZ3nbZiEiRk4rCLG+4zkv7yKIy3NmhXizkMmvva857nNQugZ8oLcM8VpvqYPmZGxw4fsyxsx3+ApxnpNK7j+zJabo+INnry87biKfH2Baem/bC1zE2Ram46VNRrqjd3jVR7rs9fYGaapGRnrwfWS/eWYO0u/Q1ckkDdqLrIsI3uqrD2QZbkAORcO7JrU0NaAje/29Lxuc+553XBc9bxecQN7XqejydaAZ7aucWurWVFbptpq/nLZGqRa092q0Y8eLcZHHxWhra0FSUnJuPrqAkyeTAHX/zdCa1NdeZnXtHXL6TOqGtufautwY3QUowNGxe0tzT4PmRDCy5AX5P4pTotRuruqtw1mT09kpqkZGfsqmkxTG2laUVJ6EnMHISRmgn5j/76u0+O4x0D1xvYG94yd09RacH3rm3uUIPOGq+TwFyh8/zO0tLUhOSkJS66bi9ypl0bEDVZcTBzWXLVR+ZBrW88MiJQZGVOM11y1QZ3nHPFSjCs1el5TnHmc65tvekqJsdbgCYozj3N91R1P9UXKzc0N+Nd/XY/Gxlq0t/dfS01NGdLSsvD9769CSoq7gB/fV4y9bxah3daMtvhuoAOI4x641jdtB1rO1mHn5nVYtsm/autwQmtTo5e2m64RdVeb70MmhPAigtwL30jpMw6E15h7xnqTigjXXyk8GjWCzOYf/n1dfNB7Y3uDBVxGz2s414x1//In1DY0orW9/+vKTp5CVnoaHv0/30b68BSYnfTEDDz1tRdQeqoYW4+9jJbOZiTHp6g0NSNjZzEmTFMb6Xn98t7/VpGxHlzfV16K2RflK2GlGJ8+7S7gFGce5/rPf04R7bnZsTU14JVn1uNcfS06nUQnJjEGnd12JLU7iXLvhrhjWhOrrSt3l2J8bmQVd/WMYhzZW2XNb8rz3z490sOGJ6OzzRaWYRGC/4ggBwHuZRrBZvC8SOD2pRfhq+NNXqujnaG4fn3ZxJD0xtaD1dRGsFoSlBhXnHIXJoozj3P9iXt+GDGRcv6oK9SHN7hn7Jym1oLrr3+1HbGd+jc4jJTf3LtVCTLT1IyM9WhoqMXRoyWYOrVHwCnGZ0+6C7jS3tgYtCXakdTmmGXc89nx18K09sEd2yJOkB2jGD9e/ihaKqsGNtN2gS0444Ynu1Rlh3ZYhOAfIshBgIVFRrAaPC8SYFvMC7IsqnraKBeMtCA/98KQ9cb2BK1NrKbWS1tbkuJx+WVZ2Fn8le5z1dY3ovTwl8ifdhmiCRZwGaGz+zyMTJS2tbeoNPibb/7XgDS1Fh0drfjoo0IlyExTMzLWg1LVHQvEd0VXtTUror/20jOofOc9HPyn36Kro3OAMDvPSD575Ch2Hy/zeciEEF5EkIMArU2sptZLW/c0rZiMaOlNzc/0FdPKxOppbwVZFONNa64IaKTrL/QZ09qkVWXtYGTGcBypPD4gTa1Fa0cHtn3wadQJMqupjRAfy7cU71sACcMS8ey/PICGuipDz8tCL8I9Y+c0tSaxMeiMt3sU5ASDowbNGilnL5iHcfOu152R7O+QCSG8iCAHAfqMaW3SqrJ2wKKl3N4xgpHYm5rpadfe1PxMXzGtTKyeZsFWsnUYpl+egQOH6tFio5jHqzQ1I2MziDFhepk+Yy0fMiNjivGae5dh/R/+w9DzcTpUtEFrE6up9dLWScMsuHniYnzQuHNAdbXbefEWtJ+pR31dHdiPJNaLjUd9TVJParW9dXB7nuxtPW3RUkQ63mYkc50+Y299uMXyZC5EkIP0Bk+fsZYP2dG0Yt2KG0y/z8jImGKs1Zua4nxCo7kHP9PG5GplCgeOxiyv7vgcLS0dSE5OwK2LtBuzsOkHfca0NrGa2tGpa9mC2cidMUGdz2pqI3BUY7RBnzGtTVpV1g64fvusv8Whz0s0q6wdJCck43x9j7B2xQEx5+26vbQTEiy4+uol6r8TLYPb80zJysK4OUNjhKBKcT//tCn6cAvGEEEOEmz6QZ8xrU2spmYBF/eMmaZmZGx2MSZMUzMy1uOMh+YegUuRd6qo2tfxjfWNbVi18Z2eKm0nb/mxsvreLl7zkJGWNLBt5t4T2PbmfrTYupBstWDpjTORO2N83++K1iZWU+ulrS0JCVh6rXmnIvkLbUL0GWv5kBkZO3zIw+ISlM9Yy4fMyJg+5BHtVlR29GwPcK+XbTpZBe2J9PQsTJ7ck1qdtaAAZyrLdNPWFPck9dbWOXDqU1YWFj78aMRZngaDGfpwC8YZ8tOeBM88tPJjlWr2xvTLR+DxDVcGMEX+ic74xiu9jm+kuN7z8E7dLYPx41Lx3GMLldiqtplPF6H2bLNbujprRArW3legImg+7wPP/V6zytpB9oUjI6bK2h9YiFV6shhFR19VPbHZhrNg8q3IGZ3n3qmrvFRVU7OAy5qYjAWzlmHmhBw89/sHUXPaKdK2A/GdDmuS0w1XTAwuGDlugA+ZVdb/tf4BzSprByNGj8M1i/8Wh3YWqQIu7hkzTc3IeCiJsWAeZPyiMGju/OX7KCs3MHN4wnC89Mx1ARrf+J6B8Y3X60bKn+yqxDO//tRrf/L77rwSeXNG4751/4uKas83HtljMvD0o9/oEW+HD7m+URVw9T1fQgKyMiLHhxxOfvP/PYrjFYf7D1CIu4FYfji9G424YCzu/dnTbp26PPmQ45MsGD4iC7fduwrW1MjrxhVoOFji5Cef4ch//Bdsp8+oW52kC0Zi6ne/hdFXzpWUdQiR8YtCyJp9aDX3CGeKnHvGemJMuP5K0VEOA1aRsR5cL9l3AnNnT8TwZCvuWHAd/nvn+zjT0KDWR2ak4ls334C8aZHRqSvcXHfFElSfKkN7R8885rjzDq8wc9f953V1dMBma3Lr0kWx/daqJ1C2vwR73ixEu60FidZkzF6wBBNn5HpttWlG4eQ0p+Ov9E9kuui2paoZiL+i2VbfgA+Xr0JL9ckB1qiWikoUP/4UkseMxjWb1yNJhkuYChFkwSO3GWj20dNTWru5h69wz9hbYxGuv7z1uK4gs4DLCGyRuu3NfcbaZr6xD5dNGol1v/tP1DY0DdhHrmtoxn+//h4mTxyH9OHSaMEbUy/NRXpaFk6drlBi7KnKmg1D/vDH9bjrZ/1duhzw8cWz8tVH0KPMXcX4civF0ob4ZCsuWbYUo/MDM76wvb4Bn6xYrSY0uU5ksozMwpUbfZ/IxGv+eOUatFRVezjBrtY+WrEa814YOFyi7/t9tRCdthbEW5Nxya1LAvb9CvqIIAseYREV9231UsjemnsMtq+1P+exmtoI7FfeYjPWyKTF1q7EuOJUrYcuXbVq/Ylfhn7/uMveheLqXSj8citaOlpUFfOSS5Yhb0y+WwtMM8B93B9951G8+PuH0VLv2ftNGhprcfTzEkydEvrOWm0NDfjg0TVKLM87i+XxMiWW165bg6R0/yNMih/FmDOM+471fubr0UP89v/5KWbfd4+yNxkVRM4/bqmp8XpeS80p1BSXYvQV+f3f76q1nr/f9au9fr/8nqqLS/D51sK+aP+yZUswRqq6DRFZuR0hpDiafXDflpGwM3w8YXwKNgawuYfR1Le382ht4h6xHly/rWCyEmUjnKxtRM2pZr2Ohaitb0LpYf1OXoGGE5h+9eYv8WLxczhcewgnmsrVZz7mca6bkeEp6cgafoHX89il68OPCxFqKCwUY4qiszg5iyXXeZ6/ME1N8et7TY1zuto7sPup5/DXX9ynomkjfPXqNnSzi5cX7J2dyg7V9/2uWqv//a5aq/v9UtBfv+8BfPbci6g9dBiN5SfUZz7mca4L+oggC7qwovm5J67FkkUTYLXGIT4+Rn3m42e3XKtZ8czirI8/rcGDKz7Bz+/9QH3mYx73liJ3FX7tFPlF3huzZOl3Y+I6C7qWLpipqqn1saOjsx3tLXGwt1php0/HU5eu9z5FKCPjte8/ioqmE2h1adjBxzzOdZ5nRtrajbWwbO3t0hVKmLZ1FkstuH6ypNTv1+CesSNNrfcvo7ujQ0XRH69YbegG4HyL8dagjuEShr/fYu3vl9f119Xr0ORB0Hmc64O5gRkKSMpa8NmG1NnZjcIdZfh01yk3G1LP+Z/h9Bn3zl6qXebauR5tS4FKkTNlTJ+xlg+ZkbHDh8zz8maNV9YmvSpr9Xapyn9pmgXsrRbAYqMrx40WWys+O3IQRZ9+AFtbG6xJSSi44lrkXTY14MVGxQYnMJWeLEH+GPP5UJMSje23W3q7dIUS7hm7CosrXP/yla0YM9e/dLqvk5YoiKeKSzDKi6d4WLLx1qCO4RLcMzb0/b66FWN6U9zOME3NjmB6cL26pBRj/fx5DQUkQha8dOr6RAmka7FVf6euT9DR0a0i4AdWfITv//gdlJ/QPp/HKdaeIuWeFPmVXlLkVxpKkbPpB33GtDZNmzISE8enqc98zOOOpiCqbeZ9Bcra5B4pqzEFwLDzA8XXHgM7W0y5EtON0+1V+KdX/x+OnCjDidM16jMfP/i759HQ7N1C5gvcM3aNjF3h+tYvXoEZueaqAiQmWHTPYZeua67q6dIVSljAZeg8m//Ru6+Tlhzzi70x6daliE3wvv0TEx/fN1zC6Pfh6efCPWMjgv75q9sMvc5QRSJkYVA2JEbCP7rzHTTbzqPV5hDhGN3zd5WcxpVzL/TYmWt4Sjzm5l2gInCeT0ZmJuG7f3spUocb2/N1iO0VuWPVhx6qbeaj31DWpuf/79uwcT6y8uF0qcjYPRKOBToTgGHOPxs74qyt6GBKziUr19rRjoozp7Dh33+PLT++O2CRMgu4jGDrMOd0oymT85CWloXTZyr0u3Rdpj8Agc1CyvYWY+8bbATSggRrMmbdVICJs/L8/lmzmtrQeVb/o3dam1hNrTeRyRUOkvAGB0skjxqlO1iCJI+6EKPycnz6Pjz9XIxG+0ZvdIYqIsgRBIVrV8lJvFr4JVo4uCE5HrcuuQT5uaODMqjBiA2pra0LrW08x/H6+tfB5/vLq8f7BNlTZ65DR3pSyKpvTQxwoqoZz7y0FyP/+3NsWnOVSnt3dVPIT+LVoi/VDGqOvby14BLMzWNrUt9+HhRv+owvuMCC8moDbxqu+8jKv9Ot+yW1jfUo/eII8iZfjkDAamojWBPMOd2IYvmD761S1iZWU7OAyzkyphj/4B9W6Yoqm4RsfWo9zp0d2CSktqJMNQlZdr9/TUJobWJ1sV7UN8xiwSW3+T++kD5jVi87V1l7g1OdvNEzWGKNpg+554QY5UO+euPavspnWpsMfb+3LhtUtG/0RmeoIoIcIdQ3tGHVug96hcu5N3Oj2ndd/ygLrIwNPwi0Dcn35z3vlhJ3ZcB7CP87xilNvuZjbHj0Cjy66UP3n0d5z89jw0r/fh5Wq8HBEE7Nl9mly25pR0e3ftEai74KP3k/YIJMaxMnMOmlrS3DLFh26W0wK2z6QZ8xrU2spmYBF/eMmaZmZKwnxoyMKcZnq90FjeLM41y/Y7W7j9kb9N1SLPWiTK6PzvV/UAXFkD5jWp9aTtagu1P/35sv84vZ8OPGl57Fyc924ci//xdaT53uueYLRmLK338Ho12ajhj+fnsjaldobWowIOiX3Rr5k7aCiQhyBEDhohifqHDfg6QY8TjXn3tifl+k3JMGrsGrhV85RdOTMDdvlOFoOlAduNyfd5jhlLgWp8/Y8MDKv+JMXavHn8fKDR/g+S3zfY6Ul944C2WVZ3SbhSTEx+HC0VYMi0+B1ZKEpddfgf/+oAgVp095ff6WtjYECvqMOdSB1dSe4HrOaHPPvKVY0mfsq9eYaWpGxnpwvXxfCS6a7dtzU6zoM9byIVNYHD7kwXpr2fTj+heeRs1nu7DnyefQ1e55dCfF9EIf5hfz2sZcdaX6MHIufcZaPuS+73f9ao/fL33GnL/MampPcH3MIG5ghgIiyBEA09RGWkoWl57EFfljVDS9cu1HPRXGTmngY2UNqsJ4w+qrDUWPPZ26GnXT1u4xYW846wEWZ3391osMp8R7nmvgq7S1d+L8Wbuxn0feGPhC3oyLkJUxHBUnPTesuDArDU898K0BDUAKi/WLkxwYHeFoBDb9WH3dOmVtYjW1c6TMyJhizHUzNgfRinaPHinBhx8WoamhFq2tLbAmJSM9NRNXXbcEl011j5a5Z6w39Ylwfc/rhT4LMmETjPnPPKWsTaym7utcddsyFRkHqtGFmsh01ZUY8S9TlLXJtWsXI2OKcbDnF6vv99knlbWJ1dR9ncluXaYiY73X5trX1j6qrE02DUGnGHNdmoPoI4IcAXDP2DktqwXXX9n2JfJyRisx1o6mmfI9p9aff3KebqTMCJtvkt1e0rC+0mNbumBQKfGYGDu6vcxE4c/j5cIvfRZkiuyau2/DmudfQW39OffpTxnD1bprNy5am8prTqoCLk8wtb3kysEP4XAmPSkdTy54RlmbWE3NAi7uGTNNzcg4EsS4ubkB//qHDahvqEVnR38Gob29FfWNtaj5cznSM7Lw9z9ciZTh/fvBLOAyQker/5XQKsqcm++3tcnn+cUvPK2sTWp+cXOL2jNmmpqRcSjETH2/V+RrWpuMCPrNTz+hrE2spnYIOtPUjIxFjL0jghwBMOVs6Dxbp0pTMzLWg+vFpTW4In+05joLrZav/gg1p2zo7HAWvpgBkS5T2k3NnWhr63YJZu2a5zt8yLwRcAi+X+gNz/Xj56ZVdf3UI99C6YEybH1rj2qbmWxNxLL5s5EzfaJma0z6jLPS0lU1tSey0jKQc+kUBBqKLn3GZvQae4N/AxTj06cr3Rd7/3xaz7eh41Ql/u33G/CTu7f0RcqspjZCgiU4PmbV97m4GF849bm+lH2u8/zv+8yvo8/Ym9fYrPD66TMWr7F/iCBHANz/NXSeNV7tGRsb0PCVpiBTKB9a9SGqHJXGAzLGPf+RkBCH+34xC3k5F+KeBz5AuXNRlsv58fGxuOySdHzjtotUZEwxVpXVaz5BzanWgdltTZ11PxgbG9NTfR2gn5sWFN38mRerDyNQJFb+3Q+VtYnV1G6jGdMy1HqkTSIKNkxTNzbWeT2Pv+3G+jp8caQUky/PU8dobWI1tV7amiMZZ98ceB+z6vu8eo1bepaVykzPXrt2cH2uhaGJCHIEQGsTq6n10tYWyzDctvQS/Nufjg4qevzks5OoPukSYbtktjvPd6ljCQmxqtf1I6s/xWln21KMU0S85ooBnblUZfUa7crqvtfxorUj0qywtbXrzzu2DMPtSy5BKElPGa58xrQ2sZqaBVzcM2aampFxpIpxd3cXdp8owesHCmFrb4E1MRk3T1+COeO5rzu4NORHHxap1LQuMUB3DNDR3op3i/6E0jcL0dZqQ2KSFXEpyehoa/VYtUDr04SZgS1qU32fV6/RLGBytInk+vynn5I0reATIsgRAH3GPS0lPXd64jr3j//4H06D33XwtAf77/91VHeAAuH6v/3nUVx9xWglti8+fZ2aUfyXrWVqX5ip7K8vm6haXLruUxuurO4djauupfcplMgri9eVeHSTdtW5688jkHR1d6Pk4FcofLcELa1tSLYkYckNucidNqkvjU3Rpa3JqLWJKduSY/uxvfQttLTbkJxoxeKc+ci9eEZIBJyvX1pZjB0Hi2DraIE1IRmLphUgZ1xPU41GWwOe2LEOdc21aOvs/72dqCtDZkoWHlj0KNKs/keCbW02w7sUiW1AU1U1mpz+QOMTk2BPSYD1fCy6nCrYGRk7fMiB/jkyTW2kTSSLwUKx9yxEDyLIXt6Ai0uqsG37EdhaOmFNjsfSxVOQlzs2pCP2KGr0GWv5kBkJOnzIvjQH8ZTyPXXGmC3nVG8HLcf1cT6x3oxiB4Yqq2OA7HEp+IfvXIZXC4/3ifztyy5Gfk6PyNNnTGuTp58H1321POnRcK4F6/7pz2qiU2t7f3ahrOoUsjJSsXR+Dt4tLe3vX33tVcibcpmuGDS0NGHj/z6H2qZ6tHX2/9zLTlciKzUDK75xD9KTUxEsGlsbsHnnetRSbJ0qtMvrypCVkoWHblqBp17bgKp690iQ4szjFOt1t9Pn618kmJRkoFGEHbC09rYTd0mfdLb3/txGZGKUdSI622xqz5hpakbGwbip4Z6xkTaRX7Dvswiy4AMiyB5oaGjFmo1vo7a2ZUBqtKysHllZyViz4kakpxuzurjCDlO7iquxtejzvg5TywouQ37eGI8iQpsSfca08rCa2vF1TFMzEnSIcazWxAMNuA+rjbGCKSN7uFo024wVWvH7YQTOD08/D/qM+fNgNbXDa800tfp5BFCMeWNGMa6ocd/rpDjz+K//tBNIaO1rs1l+sgZZaWlY+cN/QPrwFM3IlGJcWXfSbY3izONcf/zvVgRFVPj6FOPKBg2xPd+qjq8tXIF2LxXKjJz3VpRizgT/hOfqawpQU1Oum7aO6/Rex9faasPMb/4jLpnRs79sij7XPg6PEAQRZA9vwBTjispGtzWKM49z/anHF/kcKTc0tOHRDX/t9Qj3C/3x8h6P8LqVX0O6i0fYIeBsEWlr6YA1OQHfuWOKpoCnpBjr9ZySrH3ehSOtOFHpedqSA9qhuB/sa8vOFGtgZh4Tfu+0NflqbfIVpqkZGethZ8F4VxxihvVE/63tHag4fQYbfv//YcvdP3UTVaapGRnrwfXS4/uRN2kWAg3T1IyM9WhsPtv7jXmGkfJr+7f5LciTp+QiLS1Tu8q6l4RO71NwOttbseudwpAIsuE+1z4OjxCEyKwyCTJMUzMy1oPrpaXVPj0vhZVifKKiya1Aq6fDVJNa53nOAn7vA2/i2ZeKcehwLcpONKnPfMzjXHeG3biMzRSepLn2d9+arDlWcCB2xMCurFO+EqiZx6GEe8bOaWptYoEu95uI2oZGlB75wu0494yd09RacL2o5C0EA+4ZO6eptej2IsYObAbnGmvBG5Xv/2AlLrhgHOITXJqm8J+BHYjz0h/dQXtraAYX0NrEZhd6cP1SD32fBcETIsgacM9Yr4KXcH1rkbECKgeMco14hEt6hZ7CvGr9+7oCznVnAWdrTEbaenA9L0d7v5f7wPHDvP9ZdJ634+Wtx+ArjpnHerBwi3vFZoEFXIawe+hf/cFH7s9pUMRs3iqQ/YQFXIHCmmgddD/rn9+1Bd/8m7swYcIUNVQiKcGCjLQsXJQ9GZkX6E/rcpBoCc3gAvqMaW3SwzrIPtfC0ERS1hqwgMsI3Mf1Be4ZG+q4Vfg55uaNNSzgxSU9LTOJKnhafbVm60xGno7WmXqpZruKjNybezgrToyfnbbUzOM1Vyrrk+uEJ0cVtdGZx6GC1dSG8HDJLW3u3btYTW0Ea6J/dQpen9fApKjuWCDOHtv796BNUrwFt8xYGph+1lPz1IcrX+zbhaJ//yeVlvZEfKIF+fNCMzdZ9X1eu0bTh+xoE8l1sTwJviKCrAGrqY3AoipfMCrgjhsC7hkbEfBXC7/oE+S+gqcn56mUMhuAOArAmKZmZKwnduz0NbBdpnvYFzPI4RPKKvXU9dhVegovb3Wuor6or4o6bFX1+8qw7c19sLW2w2pJxNIFM7H4+hxVTa2ftu7uqT7SIDnJfYIUrU2sptZLWyfFJ6Egdz6CAa1NrKbWS1snxFuQPiwZZ1s87zXT+jQrO0e3eOzgFyV477MdfZOcrp+7CNMuNV4BPWl6LtIyMlFb43mfOW1EFi6eFrqIVPV9frqnzzWrqVnAxT1jpqkD2edaGFqIIGtAaxOrqXUbTyQNw7KCqT49r1EBd9wQsIDLCC0a51HU2InLU3tMT7xS+JUS5B5J9CyMfC+lDclflFUqf5T6MAMNTTaseWYrauubB/SvLqusRVZGCjJSh6P1zFl933Rcl3b/6muvdjtOnzGtTVpV1g64nnPRDAQD+oxpbdKqsnYwcvjIPuuTqw+ZkbHDh+zJ8nSuuRG/+dNG1Y+63alHddWpMpWO/um3V2B4SprXa6Vw33HnSvz5pQ2qW5dzpMzImGJ8x8+DU41ulj7XwtBA9pA1oM+Y1iY9uJ6T41t1L61N9MnqoTpuLblM/TerqY2QbPA8I7T0zir2RlxcrMd96Iisqn9mKypO8iZsYJTLxzze3W7BuAtHwJI48KZKFcDFdCMmsd/y5ExWRhpyplzqdpziQZ/xuMzRKhJ2ho95nOvBEhk+7/KFqzAuPRtJwwamxfmYx7mekTxC+Yx/fMMvcNmoqRiXMUF95mMe99QUhJExxbjmTOUAMSZ8zONcN9rPPDk1Hd97aAuW/P2dGDdpCkaOGa8+8/H3HnxcrQtCpCMRsqeJPytu1PQhMzJ2+JB9tTzRpsQ9XBZjeYLrub1Cf2vBJThe1uC1ZeatS9zf8P0lmbOKdYZEOI5NuijVVPu8g4FpakbGetQ3tuCu225E3LBubHu3uK8ByI1XTMe2D/+KusYu9/7VGWlY+YN/8CiqbPpBnzGtTaymZgEX94yZpmZkHOyIL82Sjk3LnsDuyhJsP1jY16lr8bQlmDOuP6XMCJi2Jl+sTUxTMzLWg+uHvtyN6ZcZa23J66GtKRTWJkEIByLIHmDTD/qMaW1iNXV/A4+pKjL2p1MXfbP0GWv5kHs6TPX4kB3eYqMCnpcbuBaRty2Z1Ns3u8ttqISDJEss/ubroe0THUy4Z+waGbvC9aK392H9/bchf8bA7/36vMuVtYnV1Czg4p4x09SMjL2Jqmq1OWlWULzGRuDr547PVx+BhHvGrpGxK1z/66dFhgVZ8N5ju7q4BF9sLURHSwsSuKe9bAnGhGh0ozB4RJC9TfzJG6c+AgWbfjyz5WZlbWI1taMlJ9PUjIydG33wv9evuk5ZmzwJONcD2ZXKYZtSfaI9PO2FI5OjJl1NWMBlBI5h9Ciql09WH0IPLOAydN4gPMyBgCnzitJiHNxRhA6bDQlWK6YtKkB2Tk8v70iB06feW73Oreq7oXf61PVrH5XpUxGACHIYoIDS1sQPIwL+7BMLlLWJ1dQs4OKeMdPUjIwDKcbq2uJisHH1VVix9mNN29QFyjZ1VcDT1fRSf1Z8UlWWO9pgMmU/Ny/w36MrrKY2Amcimw01HOLYHuzc/QZsHTZYE6xYOOcm5Fw8O6yCwmpqI3R3danvIRzX2trYgNc2b0BzbS3OO41wrCsvR0pWFm5ZvhKWtMCJWHdvBPv5tkJ02loQb03GZUt7ItjYQUSwjIwpxnrTp7h+09NPSKRscmLsBpoSNzU1IS0tDY2NjUhNDV6ze8E8sC1mj23qmOo/zZaXrKr2Zpvyh/qGNqxcrzMoYtW1ysoVLD7dcwwv/OvbumlrS1I87vnH+cifZZ4OYo0tjXjs5SdR13R2gH2KRWGZqSPw8O2/Qlqy9yrmYLD/6C78aduv9dPWnOAUE4+RaaPwf773iKGK60DBm4BXH3kQDZWeq8zTx2Xj1k1bAnKzwAj23TXrYKvV8C1nZeGGNf5HsFWffoZdz72oO/CCr5N/7y8wVirCw4JRDY2cnIwwIJr85LMqLF/9Lu554HX1mY+dO3YNFodt6rH11+DFp25Qn/k4GJExxZgpcu1uZOfUeiC/N1fyZk5U1iY9skakIGfGBJgFCgrFuKqu2s3LzMc8znWjVcyBhj5jWpt0sQNd7Z04dboS//LHTSG9VqapGRnrwfXK3aUBiYwpxk0VFW6iqSLYigq1zvP8gXvGxqZPbfPr+YXQISnrCIO9q1dteM/jcIr1K693G05hZpim9jYfubLqHH78ix24YKQVtxZcivxcz1Ox/K6q/+UyTR8yI2OK8Zp7l4V05KY3mKZmZKwH1/cc34ucSXMQahhV0mdMa1Nt/SmcP9/p1qN6GKc49RYq1DfU4vDR3Zg21bcCL4r4sf0lKH1rB9ptLUi0JiNn/iJcPEO/8Qj3jJ3T1Fpw/cD2QozPHVxVN9PUjIz14PrJ0lKMzfc9gmUBl9OP1Q3lzPNhSpUQPkSQIwjV23rDe5pV1329rTe8h2e33BT0fddA7Q8b6UbGwOn0mVacqbPhGG88MntuPAKZxk5PteKpVXegdH85tr65VxVwcc942YJZKjI2kxgT7hkbGU6xY/frYRFkwhT0/T98DE//5iHUnK1SYqHEoQuI7e4XY9LR0YYPPt7ukyC3NDXif5/biKb6WnS29f8sTleWITUjC9+4ZwWSU7XT4CzgMkKHbfA9v7lnbCSCPbp1m1+CzGrqAWLsbIi32/uOG51SJYQPEeQIwnBv69JqXGGgYCwUeNofprWK+8MGBwr1vpXbe248KntuPJ4L8I2HqqqfdZGp9ok9wQIuQ+eFuYqZUeowxGFYZ0zAKrMdkTHFuO6keztNijOPc/3vVjymGSmzmtoICdbBj1BkAZeh8/yMYC9ZshinjxxV4utGrzjbY2JwydICv55fCB3muu0XdHm16AvDva3NgJH94dNnjL4JDXyzYbTMG4+hCqupQzGJKRAkJVkDWplNmKZmZKwH14/v3625RmvTsCQvIxSTLJi+ePADK1hNbeg8iWCHPCLIEYTNZrS3daefhWLVWL76r7j7V2+qz3w8mGIqI/vD3XY7EuK9/Rm67471TMUyx41HOKC1ybXlpitcXzTnZoSb665ajMRE/WtNSEjCtVctNvyc3DN2TlNrwfWSt4o01+gzprVJD66PmzP4gRW0NhmZnzx5mX9Tsz4v2qEdHTtjt+Pzwu1+Pb8QOiRlHUFYrUZ7W8f7nFZepdLKNo20MpuP+Gc7MrI/3NnZjcQEA97ImMGPv4wm6DOmtYnV1J7ITM3E7IvC0wHMmamTc5CelqWqqfuwqxbgiOmOQYy9NzLo6jbsSWYBlxHaW7UzMHwN+oy1fMiMjB0+5EBYnugzprWJ1dSe4ProHP/En5OmAnmeED4kQo4gWGFsZDiFL72tVaGYSis3eUgrN6l1fyJlo5H6BSMtGJ89XON7642MObwhZvDjL6MJCgV9xmMzx2gOpxibORYP336/KbpN8RroM77wgnEqEuavNK4zBrFdMYi1s7QrBuc7OvCX//kdXnz+ETSfa/T6nKymNkKixXMamE0/6DP+2s/uwoWTpyIje7z6zMc8PpimIKoD2Gef4fXVq7Hj4YcRk2JFYlYW4pKS3CLj1Oxs5UP2tzkIxz4G8jwhfEiEHEEY7m3twxSqXSqtbKBQrOTkgJnLgYzUU1MTsXH1deo1Xi78Ur1ebV1rjy+VYw1jPE3FCtxQjUiETT82fmetsjaxmpoFXNwzZpqakbEZxNi54vqen23GwcMl+N8//wbn4b790t7ehtOnqvCH32/GXXdv0r1+WptYTa2Xto5PSkLufP1CJr4GbU2DtTY509rQgLc2bECLaxOQpCQkpA1H6vhsdLd3qD1jpqkZGQ+mU9dlSwtUi0xvjUEmLxv8frgQXESQIwjV23rl9Zo+5L7e1iuv96ny2GihGPdrfRVkWpt6BlXoT6u6fckl6pr5/PxgNH7Pg2+oamp/bzw4UrF4dwW27Tyo9t6Z7l+6cBry5mSbzsI0GCgotDWFy9rk67XGIQZxMbHQ+4trqK/D0SO7MfVyzxYo+oxpbdKqsnbA9YtmhPbnwptIinGjRnr6fFub+oi3WrH4ycB0ACNj8vK8p8RHZmF0rgzxMDvR8840RFC9rbfchF/elY9pU7MwcXya+szHPO5rUxCjaWV/CsXoM6a1SQ+uu06rctx4jB+X6pbG5uPx2alYv8LzjUdDYyvuX/UqXvjn93D481Mor6xXn/mYx7kuhIcPP3hNRcJ60JP84fs7dM+hmNFnnDl6nIqEneFjHud6qLMEVcXFKjLWg+tVpYPvAOYgNi4WN6xdpVLfrsVjKiU+ninxVeo8wdxIhByBqGgyb2xAvMZG08q+Foo5rpN9qL31qdYSVhaR0WdMaxOjc8f4S6apGRl7EmNGxmu2vIaKqga3Nc615nGuP7X+1qiKlCOFtjZjNrdWA+ex6Qd9xrQ2sZqaBVzcM2aampFxOFL2h4uKDDUBOVJYiOy8wKXJ2Qf75qefwMmSEhzdWqgKuLhnzDQ1I2MR48hABHmIw0IxI2llf/drKazPPzG/b3/Y0amLaWpv06r8ufFgmrq2rln3HK6X7qlEfs54n74XIZSeZGPnUXQnzcpVH2ag02gHsCBUPFN0OTxCBkhELiLIQ5x8lVY2UCjmklb2Bef94WDDPWNGwnpwfetrB0SQw8A1196CmpPlumlrVmJfc90iRCLcHzba7lIQXBFBHuKo/dpV12r6kPsKxTyklSO6eUqrsfOEwDJlag7S0jNVNbUn0jOyMHmK+YvUtJhaUID68nKvFc9TlkjFs9EiucriEhws2tE3Q3pawSKM4wzpKNxyEkEWevZre9PKar+2N62s9mu9pJXN3TzF8/ybZIuxJitCYOGb6A9+uFxZm1hNzQIu58iYYvyDHz4csW+2Y/PykJyVpVll7YDrY/1sAjKUaG1oxOsbNvY0bmnt/zs5W16mGrfcvHIFLOnhmfcdLGLsdm8914wPVxaEcPNpSbmqpu4ZoWjXGn4Dvtff+YPrccO1Q9vHHO7Ih9YmVlOzgIt7xkxTMzKOVDH26kO2WJQYz1+5EpZ0/5uODJW/j20PPoyGCs+2tvTscVi6RXt4iNkwqqHDouWXV1xaiaIdB9Fi60CyNQEFi6YhL2dcRPyyhMBBn3HmiGRUVtdrNhThMYryqzv24bqrJ0mldZjgv0v6jPW8xpEKxXbxli3K2sRqahZwcc+YaWpGxvKe5B2mqRkZ68H1ytLdGJ8XPX9DES/I9JSu37wTtbUcLN+//1lWXoesrBSsWr4Q6Wn6XlgheqDA3rp4On79h/d1++3Xnm1B6d4K5M+ZEMrLE4YIFF3amgJpbRpKHCzaMSBNrQXXDxUWiSCbKTKmGFdUevCcVjao9Sc2LZO70iHEO+9/7nX4DVPaW1/bL4JslvT1wd34+L2daGu1IclixVXXL8TkaZGfvhaCO0O6w88Z0mYlogWZaWpGxnpwvWR3JfJzxeIyVOC2RSArsoXgwUESf/zN42isrxtghaqpKkdaRia+99OHkDI8LTqqhUtKcHD79r4U9rTFizGOTTvCfNPBa6sqLlFNTShwCclWVS0+NoyVzPEGh4fwWqOJiBZk7hkb8ZwWbj8ogjyEYA1BIMdZCsETAorx6Zoq7UETNVVq/Wf3bwi7aA2Glvp6bF+1Crb6etg5MKWXurKeauGFK1aErciLBWhvrmcBWt2AArSzZeVIzsrEglXhKUCbVrBIVVPrpa2HWZJw+RL94SGRRuxQiISMnicED7a0/HRXJVasexP3PrRdfeZjHg80S26eAUuSfqtPri+7ZUbAX1swDtPUjIzhbdDEoT2IVFrOnsX/3n03WurqBogx4aCJhspK7Ny4sWeyWYjha1KMGysq3XzTfMzjXA/HtY3Ly1U3K3pwfVxOZPrVo1KQjUZCRs8Tgld4d9/Dr+G5X3+MQ0fOoLyiUX3mYx4P9LAHVlpnZeqnvLIyU5AzKzugryv4BveMvQ6aaG/Dx399DZEIhaxo1Sp0nz9voFo4cMMmjMI0NSNjPbheVRL6a4uNjVU+Y1qbGAk7w8c8zvVIzpxoEdHfDa1NliT9rDvXlyyeFrJrEgbCCHj1xndworLRbXuBj3mc64GMlFlpvfqBxcgem+4WKfNx9tgMrH5gkViewgwLuAJ5ntngnjHT1N5gpHywqAhmHYRxuLAQ4cCSnqZ8xtfddScunDoFGePHq898zOPR1hQk4veQ6TOmtUmrytoB13PnjAvpdQn9FJdU40ytfsUk10t2V2NubuB+T7S6PbnudmVtYjW1YyYy09SMjEWMww+rqX05jxHnFwd247O3+6ux5964EJdOD1w1Nl+jbHcp9r6+HR02GxKsVsy6eTEmzvHdP8wCLq/l/r3wtUKN0QrlcFYyx8bGKltTNFmbolaQ+cuiz1jLh8zI2OFDjra0RiSxdccRQ4V3rxYdCaggE4oubU3Bsjbxzbv0wJfY/s5nqKtvhK21HcmWRGRmpGLRvLnImX6p/O3pQGsTq6l1B00kJuGqr92C5qZG/OnFx9F4tk6lsR2cqixH2ohMfPuuh5CSOriIydbYiK1PbMK5ulp0tvW/Ru2JcgzPzMKyBx6BNc34a/gy0YnCH2qMVihHWyWzmYloQXZEQvQZ09rEampHpy6mqRkZyxuibzB1zKiWQtrS0oHk5AQsWzQFebmcQez7z5LPYeg8G1tdRg6NTS3Y/NKfcOZsI9o7+r/H1rZ21NY3obzqFLIy0rD8zu8gLVUm+2hBnzGtTVpV1g7SMzJx6ZSZ+L9bHsWZk+7nUZx5nGL9w4f9r8bmzRXF+GyVe6tGijOPc/2OdZsNv4bRiU4xsbGYVhD6amFam1hN7W0QxlQZhBEyIl6QCf+B0NYk1qbBweIq7ucyhewc1R4vq8fIrGSsXTHP565nFHRD51n1q6LNBN+8KcaVNWc8ntPW3onKmlpsfuk/semhH8qNoQb8mdBnTGuTGjThFPkyMqYYc/2rQ3tVZKwH1788sAeXzfRvaAPT1IyM9eB6+d7duGiOsfQpfca1x4+jq71d9zxrRgbGhWHYBH3GtDaxX3TPGJb+XrMxvY/UIIxcGYQRKuRdQghq8RWjayOFd7cWTEGkwDQ1o2Aj8LzdB78K+jVFKmz6QZ/x17/zE0y4eDIuHJ2tPvMxj3Ode8bOYq0F1z992/9qbO4ZO6epteD6nte2G35ONv0YPnKk7jmxw4Zh8fr1Yblh42tee8/diIlPgD0mtqfRe+8HH/P4tff8Qm4mQ0hURMiCeYuvmOpmdE1B9wTXc+eMQaSw491daGs3lornedvf+RS5M2SylO6giek56mMwVdbtg6jGNlpU1WGwpaPj+2LTD/qMz505MzBSjomBdcQIFKxbh+SMDIQr0/Pe8y+iy4Mti8e5HikTlaIB+SkLPhdf+QL3nZnqHj8uzS1S5mMe53okVT3bvDS9H+z5gn/V2IkGzxtMUVWCwZaODtjlatnjj+Nrd92FC6f0WnemTMGN992Hbz7/PJJHjEAkTFQSQoNEyELQi6+47/z0Y7eo6JqCzufgnjHT1IyMI0mMidWlUUGgzxcGQmsTq6n10tbcc77ixlv8fg1am1hNrZe2jk9KwuxbFvtp3clTH2ZiqE5UMjMiyEJIiq8oukx1B9raFA4W3ZCP8spTaPNSrEOSEhOweN4VIbmuaIU+Y1qbtKqsHXD9kumz/X4N+oxpbdKqsnbA9QmzoqdV41CdqGRmIis0EYJGNBZfBYuc6ZcgKyPV0LlZI1IxZ9qkoF9TNMMIkz7jkaPHqkjYGT7mca4PZp+TX0uf8Yix41Qk7Awf8zjXo2kvdahOVDIzEiGbyf9bSi/1YScv9VTVjSwUKd1oLL4KFnxTXn7ntzV9yA6SEuKRlZmG5T//TlS9iYcLNv2gz5jWJlZTs4CLe8ZMUzMyDsTPmE0/6DOmtYnV1Czg4p4x09SMjKPt9xgpE5W6u7tRUVKK/dt39I2HnLF4EbJzfe+eZnZi7Hbvvd2ampqQlpaGxsZGpKYaiwwE3/y/aze96bHb2OpHFvjs/w2kD5nX4a8POZrhGwUtTUVvf+rUqStJdepafOMVKjKOtjcMs/8+vty3G8Vv7uwT7LwFC3HJzOgT00D9vLY9+LDyIXuCQxzCWWXd2tCI7Rs3o6V2YPc0Zi3okV68YnlE9LQ2qqEiyCaIjH+1vEi3H3f2uHQ8ubkgqJFyT4Reha1Fh1BbZ0Nzy3m1r8ypSbcticziK2Ho0NLUiP9+Zosa5+j6xs1uYH/7yweRPMjWmtEIBe/1DRtVNbVzpMzImOMNOVEpXILX3d2Nlx96RI2o9ET6uHG4/fFNpr/hMqqhkrIOM0xTMzLWg+ulu6uQn5sdtMh4jYrQB0bGMeiCzRKLyy7JFDEWTAvfuCnGtRpFXxRnHuf691eFpwGHmXFMVKK1idXUjpQw09ScNRzOn1dFSamKjPXgekXpbkyIkipwEeQwwz1jI/7frdsPBUWQGRlTjCs09o75ujzO9aeCHKELkSeChw7tw3vvvYm2tlYkJVlw/fULcPnlM0P+Js40NSNjPbj+1f49uHSWtIGMlIlK+7fvMNQ9bX/RdhFkITCwgMsINoM+YV/5rLgCNae8RegtQY3Qhcji3Lkm/Pa3z6ChoX7ApKbq6kqkp2fgJz/5JYYPD93WFveMjbxx73rzNRHkCKLD6HjIMIyuDBYiyGGG1dRGsBr0CftS0f3KtoP44ss61Vjee4R+WARZUJExxfjUqZNuaxRnHuf6ffetClmkbLRlZrvN81QjwXwkGB0P6ePoSv4Nn2DV9o6d/VXbixZivAmqtkWQwwytTWXlZ3XT1qxyXrb48oDYp1wrunvEuH/Ky2A7eQnRDdPUjIz14Prhw/sxbdqskFyT0ZaZiVZxCEQSMxYvUuMhvXVPm1Gw2KeZ19s3Pobm2oHFf3Vl5UjJysTiFQ/7NPM60IgghxkKJa1NelXWXM+ZM9Zv+xQFn8+x8uEbseGxt3Vfa7CdvITohnvGzmlqLbj+17++GTJBprXpVOUJr2/c+Qv8b60phJ7s3BxlbdKrsmYleHbOHMORMcW4vlK7+I/Huf71xzaGLVKWKp0ww6iVPmNam7SGL/A4170VVDEyphhTbLXGJ/L4itWv4cyZcxpfrZ+07onQp/rwXQnRCgu4jJ0Xun09+oxpbdKDrTUnzfC/taYQemJjY5XPmNYmre5pGePGYdGK5YbFk2lqRsZ6cP3E7j0IFxIhmwA226DPmIVTrKZmARf3jJmmZmRspLrZiH3q7NlWdHu3nbuRlZVsKEIXoh9WUxs7L3TtFvmGTJ+xRx/yiEz87b0Phn1/0DVaKystxf7XXkO7zYZEqxUzbrkFE3PCv49pNlvW7Y9vUtYmVlOzgIt7xkxTMzL25WfFPWNjVds7MDE3PMV/IsgmgaLLoil/C6eM2Ke0xJi7xz1HHWvO+8l2JCYMwxoDEbowNKC1idXUA9LW/NOx9//l8E3yookXK9EJlbiw6Qd9xrQ2sZqaBVzcM2aampGxmUSO+5jbNm9Gc93Am4fa8nKkZGZi6fLlYd3HNBuxsbHK1jRYa1MkVG2LIA8x+5QW/aKMAf8VPywW9/z8GmmX2RvRlO7/EjvfKobN1g6rNREL5+chZ8YlpnqzDzb0GdPa1FdlTSHu/ZOJ6ZVke7cdH3/wHg4f3I8f/fTekFmg+HugrcnM1ibVrnLzZtRXedjHrKpS63+zyfzdpyKNhCBVbQcS+Y0PMftUrIeCah52XRo1KhV5UTAucbA0NrVgxcZ/xe/+WISjX1aiovqM+szHPM71oQJFgj7jCy8cjYSERCXGFGKHGA+wQNWcxD//5lklQkIPTFMzMtaD6yd27w7ZNQ0VZixa6LYXrV21vQjhQgQ5SqC1ycj4xIwR3u/+khLjVDGZpKp7IprHnvtvVJ2sRVtb54A1PuZxrg8l0WHES5/xtdfcgNgY/b+P+vp6HD60P2TXZna4Z2xkH3PP9u04XlyMVzdswP975BH1mY+H0t9ZoKHPmNYmPbg+fk74iv8kZT3E7FOrHp6P9Y+95WaNio2NUR8XTRyBry+bbriYTAu+aRSXVqBo54E+L3TBwunIy8mOuDQc09Sc5KQH1/fs/wo5sy7FUIG/x/Ljx+BtNk1HexvepwVqemgsUGaHBVxGOHPsGN757W8HemV795iXyB7zIKq2H9b0ITMydviQw/keJYIcZfYpI2McB1vR7c0Lvf6xHaitc/VC1yErkzcEiyJqT5p7xq6RsStc3/HWriElyKS1tTWg5w0FWE1thO7z59WH1h5z4ebN+KbsMfsFb2ToM6a1idXU/VXbi1RkHO6fqQhyFGFUbAdb0a0XGVOMK6rco3Tlha5qUOtPbLzN5z98PnfJnjIUvb6/r6iq4OYZyJ09Maj/iFpa2oydZzN2XjRhsVgCet5QgNYmVlPrpa299c1z7DFPzI2OgQqhJjY2VtmawmVt0kMEOcoIltgagWlqRsZ6VJ1sxH/9Twm+9c1cw0La0GjDhie3oU5F3f3RavmJWmRmpmDlr5YiPS04lZHddmN7dt3dvvu7I53rrp+P6ioXC5QLCYlJuO5rC0J6XWaGPmOmnbWqrI1CMd+7g15ZEeRoQ3IeQsDgnrFXL3S3HVu378eDK19WQmskMqYYV1bVDxBjwsc8zvXgFbvEBPCs6GLqtJlIz8jQPScjIwNTL58RsmsyO7wJpc84Y+xYze5TccOGDbkJR0I/IshCyL3QFOUKCunjO7wKKdPUjIz14Hrp3hMIBix0C+R50SYu9BlfOGq0ioSd4WMe53q49+XMuI9Jn/H8n/4UoydPxojsbPWZjy+YNMn0XlkheEjKWgi5F9oB09uleyqQlzPB4zncM3aNjF3heuHOvcibMxGBJtmq71t0YDV4XjRaoO69f6WyNrGamgVc3DNmmpqRsbMY8+bryIF9+PCd/vOumbcAU6bPHHKi3bOPmeuWdmbVOqupvQ3KmLUofF5ZIXiIIAsBg9YmVlPrp617+yw6hPS1/bqCzAIuIxg9z1fYjau88pRupXVSUjwWzc/HUIXiQluTnrWpuakJv3/pGTSerR+w53yyshJpIzLwwzt/iZTU0HT0MjMTDOwxc8LR+DnGJhwJkcXQui0Vggp9xrQ2+UKLFyFlNbURjJ7nK2yNmZmh7/nk+uwZxlKNQxFGxhTj0ydPuhWA8TGPc12aXvTc3CzR2WPmhKMlD4fXKysED/mtCgGDbxL0GWePTdfYU3VExnbEOC0lexFSWpssSfG653B9ycJZQfueHr7nbzF2dJaKhJ3hYx7nurxBeoZpakbGejScrceRA9LRy7HHTJ/xjT/9KUb17jHzMx9/c+NGaQoSxUjKWgi4F5o+Y1qbWE3dbwfq+ewsxkpIb9GvwKXPmNYmVlN7glF5zqzxCBZpqcnYuOL7qhsXG4DYWtthtSSqNDUjYxFjfbhnrGeNcnT04nmXz5SOXnp7zEJ0I4IsBOXNhD7j0j0nVDW1rpDOzvb6XPQZa/mQKeh8jhW/Whp0UeTzsxPXUOvGFdqOXmLlEYY2IshCUFBC+tAiZW2q9SCkXDcipGz6sWXt3yhrE6upHZ26mKZmZCwRarR09BIrjzC0EUEWgoYS0g23K2sTq6lZwMU9Y6apGRn7IqQ8l7amYFibhOBCaxOrqb119OJ5gjCUEUEWgooS0pwJutYmIbqhz5jWJlZTeyJ9xAhMmS4dvYShjeT6BEEI+k0ZfcYXjNbu6HXB6DH44Z3S0UsQYuzeBpoCaGpqQlpaGhobG5Eq5n1BEPygp1PX/t5OXTa1Z9zTqWtgRy9BiDaMaqikrAVBCAkUXdqaxNokCNrIbakgCIIgmAARZEEQBEEwAZKyFgQhqHvGH7z9NtpabUiyWHHtjTfKnrEgeEAEWRCEgHOO051efN7zdKe77sZwKRAVhAHIbaogCIGf7vTi8/rTnV58XqY7CYILIsiCIAQUpqmNTXc6ELJrEoRIQARZEISAwj1jI9OdPnj7rZBdkyBEArKHLAhRCNPBBw4cwjvvvK+mLXHAw7x512H69MuDXlDFAq5AnicIQwURZEGIMpqazuGll36Hs2cb0N7e3ne8srIaI0ak4847f4zU1OFBe31WUwfyPEEYKkjKWhCiLDKmGJ88eWqAGBM+5nGuB7OgitamRJee1a6wh/W1N84P2jUIQiQigiwIUQTT1IyM9Th7th4HDhwO2jXQZ0xrkx4ZIzIwZfr0oF2DIEQiIsiCEEVwz9g1Mnalvb0D77zzXnCnO911t8fpTheOHo0f3HW3NAcRBBdkD1kQoggWcAXyPH9h04+7H35EWZtYTd3fqWu+ioxFjAXBHRFkQYgiWE0dyPMGP91ppvoQBME7cpsqCFEErU2JiYm65yQmJmDevOtDdk2CIBhDImRBiCLoM6a1idXUnhgxIgPTp0+FGWH199H9+/HRW2+jzWZDktWKq+ffiMkzZCCFEP2IIAtCFEHRos+4x4fMwQ4dAyJjijHXzShuzU1N+NfnnkdjfT3a2/o7fdVwIEVGBr5/z91IkYEUQhQTY7fb7d5OampqQlpaGhobG5Eq/yAEIUI6dR1W1dT9nbquV5GxGcWY1/tPGzepwROeYNX2z1c8YsrrF4RAaKhEyIIQhVC0Zs6cpj4iAaapGRnr0VBfj6P7D2DqLCkSE6ITudUUBCHscM/YOU2tRUdbGz56SwZSCNGLCLIgCGGHBVyGzpOBFEIUI4IsCELYYTW1ofNkIIUQxYggC4IQdmhtSkzyMpAiKQlXz5eBFEL0IoIsCELYoc+Y1iY90jMyMHmGDKQQohcRZEEQTFEVTp+xGkjhEinzMY9zXSxPQjQjPmRBEEzWqeuAqqZ2DKRgmpqRsYixEKmID1kQhIiDokufsXiNhaGI3HIKgiAIggkQQRYEQRAEEyCCLAiCIAgmQARZEARBEEyACLIgCIIgmAARZEEQBEEwASLIgiAIgmACRJAFQRAEwQSIIAuCIAiCCRBBFgRBEAQTIIIsCIIgCCZABFkQBEEQTIAIsiAIgiCYABFkQRAEQTABIsiCIAiCYAJEkAVBEATBBIggC4IgCIIJEEEWBEEQBBMggiwIgiAIJmBYuC9AEEJNd3c39u79Am+8uQs2Wxus1iTctCAfs2ZdithYuUcVBCE8iCALQ4qmphY89fR/4uzZJrS1dfQdr6g4hREjUnH/fd9BampyWK9REIShiYQDwpCKjCnG1dW1A8SY8DGPc53nCYIghBoRZGHIwDQ1I2M9uL5v31chuyZBEAQHIsjCkIF7xq6RsStcf/2NT0N2TYIgCA5EkIUhAwu4jNBq8DxBEIRAIoIsDBlYTW0Ei8HzBEEQAokIsjBkoLUpKSlB9xyu33zTFSG7JkEQBAciyMKQgT5jWpv04PrMmZNCdk2CIAgORJCFIQObftBnPGZMllukzMc8znVpDiIIQjiIsdvtdm8nNTU1IS0tDY2NjUhN1Y8wBMHs0GdMaxOrqVnAxT1jpqkZGYsYC4IQaIxqqHTqEoYcFN3Zsy9VH4IgCGZBwgFBEARBMAEiyIIgCIJgAkSQBUEQBMEEiCALgiAIggkQQRYEQRAEEyCCLAiCIAgmwJDtyWFVppdKEARBEATjOLTTW9sPQ4J87tw59Tk7O9uHSxAEQRAEwVlL2SBkUJ262Nmouroaw4cPR0xMjLfTBUEQBEHohTJLMR4zZoxuN0BDgiwIgiAIQnCRoi5BEARBMAEiyIIgCIJgAkSQBUEQBMEEiCALgiAIggkQQRYEQRAEEyCCLAiCIAgmQARZEARBEBB+/n+7xQItU+usYAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Define colors for visualization\n",
    "colors = [\n",
    "    np.array([73, 80, 182, 255])/255,   # Blue for cluster 1\n",
    "    np.array([182, 73, 80, 255])/255,   # Red for cluster 2\n",
    "    np.array([80, 182, 73, 255])/255,   # Green for mixed\n",
    "]\n",
    "\n",
    "# Calculate point colors based on mass assignment\n",
    "point_colors = []\n",
    "for point in range(len(features)):\n",
    "    color = np.sum([colors[i] * mass[point, i] for i in range(len(colors))], axis=0)\n",
    "    color = np.clip(color[:3], 0, 1)\n",
    "    point_colors.append(color)\n",
    "\n",
    "# Plot the data points\n",
    "plt.figure(figsize=(6, 4))\n",
    "for i in range(len(features)):\n",
    "    plt.scatter(features[i, 0], features[i, 1], color=point_colors[i], linewidth=0.5, s=50)\n",
    "\n",
    "# plt.title('Initial ECM Clustering')\n",
    "# plt.xlabel('x')\n",
    "# plt.ylabel('y')\n",
    "# remove ticks\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.axis('equal')\n",
    "\n",
    "# save figure\n",
    "plt.savefig('figures_simple_example/initial_ev_clustering.pdf', bbox_inches='tight')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "653becc4",
   "metadata": {},
   "source": [
    "## Apply IEMM Classification\n",
    "\n",
    "Now we'll use the IEMM classifier to create decision boundaries."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "74f5f5ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "IEMM classifier trained with lambda = 1.0\n"
     ]
    }
   ],
   "source": [
    "# Create and fit IEMM classifier\n",
    "lambda_mistakeness = 1.0  # Parameter controlling the trade-off\n",
    "classifier = IEMM(lambda_mistakeness=lambda_mistakeness)\n",
    "classifier.fit(features, mass, F)\n",
    "\n",
    "print(f\"IEMM classifier trained with lambda = {lambda_mistakeness}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "be138988",
   "metadata": {},
   "source": [
    "## Visualize IEMM Decision Boundaries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2e6c4f1e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create a mesh for decision boundary visualization\n",
    "x_min, x_max = features[:, 0].min() - 1, features[:, 0].max() + 1\n",
    "y_min, y_max = features[:, 1].min() - 1, features[:, 1].max() + 1\n",
    "xx, yy = np.meshgrid(np.linspace(x_min, x_max, 100),\n",
    "                     np.linspace(y_min, y_max, 100))\n",
    "\n",
    "# Predict on mesh points\n",
    "mesh_points = np.column_stack((xx.ravel(), yy.ravel()))\n",
    "Z = classifier.predict(mesh_points)\n",
    "Z = Z.reshape(xx.shape[0], xx.shape[1], -1)\n",
    "\n",
    "# Create color map for regions\n",
    "Z_color = np.zeros((xx.shape[0], xx.shape[1], 3))\n",
    "for i in range(xx.shape[0]):\n",
    "    for j in range(xx.shape[1]):\n",
    "        Z_color[i, j] = colors[Z[i, j, 0]][:3]\n",
    "\n",
    "# Plot\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.imshow(Z_color, extent=(x_min, x_max, y_min, y_max), \n",
    "           origin='lower', aspect='auto', alpha=1)\n",
    "\n",
    "# Plot data points\n",
    "for i in range(len(features)):\n",
    "    # plt.scatter(features[i, 0], features[i, 1], color=point_colors[i], linewidth=0.5, s=50)\n",
    "    plt.scatter(features[i, 0], features[i, 1], color='black', linewidth=0.5, s=50)\n",
    "\n",
    "# plt.title(f'IEMM Decision Boundaries (λ = {lambda_mistakeness})')\n",
    "# plt.xlabel('x')\n",
    "# plt.ylabel('y')\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.axis('equal')\n",
    "# plt.grid(True, alpha=0.3)\n",
    "\n",
    "# Add legend\n",
    "focal_sets = ['$\\omega_1$', '$\\omega_2$', '$\\omega_1 \\cup \\omega_2$']\n",
    "# for i in range(len(focal_sets)):\n",
    "#     plt.scatter([], [], color=colors[i][:3], label=focal_sets[i], s=100, edgecolor='black')\n",
    "# plt.legend(title='Meta-clusters')\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "# save figure\n",
    "plt.savefig('figures_simple_example/iemm_decision_boundaries.pdf', bbox_inches='tight')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "279f2fe4",
   "metadata": {},
   "source": [
    "## Generate Decision Tree Visualization\n",
    "\n",
    "IEMM can also generate interpretable decision trees."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "52a1ece3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
       "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
       "  \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
       "<svg xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"986.76pt\" height=\"362.52pt\" viewBox=\"0 0 986.76 362.52\" xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\">\n",
       " <metadata>\n",
       "  <rdf:RDF xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:cc=\"http://creativecommons.org/ns#\" xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\n",
       "   <cc:Work>\n",
       "    <dc:type rdf:resource=\"http://purl.org/dc/dcmitype/StillImage\"/>\n",
       "    <dc:date>2025-09-22T23:11:50.538856</dc:date>\n",
       "    <dc:format>image/svg+xml</dc:format>\n",
       "    <dc:creator>\n",
       "     <cc:Agent>\n",
       "      <dc:title>Matplotlib v3.10.5, https://matplotlib.org/</dc:title>\n",
       "     </cc:Agent>\n",
       "    </dc:creator>\n",
       "   </cc:Work>\n",
       "  </rdf:RDF>\n",
       " </metadata>\n",
       " <defs>\n",
       "  <style type=\"text/css\">*{stroke-linejoin: round; stroke-linecap: butt}</style>\n",
       " </defs>\n",
       " <g id=\"figure_1\">\n",
       "  <g id=\"patch_1\">\n",
       "   <path d=\"M 0 362.52 \n",
       "L 986.76 362.52 \n",
       "L 986.76 0 \n",
       "L 0 0 \n",
       "z\n",
       "\" style=\"fill: #ffffff\"/>\n",
       "  </g>\n",
       "  <g id=\"axes_1\">\n",
       "   <g id=\"patch_2\">\n",
       "    <path d=\"M 388.08 40.68 \n",
       "L 388.08 4.68 \n",
       "L 748.08 4.68 \n",
       "L 748.08 76.68 \n",
       "L 388.08 76.68 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: #ffffff; stroke: #ffffff; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_3\">\n",
       "    <path d=\"M 154.08 184.68 \n",
       "L 154.08 152.28 \n",
       "L 478.08 152.28 \n",
       "L 478.08 217.08 \n",
       "L 154.08 217.08 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: #ffffff; stroke: #ffffff; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_4\">\n",
       "    <path d=\"M 4.68 328.68 \n",
       "L 4.68 299.52 \n",
       "L 296.28 299.52 \n",
       "L 296.28 357.84 \n",
       "L 4.68 357.84 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: #ffffff; stroke: #ffffff; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_5\">\n",
       "    <path d=\"M 335.88 328.68 \n",
       "L 335.88 299.52 \n",
       "L 627.48 299.52 \n",
       "L 627.48 357.84 \n",
       "L 335.88 357.84 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: #ffffff; stroke: #ffffff; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_6\">\n",
       "    <path d=\"M 658.08 184.68 \n",
       "L 658.08 152.28 \n",
       "L 982.08 152.28 \n",
       "L 982.08 217.08 \n",
       "L 658.08 217.08 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: #ffffff; stroke: #ffffff; stroke-linejoin: miter\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_1\">\n",
       "    <path d=\"M 388.08 40.68 \n",
       "L 388.08 4.68 \n",
       "L 748.08 4.68 \n",
       "L 748.08 76.68 \n",
       "L 388.08 76.68 \n",
       "L 388.08 40.68 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_2\">\n",
       "    <path d=\"M 154.08 184.68 \n",
       "L 154.08 152.28 \n",
       "L 478.08 152.28 \n",
       "L 478.08 217.08 \n",
       "L 154.08 217.08 \n",
       "L 154.08 184.68 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_3\">\n",
       "    <path d=\"M 568.08 76.68 \n",
       "L 442.08 114.48 \n",
       "L 324.700437 149.693869 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_7\">\n",
       "    <path d=\"M 325.476276 152.28 \n",
       "L 316.08 152.28 \n",
       "L 323.924597 147.107738 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_4\">\n",
       "    <path d=\"M 4.68 328.68 \n",
       "L 4.68 299.52 \n",
       "L 296.28 299.52 \n",
       "L 296.28 357.84 \n",
       "L 4.68 357.84 \n",
       "L 4.68 328.68 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_5\">\n",
       "    <path d=\"M 316.08 217.08 \n",
       "L 233.28 258.3 \n",
       "L 158.536838 295.509096 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_8\">\n",
       "    <path d=\"M 159.74011 297.926147 \n",
       "L 150.48 299.52 \n",
       "L 157.333567 293.092044 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_6\">\n",
       "    <path d=\"M 335.88 328.68 \n",
       "L 335.88 299.52 \n",
       "L 627.48 299.52 \n",
       "L 627.48 357.84 \n",
       "L 335.88 357.84 \n",
       "L 335.88 328.68 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_7\">\n",
       "    <path d=\"M 316.08 217.08 \n",
       "L 398.88 258.3 \n",
       "L 473.623162 295.509096 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_9\">\n",
       "    <path d=\"M 474.826433 293.092044 \n",
       "L 481.68 299.52 \n",
       "L 472.41989 297.926147 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_8\">\n",
       "    <path d=\"M 658.08 184.68 \n",
       "L 658.08 152.28 \n",
       "L 982.08 152.28 \n",
       "L 982.08 217.08 \n",
       "L 658.08 217.08 \n",
       "L 658.08 184.68 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"line2d_9\">\n",
       "    <path d=\"M 568.08 76.68 \n",
       "L 694.08 114.48 \n",
       "L 811.459563 149.693869 \n",
       "\" clip-path=\"url(#p67b8980cf8)\" style=\"fill: none; stroke: #000000; stroke-width: 2; stroke-linecap: round\"/>\n",
       "   </g>\n",
       "   <g id=\"patch_10\">\n",
       "    <path d=\"M 812.235403 147.107738 \n",
       "L 820.08 152.28 \n",
       "L 810.683724 152.28 \n",
       "z\n",
       "\" clip-path=\"url(#p67b8980cf8)\"/>\n",
       "   </g>\n",
       "   <g id=\"text_1\">\n",
       "    <!-- 200 samples -->\n",
       "    <g transform=\"translate(517.01375 37.3525) scale(0.16 -0.16)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-32\" d=\"M 1228 531 \n",
       "L 3431 531 \n",
       "L 3431 0 \n",
       "L 469 0 \n",
       "L 469 531 \n",
       "Q 828 903 1448 1529 \n",
       "Q 2069 2156 2228 2338 \n",
       "Q 2531 2678 2651 2914 \n",
       "Q 2772 3150 2772 3378 \n",
       "Q 2772 3750 2511 3984 \n",
       "Q 2250 4219 1831 4219 \n",
       "Q 1534 4219 1204 4116 \n",
       "Q 875 4013 500 3803 \n",
       "L 500 4441 \n",
       "Q 881 4594 1212 4672 \n",
       "Q 1544 4750 1819 4750 \n",
       "Q 2544 4750 2975 4387 \n",
       "Q 3406 4025 3406 3419 \n",
       "Q 3406 3131 3298 2873 \n",
       "Q 3191 2616 2906 2266 \n",
       "Q 2828 2175 2409 1742 \n",
       "Q 1991 1309 1228 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-30\" d=\"M 2034 4250 \n",
       "Q 1547 4250 1301 3770 \n",
       "Q 1056 3291 1056 2328 \n",
       "Q 1056 1369 1301 889 \n",
       "Q 1547 409 2034 409 \n",
       "Q 2525 409 2770 889 \n",
       "Q 3016 1369 3016 2328 \n",
       "Q 3016 3291 2770 3770 \n",
       "Q 2525 4250 2034 4250 \n",
       "z\n",
       "M 2034 4750 \n",
       "Q 2819 4750 3233 4129 \n",
       "Q 3647 3509 3647 2328 \n",
       "Q 3647 1150 3233 529 \n",
       "Q 2819 -91 2034 -91 \n",
       "Q 1250 -91 836 529 \n",
       "Q 422 1150 422 2328 \n",
       "Q 422 3509 836 4129 \n",
       "Q 1250 4750 2034 4750 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-20\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-73\" d=\"M 2834 3397 \n",
       "L 2834 2853 \n",
       "Q 2591 2978 2328 3040 \n",
       "Q 2066 3103 1784 3103 \n",
       "Q 1356 3103 1142 2972 \n",
       "Q 928 2841 928 2578 \n",
       "Q 928 2378 1081 2264 \n",
       "Q 1234 2150 1697 2047 \n",
       "L 1894 2003 \n",
       "Q 2506 1872 2764 1633 \n",
       "Q 3022 1394 3022 966 \n",
       "Q 3022 478 2636 193 \n",
       "Q 2250 -91 1575 -91 \n",
       "Q 1294 -91 989 -36 \n",
       "Q 684 19 347 128 \n",
       "L 347 722 \n",
       "Q 666 556 975 473 \n",
       "Q 1284 391 1588 391 \n",
       "Q 1994 391 2212 530 \n",
       "Q 2431 669 2431 922 \n",
       "Q 2431 1156 2273 1281 \n",
       "Q 2116 1406 1581 1522 \n",
       "L 1381 1569 \n",
       "Q 847 1681 609 1914 \n",
       "Q 372 2147 372 2553 \n",
       "Q 372 3047 722 3315 \n",
       "Q 1072 3584 1716 3584 \n",
       "Q 2034 3584 2315 3537 \n",
       "Q 2597 3491 2834 3397 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-61\" d=\"M 2194 1759 \n",
       "Q 1497 1759 1228 1600 \n",
       "Q 959 1441 959 1056 \n",
       "Q 959 750 1161 570 \n",
       "Q 1363 391 1709 391 \n",
       "Q 2188 391 2477 730 \n",
       "Q 2766 1069 2766 1631 \n",
       "L 2766 1759 \n",
       "L 2194 1759 \n",
       "z\n",
       "M 3341 1997 \n",
       "L 3341 0 \n",
       "L 2766 0 \n",
       "L 2766 531 \n",
       "Q 2569 213 2275 61 \n",
       "Q 1981 -91 1556 -91 \n",
       "Q 1019 -91 701 211 \n",
       "Q 384 513 384 1019 \n",
       "Q 384 1609 779 1909 \n",
       "Q 1175 2209 1959 2209 \n",
       "L 2766 2209 \n",
       "L 2766 2266 \n",
       "Q 2766 2663 2505 2880 \n",
       "Q 2244 3097 1772 3097 \n",
       "Q 1472 3097 1187 3025 \n",
       "Q 903 2953 641 2809 \n",
       "L 641 3341 \n",
       "Q 956 3463 1253 3523 \n",
       "Q 1550 3584 1831 3584 \n",
       "Q 2591 3584 2966 3190 \n",
       "Q 3341 2797 3341 1997 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-6d\" d=\"M 3328 2828 \n",
       "Q 3544 3216 3844 3400 \n",
       "Q 4144 3584 4550 3584 \n",
       "Q 5097 3584 5394 3201 \n",
       "Q 5691 2819 5691 2113 \n",
       "L 5691 0 \n",
       "L 5113 0 \n",
       "L 5113 2094 \n",
       "Q 5113 2597 4934 2840 \n",
       "Q 4756 3084 4391 3084 \n",
       "Q 3944 3084 3684 2787 \n",
       "Q 3425 2491 3425 1978 \n",
       "L 3425 0 \n",
       "L 2847 0 \n",
       "L 2847 2094 \n",
       "Q 2847 2600 2669 2842 \n",
       "Q 2491 3084 2119 3084 \n",
       "Q 1678 3084 1418 2786 \n",
       "Q 1159 2488 1159 1978 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2956 \n",
       "Q 1356 3278 1631 3431 \n",
       "Q 1906 3584 2284 3584 \n",
       "Q 2666 3584 2933 3390 \n",
       "Q 3200 3197 3328 2828 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-70\" d=\"M 1159 525 \n",
       "L 1159 -1331 \n",
       "L 581 -1331 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2969 \n",
       "Q 1341 3281 1617 3432 \n",
       "Q 1894 3584 2278 3584 \n",
       "Q 2916 3584 3314 3078 \n",
       "Q 3713 2572 3713 1747 \n",
       "Q 3713 922 3314 415 \n",
       "Q 2916 -91 2278 -91 \n",
       "Q 1894 -91 1617 61 \n",
       "Q 1341 213 1159 525 \n",
       "z\n",
       "M 3116 1747 \n",
       "Q 3116 2381 2855 2742 \n",
       "Q 2594 3103 2138 3103 \n",
       "Q 1681 3103 1420 2742 \n",
       "Q 1159 2381 1159 1747 \n",
       "Q 1159 1113 1420 752 \n",
       "Q 1681 391 2138 391 \n",
       "Q 2594 391 2855 752 \n",
       "Q 3116 1113 3116 1747 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-6c\" d=\"M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-65\" d=\"M 3597 1894 \n",
       "L 3597 1613 \n",
       "L 953 1613 \n",
       "Q 991 1019 1311 708 \n",
       "Q 1631 397 2203 397 \n",
       "Q 2534 397 2845 478 \n",
       "Q 3156 559 3463 722 \n",
       "L 3463 178 \n",
       "Q 3153 47 2828 -22 \n",
       "Q 2503 -91 2169 -91 \n",
       "Q 1331 -91 842 396 \n",
       "Q 353 884 353 1716 \n",
       "Q 353 2575 817 3079 \n",
       "Q 1281 3584 2069 3584 \n",
       "Q 2775 3584 3186 3129 \n",
       "Q 3597 2675 3597 1894 \n",
       "z\n",
       "M 3022 2063 \n",
       "Q 3016 2534 2758 2815 \n",
       "Q 2500 3097 2075 3097 \n",
       "Q 1594 3097 1305 2825 \n",
       "Q 1016 2553 972 2059 \n",
       "L 3022 2063 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-32\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(63.623047 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(127.246094 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(190.869141 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(222.65625 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(274.755859 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6d\" transform=\"translate(336.035156 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-70\" transform=\"translate(433.447266 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(496.923828 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(524.707031 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(586.230469 0)\"/>\n",
       "    </g>\n",
       "    <!-- mistakeness of cut: 0.29 -->\n",
       "    <g transform=\"translate(469.815 52.8375) scale(0.16 -0.16)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-69\" d=\"M 603 3500 \n",
       "L 1178 3500 \n",
       "L 1178 0 \n",
       "L 603 0 \n",
       "L 603 3500 \n",
       "z\n",
       "M 603 4863 \n",
       "L 1178 4863 \n",
       "L 1178 4134 \n",
       "L 603 4134 \n",
       "L 603 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-74\" d=\"M 1172 4494 \n",
       "L 1172 3500 \n",
       "L 2356 3500 \n",
       "L 2356 3053 \n",
       "L 1172 3053 \n",
       "L 1172 1153 \n",
       "Q 1172 725 1289 603 \n",
       "Q 1406 481 1766 481 \n",
       "L 2356 481 \n",
       "L 2356 0 \n",
       "L 1766 0 \n",
       "Q 1100 0 847 248 \n",
       "Q 594 497 594 1153 \n",
       "L 594 3053 \n",
       "L 172 3053 \n",
       "L 172 3500 \n",
       "L 594 3500 \n",
       "L 594 4494 \n",
       "L 1172 4494 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-6b\" d=\"M 581 4863 \n",
       "L 1159 4863 \n",
       "L 1159 1991 \n",
       "L 2875 3500 \n",
       "L 3609 3500 \n",
       "L 1753 1863 \n",
       "L 3688 0 \n",
       "L 2938 0 \n",
       "L 1159 1709 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-6e\" d=\"M 3513 2113 \n",
       "L 3513 0 \n",
       "L 2938 0 \n",
       "L 2938 2094 \n",
       "Q 2938 2591 2744 2837 \n",
       "Q 2550 3084 2163 3084 \n",
       "Q 1697 3084 1428 2787 \n",
       "Q 1159 2491 1159 1978 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 3500 \n",
       "L 1159 3500 \n",
       "L 1159 2956 \n",
       "Q 1366 3272 1645 3428 \n",
       "Q 1925 3584 2291 3584 \n",
       "Q 2894 3584 3203 3211 \n",
       "Q 3513 2838 3513 2113 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-6f\" d=\"M 1959 3097 \n",
       "Q 1497 3097 1228 2736 \n",
       "Q 959 2375 959 1747 \n",
       "Q 959 1119 1226 758 \n",
       "Q 1494 397 1959 397 \n",
       "Q 2419 397 2687 759 \n",
       "Q 2956 1122 2956 1747 \n",
       "Q 2956 2369 2687 2733 \n",
       "Q 2419 3097 1959 3097 \n",
       "z\n",
       "M 1959 3584 \n",
       "Q 2709 3584 3137 3096 \n",
       "Q 3566 2609 3566 1747 \n",
       "Q 3566 888 3137 398 \n",
       "Q 2709 -91 1959 -91 \n",
       "Q 1206 -91 779 398 \n",
       "Q 353 888 353 1747 \n",
       "Q 353 2609 779 3096 \n",
       "Q 1206 3584 1959 3584 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-66\" d=\"M 2375 4863 \n",
       "L 2375 4384 \n",
       "L 1825 4384 \n",
       "Q 1516 4384 1395 4259 \n",
       "Q 1275 4134 1275 3809 \n",
       "L 1275 3500 \n",
       "L 2222 3500 \n",
       "L 2222 3053 \n",
       "L 1275 3053 \n",
       "L 1275 0 \n",
       "L 697 0 \n",
       "L 697 3053 \n",
       "L 147 3053 \n",
       "L 147 3500 \n",
       "L 697 3500 \n",
       "L 697 3744 \n",
       "Q 697 4328 969 4595 \n",
       "Q 1241 4863 1831 4863 \n",
       "L 2375 4863 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-63\" d=\"M 3122 3366 \n",
       "L 3122 2828 \n",
       "Q 2878 2963 2633 3030 \n",
       "Q 2388 3097 2138 3097 \n",
       "Q 1578 3097 1268 2742 \n",
       "Q 959 2388 959 1747 \n",
       "Q 959 1106 1268 751 \n",
       "Q 1578 397 2138 397 \n",
       "Q 2388 397 2633 464 \n",
       "Q 2878 531 3122 666 \n",
       "L 3122 134 \n",
       "Q 2881 22 2623 -34 \n",
       "Q 2366 -91 2075 -91 \n",
       "Q 1284 -91 818 406 \n",
       "Q 353 903 353 1747 \n",
       "Q 353 2603 823 3093 \n",
       "Q 1294 3584 2113 3584 \n",
       "Q 2378 3584 2631 3529 \n",
       "Q 2884 3475 3122 3366 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-75\" d=\"M 544 1381 \n",
       "L 544 3500 \n",
       "L 1119 3500 \n",
       "L 1119 1403 \n",
       "Q 1119 906 1312 657 \n",
       "Q 1506 409 1894 409 \n",
       "Q 2359 409 2629 706 \n",
       "Q 2900 1003 2900 1516 \n",
       "L 2900 3500 \n",
       "L 3475 3500 \n",
       "L 3475 0 \n",
       "L 2900 0 \n",
       "L 2900 538 \n",
       "Q 2691 219 2414 64 \n",
       "Q 2138 -91 1772 -91 \n",
       "Q 1169 -91 856 284 \n",
       "Q 544 659 544 1381 \n",
       "z\n",
       "M 1991 3584 \n",
       "L 1991 3584 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-3a\" d=\"M 750 794 \n",
       "L 1409 794 \n",
       "L 1409 0 \n",
       "L 750 0 \n",
       "L 750 794 \n",
       "z\n",
       "M 750 3309 \n",
       "L 1409 3309 \n",
       "L 1409 2516 \n",
       "L 750 2516 \n",
       "L 750 3309 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-2e\" d=\"M 684 794 \n",
       "L 1344 794 \n",
       "L 1344 0 \n",
       "L 684 0 \n",
       "L 684 794 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-39\" d=\"M 703 97 \n",
       "L 703 672 \n",
       "Q 941 559 1184 500 \n",
       "Q 1428 441 1663 441 \n",
       "Q 2288 441 2617 861 \n",
       "Q 2947 1281 2994 2138 \n",
       "Q 2813 1869 2534 1725 \n",
       "Q 2256 1581 1919 1581 \n",
       "Q 1219 1581 811 2004 \n",
       "Q 403 2428 403 3163 \n",
       "Q 403 3881 828 4315 \n",
       "Q 1253 4750 1959 4750 \n",
       "Q 2769 4750 3195 4129 \n",
       "Q 3622 3509 3622 2328 \n",
       "Q 3622 1225 3098 567 \n",
       "Q 2575 -91 1691 -91 \n",
       "Q 1453 -91 1209 -44 \n",
       "Q 966 3 703 97 \n",
       "z\n",
       "M 1959 2075 \n",
       "Q 2384 2075 2632 2365 \n",
       "Q 2881 2656 2881 3163 \n",
       "Q 2881 3666 2632 3958 \n",
       "Q 2384 4250 1959 4250 \n",
       "Q 1534 4250 1286 3958 \n",
       "Q 1038 3666 1038 3163 \n",
       "Q 1038 2656 1286 2365 \n",
       "Q 1534 2075 1959 2075 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-6d\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-69\" transform=\"translate(97.412109 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(125.195312 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-74\" transform=\"translate(177.294922 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(216.503906 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6b\" transform=\"translate(277.783203 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(332.068359 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6e\" transform=\"translate(393.591797 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(456.970703 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(518.494141 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(570.59375 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(622.693359 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6f\" transform=\"translate(654.480469 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-66\" transform=\"translate(715.662109 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(750.867188 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-63\" transform=\"translate(782.654297 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-75\" transform=\"translate(837.634766 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-74\" transform=\"translate(901.013672 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" transform=\"translate(940.222656 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(973.914062 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(1005.701172 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(1069.324219 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(1101.111328 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-39\" transform=\"translate(1164.734375 0)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_2\">\n",
       "    <!-- 144 samples -->\n",
       "    <g transform=\"translate(270.120375 181.68525) scale(0.144 -0.144)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-31\" d=\"M 794 531 \n",
       "L 1825 531 \n",
       "L 1825 4091 \n",
       "L 703 3866 \n",
       "L 703 4441 \n",
       "L 1819 4666 \n",
       "L 2450 4666 \n",
       "L 2450 531 \n",
       "L 3481 531 \n",
       "L 3481 0 \n",
       "L 794 0 \n",
       "L 794 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-34\" d=\"M 2419 4116 \n",
       "L 825 1625 \n",
       "L 2419 1625 \n",
       "L 2419 4116 \n",
       "z\n",
       "M 2253 4666 \n",
       "L 3047 4666 \n",
       "L 3047 1625 \n",
       "L 3713 1625 \n",
       "L 3713 1100 \n",
       "L 3047 1100 \n",
       "L 3047 0 \n",
       "L 2419 0 \n",
       "L 2419 1100 \n",
       "L 313 1100 \n",
       "L 313 1709 \n",
       "L 2253 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-31\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-34\" transform=\"translate(63.623047 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-34\" transform=\"translate(127.246094 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(190.869141 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(222.65625 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(274.755859 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6d\" transform=\"translate(336.035156 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-70\" transform=\"translate(433.447266 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(496.923828 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(524.707031 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(586.230469 0)\"/>\n",
       "    </g>\n",
       "    <!-- mistakeness of cut: 0.4 -->\n",
       "    <g transform=\"translate(232.2225 195.62175) scale(0.144 -0.144)\">\n",
       "     <use xlink:href=\"#DejaVuSans-6d\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-69\" transform=\"translate(97.412109 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(125.195312 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-74\" transform=\"translate(177.294922 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(216.503906 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6b\" transform=\"translate(277.783203 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(332.068359 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6e\" transform=\"translate(393.591797 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(456.970703 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(518.494141 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(570.59375 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(622.693359 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6f\" transform=\"translate(654.480469 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-66\" transform=\"translate(715.662109 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(750.867188 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-63\" transform=\"translate(782.654297 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-75\" transform=\"translate(837.634766 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-74\" transform=\"translate(901.013672 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" transform=\"translate(940.222656 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(973.914062 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-30\" transform=\"translate(1005.701172 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(1069.324219 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-34\" transform=\"translate(1101.111328 0)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_3\">\n",
       "    <!-- x ≤ 5.65 -->\n",
       "    <g transform=\"translate(427.029292 136.00717) rotate(-16.699244) scale(0.096 -0.096)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-78\" d=\"M 3513 3500 \n",
       "L 2247 1797 \n",
       "L 3578 0 \n",
       "L 2900 0 \n",
       "L 1881 1375 \n",
       "L 863 0 \n",
       "L 184 0 \n",
       "L 1544 1831 \n",
       "L 300 3500 \n",
       "L 978 3500 \n",
       "L 1906 2253 \n",
       "L 2834 3500 \n",
       "L 3513 3500 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-2264\" d=\"M 4684 3175 \n",
       "L 1684 2309 \n",
       "L 4684 1453 \n",
       "L 4684 897 \n",
       "L 678 2047 \n",
       "L 678 2578 \n",
       "L 4684 3725 \n",
       "L 4684 3175 \n",
       "z\n",
       "M 678 531 \n",
       "L 4684 531 \n",
       "L 4684 0 \n",
       "L 678 0 \n",
       "L 678 531 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-35\" d=\"M 691 4666 \n",
       "L 3169 4666 \n",
       "L 3169 4134 \n",
       "L 1269 4134 \n",
       "L 1269 2991 \n",
       "Q 1406 3038 1543 3061 \n",
       "Q 1681 3084 1819 3084 \n",
       "Q 2600 3084 3056 2656 \n",
       "Q 3513 2228 3513 1497 \n",
       "Q 3513 744 3044 326 \n",
       "Q 2575 -91 1722 -91 \n",
       "Q 1428 -91 1123 -41 \n",
       "Q 819 9 494 109 \n",
       "L 494 744 \n",
       "Q 775 591 1075 516 \n",
       "Q 1375 441 1709 441 \n",
       "Q 2250 441 2565 725 \n",
       "Q 2881 1009 2881 1497 \n",
       "Q 2881 1984 2565 2268 \n",
       "Q 2250 2553 1709 2553 \n",
       "Q 1456 2553 1204 2497 \n",
       "Q 953 2441 691 2322 \n",
       "L 691 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-36\" d=\"M 2113 2584 \n",
       "Q 1688 2584 1439 2293 \n",
       "Q 1191 2003 1191 1497 \n",
       "Q 1191 994 1439 701 \n",
       "Q 1688 409 2113 409 \n",
       "Q 2538 409 2786 701 \n",
       "Q 3034 994 3034 1497 \n",
       "Q 3034 2003 2786 2293 \n",
       "Q 2538 2584 2113 2584 \n",
       "z\n",
       "M 3366 4563 \n",
       "L 3366 3988 \n",
       "Q 3128 4100 2886 4159 \n",
       "Q 2644 4219 2406 4219 \n",
       "Q 1781 4219 1451 3797 \n",
       "Q 1122 3375 1075 2522 \n",
       "Q 1259 2794 1537 2939 \n",
       "Q 1816 3084 2150 3084 \n",
       "Q 2853 3084 3261 2657 \n",
       "Q 3669 2231 3669 1497 \n",
       "Q 3669 778 3244 343 \n",
       "Q 2819 -91 2113 -91 \n",
       "Q 1303 -91 875 529 \n",
       "Q 447 1150 447 2328 \n",
       "Q 447 3434 972 4092 \n",
       "Q 1497 4750 2381 4750 \n",
       "Q 2619 4750 2861 4703 \n",
       "Q 3103 4656 3366 4563 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-78\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(59.179688 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2264\" transform=\"translate(90.966797 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(174.755859 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(206.542969 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(270.166016 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(301.953125 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(365.576172 0)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_4\">\n",
       "    <!-- 76 samples -->\n",
       "    <g transform=\"translate(113.239238 325.984725) scale(0.1296 -0.1296)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-37\" d=\"M 525 4666 \n",
       "L 3525 4666 \n",
       "L 3525 4397 \n",
       "L 1831 0 \n",
       "L 1172 0 \n",
       "L 2766 4134 \n",
       "L 525 4134 \n",
       "L 525 4666 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-37\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(63.623047 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(127.246094 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(159.033203 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(211.132812 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6d\" transform=\"translate(272.412109 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-70\" transform=\"translate(369.824219 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(433.300781 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(461.083984 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(522.607422 0)\"/>\n",
       "    </g>\n",
       "    <!-- label: $\\omega_1$ -->\n",
       "    <g transform=\"translate(122.0328 338.527575) scale(0.1296 -0.1296)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-62\" d=\"M 3116 1747 \n",
       "Q 3116 2381 2855 2742 \n",
       "Q 2594 3103 2138 3103 \n",
       "Q 1681 3103 1420 2742 \n",
       "Q 1159 2381 1159 1747 \n",
       "Q 1159 1113 1420 752 \n",
       "Q 1681 391 2138 391 \n",
       "Q 2594 391 2855 752 \n",
       "Q 3116 1113 3116 1747 \n",
       "z\n",
       "M 1159 2969 \n",
       "Q 1341 3281 1617 3432 \n",
       "Q 1894 3584 2278 3584 \n",
       "Q 2916 3584 3314 3078 \n",
       "Q 3713 2572 3713 1747 \n",
       "Q 3713 922 3314 415 \n",
       "Q 2916 -91 2278 -91 \n",
       "Q 1894 -91 1617 61 \n",
       "Q 1341 213 1159 525 \n",
       "L 1159 0 \n",
       "L 581 0 \n",
       "L 581 4863 \n",
       "L 1159 4863 \n",
       "L 1159 2969 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "      <path id=\"DejaVuSans-Oblique-3c9\" d=\"M 1369 -91 \n",
       "Q 72 -91 434 1766 \n",
       "Q 575 2500 1256 3500 \n",
       "L 1875 3500 \n",
       "Q 1231 2500 1088 1750 \n",
       "Q 819 397 1519 397 \n",
       "Q 2166 397 2478 2078 \n",
       "L 3009 2078 \n",
       "Q 2669 388 3316 397 \n",
       "Q 4013 403 4275 1750 \n",
       "Q 4419 2500 4169 3500 \n",
       "L 4788 3500 \n",
       "Q 5075 2500 4934 1766 \n",
       "Q 4578 -94 3278 -91 \n",
       "Q 2428 -88 2503 844 \n",
       "Q 2194 -91 1369 -91 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(0 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(27.783203 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-62\" transform=\"translate(89.0625 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(152.539062 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(214.0625 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" transform=\"translate(241.845703 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(275.537109 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-Oblique-3c9\" transform=\"translate(307.324219 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(391.064453 -16.390625) scale(0.7)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_5\">\n",
       "    <!-- x ≤ 3.57 -->\n",
       "    <g transform=\"translate(223.618161 280.497064) rotate(-26.46532) scale(0.0864 -0.0864)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-33\" d=\"M 2597 2516 \n",
       "Q 3050 2419 3304 2112 \n",
       "Q 3559 1806 3559 1356 \n",
       "Q 3559 666 3084 287 \n",
       "Q 2609 -91 1734 -91 \n",
       "Q 1441 -91 1130 -33 \n",
       "Q 819 25 488 141 \n",
       "L 488 750 \n",
       "Q 750 597 1062 519 \n",
       "Q 1375 441 1716 441 \n",
       "Q 2309 441 2620 675 \n",
       "Q 2931 909 2931 1356 \n",
       "Q 2931 1769 2642 2001 \n",
       "Q 2353 2234 1838 2234 \n",
       "L 1294 2234 \n",
       "L 1294 2753 \n",
       "L 1863 2753 \n",
       "Q 2328 2753 2575 2939 \n",
       "Q 2822 3125 2822 3475 \n",
       "Q 2822 3834 2567 4026 \n",
       "Q 2313 4219 1838 4219 \n",
       "Q 1578 4219 1281 4162 \n",
       "Q 984 4106 628 3988 \n",
       "L 628 4550 \n",
       "Q 988 4650 1302 4700 \n",
       "Q 1616 4750 1894 4750 \n",
       "Q 2613 4750 3031 4423 \n",
       "Q 3450 4097 3450 3541 \n",
       "Q 3450 3153 3228 2886 \n",
       "Q 3006 2619 2597 2516 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-78\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(59.179688 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2264\" transform=\"translate(90.966797 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(174.755859 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-33\" transform=\"translate(206.542969 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(270.166016 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(301.953125 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-37\" transform=\"translate(365.576172 0)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_6\">\n",
       "    <!-- 68 samples -->\n",
       "    <g transform=\"translate(444.439238 325.984725) scale(0.1296 -0.1296)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-38\" d=\"M 2034 2216 \n",
       "Q 1584 2216 1326 1975 \n",
       "Q 1069 1734 1069 1313 \n",
       "Q 1069 891 1326 650 \n",
       "Q 1584 409 2034 409 \n",
       "Q 2484 409 2743 651 \n",
       "Q 3003 894 3003 1313 \n",
       "Q 3003 1734 2745 1975 \n",
       "Q 2488 2216 2034 2216 \n",
       "z\n",
       "M 1403 2484 \n",
       "Q 997 2584 770 2862 \n",
       "Q 544 3141 544 3541 \n",
       "Q 544 4100 942 4425 \n",
       "Q 1341 4750 2034 4750 \n",
       "Q 2731 4750 3128 4425 \n",
       "Q 3525 4100 3525 3541 \n",
       "Q 3525 3141 3298 2862 \n",
       "Q 3072 2584 2669 2484 \n",
       "Q 3125 2378 3379 2068 \n",
       "Q 3634 1759 3634 1313 \n",
       "Q 3634 634 3220 271 \n",
       "Q 2806 -91 2034 -91 \n",
       "Q 1263 -91 848 271 \n",
       "Q 434 634 434 1313 \n",
       "Q 434 1759 690 2068 \n",
       "Q 947 2378 1403 2484 \n",
       "z\n",
       "M 1172 3481 \n",
       "Q 1172 3119 1398 2916 \n",
       "Q 1625 2713 2034 2713 \n",
       "Q 2441 2713 2670 2916 \n",
       "Q 2900 3119 2900 3481 \n",
       "Q 2900 3844 2670 4047 \n",
       "Q 2441 4250 2034 4250 \n",
       "Q 1625 4250 1398 4047 \n",
       "Q 1172 3844 1172 3481 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-36\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-38\" transform=\"translate(63.623047 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(127.246094 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(159.033203 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(211.132812 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6d\" transform=\"translate(272.412109 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-70\" transform=\"translate(369.824219 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(433.300781 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(461.083984 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(522.607422 0)\"/>\n",
       "    </g>\n",
       "    <!-- label: $\\omega_1 \\cup \\omega_2$ -->\n",
       "    <g transform=\"translate(437.4864 338.527575) scale(0.1296 -0.1296)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-222a\" d=\"M 825 1856 \n",
       "L 825 3706 \n",
       "L 1363 3706 \n",
       "L 1363 1934 \n",
       "Q 1363 1172 1594 842 \n",
       "Q 1825 513 2344 513 \n",
       "Q 2859 513 3090 842 \n",
       "Q 3322 1172 3322 1934 \n",
       "L 3322 3706 \n",
       "L 3859 3706 \n",
       "L 3859 1856 \n",
       "Q 3859 931 3476 465 \n",
       "Q 3094 0 2344 0 \n",
       "Q 1591 0 1208 465 \n",
       "Q 825 931 825 1856 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(0 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(27.783203 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-62\" transform=\"translate(89.0625 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(152.539062 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(214.0625 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" transform=\"translate(241.845703 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(275.537109 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-Oblique-3c9\" transform=\"translate(307.324219 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-31\" transform=\"translate(391.064453 -16.390625) scale(0.7)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-222a\" transform=\"translate(457.817383 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-Oblique-3c9\" transform=\"translate(550.493164 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(634.233398 -16.390625) scale(0.7)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_7\">\n",
       "    <!-- x &gt; 3.57 -->\n",
       "    <g transform=\"translate(375.344844 263.970734) rotate(-333.53468) scale(0.0864 -0.0864)\">\n",
       "     <defs>\n",
       "      <path id=\"DejaVuSans-3e\" d=\"M 678 3150 \n",
       "L 678 3719 \n",
       "L 4684 2266 \n",
       "L 4684 1747 \n",
       "L 678 294 \n",
       "L 678 863 \n",
       "L 3897 2003 \n",
       "L 678 3150 \n",
       "z\n",
       "\" transform=\"scale(0.015625)\"/>\n",
       "     </defs>\n",
       "     <use xlink:href=\"#DejaVuSans-78\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(59.179688 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3e\" transform=\"translate(90.966797 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(174.755859 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-33\" transform=\"translate(206.542969 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(270.166016 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(301.953125 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-37\" transform=\"translate(365.576172 0)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_8\">\n",
       "    <!-- 56 samples -->\n",
       "    <g transform=\"translate(778.701375 181.68525) scale(0.144 -0.144)\">\n",
       "     <use xlink:href=\"#DejaVuSans-35\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(63.623047 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(127.246094 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(159.033203 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(211.132812 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6d\" transform=\"translate(272.412109 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-70\" transform=\"translate(369.824219 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(433.300781 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(461.083984 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-73\" transform=\"translate(522.607422 0)\"/>\n",
       "    </g>\n",
       "    <!-- label: $\\omega_2$ -->\n",
       "    <g transform=\"translate(788.472 195.62175) scale(0.144 -0.144)\">\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(0 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-61\" transform=\"translate(27.783203 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-62\" transform=\"translate(89.0625 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-65\" transform=\"translate(152.539062 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-6c\" transform=\"translate(214.0625 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3a\" transform=\"translate(241.845703 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(275.537109 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-Oblique-3c9\" transform=\"translate(307.324219 0.015625)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-32\" transform=\"translate(391.064453 -16.390625) scale(0.7)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "   <g id=\"text_9\">\n",
       "    <!-- x &gt; 5.65 -->\n",
       "    <g transform=\"translate(669.664912 124.167431) rotate(-343.300756) scale(0.096 -0.096)\">\n",
       "     <use xlink:href=\"#DejaVuSans-78\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(59.179688 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-3e\" transform=\"translate(90.966797 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-20\" transform=\"translate(174.755859 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(206.542969 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-2e\" transform=\"translate(270.166016 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-36\" transform=\"translate(301.953125 0)\"/>\n",
       "     <use xlink:href=\"#DejaVuSans-35\" transform=\"translate(365.576172 0)\"/>\n",
       "    </g>\n",
       "   </g>\n",
       "  </g>\n",
       " </g>\n",
       " <defs>\n",
       "  <clipPath id=\"p67b8980cf8\">\n",
       "   <rect x=\"0\" y=\"-0\" width=\"986.76\" height=\"362.52\"/>\n",
       "  </clipPath>\n",
       " </defs>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<schemdraw.schemdraw.Drawing at 0x1381ef380>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Generate decision tree diagram\n",
    "diagram = classifier.plot_tree(\n",
    "    class_names=['$m_{\\omega_1}$', '$m_{\\omega_2}$', '$m_{\\omega_1 \\cup \\omega_2}$'],\n",
    "    cluster_names=focal_sets,\n",
    "    feature_names=feature_names\n",
    ")\n",
    "\n",
    "# Display the decision tree\n",
    "diagram"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8900782c",
   "metadata": {},
   "source": [
    "## Get Decision Paths\n",
    "\n",
    "Extract interpretable decision rules from the classifier."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d42b8fa4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Decision Rules:\n",
      "\n",
      "Rule 1:\n",
      "  $\\omega_1$: $(x \\leq 3.57)$\n",
      "\n",
      "Rule 2:\n",
      "  $\\omega_1 \\cup \\omega_2$: $(x \\leq 5.65) \\wedge (x > 3.57)$\n",
      "\n",
      "Rule 3:\n",
      "  $\\omega_2$: $(x > 5.65)$\n"
     ]
    }
   ],
   "source": [
    "# Get decision paths\n",
    "try:\n",
    "    paths = classifier.get_path(['x', 'y'], focal_sets)\n",
    "    \n",
    "    print(\"Decision Rules:\")\n",
    "    for i, path in enumerate(paths):\n",
    "        print(f\"\\nRule {i+1}:\")\n",
    "        for key, value in path.items():\n",
    "            print(f\"  {key}: {value}\")\n",
    "except Exception as e:\n",
    "    print(f\"Could not generate paths: {e}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a5a034a",
   "metadata": {},
   "source": [
    "## Summary\n",
    "\n",
    "This example demonstrates the basic workflow of using IEMM:\n",
    "\n",
    "1. **Data Preparation**: Load your 2D dataset\n",
    "2. **Initial Clustering**: Use ECM to create a credal partition with mass functions\n",
    "3. **IEMM Training**: Fit the IEMM classifier with your chosen λ parameter\n",
    "4. **Visualization**: Plot decision boundaries and data points\n",
    "5. **Interpretation**: Generate decision trees and extract decision rules\n",
    "\n",
    "The λ parameter controls the trade-off between precision and specificity in the classification. You can experiment with different values to see how it affects the decision boundaries."
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "iemm",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.13.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
