{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ce93ab14-3eee-407e-be4d-b7a2820cc7ac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "merge regret mean:  22526.393999999975 cumulative regret std:  10828.857210854523\n",
      "merge cumulative regret mean:  2159852.3663999983 cumulative regret std:  479750.7005181186\n",
      "mallows regret mean:  88584.85799999996 cumulative regret std:  7559.063691745153\n",
      "mallows cumulative regret mean:  5289282.623999998 cumulative regret std:  331490.3419659594\n",
      "regret win:  50 , tie:  0 , loss:  0\n",
      "AUC win:  50 , tie:  0 , loss:  0\n"
     ]
    }
   ],
   "source": [
    "# import torch\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "def read_file(folder):\n",
    "    merge = []\n",
    "    mallows = []\n",
    "    random = []\n",
    "    methods = ['Merge', 'DPPMallows', 'Random']\n",
    "    arrays = [merge, mallows, random]\n",
    "    for method, array in zip(methods, arrays):\n",
    "        for i in range(50):\n",
    "            df = pd.read_csv(f'./{folder}/{method}_{i}.csv')\n",
    "            value = df.value.to_list()[:55]\n",
    "            array.append(value)\n",
    "        array = np.array(array)\n",
    "    return {'merge': np.array(merge), 'mallows': np.array(mallows), 'random': np.array(random)}\n",
    "\n",
    "d = read_file('instances_a280_n279_uncorr_08.ttp_2_10000_60000')\n",
    "\n",
    "def array_to_regret(d):\n",
    "    max = np.max([d['merge'], d['mallows'], d['random']])\n",
    "    best_so_far = [np.maximum.accumulate(res, axis=1) for res in [d['merge'], d['mallows'], d['random']]]\n",
    "    regrets = [max - bfs for bfs in best_so_far]\n",
    "    return {'merge': regrets[0], 'mallows': regrets[1], 'random': regrets[2]}\n",
    "\n",
    "regrets = array_to_regret(d)\n",
    "\n",
    "for i in ['merge', 'mallows']:\n",
    "    print(i, 'regret mean: ', regrets[i][:, -1].mean(), 'cumulative regret std: ', regrets[i][:, -1].std())\n",
    "    print(i, 'cumulative regret mean: ', regrets[i].sum(axis=1).mean(), 'cumulative regret std: ', regrets[i].sum(axis=1).std())\n",
    "    \n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i, -1] < regrets['mallows'][i, -1]:\n",
    "        win += 1\n",
    "    elif regrets['merge'][i, -1] == regrets['mallows'][i, -1]:\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('regret win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i].sum() < regrets['mallows'][i].sum():\n",
    "        win += 1\n",
    "    elif regrets['merge'][i].sum() == regrets['mallows'][i].sum():\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('AUC win: ', win, ', tie: ', tie, ', loss: ', loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "7baacae8-fa11-4c0e-8ab6-0225c740c630",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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M1dddRWFhYU+G8ZoajweMElNTXXxbCoZNGgQv/76q0fXmjdvHpIk1bsdPHjQUxNrUFxczLhx4+jVqxdPPPGEy7HHH3+cSy+9lJSUFB599FEeeeQRXnjhhXqvt3jxYkJDQ52bu5kTLCZjYz+CoI0xZcoUJEni3nvvrXFsxowZSJLElClTmt6wForHQpWQkMDbb79dY/8777zjcaqTOXPmcODAgXq35ORk4uLiyM3NdTnXZrNRUFDQYOnzkpISRo8eTXBwMGvXrkWr1dbbfujQoZw6dcrFYzqX+fPnYzAYnNvJkyfd+rw2cyl2h8j8LFBISEhg9erVmEwm577y8nJWrVpFp06dmtGylofHQvXvf/+bV199lT59+nD33Xdz991307dvX1599VX+/e9/e3St6OhoevToUe+m0+kYNmwYRUVFpKWlOc/duHEjDoeDoUOH1nn94uJiRo0ahU6nY926dW4t8dmzZw/h4eHo9fo62+j1ememBE8yJkg2kxinEjgZMGAACQkJfP755859n3/+OZ06dXJWIgL4/vvvueyyywgLCyMyMpJrr72WjIwMj97rs88+46KLLkKv15OYmMhLL73kPPbaa6/Ru3dv5+svvvgCSZJ48803nftGjhzJY489BsDevXu56qqrCA4OJiQkhIEDB7Jr1y6PP78neCxUY8eO5fDhw1x33XUUFBRQUFDAX//6V/7880/Gjh3rCxvp2bMno0ePZtq0afz6669s376dmTNnMnHiRGd59NOnT9OjRw9n97NSpEpLS3n33XcpLi4mJyeHnJwc7HZFLL766iveeecdfv/9d44cOcL//d//8eyzz3L//ff75HOobOVCqHyMLMuUWWzNsjVmEubvf/87K1ascL5evnw5U6dOdWlTWlrK7Nmz2bVrFxs2bEClUjF+/HgcDodb75GWlsYtt9zCxIkT2b9/P0888QSPP/44K1euBJQx6PT0dM6ePQvAli1biIqKYvPmzYASVpCamsrw4cMBJVToggsuYOfOnaSlpTFv3rwGeyrni8eLkjMzM0lISOCZZ56p9ZivXNaPPvqImTNnMmLECFQqFRMmTGDZsmXO41arlUOHDlFWVgbA7t27nTOCXbp0cbnWsWPHSExMRKvV8vrrrzNr1ixkWaZLly68/PLLTJs2zSefQXLYKC83QVDd3prg/DBZ7fRa8EOzvHf6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gQN8//33vPPOOwwdOpTLLruMV199ldWrV5OVVf8MT0BAAHFxcc6tuov9448/kp6ezocffkj//v0ZM2YMixYt4vXXX/dquezq6GKV6eFE6xHsjtrDOSSHhdKsP8kuEktrBOfHiy++SL9+/Rg5ciSlpaX89NNPLuEPrYVGC9XHH39MaWnVg1ReXs7777/vFaPOJTU1lbCwMJc4kZEjR6JSqdixY0e953700UdERUXRu3dv5s+fT1lZVdRyamoqffr0ITY21rnvmmuuobi4mD/++MP7HwQIjleEqrN0hpyCojrbSXYTxaePcMZgqrONQFAfKSkppKWlYTQaKSgoYP369a02XXijheqee+7hzJkzztcGg4GpU6d6xahzycnJISYmxmWfRqMhIiKCnJy6czrddtttfPjhh2zatIn58+fzwQcfuASs5uTkuIgU4Hxd33XNZjPFxcUum7tIfsGckpRYqeLTh+ptq7IWU5h1lGwhVoJ2TqOFSvZCFPq8efOQJKne7eDBg42+/vTp07nmmmvo06cPkyZN4v3332ft2rVkZGScl92LFy8mNDTUuSUkJHh0/pmAijVUOb832FZtLiCvuJyTBWUi8r8OxH1p2Xjj73NeY1TSeQYmzpkzhwMHDtS7JScnExcXR25ursu5NpuNgoICjwJRhw4dCijLEkAJYq3uFQLO1/Vdd/78+RgMBud28uRJt20A0HZSurBXl31P1pncBlqD5LBRVGblWF5pneNa7RGtVsk3X707L2h5VP59Kv9ejcGjWb+pU6c6xclsNvPII48QHKyUfFq8eLHHbx4dHU10dHSD7YYNG0ZRURFpaWnOhc8bN27E4XA4xccd9uzZA0CHDh2c133mmWfIzc11di3Xr19PSEgIvXr1qvM6er2+xvIFT/DvNpzDh7+iq+0wfrvfhjH/qv8EWcm1Xmq2czi3hKggPREBOlTtPNZKrVYTFhbm/BILCAg47y9PgfeQZZmysjJyc3MJCwurEczqCR4JVWJiovN3SZKIj493Vk32JT179mT06NFMmzaNN998E6vVysyZM5k4caJz1ffp06cZMWIE77//PkOGDCEjI4NVq1YxduxYIiMj2bdvH7NmzeKKK66gb18lid2oUaPo1asXd9xxB88//zw5OTk89thjzJgx47yEqEEkFXn97iN512yGmlNJO7qLkORBdTd32Kj0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cZvmHs1vi6xevVrW6/XyypUr5fT0dHn69OlyWFiYnJOT09ymNRn/+Mc/5NDQUHnz5s1ydna2cysrK3O2uffee+VOnTrJGzdulHft2iUPGzZMHjZsWDNa3fRUn/WTZXFP6kIIlY949dVX5U6dOsk6nU4eMmSI/MsvvzS3SU0KUOu2YsUKZxuTySTfd999cnh4uBwQECCPHz9ezs7Obj6jm4FzhUrck9oR2RMEAkGLR4xRCQSCFo8QKoFA0OIRQiUQCFo8QqgEAkGLRwiVQCBo8QihEggELR4hVAKBoMUjhEogELR4hFAJBEBiYiKvvPJKc5shqAMhVIImZ8qUKdxwww0ADB8+3CVnuK9ZuXJljXxPoKQGnj59epPZIfAMkY9K0CawWCzodLpGnx8dHe1FawTeRnhUgmZjypQpbNmyhaVLlyJJEpIkcfz4cQB+//13xowZQ1BQELGxsdxxxx3k5eU5zx0+fDgzZ87koYceIioqimuuuQaAl19+mT59+hAYGEhCQgL33XcfRqMRgM2bNzN16lQMBoPz/Z544gmgZtcvMzOT66+/nqCgIEJCQrjllltccow98cQT9O/fnw8++IDExERCQ0OZOHEiJSUlvr1p7RQhVIJmY+nSpQwbNoxp06aRnZ1NdnY2CQkJFBUVcfXVV5OSksKuXbv4/vvvOXPmDLfccovL+e+99x46nY7t27fz5ptvAkp++mXLlvHHH3/w3nvvsXHjRh555BEALrnkEl555RVCQkKc7zd37twadjkcDq6//noKCgrYsmUL69ev5+jRo/ztb39zaZeRkcEXX3zB119/zddff82WLVt47rnnfHS32jnNnb5B0P6488475euvv16W5ZppTmRZlhctWiSPGjXKZd/JkydlQD506JDzvJSUlAbf65NPPpEjIyOdr1esWCGHhobWaNe5c2f53//+tyzLsvzjjz/KarVazszMdB7/448/ZED+9ddfZVmW5YULF8oBAQFycXGxs83DDz8sDx06tEGbBJ4jPCpBi2Pv3r1s2rSJoKAg59ajRw9A8WIqGThwYI1z//e//zFixAg6duxIcHAwd9xxB/n5+ZSVlbn9/gcOHCAhIYGEhATnvl69ehEWFsaBAwec+xITEwkODna+7tChQ7uq3diUiMF0QYvDaDTy17/+lSVLltQ41qFDB+fvgYGBLseOHz/Otddeyz/+8Q+eeeYZIiIi2LZtG3fddRcWi4WAgACv2qnVal1eS5KEw+Hw6nsIFIRQCZoVnU6H3W532TdgwAA+++wzEhMT0Wjc/xdNS0vD4XDw0ksvoVIpnYU1a9Y0+H7n0rNnT06ePMnJkyedXlV6ejpFRUX06tXLbXsE3kN0/QTNSmJiIjt27OD48ePk5eXhcDiYMWMGBQUF3HrrrezcuZOMjAx++OEHpk6dWq/IdOnSBavVyquvvsrRo0f54IMPnIPs1d/PaDSyYcMG8vLyau0Sjhw5kj59+jBp0iR2797Nr7/+yuTJk7nyyisZNGiQ1++BoGGEUAmalblz56JWq+nVqxfR0dFkZmYSHx/P9u3bsdvtjBo1ij59+vDQQw8RFhbm9JRqo1+/frz88sssWbKE3r1789FHH7F48WKXNpdccgn33nsvf/vb34iOjub555+vcR1Jkvjyyy8JDw/niiuuYOTIkSQnJ/Pf//7X659f4B4iZ7pAIGjxCI9KIBC0eIRQCQSCFo8QKoFA0OIRQiUQCFo8QqgEAkGLRwiVQCBo8QihEggELR4hVAKBoMUjhEogELR4hFAJBIIWjxAqgUDQ4hFCJRAIWjz/D8rW5VeZ6+6aAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ---------- 1. 读取并整理数据 ----------\n",
    "results = {'Mallows': d['mallows'], 'Merge': d['merge']}\n",
    "\n",
    "global_max = -np.inf\n",
    "for arr in results.values():\n",
    "    global_max = max(global_max, arr[:, :].min())\n",
    "\n",
    "# 把每个算法的 simple regret（best‑so‑far – global_min）整理成均值±std\n",
    "mean_regret = {}\n",
    "std_regret  = {}\n",
    "\n",
    "for algo, outputs in results.items():\n",
    "    outputs        = outputs[:, :]                          \n",
    "    best_so_far    = np.maximum.accumulate(outputs, axis=1)    \n",
    "    regrets        = global_max - best_so_far              \n",
    "    mean_regret[algo] = regrets.mean(axis=0)             \n",
    "    std_regret[algo]  = regrets.std(axis=0)\n",
    "\n",
    "# ---------- 2. 画图 ----------\n",
    "iters = np.arange(1, 56)\n",
    "\n",
    "plt.figure(figsize=(3, 3))\n",
    "\n",
    "for algo in mean_regret:\n",
    "    mean = mean_regret[algo]\n",
    "    std  = std_regret[algo]\n",
    "    plt.plot(iters, mean, label=algo)\n",
    "    plt.fill_between(iters, mean - std, mean + std, alpha=0.2)\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Simple Regret (mean ± 1 std)\")\n",
    "plt.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "# plt.yscale(\"log\")           # 若差距跨数量级，建议用对数轴；可去掉\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"ttp_1.pdf\", dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "961e944f-0ca6-453e-a15d-4a29f7d816e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "merge regret mean:  145961.83499945735 cumulative regret std:  71609.04924044195\n",
      "merge cumulative regret mean:  13050540.5690045 cumulative regret std:  3519536.4087797604\n",
      "mallows regret mean:  556663.5545998329 cumulative regret std:  58116.0186344121\n",
      "mallows cumulative regret mean:  33266720.951492514 cumulative regret std:  2688482.805945845\n",
      "regret win:  50 , tie:  0 , loss:  0\n",
      "AUC win:  50 , tie:  0 , loss:  0\n"
     ]
    }
   ],
   "source": [
    "# import torch\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "def read_file(folder):\n",
    "    merge = []\n",
    "    mallows = []\n",
    "    random = []\n",
    "    methods = ['Merge', 'DPPMallows', 'Random']\n",
    "    arrays = [merge, mallows, random]\n",
    "    for method, array in zip(methods, arrays):\n",
    "        for i in range(50):\n",
    "            df = pd.read_csv(f'./{folder}/{method}_{i}.csv')\n",
    "            value = df.value.to_list()[:55]\n",
    "            array.append(value)\n",
    "        array = np.array(array)\n",
    "    return {'merge': np.array(merge), 'mallows': np.array(mallows), 'random': np.array(random)}\n",
    "\n",
    "d = read_file('instances_a280_n837_bounded-strongly-corr_08.ttp_2_10000_60000')\n",
    "\n",
    "def array_to_regret(d):\n",
    "    max = np.max([d['merge'], d['mallows'], d['random']])\n",
    "    best_so_far = [np.maximum.accumulate(res, axis=1) for res in [d['merge'], d['mallows'], d['random']]]\n",
    "    regrets = [max - bfs for bfs in best_so_far]\n",
    "    return {'merge': regrets[0], 'mallows': regrets[1], 'random': regrets[2]}\n",
    "\n",
    "regrets = array_to_regret(d)\n",
    "\n",
    "for i in ['merge', 'mallows']:\n",
    "    print(i, 'regret mean: ', regrets[i][:, -1].mean(), 'cumulative regret std: ', regrets[i][:, -1].std())\n",
    "    print(i, 'cumulative regret mean: ', regrets[i].sum(axis=1).mean(), 'cumulative regret std: ', regrets[i].sum(axis=1).std())\n",
    "    \n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i, -1] < regrets['mallows'][i, -1]:\n",
    "        win += 1\n",
    "    elif regrets['merge'][i, -1] == regrets['mallows'][i, -1]:\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('regret win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i].sum() < regrets['mallows'][i].sum():\n",
    "        win += 1\n",
    "    elif regrets['merge'][i].sum() == regrets['mallows'][i].sum():\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('AUC win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "0e1a080d-abe9-4883-b9ce-d4a24fc8ef10",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAASIAAAEiCAYAAABdvt+2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABQCklEQVR4nO2dd3hUVfrHP3dqeoaEVAyESBPpRQRUULIKqKsIq2IssKjrLtgou/hzEdeGrOIKurtYQXdFBNsqlgWpglm6SA0QSmipQ8pkMv3+/rjJkCFtJsxkUs7nee6TmXPbm0nme895z/u+R5JlWUYgEAiCiCrYBggEAoEQIoFAEHSEEAkEgqAjhEggEAQdIUQCgSDoCCESCARBRwiRQCAIOkKIBAJB0BFCJBAIgo4QIoFAEHSEEHnJpk2buPXWW0lOTkaSJL788kufryHLMq+++irdunVDr9fToUMHXnzxRf8bKxC0MDTBNqClUF5eTt++ffntb3/LHXfc0ahrPP7446xevZpXX32V3r17YzQaMRqNfrZUIGh5SCLp1XckSeKLL77g9ttvd7dZrVaefvppPv74Y4qLi+nVqxfz589n5MiRABw8eJA+ffqwb98+unfvHhzDBYJmihia+Ylp06aRmZnJ8uXL+eWXX/jNb37D6NGjOXLkCABff/01aWlprFq1is6dO5OamsqDDz4oekQCAUKI/EJOTg5Llixh5cqVXHvttVx++eXMnDmTa665hiVLlgBw7NgxTp48ycqVK/nwww9ZunQpO3fuZMKECUG2XiAIPsJH5Af27t2L0+mkW7duHu1Wq5XY2FgAXC4XVquVDz/80H3ce++9x8CBA8nKyhLDNUGbRgiRHzCZTKjVanbu3IlarfbYFxERAUBSUhIajcZDrK644gpA6VEJIRK0ZYQQ+YH+/fvjdDrJz8/n2muvrfWY4cOH43A4yM7O5vLLLwfg8OHDAHTq1KnJbBUImiNi1sxLTCYTR48eBRThee2117j++uuJiYmhY8eO3HvvvWzZsoUFCxbQv39/CgoKWLt2LX369OHmm2/G5XIxePBgIiIieP3113G5XEydOpWoqChWr14d5N9OIAgyssAr1q9fLwM1tgceeECWZVm22WzyM888I6empsparVZOSkqSx40bJ//yyy/ua5w5c0a+44475IiICDkhIUGeNGmSXFRUFKTfSCBoPogekUAgCDpi+l4gEAQdIUQCgSDoiFmzBnC5XJw9e5bIyEgkSQq2OQJBi0GWZcrKykhOTkalqr/PI4SoAc6ePUtKSkqwzRAIWiynTp3isssuq/cYIUQNEBkZCSgfZlRUVJCtEQhaDqWlpaSkpLi/Q/UhhKgBqoZjUVFRQogEgkbgjUtDOKsFAkHQEUIkEAiCjs9Ds+PHj/Pjjz9y8uRJzGYzcXFx9O/fn6FDhxISEhIIGwUCQSvHayH66KOPWLhwITt27CAhIYHk5GRCQ0MxGo1kZ2cTEhJCRkYGf/rTn0QSp8CvuFwubDZbsM0QXIRWq61RbaKxeCVE/fv3R6fTMWnSJD777LMa09lWq9VdnXDQoEH84x//4De/+Y1fDBS0bWw2G8ePH8flcgXbFEEtGAwGEhMTLznGzqtcs//+97/cdNNNXl2wqKiIEydOMHDgwEsyrLlQWlpKdHQ0JSUlYtasiZFlmZycHOx2u1dBcYKmQ5ZlzGYz+fn5GAwGkpKSahzjy3fHqx6RtyIEEBsb665KKBBcCg6HA7PZTHJyMmFhYcE2R3ARoaGhAOTn5xMfH39JwzSvhKi0tNTrC7bVXoPV7kCvFWFZ/sTpdAKg0+mCbImgLqoeEHa7PfBCZDAYvB4DVv3ztDUs5Sb0BkOwzWiViBy/5ou//jZeCdH69evdr0+cOMHs2bOZNGkSQ4cOBSAzM5MPPviAefPm+cWoloitohSEEAkEjcIrIRoxYoT79XPPPcdrr73GxIkT3W2//vWv6d27N2+//TYPPPCA/61sAdgqzLicLlRq4VAV+I8TJ07QuXNndu/eTb9+/diwYQPXX38958+fx9CKHnw+f2syMzMZNGhQjfZBgwaxbds2vxjVMnFiqfDelyZovUyaNAlJknjkkUdq7Js6dSqSJDFp0qSmN6wZ47MQpaSk8M4779Rof/fdd9t8uQxLuRAigUJKSgrLly+noqLC3WaxWFi2bBkdO3YMomXNE5+F6G9/+xtvvPEGvXv35sEHH+TBBx+kT58+vPHGG/ztb38LhI0tBqvZFGwTBM2EAQMGkJKSwueff+5u+/zzz+nYsSP9+/d3t33//fdcc801GAwGYmNjueWWW8jOzvbpXp999hlXXnkler2e1NRUFixY4N735ptv0qtXL/f7L7/8EkmSWLx4sbstPT2dP//5zwDs2bOH66+/nsjISKKiohg4cCA7duzw+ff3FZ+FaOzYsRw5coRf//rXGI1GjEYjt956K4cPH2bs2LGBsBEAo9FIRkYGUVFRGAwGpkyZgslU9xffaDTy6KOP0r17d0JDQ+nYsSOPPfYYJSUlAbPRXlEWsGsLKoPobI6gbI1ZY+K3v/2te8lxgPfff5/Jkyd7HFNeXs706dPZsWMHa9euRaVSMW7cOK8jyXfu3Mmdd97J3Xffzd69e3n22WeZM2cOS5cuBRT/7oEDBygoKABg48aNtG/fng0bNgDKtHtmZiYjR44EICMjg8suu4zt27ezc+dOZs+ejVar9fl39xWfA19ycnJISUnhxRdfrHVfoLqdGRkZnDt3jjVr1mC325k8eTIPP/wwy5Ytq/X4s2fPcvbsWV599VV69uzJyZMneeSRRzh79iyffvppQGy02WzI9gokbWhArt/WqbA76fnMf4Ny7wPP3USYzrevy7333stTTz3FyZMnAdiyZQvLly93iwDA+PHjPc55//33iYuL48CBAx49mbp47bXXGDVqFHPmzAGgW7duHDhwgFdeeYVJkybRq1cvYmJi2LhxIxMmTGDDhg3MmDGDhQsXArBt2zbsdjvDhg0DlO/wrFmz6NGjBwBdu3b16XduLD73iDp37uxW1+oUFRXRuXNnvxh1MQcPHuT777/n3XffZciQIVxzzTW88cYbLF++nLNnz9Z6Tq9evfjss8+49dZbufzyy7nhhht48cUX+frrr3E4HAGxU0YMzwQXiIuL4+abb2bp0qUsWbKEm2++mfbt23scc+TIESZOnEhaWhpRUVGkpqYCiiB4w8GDBxk+fLhH2/Dhwzly5AhOpxNJkrjuuuvYsGEDxcXFHDhwgD/84Q9YrVYOHTrExo0bGTx4sDswcfr06Tz44IOkp6fz8ssv+zxMbCw+94hkWa41iMlkMgWsDEhmZiYGg8Fjti49PR2VSsXWrVsZN26cV9epynnRaAIXAW01lxISHRew67dlQrVqDjznfbqRv+/dGH77298ybdo0AP7+97/X2H/rrbfSqVMn3nnnHZKTk3G5XPTq1cuv1QZGjhzJ22+/zY8//kj//v2Jiopyi9PGjRs9wnOeffZZ7rnnHr755hu+++475s6dy/Lly73+jjUWr7+R06dPB5RIyjlz5njk/jidTrZu3Uq/fv38biBAbm4u8fHxHm0ajYaYmBhyc3O9ukZhYSHPP/88Dz/8cL3HWa1WrFar+70v6S0ANrOYOQsUkiT5PDwKNqNHj8ZmsyFJUo2czaKiIrKysnjnnXe49tprAdi8ebNP17/iiivYsmWLR9uWLVvo1q2bO+VixIgRPPHEE6xcudLtCxo5ciQ//PADW7ZsYcaMGR7nd+vWjW7duvHkk08yceJElixZ0nyEaPfu3YDSI9q7d69H/o9Op6Nv377MnDnTp5vPnj2b+fPn13vMwYMHfbpmbZSWlnLzzTfTs2dPnn322XqPnTdvHn/5y18afS+rpQKcDlC3rC+MIDCo1Wr3//DFuVjt2rUjNjaWt99+m6SkJHJycpg9e7ZP158xYwaDBw/m+eef56677iIzM5M333yTf/zjH+5j+vTpQ7t27Vi2bBmrVq0CFCGaOXMmkiS5h3YVFRXMmjWLCRMm0LlzZ06fPs327dtr+LECgdfflqo0j8mTJ7Nw4UK/JLfOmDGjwcCutLQ0EhMTyc/P92h3OBwYjUYSExPrPb+srIzRo0cTGRnJF1980eAMwFNPPeXu/cGFlQi8xepwgr0c1NFenyNo3dT1XVGpVCxfvpzHHnuMXr160b17dxYtWuTutXjDgAEDWLFiBc888wzPP/88SUlJPPfccx7fK0mSuPbaa/nmm2+45pprAEWcoqKi6N69O+Hh4YAilEVFRdx///3k5eXRvn177rjjjkt6MHuLV/WI6qO0tJR169bRo0cPt6fd3xw8eJCePXuyY8cOd52j1atXM3r0aE6fPk1ycnKdtt10003o9Xq+/fbbRpWS8Lamyplj+zGXGgHo1LEzupj613ESNIzFYuH48eN07txZlCFuptT3N/KlHpHPs2Z33nknb775JqB05QYNGsSdd95J7969+eyzz3y9nFdcccUVjB49moceeoht27axZcsWpk2bxt133+0WoTNnztCjRw93mklpaSk33ngj5eXlvPfee5SWlpKbm0tubm7AKwRYhZ9IIPAJn4Vo06ZNbsfaF198gSzLFBcXs2jRIl544QW/G1jFRx99RI8ePRg1ahRjx47lmmuu4e2333bvt9vtZGVlYTabAdi1axdbt25l7969dOnShaSkJPd26tSpgNkJYKsoA4e14QMFAgHQiOn7kpISYmJiACU8ffz48YSFhXHzzTcza9YsvxtYRUxMTJ3BiwCpqake0a8jR45sVDSsP7DaXWA2QlTN8pkCgaAmjUp6zczMpLy8nO+//54bb7wRgPPnz4txfCUVdgeyuRCCJIQCQUvDZyF64okn3PkoycnJbg//pk2b6N27t7/ta5G4ZDBVWMAqfEUCgTf4PDT7wx/+wJAhQ8jJyeFXv/qVe2WFtLS0gPqIWhomi4NIcxGEiGl8gaAhGhV1N3DgwBrLBd18881+MahFsv09DD9/hqX7/biiOgBQbnXgqihBJYIbBYIGEXVN/cDhdR8SfmYLZSd3udtkFDGiwhg8wwSCFoIQIj+QFTYAAG3uHo/2MosDzEXBMEkgaFEIIfID+m7XA5BSvg/kC8GSZpsDh60CrKJgmkBQH34TooMHD5KWluavy7Uorhg4kjI5lChMUHTM3S6jOK0pPRc84wRNjiie7zt+EyKbzeauRNfWSGkfxc+qngCUndztsa/M6lCSYM3CV9SWCFTxfFmWA1bYL5j4XI+oLmqr2tiWKGjXH4w7CSvYA9zpbrfYndidMtrSs8pUvqrxy/IKWg4DBgwgOzubzz//nIyMDOBC8fzqlUxdLhfz58/n7bffJjc3l27dujFnzhwmTJgA4F7H7Ntvv+XPf/4ze/fuZfXq1QwcOJBHHnmEL7/8kqioKP74xz/yn//8h379+vH6668DSm2tp59+mo8//pji4mJ69erF/Pnzfcrubyq8FqKFCxfSr1+/OrNo6ytk3xbQdroKjO+SajnIaacdWX2h3EhJhZ32agnKciG6QxCtbOHIMtjNwbm3Ngx8XF65qnh+lRBVFc+vXrN63rx5/Pvf/2bx4sV07dqVTZs2ce+99xIXF+dROXH27Nm8+uqrpKWl0a5dO6ZPn86WLVv46quvSEhI4JlnnmHXrl0exQmnTZvGgQMHWL58OcnJyXzxxReMHj2avXv3Nlktam/xWoi6dOnCk08+yb333lvr/p9//rlGbFFbIq1LDwp2RRMnlWDLPYi2Qx/3vpIKG4YwLZryAgiLBa1IhWkUdjO8VHvJl4Dzf2dBF+7TKQ0Vz7darbz00kv88MMP7uXb09LS2Lx5M2+99VaNFZZ/9atfAUqNrQ8++IBly5YxatQoAJYsWeJRDicnJ4clS5aQk5Pjbp85cybff/89S5Ys4aWXXmrc5xAgvBaiQYMGsXPnzjqFSJKkoCWZNgcMoRp+0fRilHMLFTm7PYTIJSu9othwHZSegdjLg2ipoKmoXjxfluUaxfOPHj2K2Wx2C0wVNpvNY+0zwKNe+7Fjx7Db7Vx11VXutujoaLp37+5+v3fvXpxOJ926dfO4jtVqJTY21i+/nz/xWogWLFjgUcv5Yvr27ev1WkytlSJDHyjagsG4h4s/iWKzDUOoDrW1FCrOQ2i7oNjYotGGKT2TYN27EdRXPL/KnfHNN9/QoYPnkF2v13u8r6qi6C0mkwm1Ws3OnTtrlKiNiIjw6VpNgddC1FBJVgGEdOwPRdDJfpQTtnLkal15pVdkIyZcByVnQB8lHNe+Ikk+D4+CTX3F83v27IlerycnJ8djGNYQaWlpaLVatm/f7p6BKykp4fDhw1x33XUA9O/fH6fTSX5+vrt+WHNGJEH5kbQOSZzYlUCqlEf56b2EpV3tsf+82UZ0qA41dig7B9GinGxrp77i+ZGRkcycOZMnn3wSl8vFNddcQ0lJCVu2bCEqKooHHnig1mtGRkbywAMPMGvWLGJiYoiPj2fu3LmoVCr3Ul/dunUjIyOD+++/nwULFtC/f38KCgpYu3Ytffr0aXa5oSKy2o/oNRJZeqUUiuP07hr7q3pFAJQXgi1IM0CCJiUqKqrO2ebnn3+eOXPmMG/ePHdJ5G+++abBxUpfe+01hg4dyi233EJ6ejrDhw/niiuu8KgJtmTJEu6//35mzJhB9+7duf322z16Uc2JSy6e39rxtXj+nq3rmXBuAWdVyZTf+laNKV+VBB1jw9GqJNCGQ1y3Oq4oEMXzvae8vJwOHTqwYMECpkyZ0mT3DVrxfEH9RKcNxCJrSXadxVVwpMZ+lwyFZZVOf3u5yEMTNIrdu3fz8ccfk52dza5du9yxSrfddluQLWscQoj8TKf2kWxRDwbAfGhNrceYrA5Mtsowfae9qUwTtDJeffVV+vbtS3p6OuXl5fz4448e4QEtiUYL0ccff0x5ebn7vcVi4cMPP/SLUS0ZSZIoSL4BgDTjZnDVLjQFZVZcLsDV+vKGBIGnf//+7Ny5E5PJhNFoZM2aNS26VHOjheh3v/sdeXl57vclJSVMnjzZL0a1dNKuHEiebCCaMsqPba31GIdTpshsFUIkEHAJQiR83HXTLlTLtlAlnkOTvbbO40rMdirqCRIVKIj/teaLv/42l+QjknxMAmxLuLooOUDdzbuQK4prPUYGTheWKiVlBTWoirux2WxBtkRQF1ULmmq12gaOrB+fAhonT57sFh+r1cof//hHIiMjASWLWHCBbmlp7N/bmSul45w/sJ6YgeNqPU52OjheWE6n2DAiQy7tj9na0Gg0hIWFUVBQgFarda8YIwg+sixjNpvJz8/HYDDUCNb0FZ+EKDU11f1akiSSk5Pdq74KPNGoJPbHjuRK43Hizq7HWYcQ4XIiy3CyyExKuzCiw4QYVSFJEklJSRw/frzNFt1r7hgMBr+kfzU6oDEyMpI9e/a4y8Pm5eWRnJyM0+ls4MyWhbdBWaePH6KixLM43NkCI8M2T0YrOdk79G+EJNRWA0aFpX0v9zuNWiJcpyFMryYqRItOI3oBLpdLDM+aIVqttt6ekC8BjY3ONRP+IU9kXSTgKUTJcTH8pLmKEc5MIre9jn3M30Cju+hMF8gukBTBcThlSirslFTYyVNZSIoOVRJl2zAqlUpEVrdy/Dpr1qZnN/RRQE1xtg96GKMcSarzJMYt79d6qlTHFL7LBWfOV3C8sBybo22XWBG0bhotRN99951HDZWYmBjWr1/vF6NaIjGRobi0Neu8dEqKY2OnRwEYcn4V+Vnbap4s1z+cNVkcHM4rIyu3jCN5ZRzNN3GyqJyCMitmm6NtPwAErQKR9NoAvoxzj508ifN8To12WZbJWf130iu+p5Bocq5/g8joC05+W1QqLl39164PSYLoUC0x4TrC9aKyi6B5IJJeg0RMTO0lOCVJImHEgxyTUmhPCfKm17A5LvSCJNelOfhlGYrNdo4VlHMkr4zcEgsFZVbOl9sotdgpq7aJIZ6gOSKEyI9ER4Sj0tVeUjQkJIS8QbOwyFoGOn9m/9qPcLqUzmhdPqLGYLG7KCizklti4fT5Ck4WmjlRbcvKLeNEYTllFpFsK2g+CCHyI5IkEd2u7uzn9h3S2Nv19wBMMK/k2x+34pLlBn1E/qbM4uBEoZnDeWXkl1qwOlpXyIWg5SGEyM8Y2sXWMndWbX+vG8mKuxGVJDPJ+DordpwGZ3BiZKx2F3mlVg7nmjiar4iS2SbSTQRNjxAiP6MJiSAivP4VH9RXP0J+6OXESCZuPfUqX+wtbCLr6qbCpohSdn45B86WcspoxiRy4ARNhM9C5HQ6ee+997jnnntIT0/nhhtu8NgChdFoJCMjg6ioKAwGA1OmTPF6dVlZlhkzZgySJPHll18GzMYqDPUMzwBktY7ya/6PClU4/VTZHNqTyZajwRejKpwumWKzneMF5RzOK6PQZMXqcOJyiQlWQWDwea738ccfZ+nSpdx888306tWrySKsMzIyOHfuHGvWrMFutzN58mQefvhhli1b1uC5r7/+epNGgodEtCNUe4YKe92+F0d4Aq7YblCwm1hKeW3NYWLDdfRIavw0fiCw2l2cK7ZwrvK9JIFWrUKtApUkoVZJaNUqwnUawvVqNGrRyRb4js9CtHz5clasWMHYsWMDYU+tHDx4kO+//57t27e7V7x84403GDt2LK+++qrHUrsX8/PPP7NgwQJ27NhBUlJS0xisjyQ6IpSK8/X32FxaZY2uPgYLXxhdPP/NAZ67rRdp7cObbQqNLFNrCEARip9Lp1Gh16jQalTo1CrUKmUFYLna+QAyMhISkqQImkoCCQkkZYEBlSShUUtoVSpUqub5WQj8h89CpNPp6NKlSyBsqZPMzEwMBoPHsrvp6emoVCq2bt3KuHG1Z7abzWbuuece/v73v3udIWy1Wj1WtC0tLfXdYEkiIjoWTWk5Dmfdw5kqIRqTYucjdThHC8p54pOfiYvU0+8yA4NS23F1WiyqZipKtWFzuPweq3Txry9VipZ0kWBp1FK9n5VKAk2lOOrUKkK0qmYr+G0Nn4VoxowZLFy4kDfffLPJ/oi5ubnEx8d7tGk0GmJiYsjNza3zvCeffJJhw4b5tLLBvHnz+Mtf/tJoW6uQQmOIDjlHUXndM2JVQqR3ljN3bFde33CSPaeKKSizsuZgHmsO5jGgo4HHbuhKbIS+zuu0di6O/Vfeu/tYKBN9vocgqFQQVjmk1FbWOqr6l5Zl5Q6yLBOiVROmUwvRCiA+C9HmzZtZv3493333HVdeeWWNymyff/6519eaPXs28+fPr/eYqlUyfeWrr75i3bp17N5dc6HD+njqqaeYPn26+31paSkpKSm+G6CPIDIiHGO5jbr6RM5KIVLZy2kXqubZW6/EYney/2wpu3PO892+XHblFPPo8t1Mu74Lwy5vmSs0NFdcLiWPz2RpeHZQrZKIDNEQFaIlKlQjRMnP+CxEBoOhzqGQr8yYMYNJkybVe0xaWhqJiYnk5+d7tDscDoxGY51DrnXr1pGdnY3BYPBoHz9+PNdeey0bNmyo9Ty9Xo9e75/ehzY8hoiQMsrq+Ed3aZVpfpW9HMllRyaUEK2agZ3aMbBTO266MpEFa7LILihn3neHiAzRoFZJqCWJUJ2aDoZQUtqFkRITSu8OBuIi226vKdBUzSQWm+1o1BKx4TrahevQCue8X2gRSa8HDx6kZ8+e7Nixg4EDBwKwevVqRo8ezenTp2t1Vufm5lJY6Dkl3rt3bxYuXMitt97a4JK+VfiSuFcDu4WKM/s4XVxR6+7IU+tJ3LmA8rj+nLxpKc6QdjUv4XTx8bYcPtt1moZmz3smRXFt1/Zc1TmG9hH6FuVbaolU+agk6YLfSiWBqvJhUbVPrVJeq1S421XKCTX9X1yYjVRJElq11GJ7X01SGK0pqVoT/KGHHmLx4sXY7XamTZvG3Xff7RahM2fOMGrUKD788EOuuuoqEhMTa+0tdezY0WsRumS0IYSGRRBSbsNSy1S+S6P0iNR2U535Zlq1ivuHpnJbvw6UVNhxuWScskyZxcEpo5nTxRUcKzCRlVvGgXOlHDhXylubjqFWKU/t2Ag9OvWFf2RDmI5RPeLpm2IQQnWJyDI4PZ7j/n+mSxJEhmiIDNESFaJpteERjRKiTz/9lBUrVpCTk1OjhOeuXbv8YtjFfPTRR0ybNo1Ro0ahUqkYP348ixYtcu+32+1kZWW5VxVoNoS24zJDBecrbBhNnv6i6j4i5Pr9FNGhWqJDPf1x/VIM7tdFJiubjxay6UgBR/NNOF0y+WVW8stqLle08XABydEhjO6VyMBOMXQwhKIWU+TNElmG0goHpRUOzly0r6q3pVVLqFUqj9SiqtlEjbpqhlBNiPbSCtwHEp+FaNGiRTz99NNMmjSJ//znP0yePJns7Gy2b9/O1KlTA2EjoBReqy94MTU1tcECYUEZhYa2Qyo7S0yYjsgQLUUmq9tnVDVrpnKYLzkDPzZCz239OnBbvw44XTLnzTYKy6wUldtwVI7pZFkmK7eMdVn5nC2x8P6WE7y/5QRatURKTBipseF0igmjY2wYHWPCiIvQt9hhQVtAlpXSwkqISMMhE5IEoTpFkDQqZfinUUnoKmO+gtnb8tlH1KNHD+bOncvEiRM9Cug/88wzGI1G3nzzzUDZGhQuyUdURVE2WC/EI1XYnRSW2XCUnqPz6t/iUmk4Mn4dtuhU/xjdABU2J5uOFLA+K59jBeV1RoBH6jVcHh9Bl7gIOsaG0S5MhyFUS7twXY3emaDlo1KBXqOEKoRq1YTq1JVR9I17GAXUR5STk8OwYcMACA0NpaysDID77ruPq6++utUJkV9olwqFR8ChOK1DtWpSYkIp0yhVGlUuBypH0w0pQ3VqbroykZuuTMQly+SXWjleaOKk0czJIjM5RjNniisoszr4+VQxP58qrnGNuEg9VyZH0Ss5mj6XRZMUHdpk9gsCg8ulPKQqbJ4PJknCPcQLrRSpMJ3GryvM+CxEiYmJGI1GOnXqRMeOHfnf//5H3759OX78uKidXBcqNcReroiR84LPJjIyqjLRQUZlLQ6OaZJEYnQIidEhDL38Qrvd6eJEYTlHC0xk55s4V2LhfIWdYrONMouDgjIrG7IK2JClrFySFB2ihB10bEfHmDBiI/TC79RKkGWwO2TsDiflVkWkYiJ0dDD47+HjsxDdcMMNfPXVV/Tv35/Jkyfz5JNP8umnn7Jjxw7uuOMOvxnW6lBrL4iRq7I6oqRC0oWDzYTa2ohUkgCiVavomhBJ14TIGvsqbE4O5Zay/2wp+86WcCi3jHMlFlb9co5VvyjpsSpJ8Vt1i4/grsEpdG5fc2EBgaAKn31ELpcLl8uFRqNo2PLly/npp5/o2rUrv/vd79DpWtcaXH7xEVXHXgFFR6HKOb3sLjDlkX/D38jrPM69vllLwmxzsOdUMTtPnmfvmRLyy6xuB3kV13Ztzz1XdeSydvXXahK0DLzpEfny3WkRAY3BxO9CBGC3VIqRHT6bAkXZOEb/lcMdxuOUWr4T2CXLnC+3kVtq4du959h0RAksVUnQ5zIDwy6P5erOsbRr4wtHtmT8LUSNiiP68ccfeeutt8jOzubTTz+lQ4cO/Otf/6Jz585cc801jblk20IbAu27KmKkU4YsGns5HQ1a8ixqzNaWXUNaJUnERuiJjdBzZXI0Ewaa+Pf/cth2wuh2fv9zQzYJUSFKrItKQqNSVUYTK5HJeo2KCL2WiBAN4Tq1RymQCL2G5OhQkg0hJESFiDSLVoDPQvTZZ59x3333kZGRwe7du90lM0pKSnjppZf49ttv/W5kq0Sjh9iuoK/0wdjKidBCRGQEDqcLk9VBUbmtxYsSQOf2Ecy5pSdnzleQeayI/x0rIiuvjNxSi1+ur9OoCNGo3PExdaFRq9zT0hF6DV3iI+iRGEnX+Ei/zgAJfMdnIXrhhRdYvHgx999/P8uXL3e3Dx8+nBdeeMGvxrV6NDrQRyuvbSaoXN9Mo1ZhCNNhCNORX2ohv8xaoxRGS6RDu1AmDLyMCQMvo8hkdfuSnC4Zh9OFS1ZeO2Ww2p2UWZXM+HKro1rRDygx2zhXYuFsSQUWu8tdA6nUiyz66myuLM+rUUnuuKiq/LHQytIfoToNydEhdE+MpHtiJIlRISLIMwD4LERZWVlcd911Ndqjo6MpLi72h01ti5DKsbPNBM6aa43FR4UQrtdw6rwZu6MVqFElVUO3S0GWZUotDirsTqx2Jxa766LcL89jHU6ZCruTCrsTY7mNrNwyDuaWUmy211s3ahewaq8yGxgZoqFLXARd4iO4PC6CduE6VChLSUkS1SKWlUJtWrUKjUpCr1Wh1zTfFItg06g4oqNHj5KamurRvnnzZtLS0vxlV9uhamhmNV2YSbuIcL2GbvGROFxyZZa30jNwOGUcLhcOp4zJ6sBkddRbEbK1IUlSrTl4viDLSk6eyepw9zpdsozZ5sRsUz7Tk0XKwpTZBSbKLA52nypmdy1Bng2hU6sqE1g1hGqVqGWtRhGq6p0srVpFiEaNXqsiOlRL1/hIuidEEhHSInLUG4XPv9lDDz3E448/zvvvv48kSZw9e5bMzExmzpzJnDlzAmFj6yakamhWXqcQgeLA1V3k/1ByGJWnbNUMVIXNSbnNgc3hwupwYa8c8lThcMqtYpjnLyRJIiEqhAQvjrU7XRwvLCe7wMTRfBPHCsox25Rho0uWccngrHw4OF0ydveQUznf5nRRVG6rt/dVHx0MoURVE12tSiI6TEt0iJaoUK2H014lUZnoqvjFLmsXRod2oc224oLPQjR79mxcLhejRo3CbDZz3XXXodfrmTlzJo8++mggbGzd6KsNzfyw9HSoTnHG1oVS4MvGebONCpt/a0u3drRqFd0SIulWS5BnfThdMha7E5PVQZnFQanFrjwkHC5sTuVhUR2704XF7sJid1JgsnI4t4yzJRbOFFdwpo7aVt4QqlXTJV4ZVqbGhpMaG0ZKTFizmHVsdByRzWbj6NGjmEwmevbsSURE64ycDUgcUXV2fgBfPwaJvWHc25DQ0//3qAOL3Ynd6aqszawMU5yVzuPq8YiSVJnpXTkMdLhcQsSamJIKO9n5JizVlgdXHPRK1ciSCjvOan80pyxjrRSzcpsyvLTWsqiBSgJDqE7pWYVqMYRpiQ3XEROuJzZcR2SIhnC9hgi9Uia36iHXLOKIQFnNo2fPpvvStFqqD82cViXzUNU0T6hLqVFjsTspKLNSUmEXQ70mIDpUy4BONSt4eovTJXPKaOZwfhnHC8o5XlTOiaJyyq1OjGYbRrN3w8UwnZrYcB0J0SGMvjKRB6/1j1/YZyGyWCy88cYbrF+/nvz8fFwuT5UNVGG0VkuVEFkr10BzWEDX/NMgQrRqUmLCSHK6OF/5RL44a1vQfFCrJFLbh5PaPtzdJssyxnKb++9XUmHnvNmGsdKPdb7cRpnVQbnFganS76g48Ss4db6CtGrXulR8FqIpU6awevVqJkyYwFVXXSViKi4V9/R9ufKzhQhRFRq1irhIPXGRevdQwVbpJK/ydYgeU/NEqhYB7w1mmxJkazTZsDic9O4Q7TdbfBaiVatW8e233zJ8+HC/GdGmqSqYby9XAhrtZiAmqCY1Fp1GRfuL/qmLzTZOGRvvYBU0H8J0GsJ0GlLahfm9DIjPzogOHToQGenbrIGgHkKqPVXsZiUhthVhCNORbAgJthmCZo7PQrRgwQL+9Kc/cfLkyUDY0/bQhYG6MgvdZnJXcWxNxEboSYgWa64J6sbnodmgQYOwWCykpaURFhZWY6VXo9HoN+PaBJIKdOFQYbsQ1Oi0K4XUWhHxkUqvKL+0deTNCfyLz0I0ceJEzpw5w0svvURCQoJwVl8qklopBVJx/sLMmb2i1QkRKGIUqddy+rwZi13EIQku4LMQ/fTTT2RmZtK3b99A2NP2kFTumkQeM2cEIHiyGRCqU6J7C0xWSsxKkq/HEoWVb2SUwEol0LLp7RQ0LT4LUY8ePaioaH1+jKChUoG+Soiq9YhaMZIkER8Z4h6uNYQse+bH2SrrNZVbHZRbnciVSxB4dS2q1ngTAtec8FmIXn75ZWbMmMGLL75I7969a/iIApIG0dqptUckqKKqxEYVISolIvziUAFfkGUZa2WAXoXdibNa1QIZWalx5HThEiPIJsFnIRo9ejQAo0aN8miXZRlJknA6RXStz7irNFaLrhYEFEmSvEpxcTgVQbLalZ82h8tdPE0pyVKzJ1ab29RVWQ/JUZmR75RlXC6lXfTMGiFE69evD4QdbZuLhUh2KfFEWhF/E2w0lUsxhzVhnf+qoaiMkiNWJYA2h2dJFxml7Ii9suyIfFGiMuCWSaujeUe4+yxEI0aMCIQdbZvqxdGqcFQIIWqjVB+KqivXpucSw7BkWcZid1Fhd1LeDIvoeSVEOTk5dOzY0euLnjlzhg4dOjTaqDbHxT0iUHpEYhVngZ+QJMldqyqmsoiexe6kzOJQelNcKP1SvTJQlVNfKfwmu0vGaNX+DdvxSogGDx7M7bffzoMPPsjgwYNrPaakpIQVK1awcOFCHn74YR577DG/Gtqq0V+U+AqtMsJa0Ly4lDIw/sYrITpw4AAvvvgiv/rVrwgJCWHgwIEkJycTEhLC+fPnOXDgAPv372fAgAH89a9/ZezYsYG2u3VRvUpjFa0s50wgqA+vcs1iY2N57bXXOHfuHG+++SZdu3alsLCQI0eOAJCRkcHOnTvJzMwUItQYQqsVR6uiqkiaQNAG8MlZHRoayoQJE5gwYUKg7GmbVPWIqjurQRme6fxXfEogaK4Ev2q2AEIMyk9buWe478XCJBC0UoQQNQeqahK57OCsVjvYJoRI0DZoMUJkNBrJyMggKioKg8HAlClTMJka/qJmZmZyww03EB4eTlRUFNddd13zy5ULicIdelZdfGwmkRAlaBO0GCHKyMhg//79rFmzhlWrVrFp0yYefvjhes/JzMxk9OjR3HjjjWzbto3t27czbdo0VE20SobXqDQX6lRXFyLZ5enAFghaK7KPbNy4Ubbb7TXa7Xa7vHHjRl8v5xUHDhyQAXn79u3utu+++06WJEk+c+ZMnecNGTJE/vOf/3xJ9y4pKZEBuaSk5JKuUy9moyy/0lWW50bJ8u5/y/KZXRe20nOBu69AEEB8+e743DW4/vrra63CWFJSwvXXX3/pylgLmZmZGAwGBg0a5G5LT09HpVKxdevWWs/Jz89n69atxMfHM2zYMBISEhgxYgSbN28OiI2XRFVxNKjpoBYOa0EbwGchkiuz7C+mqKiI8PDATDXn5uYSHx/v0abRaIiJiSE3N7fWc44dOwbAs88+y0MPPcT333/PgAEDGDVqlDv+qTasViulpaUeW8CRqtckumgoZjOJeCJBq8frOKI77rgDUHJWJk2ahF5/IQvP6XTyyy+/MGzYMJ9uPnv2bObPn1/vMQcPHvTpmlVULfz4u9/9jsmTJwPQv39/1q5dy/vvv8+8efNqPW/evHn85S9/adQ9G41KDdpKEa8xUyYrSw3pxcopgtaL10IUHa1MMcuyTGRkJKGhFzIydTodV199NQ899JBPN58xYwaTJk2q95i0tDQSExPJz8/3aHc4HBiNRhITE2s9LykpCaDGsthXXHEFOTk5dd7vqaeeYvr06e73paWlpKSk1GvjJVNfjwjAWiaESNCq8VqIlixZAkBqaiozZ870yzAsLi6OuLi4Bo8bOnQoxcXF7Ny5k4EDBwKwbt06XC4XQ4YMqfWc1NRUkpOTycrK8mg/fPgwY8aMqfNeer3eo7fXJEjqCxHUtfmEhJ9I0Mrx2Uc0d+5c9Ho9P/zwA2+99RZlZWUAnD171qu4nsZwxRVXMHr0aB566CG2bdvGli1bmDZtGnfffTfJycmAUnqkR48ebNu2DVCGkLNmzWLRokV8+umnHD16lDlz5nDo0CGmTJkSEDsbjUcB/Vo+Q7tZ+IkErRqfC6OdPHmS0aNHk5OTg9Vq5Ve/+hWRkZHMnz8fq9XK4sWLA2EnH330EdOmTWPUqFGoVCrGjx/PokWL3PvtdjtZWVmYzWZ32xNPPIHFYuHJJ5/EaDTSt29f1qxZw+WXXx4QGxuNSnWhR1RrNLUMtjLPVWEFglaEz0L0+OOPM2jQIPbs2UNsbKy7fdy4cT77iHwhJiaGZcuW1bk/NTXVo6BTFbNnz2b27NkBs8tv1FYKpDpWkxAiQavFZyH68ccf+emnn9DpPIv4pqamcubMGb8Z1uaorVxsdSwlEJVce2V2gaCF47OPyOVy1bpSx+nTp4mMFDM7jSZK8XVRnFN7fpnTqqwGKxC0QnwWohtvvJHXX3/d/V6SJEwmE3PnzhVF0S6FuB7KMtPWUig5XfsxprymtUkgaCJ8FqJXX32VLVu20LNnTywWC/fcc497WNZQcKKgHjR6aN9deZ2/v/ZjHBbRKxK0Snz2EaWkpLBnzx4++eQT9uzZg8lkYsqUKWRkZHgEOQp8RFJBQk/I2wd5+6Hb6NqPK8uD0HZNa5tAEGB8EiK73U6PHj1YtWoVGRkZZGRkBMqutoekgvgrldd5B+o+zlEBFcUQamgKqwSCJsGnoZlWq8ViEatLBASVGhIqhej8cbCZ6z7WlF/3PoGgBeKzj2jq1KnMnz8fh8MRCHvaLpIKwttDRIJSEK3gUN3H2suV/DOBoJXgs49o+/btrF27ltWrV9O7d+8aOWeff/6534xrU0iVC93F91Rmx/L2Q4cBdR9vNopEWEGrwWchMhgMjB8/PhC2tG2kys5pQk84tr7umbMqLCVK/llzK3srEDQCn4WoKgtf4GfcQlTNYS3LdUdSy06wFENYTJOYJxAEEvE4bS6oKodmsV0bDmysQsQUCVoJPveI+vfvX2upWEmSCAkJoUuXLkyaNClg9atbLVWfqVqrBDbm7VOGZ4Z6irJZy8DpALXPf0aBoFnhc49o9OjRHDt2jPDwcK6//nquv/56IiIiyM7OZvDgwZw7d4709HT+85//BMLe1kuVsxoUPxHUH08EgCx6RYJWgc+P0sLCQmbMmMGcOXM82l944QVOnjzJ6tWrmTt3Ls8//zy33Xab3wxt9UjVnglVgY0NOawBKowQ0XCVS4GgOeNzj2jFihVMnDixRvvdd9/NihUrAJg4cWKNEq2CBlBV7xFVCpGxgcBGUKo32kWQqaBl47MQhYSE8NNPP9Vo/+mnnwgJCQGUUiFVrwVeUr1HVD2wMW9fw+eK4ZmghePz0OzRRx/lkUceYefOnQwePBhQghzfffdd/u///g+A//73v/Tr18+vhrZ6pIueCZcNhkOr4MRmSLmq/nPL80EbIpJhBS0WSa6tvmoDfPTRR7z55pvu4Vf37t159NFHueeeewCoqKhwz6K1dEpLS4mOjqakpISoqKjA3cjlgtw9F96f2grf/UkRl4xPPYdudRGZDJEJgbNRIPABX747jZr3bSjzXpQDaQQXR0gnD1AK6lecV9I9kvo0fI2ys0olx+gUUVJW0KJoVEBjcXGxeyhmNBoB2LVrl6hZfalUn8JXa6HTcOX18Y3eX8NcpGTv+97RFQiChs9C9Msvv9CtWzfmz5/PK6+8QnFxMaAkuz711FP+tq9tcbGfqPN1ys/jP/omLJYSIUaCFoXPQjR9+nQmTZrEkSNHPHxAY8eOZdOmTX41rs1Rm8NaE6I4o+srC1IblhIwHhNiJGgR+CxE27dv53e/+12N9g4dOpCbm+sXo9osFzukNXroOFR5fbwRIm8thaJscNov3TaBIID4LER6vZ7S0tIa7YcPH/ZqHXtBPVzcI4Jqw7NNjevd2Mog/6BSv0ggaKb4LES//vWvee6557DblaesJEnk5OTwpz/9SdQpulRqE6KOQ0Ctg9IzylCrMchOKD5Z2TsSlTUFzQ+fhWjBggWYTCbi4+OpqKhgxIgRdOnShYiICF588cVA2Nh2qE2ItGGKrwgaNzyrjrUUio6IoZqg2eFzHFF0dDRr1qxh8+bN/PLLL5hMJgYMGEB6enog7Gtb1BW0mDYCTm6BrG+hf4bSQ2osDgsUHoHYLqC5hOsIBH6kUZHVtbFr1y6eeeYZVq1a5Y/LNRuaLLIalEJo5QU12x1W+CQDygth+BNw5e2Xfi+1rlKM9Jd+LYGgFnz57vg0NPvvf//LzJkz+b//+z+OHVP8FYcOHeL2229n8ODBuFyuxlstqH1oBopY9LtXef3zvxVhulScNiUkIHefsuXtV3pKpnxw2C79+gKBD3gtRO+99x5jxoxh6dKlzJ8/n6uvvpp///vfDB06lMTERPbt28e3334bSFtbP1I9+WQ9xkJ4vNIrOvSNf+4nu8BlVzanDWwmxSmevx/yDyllSEpOC3ESBByvhWjhwoXMnz+fwsJCVqxYQWFhIf/4xz/Yu3cvixcv5oorrgiknW2DunpEoAyl+lf2inb7qVdUH44KpTh/eYEiToVZYi01QcDwWoiys7P5zW9+A8Add9yBRqPhlVde4bLLLguYcW2OhjLsu49R6hRVGOHgV01jUxUuhzL9X17YtPcVtAm8FqKKigrCwsIAJXZIr9eTlJQUMMPaJA1lzKu1MOA+5fXPy5QZsCZFhpJTUJwDLmcT31vQmvFp+v7dd98lIiICAIfDwdKlS2nfvr3HMY899pj/rGtr1OcjqqLbaNj9EZSdg/1fQt+7A25WDcxFyjAtqgOEGpr+/oJWh9fT96mpqbUuI+RxMUlyz6b5G6PRyKOPPsrXX3+NSqVi/PjxLFy40C2MtZGbm8usWbNYs2YNZWVldO/enaefftqnCPAmnb53WCG/oZU7gMPfw4aXQR8FE5eDLiywdtVHiAHCYpVhpUqjiKlY3khAgAqjnThx4lLtuiQyMjI4d+4ca9aswW63M3nyZB5++GGWLVtW5zn3338/xcXFfPXVV7Rv355ly5Zx5513smPHDvr379+E1nuJRq9k2zc05OqSrvSKSk7Bvk9hwP1NY19tWIqV7WJUmkphqj76l0AfAfpI0EWI4m0CN34LaAwkBw8epGfPnmzfvp1BgwYB8P333zN27FhOnz5NcnJyredFRETwz3/+k/vuu8/dFhsby/z583nwwQe9uneT9ogASs4oZT8a4uhaWPe8UsVx4nLly92SkNSK7dpQRXy1oaDSKj0rIVCtgoAFNAaLzMxMDAaDW4QA0tPTUalUbN26tc7zhg0bxieffILRaMTlcrF8+XIsFgsjR45sAqsbSUi0d8ddfj206wy2cvjlk8DaFAhkp5L7ZspTEnILDkHeXjj3M5z7BQqy4PxJJYbJUqL8ng6rSNptpbSIwXxubi7x8fEebRqNhpiYmHprIK1YsYK77rqL2NhYNBoNYWFhfPHFF3Tp0qXOc6xWK1brhRid2kqeBBRduDKkcTXwhZNUMPi3sHoO7P0Uek1oPY5j2Vm5XpsZKmrZr9JCSJTiI9NH1az3LWhxBPUvOHv2bCRJqnc7dMjHyoTVmDNnDsXFxfzwww/s2LGD6dOnc+edd7J37946z5k3bx7R0dHuLSWlnrXnA4EkeT/M6nQNtO+m+JTWPqekabQFXPYLtblzf1FSU8pylV6TSDNqkQTVR1RQUEBRUVG9x6SlpfHvf/+bGTNmcP78hYUEHQ4HISEhrFy5knHjxtU4Lzs7my5durBv3z6uvPJKd3t6ejpdunRh8eLFtd6vth5RSkpK0/mIQCliVnzSu2PP7IJvZyrpGqCsEtvnbki9pu36WtQ6UOvrry4gqSt7VS3Mt9aCCPhyQtnZ2SxZsoTs7GwWLlxIfHw83333HR07dvT40jdEXFycV1Udhw4dSnFxMTt37mTgwIEArFu3DpfLxZAhQ2o9x2xWlmpWXdRtV6vV9Sbn6vV69PogZ6SHRAMS4MUzosMAGP8u/LISjv6g9IrWzFEWZbxmOkQmBtra5ofTVpk718Bx5fnKMDgkWpnFq3Kct1UBDyI+94g2btzImDFjGD58OJs2beLgwYOkpaXx8ssvs2PHDj799NOAGDpmzBjy8vJYvHixe/p+0KBB7un7M2fOMGrUKD788EOuuuoq7HY7PXv2JCkpiVdffZXY2Fi+/PJLZs2axapVqxg7dqxX923yWbMqCo8qZV59wVwE+z6HvSuU4meaELjqYaVsSH15bIILSCqlNwXVBElSXkuqaj8rN+oRLUmqdq5a6aGp9UqYRhsQu4D2iGbPns0LL7zA9OnTiYy80K294YYbePPNN3231ks++ugjpk2bxqhRo9wBjYsWLXLvt9vtZGVluXtCWq2Wb7/9ltmzZ3PrrbdiMpno0qULH3zwgdciFFRConwXorBYuOoh6HYTbHoFcvfCT4uUvLT+90LaSKUHIKgb2aUk/AacakIkqZThpEZ3YVip1la2hbQJZ7zPPaKIiAj27t1L586diYyMZM+ePaSlpXHixAl69OiBxdLU+U+BJWg9IrsFCg42/nzZBQe+gm3vgL1caYvqoOSqdb2pTTyRWweVkxf6KOXhpNK2GGEKaI/IYDBw7tw5Onfu7NG+e/duOnTo4OvlBHWhDVGejM5GlvuQVMqQrMso2P+FMsVfekZJDTnxE4z8o+IXETRzZCXeyloK1SNJJFVlOo2usvekrWX4LV0YHmp0oAlttsNCn4Xo7rvv5k9/+hMrV65EkiRcLhdbtmxh5syZ3H9/EFMNWiNhscp69peCPlJJAek9AfZ9ATuXwIlN8PlRSP8LtO/qH1sFTYvsulDYzqe1ECRFjNwC1oAwSWqlByapK6PeK31jKk3DZWt8scrXoZnNZmPq1KksXboUp9OJRqPB6XRyzz33sHTpUtRq/xnXHAja0AyUUht5+y5MzfuD/IPww7NKRLNaC+27VyasqpUE1oRekNgbYjoLf5KgbsLag6H+GDtfvjuNjiPKyclh3759mEwm+vfvT9eurfPJGlQhAig+BWY/FyOzlMKGlyDnf3UfowmB8LgLsTaGVOg9XmkTCJqLELUVgi5El+q0rgvZpcyqWUqVlAqXQ4lOzt2rFNOvcnBXR62FnrdDv3sgtJ3/bRK0HPwsRF71vadPn+61fa+99prXxwq8QBuizJhY/ZzzJqkgqW/t+1xOKD0NFcWKUFmK4chqRaT2roSDX0O/DKUom1rrX7sEbRKvhGj37t1eXayhwmmCRhIR738hqg+VGgydlK2KHrfA6e2w430lU37He5C9Fq6bpaSVCASXgBiaNUDQh2ZV5B9qokC7BpBlJZUk802lPAcSpA5XfEe6CKXwmS7iwuvqszKSGmLTLm2lWkHzIBhDs7o4deoUQNNnqLdFIuK9T4QNJJIEXX+l5LL9759K2doTm70/XxsKl12liFdSvwtlZgVtGp97RA6Hg7/85S8sWrQIk8kEKNHWjz76KHPnzkWrbV0+g2bTI5JlZeq9sQGOgSJvv+I7spUrBfVtJmWzVv6svjCjzVRziCmplKdrRLziAA81KD/DYpWE3chEZWFJkYzavAh2j+jRRx/l888/569//StDhw4FlAqKzz77LEVFRfzzn//09ZICb5Ak5UvZHHpF1Um40nsfkeyCgsNwcjOc/AnOn1DayvMbLo8rqSqz40MhLAYMHRUfVrtOEJUMkUlKUTlBi8TnHlF0dDTLly9nzJgxHu3ffvstEydOpKSkxK8GBptm0yOqorn4ivyBywkV5xURMhUos3NmY2VbIZhylZACu9m76+mjICoJIpMV0Y6IrzsoU62D5H7KgpUC3wl2j0iv15OamlqjvXPnzuh0wgkZcKKSwBiYJZuaHJUawtsrW3wdx8jyhbKxdovyszwfzucovcPiHGWNN0uJMuwrKFXqXXtL7OXQaThcNkiJMtcEuRZVG8XnHtFzzz3HoUOHWLJkibuAmNVqZcqUKXTt2pW5c+cGxNBg0ex6RKCURrWZgm1F88JmVvLyys5Baa7yurwIqCM9puK84nOrnj4jqRVhat9d8VXpo5SZP42+WpKpVkmFqfJltVXhCnZk9bhx41i7di16vZ6+fZWAuD179mCz2Rg1apTHsZ9//rkvl26WNEshspqg6EiwrWj5WIohZ6vir8rdCxVG/9+jKklUra10wrdXHPHVy9hK6mqhD+HVtghF9AwpzS/vL9hDM4PBUGOlVDF938ToI5R/6orzDR8rqJsQg1JErttNyhDQlKf0kozHlBlAa5lSnM5hu5Dt7rAqAlZRrGS+N4Q7S94B9goobUQ1BbUWYtIgtotS1rZq8Up9ZGWCclqLr8ApAhoboFn2iED54hRl+17FUeAfZFnJx3PWI0ayDMgXBMxsVMr5mos8l4tyOSrDH0wXwh9s5cpWXtCws14fCYl9aub/uUt2qEEbVllcrbLIWlWxNX1E/XFcVRUjLz4m2D0iQTNBkpRSHYVHWs8sWktCknwvLBd9me/3kV1KL6roqPLgsZuV2UaXU5lVzNun9NxObvH92r6g1im/b0SCMhvZLlUputfzNr9c3mchKioq4plnnmH9+vXk5+fXWBHDaAzAOFtQO6pK52rhYWXVCkHrQ1IpAhZ9mVJz/GJcDuXvn7tfWd/Ojaz0yGSXIlo2U+Vws7Lao7VM6YFZy/BqtRinTfGhVRiVahDHNyr3C5YQ3XfffRw9epQpU6aQkJAgEl2DjVqrLLJor7jgj3DalX82MbPW+lFpIL6nsjWGej0zsiJADosytKworoz5yleqMnS+rnH3rAWfhejHH39k8+bN7hkzQTOgqmZxdSITlHXirZVlPKxl/q30KGgd1NuRkJTUGk2I8jYiAeK6K6+98BH5gs9C1KNHDyoqhE+iRaDWKOkQYTHKk89apjhKLcXBtkwg8MDnOb9//OMfPP3002zcuJGioiJKS0s9NkEzRZKUsq8xnSG2K2hFXpag+dCoOKLS0lJuuOEGj3ZZlpEkCafT6TfjBAFCHwFx3ZQxv9N2wakpOxVfgMMinN+CJsVnIcrIyECr1bJs2TLhrG7phBrq3ifLymxLVRyM034h58tWLoRK4Fd8FqJ9+/axe/duunfvHgh7BM0FSVJ8TFVo9EpPChSRKi9Q8rqEA1zgB3z2EQ0aNMhdmVHQRpEkJagt7golOlcguEQaVRjt8ccfZ9asWfTu3btGRcY+ffr4zThBM0ejUwIqnXZlGCc7LwTQVcU0Ve8xya4LVRwFgmr4nGumUtXsREmS1Gqd1c0216wl47Qr9YPs5mqCJVcKmt0zD0vQPAl2rtnx48d9PUUg8EStVYqh1YUsK2Lkqlz4saqnVfXMrHotu6iRnuByKo70KlGri6oenKBZ4LMQderUqeGDBIJLQZJqjxb3NzbzhbwrWzle5VwJAoJXQvTVV18xZswYtFotX331Vb3H/vrXv/aLYQJBwNGFKVtkIrhc1UpwmJXVUkSIQpPhlY9IpVKRm5tLfHx8rT4i98WEj0jQmpBlJcCzyuEuSZW+LKsy9Ku+rz6qzpOdnvFZtR9c87wqv1lzCpUIho+oeqmPi8t+CAStFkkCbUgtO8Ka3BSg0q9VKWCSpPTYzEVKpc4W7uAXhdEEgpbCxVUSVaFKnaKoDsosZL1iJFVb+ltqoPxHNdxVJisnEOxmpeSMn/FaiDIzMykqKuKWW25xt3344YfMnTuX8vJybr/9dt544w33yh4CgaCJkKT603UCgZ8rTHsdWf3cc8+xf/9+9/u9e/cyZcoU0tPTmT17Nl9//TXz5s3zq3HVefHFFxk2bBhhYWEYDAavzpFlmWeeeYakpCRCQ0NJT0/nyBGx+oVAcMn4OcfUayH6+eefPZYLWr58OUOGDOGdd95h+vTpLFq0iBUrVvjVuOrYbDZ+85vf8Pvf/97rc/7617+yaNEiFi9ezNatWwkPD+emm27CYrE0fLJAIGg6ZC/R6/VyTk6O+/3w4cPlF154wf3++PHjckREhLeXazRLliyRo6OjGzzO5XLJiYmJ8iuvvOJuKy4ulvV6vfzxxx97fb+SkhIZkEtKShpjrkDQZvHlu+N1jyghIcEdVW2z2di1axdXX321e39ZWVmNvLNgcvz4cXJzc0lPT3e3RUdHM2TIEDIzM+s8z2q1imJvAkET47UQjR07ltmzZ/Pjjz/y1FNPERYWxrXXXuve/8svv3D55ZcHxMjGkJubCygCWp2EhAT3vtqYN28e0dHR7k0sHikQBB6vhej5559Ho9EwYsQI3nnnHd555x10ugvL5r7//vvceOONPt189uzZSJJU73bo0CGfrnmpPPXUU5SUlLg3UfJEIAg8Xk/ft2/fnk2bNlFSUkJERARqtWdMw8qVK4mI8G3BuRkzZjBp0qR6j0lLS/PpmlUkJiYCkJeXR1JSkrs9Ly+Pfv361XmeXq8XIQgCQRPjc0BjdHR0re0xMTE+3zwuLo64uDifz/OGzp07k5iYyNq1a93CU1paytatW32aeRMIBIGnxURW5+TkYDQaycnJwel08vPPPwPQpUsXd0+sR48ezJs3j3HjxiFJEk888QQvvPACXbt2pXPnzsyZM4fk5GRuv/12r+8rVwZuCae1QOAbVd8Z2Zvgx4DP4fmJBx54oDLW3HNbv369+xhAXrJkifu9y+WS58yZIyckJMh6vV4eNWqUnJWV5dN9T506Vet9xSY2sXm3nTp1qsHvmc8VGtsaLpeLs2fPEhkZ6bFiSWlpKSkpKZw6dUpk5VdDfC41aaufiSzLlJWVkZycXG/VDmhBQ7NgoVKpuOyyy+rcHxUV1ab+ubxFfC41aYufSV0+5YvxeRUPgUAg8DdCiAQCQdARQtRI9Ho9c+fOFTFHFyE+l5qIz6RhhLNaIBAEHdEjEggEQUcIkUAgCDpCiAQCQdARQtQI/v73v5OamkpISAhDhgxh27ZtwTapSZk3bx6DBw8mMjKS+Ph4br/9drKysjyOsVgsTJ06ldjYWCIiIhg/fjx5eXlBsrjpefnll91pRlW09c+kPoQQ+cgnn3zC9OnTmTt3Lrt27aJv377cdNNN5OfnB9u0JmPjxo1MnTqV//3vf6xZswa73c6NN95IeXm5+5gnn3ySr7/+mpUrV7Jx40bOnj3LHXfcEUSrm47t27fz1ltv0adPH4/2tvyZNIhPiVcC+aqrrpKnTp3qfu90OuXk5GR53rx5QbQquOTn58uAvHHjRlmWlZK8Wq1WXrlypfuYgwcPyoCcmZkZLDObhLKyMrlr167ymjVr5BEjRsiPP/64LMtt+zPxBtEj8gGbzcbOnTs9ys+qVCrS09PrLT/b2ikpKQEulILZuXMndrvd43Pq0aMHHTt2bPWf09SpU7n55ps9fndo25+JN4hcMx8oLCzE6XTWWn62qStJNhdcLhdPPPEEw4cPp1evXoBSplen09VY9qmhMr0tneXLl7Nr1y62b99eY19b/Uy8RQiR4JKYOnUq+/btY/PmzcE2JaicOnWKxx9/nDVr1hASUtsy1YL6EEMzH2jfvj1qtbrGTEdeXp67NG1bYtq0aaxatYr169d7VChITEzEZrNRXFzscXxr/px27txJfn4+AwYMQKPRoNFo2LhxI4sWLUKj0ZCQkNDmPhNfEELkAzqdjoEDB7J27Vp3m8vlYu3atQwdOjSIljUtsiwzbdo0vvjiC9atW0fnzp099g8cOBCtVuvxOWVlZZGTk9NqP6dRo0axd+9efv75Z/c2aNAgMjIy3K/b2mfiE8H2lrc0li9fLuv1ennp0qXygQMH5Icfflg2GAxybm5usE1rMn7/+9/L0dHR8oYNG+Rz5865N7PZ7D7mkUcekTt27CivW7dO3rFjhzx06FB56NChQbS66ak+aybL4jOpDyFEjeCNN96QO3bsKOt0Ovmqq66S//e//wXbpCaFOkqCVi/TW1FRIf/hD3+Q27VrJ4eFhcnjxo2Tz507Fzyjg8DFQiQ+k7oR2fcCgSDoCB+RQCAIOkKIBAJB0BFCJBAIgo4QIoFAEHSEEAkEgqAjhEggEAQdIUQCgSDoCCESCARBRwiRoNWTmprK66+/HmwzBPUghEjgVyZNmsTtt98OwMiRIz1qNgeapUuX1qj3A0rp1ocffrjJ7BD4jqhHJGj22Gw2dDpdo8+Pi4vzozWCQCB6RIKAMGnSJDZu3MjChQuRJAlJkjhx4gQA+/btY8yYMURERJCQkMB9991HYWGh+9yRI0cybdo0nnjiCdq3b89NN90EwGuvvUbv3r0JDw8nJSWFP/zhD5hMJgA2bNjA5MmTKSkpcd/v2WefBWoOzXJycrjtttuIiIggKiqKO++806PG1LPPPku/fv3417/+RWpqKtHR0dx9992UlZUF9kNrwwghEgSEhQsXMnToUB566CHOnTvHuXPnSElJobi4mBtuuIH+/fuzY8cOvv/+e/Ly8rjzzjs9zv/ggw/Q6XRs2bKFxYsXA0p98EWLFrF//34++OAD1q1bxx//+EcAhg0bxuuvv05UVJT7fjNnzqxhl8vl4rbbbsNoNLJx40bWrFnDsWPHuOuuuzyOy87O5ssvv2TVqlWsWrWKjRs38vLLLwfo0xKIMiACv/LAAw/It912myzLNctgyLIsP//88/KNN97o0Xbq1CkZkLOystzn9e/fv8F7rVy5Uo6NjXW/X7JkiRwdHV3juE6dOsl/+9vfZFmW5dWrV8tqtVrOyclx79+/f78MyNu2bZNlWZbnzp0rh4WFyaWlpe5jZs2aJQ8ZMqRBmwSNQ/SIBE3Knj17WL9+PREREe6tR48egNILqWLgwIE1zv3hhx8YNWoUHTp0IDIykvvuu4+ioiLMZrPX9z948CApKSmkpKS423r27InBYODgwYPuttTUVCIjI93vk5KS2tTadU2NcFYLmhSTycStt97K/Pnza+xLSkpyvw4PD/fYd+LECW655RZ+//vf8+KLLxITE8PmzZuZMmUKNpuNsLAwv9qp1Wo93kuShMvl8us9BBcQQiQIGDqdDqfT6dE2YMAAPvvsM1JTU9FovP/327lzJy6XiwULFqBSKR35FStWNHi/i7niiis4deoUp06dcveKDhw4QHFxMT179vTaHoF/EUMzQcBITU1l69atnDhxgsLCQlwuF1OnTsVoNDJx4kS2b99OdnY2//3vf5k8eXK9ItKlSxfsdjtvvPEGx44d41//+pfbiV39fiaTibVr11JYWFjrkC09PZ3evXuTkZHBrl272LZtG/fffz8jRoxg0KBBfv8MBN4hhEgQMGbOnIlaraZnz57ExcWRk5NDcnIyW7Zswel0cuONN9K7d2+eeOIJDAaDu6dTG3379uW1115j/vz59OrVi48++oh58+Z5HDNs2DAeeeQR7rrrLuLi4vjrX/9a4zqSJPGf//yHdu3acd1115Genk5aWhqffPKJ339/gfeImtUCgSDoiB6RQCAIOkKIBAJB0BFCJBAIgo4QIoFAEHSEEAkEgqAjhEggEAQdIUQCgSDoCCESCARBRwiRQCAIOkKIBAJB0BFCJBAIgo4QIoFAEHT+H4jpRpxb3C+DAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ---------- 1. 读取并整理数据 ----------\n",
    "results = {'Mallows': d['mallows'], 'Merge': d['merge']}\n",
    "\n",
    "global_max = -np.inf\n",
    "for arr in results.values():\n",
    "    global_max = max(global_max, arr[:, :].min())\n",
    "\n",
    "# 把每个算法的 simple regret（best‑so‑far – global_min）整理成均值±std\n",
    "mean_regret = {}\n",
    "std_regret  = {}\n",
    "\n",
    "for algo, outputs in results.items():\n",
    "    outputs        = outputs[:, :]                          \n",
    "    best_so_far    = np.maximum.accumulate(outputs, axis=1)    \n",
    "    regrets        = global_max - best_so_far              \n",
    "    mean_regret[algo] = regrets.mean(axis=0)             \n",
    "    std_regret[algo]  = regrets.std(axis=0)\n",
    "\n",
    "# ---------- 2. 画图 ----------\n",
    "iters = np.arange(1, 56)\n",
    "\n",
    "plt.figure(figsize=(3, 3))\n",
    "\n",
    "for algo in mean_regret:\n",
    "    mean = mean_regret[algo]\n",
    "    std  = std_regret[algo]\n",
    "    plt.plot(iters, mean, label=algo)\n",
    "    plt.fill_between(iters, mean - std, mean + std, alpha=0.2)\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Simple Regret (mean ± 1 std)\")\n",
    "plt.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "# plt.yscale(\"log\")           # 若差距跨数量级，建议用对数轴；可去掉\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"ttp_2.pdf\", dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4967f801-d43f-4ec3-87f2-454ec0a9e5a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "merge regret mean:  74965.35892147488 cumulative regret std:  29562.25562402866\n",
      "merge cumulative regret mean:  7095727.4420137815 cumulative regret std:  1538834.2145249024\n",
      "mallows regret mean:  278589.7429801994 cumulative regret std:  26469.638394077123\n",
      "mallows cumulative regret mean:  16575741.826229028 cumulative regret std:  1446788.1571732673\n",
      "regret win:  50 , tie:  0 , loss:  0\n",
      "AUC win:  50 , tie:  0 , loss:  0\n"
     ]
    }
   ],
   "source": [
    "# import torch\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "import pandas as pd\n",
    "\n",
    "\n",
    "def read_file(folder):\n",
    "    merge = []\n",
    "    mallows = []\n",
    "    random = []\n",
    "    methods = ['Merge', 'DPPMallows', 'Random']\n",
    "    arrays = [merge, mallows, random]\n",
    "    for method, array in zip(methods, arrays):\n",
    "        for i in range(50):\n",
    "            df = pd.read_csv(f'./{folder}/{method}_{i}.csv')\n",
    "            value = df.value.to_list()[:55]\n",
    "            array.append(value)\n",
    "        array = np.array(array)\n",
    "    return {'merge': np.array(merge), 'mallows': np.array(mallows), 'random': np.array(random)}\n",
    "\n",
    "d = read_file('instances_a280_n837_uncorr_08.ttp_2_10000_60000')\n",
    "\n",
    "def array_to_regret(d):\n",
    "    max = np.max([d['merge'], d['mallows'], d['random']])\n",
    "    best_so_far = [np.maximum.accumulate(res, axis=1) for res in [d['merge'], d['mallows'], d['random']]]\n",
    "    regrets = [max - bfs for bfs in best_so_far]\n",
    "    return {'merge': regrets[0], 'mallows': regrets[1], 'random': regrets[2]}\n",
    "\n",
    "regrets = array_to_regret(d)\n",
    "\n",
    "for i in ['merge', 'mallows']:\n",
    "    print(i, 'regret mean: ', regrets[i][:, -1].mean(), 'cumulative regret std: ', regrets[i][:, -1].std())\n",
    "    print(i, 'cumulative regret mean: ', regrets[i].sum(axis=1).mean(), 'cumulative regret std: ', regrets[i].sum(axis=1).std())\n",
    "    \n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i, -1] < regrets['mallows'][i, -1]:\n",
    "        win += 1\n",
    "    elif regrets['merge'][i, -1] == regrets['mallows'][i, -1]:\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('regret win: ', win, ', tie: ', tie, ', loss: ', loss)\n",
    "\n",
    "win = 0\n",
    "tie = 0\n",
    "loss = 0\n",
    "for i in range(50):\n",
    "    if regrets['merge'][i].sum() < regrets['mallows'][i].sum():\n",
    "        win += 1\n",
    "    elif regrets['merge'][i].sum() == regrets['mallows'][i].sum():\n",
    "        tie += 1\n",
    "    else:\n",
    "        loss +=1 \n",
    "print('AUC win: ', win, ', tie: ', tie, ', loss: ', loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "2108d1a2-c1c4-4b6f-90d1-e437615c0b38",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ---------- 1. 读取并整理数据 ----------\n",
    "results = {'Mallows': d['mallows'], 'Merge': d['merge']}\n",
    "\n",
    "global_max = -np.inf\n",
    "for arr in results.values():\n",
    "    global_max = max(global_max, arr[:, :].min())\n",
    "\n",
    "# 把每个算法的 simple regret（best‑so‑far – global_min）整理成均值±std\n",
    "mean_regret = {}\n",
    "std_regret  = {}\n",
    "\n",
    "for algo, outputs in results.items():\n",
    "    outputs        = outputs[:, :]                          \n",
    "    best_so_far    = np.maximum.accumulate(outputs, axis=1)    \n",
    "    regrets        = global_max - best_so_far              \n",
    "    mean_regret[algo] = regrets.mean(axis=0)             \n",
    "    std_regret[algo]  = regrets.std(axis=0)\n",
    "\n",
    "# ---------- 2. 画图 ----------\n",
    "iters = np.arange(1, 56)\n",
    "\n",
    "plt.figure(figsize=(3, 3))\n",
    "\n",
    "for algo in mean_regret:\n",
    "    mean = mean_regret[algo]\n",
    "    std  = std_regret[algo]\n",
    "    plt.plot(iters, mean, label=algo)\n",
    "    plt.fill_between(iters, mean - std, mean + std, alpha=0.2)\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Simple Regret (mean ± 1 std)\")\n",
    "plt.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "# plt.yscale(\"log\")           # 若差距跨数量级，建议用对数轴；可去掉\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"ttp_3.pdf\", dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
