{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "def extract_metrics(data, share_ttft_con, share_tpot_cons):\n",
    "    ttfts = data['ttfts']\n",
    "    tpots = data['tpots']\n",
    "    e2els = data['e2els']\n",
    "\n",
    "    ttft_class = []  # sharegpt, splitwise\n",
    "    tpot_class = []\n",
    "    e2el_class = []\n",
    "    goodput = 0\n",
    "\n",
    "\n",
    "    for i in range(len(ttfts)):\n",
    "        ttft_class.append(ttfts[i])\n",
    "        tpot_class.append(tpots[i])\n",
    "        e2el_class.append(e2els[i])\n",
    "\n",
    "\n",
    "        if ttfts[i] <= share_ttft_con and tpots[i] <= share_tpot_cons:\n",
    "            goodput += 1\n",
    "\n",
    "    scale = 1000  # to ms\n",
    "\n",
    "    result = {\n",
    "        'share_avg_ttft': round(np.mean(ttft_class) * scale, 4),\n",
    "        'share_avg_tpot': round(np.mean(tpot_class) * scale, 4),\n",
    "        'share_avg_e2el': round(np.mean(e2el_class) * scale, 4),\n",
    "        'share_goodput': round(goodput / len(ttft_class) * 100, 4)\n",
    "    }\n",
    "    return result\n",
    "\n",
    "def process_all_results(base_dir, share_ttft_con, share_tpot_cons):\n",
    "    all_data = []\n",
    "    for filename in os.listdir(base_dir):\n",
    "        if filename.startswith('output_') and filename.endswith('.json'):\n",
    "            output_len_value = int(filename.split('_')[1].split('.')[0])\n",
    "            filepath = os.path.join(base_dir, filename)\n",
    "            with open(filepath, 'r') as f:\n",
    "                data = json.load(f)\n",
    "                metrics = extract_metrics(data, share_ttft_con, share_tpot_cons)\n",
    "                token_throughput = round(data['total_token_throughput'], 4)\n",
    "                metrics['output_len'] = output_len_value\n",
    "                metrics['token_throughput'] = token_throughput\n",
    "                all_data.append(metrics)\n",
    "\n",
    "    if len(all_data) != 0:\n",
    "        df = pd.DataFrame(all_data)\n",
    "        df = df.sort_values('output_len')  # 按rate排序\n",
    "        df = df.set_index('output_len')\n",
    "        return df\n",
    "    else:\n",
    "        return None\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_dir = '/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/results/32B/random/'\n",
    "# base_dir='/mnt/sda/2022-0526/home/xuhx/projects/gLLM/backup/results_54_1048/32B/random/'\n",
    "# base_dir = '/mnt/sda/2022-0526/home/xuhx/projects/gLLM/backup/results_51_935/sharegpt/'\n",
    "share_ttft_con = 0.7\n",
    "share_tpot_cons = 0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>share_avg_ttft</th>\n",
       "      <th>share_avg_tpot</th>\n",
       "      <th>share_avg_e2el</th>\n",
       "      <th>share_goodput</th>\n",
       "      <th>token_throughput</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>output_len</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>30569.2371</td>\n",
       "      <td>-363.1054</td>\n",
       "      <td>30932.3628</td>\n",
       "      <td>1.2939</td>\n",
       "      <td>10678.4844</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>53334.7211</td>\n",
       "      <td>363.5977</td>\n",
       "      <td>65129.0508</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>9089.4639</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>72847.6026</td>\n",
       "      <td>261.5922</td>\n",
       "      <td>90130.1699</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>8286.2816</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>77563.6534</td>\n",
       "      <td>213.9587</td>\n",
       "      <td>98892.2596</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>7593.9993</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>44846.7004</td>\n",
       "      <td>184.1038</td>\n",
       "      <td>69386.0724</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>6978.8183</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>65334.7941</td>\n",
       "      <td>146.1510</td>\n",
       "      <td>94615.7829</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>6408.6193</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>92003.3098</td>\n",
       "      <td>129.6809</td>\n",
       "      <td>126693.5332</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>5803.0332</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>146053.5669</td>\n",
       "      <td>113.0233</td>\n",
       "      <td>206690.8448</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>4359.1099</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            share_avg_ttft  share_avg_tpot  share_avg_e2el  share_goodput  \\\n",
       "output_len                                                                  \n",
       "1               30569.2371       -363.1054      30932.3628         1.2939   \n",
       "32              53334.7211        363.5977      65129.0508         0.0000   \n",
       "64              72847.6026        261.5922      90130.1699         0.0000   \n",
       "96              77563.6534        213.9587      98892.2596         0.0000   \n",
       "128             44846.7004        184.1038      69386.0724         0.0000   \n",
       "192             65334.7941        146.1510      94615.7829         0.0000   \n",
       "256             92003.3098        129.6809     126693.5332         0.0000   \n",
       "512            146053.5669        113.0233     206690.8448         0.0000   \n",
       "\n",
       "            token_throughput  \n",
       "output_len                    \n",
       "1                 10678.4844  \n",
       "32                 9089.4639  \n",
       "64                 8286.2816  \n",
       "96                 7593.9993  \n",
       "128                6978.8183  \n",
       "192                6408.6193  \n",
       "256                5803.0332  \n",
       "512                4359.1099  "
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_dynamic= process_all_results(base_dir + 'dynamic', share_ttft_con, share_tpot_cons)\n",
    "df_dynamic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>share_avg_ttft</th>\n",
       "      <th>share_avg_tpot</th>\n",
       "      <th>share_avg_e2el</th>\n",
       "      <th>share_goodput</th>\n",
       "      <th>token_throughput</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>output_len</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>30244.8397</td>\n",
       "      <td>-352.4592</td>\n",
       "      <td>30597.3200</td>\n",
       "      <td>1.1963</td>\n",
       "      <td>10759.6896</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>48453.9828</td>\n",
       "      <td>373.7624</td>\n",
       "      <td>60587.6591</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>9444.3480</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>77822.0752</td>\n",
       "      <td>301.9884</td>\n",
       "      <td>97750.8300</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>7888.3297</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>81477.5617</td>\n",
       "      <td>246.4922</td>\n",
       "      <td>106035.0881</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>7294.4261</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>47606.8926</td>\n",
       "      <td>212.1526</td>\n",
       "      <td>75864.4785</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>6751.8074</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>69064.1802</td>\n",
       "      <td>170.1507</td>\n",
       "      <td>103171.9290</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>6178.0886</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>96017.9957</td>\n",
       "      <td>156.4933</td>\n",
       "      <td>137899.0726</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>5409.0576</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>155217.0155</td>\n",
       "      <td>131.7665</td>\n",
       "      <td>225865.1768</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>4204.6586</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            share_avg_ttft  share_avg_tpot  share_avg_e2el  share_goodput  \\\n",
       "output_len                                                                  \n",
       "1               30244.8397       -352.4592      30597.3200         1.1963   \n",
       "32              48453.9828        373.7624      60587.6591         0.0000   \n",
       "64              77822.0752        301.9884      97750.8300         0.0000   \n",
       "96              81477.5617        246.4922     106035.0881         0.0000   \n",
       "128             47606.8926        212.1526      75864.4785         0.0000   \n",
       "192             69064.1802        170.1507     103171.9290         0.0000   \n",
       "256             96017.9957        156.4933     137899.0726         0.0000   \n",
       "512            155217.0155        131.7665     225865.1768         0.0000   \n",
       "\n",
       "            token_throughput  \n",
       "output_len                    \n",
       "1                 10759.6896  \n",
       "32                 9444.3480  \n",
       "64                 7888.3297  \n",
       "96                 7294.4261  \n",
       "128                6751.8074  \n",
       "192                6178.0886  \n",
       "256                5409.0576  \n",
       "512                4204.6586  "
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# 用法\n",
    "df_0 = process_all_results(base_dir + 'baseline0',  share_ttft_con, share_tpot_cons)\n",
    "df_0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>share_avg_ttft</th>\n",
       "      <th>share_avg_tpot</th>\n",
       "      <th>share_avg_e2el</th>\n",
       "      <th>share_goodput</th>\n",
       "      <th>token_throughput</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>output_len</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>33554.9813</td>\n",
       "      <td>-477.9978</td>\n",
       "      <td>34032.9988</td>\n",
       "      <td>1.709</td>\n",
       "      <td>10372.7805</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>51347.8933</td>\n",
       "      <td>370.5520</td>\n",
       "      <td>63381.9575</td>\n",
       "      <td>0.000</td>\n",
       "      <td>9280.4450</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>75538.8615</td>\n",
       "      <td>289.1314</td>\n",
       "      <td>94649.9826</td>\n",
       "      <td>0.000</td>\n",
       "      <td>7996.0690</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>72754.1228</td>\n",
       "      <td>223.6363</td>\n",
       "      <td>95020.6040</td>\n",
       "      <td>0.000</td>\n",
       "      <td>7774.6287</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>43449.1654</td>\n",
       "      <td>196.8125</td>\n",
       "      <td>69662.8339</td>\n",
       "      <td>0.000</td>\n",
       "      <td>7015.7187</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>63067.4036</td>\n",
       "      <td>159.6753</td>\n",
       "      <td>95037.1133</td>\n",
       "      <td>0.000</td>\n",
       "      <td>6277.6161</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>91563.9200</td>\n",
       "      <td>143.9257</td>\n",
       "      <td>130074.2351</td>\n",
       "      <td>0.000</td>\n",
       "      <td>5673.8144</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>148582.7863</td>\n",
       "      <td>123.0809</td>\n",
       "      <td>214605.5572</td>\n",
       "      <td>0.000</td>\n",
       "      <td>4363.6128</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            share_avg_ttft  share_avg_tpot  share_avg_e2el  share_goodput  \\\n",
       "output_len                                                                  \n",
       "1               33554.9813       -477.9978      34032.9988          1.709   \n",
       "32              51347.8933        370.5520      63381.9575          0.000   \n",
       "64              75538.8615        289.1314      94649.9826          0.000   \n",
       "96              72754.1228        223.6363      95020.6040          0.000   \n",
       "128             43449.1654        196.8125      69662.8339          0.000   \n",
       "192             63067.4036        159.6753      95037.1133          0.000   \n",
       "256             91563.9200        143.9257     130074.2351          0.000   \n",
       "512            148582.7863        123.0809     214605.5572          0.000   \n",
       "\n",
       "            token_throughput  \n",
       "output_len                    \n",
       "1                 10372.7805  \n",
       "32                 9280.4450  \n",
       "64                 7996.0690  \n",
       "96                 7774.6287  \n",
       "128                7015.7187  \n",
       "192                6277.6161  \n",
       "256                5673.8144  \n",
       "512                4363.6128  "
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_1 = process_all_results(base_dir + 'baseline1',  share_ttft_con, share_tpot_cons)\n",
    "df_1\n",
    "# rate 8 有问题"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>share_avg_ttft</th>\n",
       "      <th>share_avg_tpot</th>\n",
       "      <th>share_avg_e2el</th>\n",
       "      <th>share_goodput</th>\n",
       "      <th>token_throughput</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>output_len</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>35515.3564</td>\n",
       "      <td>-360.6141</td>\n",
       "      <td>35875.9902</td>\n",
       "      <td>1.2695</td>\n",
       "      <td>10198.3958</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>77676.0302</td>\n",
       "      <td>293.5513</td>\n",
       "      <td>97053.4082</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>7886.2426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>43588.7212</td>\n",
       "      <td>196.8032</td>\n",
       "      <td>69778.2963</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>7012.5580</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>63655.6044</td>\n",
       "      <td>157.3219</td>\n",
       "      <td>95203.7345</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>6332.9458</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>89840.4160</td>\n",
       "      <td>141.8552</td>\n",
       "      <td>127798.6645</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>5750.4057</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>144244.2956</td>\n",
       "      <td>120.2996</td>\n",
       "      <td>208762.8850</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>4471.2331</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            share_avg_ttft  share_avg_tpot  share_avg_e2el  share_goodput  \\\n",
       "output_len                                                                  \n",
       "1               35515.3564       -360.6141      35875.9902         1.2695   \n",
       "64              77676.0302        293.5513      97053.4082         0.0000   \n",
       "128             43588.7212        196.8032      69778.2963         0.0000   \n",
       "192             63655.6044        157.3219      95203.7345         0.0000   \n",
       "256             89840.4160        141.8552     127798.6645         0.0000   \n",
       "512            144244.2956        120.2996     208762.8850         0.0000   \n",
       "\n",
       "            token_throughput  \n",
       "output_len                    \n",
       "1                 10198.3958  \n",
       "64                 7886.2426  \n",
       "128                7012.5580  \n",
       "192                6332.9458  \n",
       "256                5750.4057  \n",
       "512                4471.2331  "
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_2 = process_all_results(base_dir + 'baseline2',  share_ttft_con, share_tpot_cons)\n",
    "df_2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>share_avg_ttft</th>\n",
       "      <th>share_avg_tpot</th>\n",
       "      <th>share_avg_e2el</th>\n",
       "      <th>share_goodput</th>\n",
       "      <th>token_throughput</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>output_len</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>35701.3551</td>\n",
       "      <td>-397.8600</td>\n",
       "      <td>36099.2347</td>\n",
       "      <td>1.3184</td>\n",
       "      <td>10172.8381</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>78917.2627</td>\n",
       "      <td>295.0473</td>\n",
       "      <td>98404.2923</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>7839.1101</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>128</th>\n",
       "      <td>43871.9984</td>\n",
       "      <td>197.3996</td>\n",
       "      <td>70137.8818</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>6990.5431</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>192</th>\n",
       "      <td>63440.2591</td>\n",
       "      <td>155.9932</td>\n",
       "      <td>94707.8073</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>6388.2165</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>89385.8922</td>\n",
       "      <td>139.9294</td>\n",
       "      <td>126819.6677</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>5810.5120</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>512</th>\n",
       "      <td>137561.1002</td>\n",
       "      <td>115.9954</td>\n",
       "      <td>199781.0977</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>4617.9379</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            share_avg_ttft  share_avg_tpot  share_avg_e2el  share_goodput  \\\n",
       "output_len                                                                  \n",
       "1               35701.3551       -397.8600      36099.2347         1.3184   \n",
       "64              78917.2627        295.0473      98404.2923         0.0000   \n",
       "128             43871.9984        197.3996      70137.8818         0.0000   \n",
       "192             63440.2591        155.9932      94707.8073         0.0000   \n",
       "256             89385.8922        139.9294     126819.6677         0.0000   \n",
       "512            137561.1002        115.9954     199781.0977         0.0000   \n",
       "\n",
       "            token_throughput  \n",
       "output_len                    \n",
       "1                 10172.8381  \n",
       "64                 7839.1101  \n",
       "128                6990.5431  \n",
       "192                6388.2165  \n",
       "256                5810.5120  \n",
       "512                4617.9379  "
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_3 = process_all_results(base_dir + 'baseline3',  share_ttft_con, share_tpot_cons)\n",
    "df_3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Could not save font_manager cache [Errno 2] No such file or directory: '/mnt/sda/2022-0526/home/xuhx/.cache/matplotlib/fontlist-v390.json.matplotlib-lock'\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj8AAADpCAYAAADLVFYsAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAg6ZJREFUeJztnXd8FMX7xz+7V5LcpSekEEoghVCkIyJSBQSlKD1IExFQEBTEn35VBP0KoogoIE2q+iUgiDTpvUjvPYEEQkjv5eru/P643OYuuUvukruUy7xfr3vd7ezs7Ow9Wz4788wzDCGEgEKhUCgUCqWWwFZ1BSgUCoVCoVAqEyp+KBQKhUKh1Cqo+KFQKBQKhVKroOKHQqFQKBRKrYKKHwqFQqFQKLUKKn4oFAqFQqHUKqj4oVAoFAqFUqug4odCoVAoFEqtgoofCoVCoVAotYpqJ37279+PPn36YOPGjaXmO3jwINq1aweZTIY2bdrg4MGDlVRDCoVCoVAoNZlqI362bduGLl26oF+/fjh06BBKm3Xj/PnzGDBgAK5fvw6FQoFr165h4MCBePDgQSXWmEKhUCgUSk2k2oifN954Azt27LAo744dO3D79m0oFArMnTsXAKBSqbBr1y471pBCoVAoFIojUG3Ej0gkgq+vr0V5586di9DQUEgkEsyZMwceHh4AgICAAHtWkUKhUCgUigMgruoKlAdnZ2ejZbVaDXd3dwwaNMjsNiqVCiqVSlgOCwtDQUEBGjRoYLd6UigUCoVCqTyePHkCuVyOpKSkUvPVSPFjyJkzZ6BQKLB8+XK4ubmZzbdgwQLMmzfPKE0kEhkJIpFIBLFYDK1WC47jhHSxWAyRSASNRgOe54V0iUQClmVNphNCwHGcke+SVCoFwzBG+wQAJycnEEKgVquFNIZhIJVKwfM8NBqNkM6yLCQSidl0juOg1Wrtckwsy0KtVteqYyKEgGEYhzomR7RTWcdECIGzs7NDHZMj2qmsY+I4DhqNRrgmHeGYHNFOlhwTIQRisdjmx1S8/uZgSGmexVWA/qRev349xo8fX2b+fv36oUmTJliyZEmp+Yq3/HTs2BEMw+DmzZtG+2ZZFjzPG50U5tJZlgXDMCXSCSGIiYlB48aNIRKJjPIDMDJaaekikQiEEKN0fV3MpVtad2uPSZ9ueII6+jFpNBrExMQgNDQUIpHIIY7JEe1U1jFxHIeYmBg0adJE2G9NPyY9jmQnS45Jq9XiwYMHwjXpCMfkiHYq65j012RYWJgglmx1TC1btgQA3L59G6VRo1t+Vq1aBX9/f/z4448AgJycHLi7u5vM6+TkBCcnJ2FZb1BDcVJ8XXnTeZ6Hr68vxGKxyW1M7dNcOsMwVqVXtO5lpVtTd3PpNeWYxGIx/Pz8StixJh+TI9qprHSGYeDn5weGYRzmmAypTcfEsqzJa7ImH5Mj2qmsY9Jfk/o89j4mk2VYnLMKWb9+PV599VVcvHhRSDt//jx27NiBmTNn4vbt27hw4QKmT59ehbUsgmVZ+Pr6mjUQpWZA7egYUDs6DtSWjkF1sGO1avlRKpXCb8MuqunTpyMvLw9isRi7du3C06dP8cYbbyAxMREHDhwQ8r3++uuVWV2z8DyPhIQEBAUF0Yu0BkPt6BhQOzoO1JaOQXWwY7U5e44cOYLZs2cLy6tXr8aWLVsAAJGRkXBzc8PQoUOhVCoxYMAAJCYmliijbdu2lVbf0iCEID8/v9RAjZTqD7WjY0Dt6DhQWzoG1cGO1abl5+WXX8bLL7+MpUuXlli3evVqrF69Wli+evVqZVaNQqFQKBSKA1FtxI8joB+GyXEceJ6HUqm0ygGLUr2gdnQMqB0dB2pLx6A8dpRIJDa1ORU/NoAQgqSkJGRlZRmlPXnypOoqRbEJ1I6OAbWj40Bt6RiUx46enp4ICAgQQuJUBCp+bIBe+Pj5+UEmk9nEMBQKhUKhUHRCqaCgACkpKQCAwMDACpdJxU8F4ThOED4+Pj4AIETD1EfMpNRMqB0dA2pHx4Ha0jEojx1dXFwAACkpKUYxgspLtRntVVPRh/CWyWRG6cWjYVJqJtSOjgG1o+NAbekYlMeO+ues4dQZ5YWKHxtB30IoFAqFQrEftnzOUvFDoVAoFAqlVkHFj52QSqVVXQWKDaB2dAyoHR0HakvHoKrtSMWPHdBP6ka7wmo21I7lY+X1lWi5sSVWXl9Z1VUBQO3oSFBbOgbVwY5U/NgBQgiUSiUNwV6FcByHw4cPV6gMa+147do1YShmbWXl9ZVYfm05CAiWX1teLQRQTboebXHe1nTOnTuHnJwck+vsYcvo6Gh8+umniIyMxKefforo6GiblW0pR48eRf/+/cEwDBiGQceOHfH666+jefPmeP3117Fr165Kr9Px48cxYMAAoU49e/ZE+/btUb9+fURGRuLu3btC3k8//RQeHh7Ys2ePRWVXh2uSih87YQuj5p6/iLvDRyH3/MWyM9sBlUqFL7/8Eq+99hrGjRuHkSNH4tdff8Wnn35aIu/Zs2etLp/jOFy4cEFYjouLQ4MGDdCzZ88KjehISkrC4MGD4ePjg6SkJHTu3BkMw6B79+5Wl2XKjt9++y369euHUaNGYebMmcLIg7CwMMyePRt79+4td91rMnrhY0hVCKDi521kZCTWrVtXq85bU2VHRkbCy8sLAQEB+Oyzz8BxXIXLLS/R0dF47bXX4ObmhoYNG+LHH38U1oWGhmLChAlG/7Ehtnxgrl+/HhEREfj++++xdetWfP/994iIiMCGDRtstg9L6NmzJz744ANh+d1338Xff/+NY8eOIS4uDoMGDcKECRMqtU7du3fH9OnTheU5c+bg0qVL6NmzJ6KiotCpUychSOH+/fuRk5ODo0ePWlx+lb+MkFpKs2bNSLNmzSpcjkKhIHfu3CEKhYKotRxRaLSkQK0l2XkFpECtJQqNlqi1nNXl8jxP7o2dQK6270TujZ1AeJ6vcF2tZeLEiaRt27ZEq9USQghRqVTk7bffJkFBQUb59u3bR3r06GF1+Z988gn58ssvheW///6bACAsy5KMjIxy1Tk3N5c0a9aMbNu2TUj74osvCADSrVs3q8rieZ4UFBQY/ffffPMNAUBu3LhBCgoKiEQiIW+99ZawPjMzkwQEBJATJ06Uq/41lRXXVpAWG1qY/ay4tqLS6lL8vFUqlWTcuHG15rwtjkajIe3atSMikYgAED5z586tULnlJTMzkzRs2LBEfTZs2CDkiYmJIb6+vuTevXtG25q6JsvLgwcPCMuyRnXQf1iWJdHR0RXehzUcO3ZM2P/69euF9HPnzgnpS5curbI6HTt2jBBCyM6dO4W0H374gRBCyOXLl8mcOXNIamqqReWW146Gz1tzWPpsp0EObQRPCBKyleAM1KzynQkgmZkAADFrXd8mr1KDy84GACju3MWt3q+CdSq/g5jYxwdNNq2zOL9CocCGDRvQunVrsKyugVAqlWLFihXo37+/kO/s2bOIjIxEq1atrKrP8uXLsXDhQsyZM0dI69+/P3744Qc0atQIXl5eVpWn55NPPkF2djbeeOMNIU1f/4qiUCjw7bffAgCCg4Ph4uKCwMBAbNiwAV9++SUaNmwIT09PDB8+HKNHj8b9+/eFwFw1hRF7RiBNkWbVNvmafORr8kvNs/zacmy4vQFyidzicn1dfLGl/xar6mLuvP35558xbNgwIV9tOm/37NmDmTNnYuTIkbh8+TJeeeUVZGZm4s8//8SXX35pk31Yw5YtW7BmzRr06tULBw4cwMCBA6HRaPDnn39i3LhxAICQkBC8+OKLGDNmDM6fP1+mb0j79u2RlJRkVT2ys7PNttTxPI82bdrAw8PDqjIBICAgAJcuXbJ6O3N07NgRwcHBiIuLww8//ICUlBR8/fXXAHStM9u2bYNSqcTYsWPBcRy2bNmCjz76CL///jsA4H//+x/mzZuHhIQE/Oc//zFqAV23bh2OHj2K1NRUXL16FZMmTcJXX31V6rmnUqmE3z4+Pjh69CiGDBmCrKwsMAyDOXPmYObMmfjpp58AABs2bMC3336LZ8+eYcyYMViyZIkQoDAvLw+zZs1CTk4OUlNTMWDAAKMWMHtCu71sBANALDK+QElmJkhaGkhaGjQpqVZ99MJHD5edbXUZhh9terpVx6NWq8FxHC5duoQBAwbgwYMHAHSTy02dOhWA7gEyfPhwZGVl4eLFi2jRogV++OEHAMDp06eFLgcfHx8MGzYMGRkZAIAVK1bg448/BiEEv/zyC1q0aIGTJ09i/PjxmDVrFgYPHmxUl0WLFqFXr17o2LEjunfvjvv375us87Nnz7Bq1Sr06NGj1Iv38uXLCA4ORuPGjbFp0yYcP35c6Nc2/LAsC5lMBpZlMX78eJw7dw65ubkAAGdnZwA6xz1CCA4ePCiU369fP8THx2PNmjVW/efVgTRFGlIKUqz6lCV89ORr8q0q11oRBpg/b11dXfHee+8BcPzz1vAzfvx49O3bF6NGjQLLsujQoQPGjBkDQPeQNoVGo8GYMWOEMv788088//zzkMlkGDRoEJ49e4b3338f3t7eqF+/Pg4cOABA95Arqz5z587FuHHj0Lt3bzAMg759+6Jfv34m69OvXz9cvHgRu3fvNkp3cnIqUeekpCQkJCRY9cnLyzP7XwO6B7O1ZSYkJFgtwiwhPDwcgK6LdcKECejQoQMAwNvbGz4+PggKCsILL7yAFStWwN/fH+PHjxe25TgO+/btQ15eHj777DM8e/YMgE74vP322xgzZgwOHDiAwMBAfPPNN9i6davZeuTn5+OXX34BALRu3RojRoxAz5490aJFCyEPy7KYNm2asHz58mWcPn0abdq0wfLly/HVV18B0Nlx8ODB2LVrF3777Td8/PHH+PDDD7Fz507b/GllQFt+bATDMPB1ESMht0gVM4VvgSwDsFZ4tRu2+hgi8vAod+uPuHDqDUvx8PDAiBEjEBUVhb1792Lfvn0YOnQo5s2bh4EDBwIAXnzxRUycOBHz5s1Dhw4dcPz4cQDAvXv30LNnT8yaNQsLFizAjBkz8PPPP8PHxwcrV67Eu+++iy1btuDEiRN47733MHfuXAC6m67+bUXPTz/9hNmzZ+Ps2bPIz89H7969MWnSJJw4caJEnbdv3w6tVouwsLBSj61JkyZo2rQp1q9fj4CAAGg0GqSmppbIRwxa8VxcXLBp0yZhWSw2vnQMnSSbNm0KANi8ebNRn3lNwNfF1+ptLGn5AQC5RG51y4+1mDtv586dW2vOW0OcnZ0Foa5HrVYDAMaOHWtyG4lEgvHjxwvHlJaWhtOnTyM0NBS7du1CUlISdu3ahZYtW2LSpEmYOXMmbt++jcjISKNWYVPIZDKz9dGLMj2G15HedoDpQHfmhFxpZGdnlyqAXF1dy93yY2t8fYuuhaSkJEyfPh1jxozBnj17kJaWBl9fX2RmZgr/meHUD6NHjxbuZYQQxMXFoW7dunj48CEA4MiRI3jllVeEVkt9enEWLFgAnufh7u6On376CRMnThRsWXyqCcP74wcffAAfHx+MGzcOJ06cwJo1azB37lycOXMGhw8fRt++fSGRSNCoUSMAwK+//opBgwZV6P+yBCp+bIhMIgLD8OB5FgwDOC/9RVgnZhl4OUvg7iSGqJQuMEIIHoyfCEVODmDoEMYwkAbVRfiGXytteOC6devg7OyMDRs2gOd5bN26FTt27MCCBQswa9Yss9vFx8dDo9HgyJEjAFDmRaWn+AWkVqvxzTffANC9ZXAch+eff97oLcOQixd1juGGN4riKJVKvPPOO1i7dq1wk5JIJCa3IYUjEpydncEwDDILuzCBkjfgrKws4XedOnUAAFeuXIFWqy0hlKoz1nYz6THl7GzI1NZTMaXVlPJWyyrMnbfz58/HRx99ZHY7RzlvS4MQgiNHjqB79+4YPXq0Rcf07rvvAtB19cbHx6Nfv37w9/dHSEgIgKL/x8nJyWSrTGnk5+fj33//xdixY9GtWzejdfrr6Pz580bp+mvSkPJ0M0VHRyMiIsJk1xfLsrh69SpCQ0OtLtceGHY1eXl5YejQoZgxYwYyMjKwYcMGDBo0CM2bNze7veH9Sj9AY+7cuejbty8CAgIwa9YsxMTEAAC0Wq3JMj799NNyOd/rWzODgoIA6MRbWloazpw5AwC4e/cuPvjgA6hUKnTs2LFcgrM80G4vG5KqSIWGT4EpbaLlCVIL1IjNKkBKvgoaznRfM9FooElKNhY+AEAINMnJIDaY08QSlEolNBoN1q9fj4sXL+K1114DoLtwPvroo1KH4/bu3RuXLl1CVFQUvvvuO6HZ2txFZY6HDx8Kb7Ycx8HV1RXnz5/H8uWmH7LJyckAYNbPRq1WY/DgwdiyZQsePXokpJ86dQqurq4lPm5ubqhTpw7c3NwwZcoUyOXmWy3c3d2F3/obs1qtRrqV3Y01lSmtpmBq66km11Wm8CntvJ09e3atOG8NP1OmGP/vW7duBSEEW7dutdqnqHh+/bL+wfzHH3+UWZ/58+cblbFs2TI0bdoUK1eWHBGov44SExOtqqelhIWFYe3atWBZFiKRyOh77dq11Ub4AEUCMyAgAOHh4XB2dhZa7lavXo2tW7dixIgRFpWlbwWSSCT4999/0bVrV4wePVo4XmKnUViGglrvLgDofPKWLFmCFStW4Ny5cyVaUe1FzXklreakK9KRxWUBAHiiAss4gScq8MgECw+wjEvhOiBLqUWWUgtXqQhezhI4i1lBmbNSKcI3roXWoCVBj9jLC2wlRcVMSkrCnj17MG3aNLRv3x579uzBqVOnMHjwYKSlpWH37t3o1auX2e1TUlIwaNAgfPXVVxgwYACuXLli9UVl+LZz48YNvPjii6Xm19+Mze3nwYMHaNu2LQghmDhxIq5duwZnZ2e0b98e165dK5GfEAKVSgUnJyd4eHjgypUrwjqe540eBvrmZv06PbUpGJte4Bi2AFWm8AFMn7cnT57EkCFDas15a4ihKE9ISMB3332Hw4cPC60qOTk5RnkqwsCBA9GxY8dS83h7ewu/r1+/jh07dmDfvn1wcXEBx3FQqVTC5JX668ie19D48ePx0ksvYe3atYiLi0NwcDDefvvtaiV8EhIScOPGDQDA7Nmzhf9j0qRJWLJkCaKjo3Hr1i2rWwF/+eUX/N///R9mzJiBNm3a2LzexdG/CAYEBMDX1xdNmjQBoBN2N27cQMuWLQEAd+7cQbNmzexeH9ryYwNy1bnIUGYIyzwyQYhG9w0lOCRDQxIgFWlheBnnqTnE5ygRn6NEjkpbpIQD/CGLaFLiI/X3q9TjWr16tdAfDwBdunTBokWLAEBomjT19njt2jUMGjQIvr6+ZmNTWPLWGRYWJrz9rV69WkjPy8sz+aCoV68eAN2IH1O0aNECv//+O7y9vXH//n3MmzcPgO6NOzQ01OQnJCQEoaGh8PPzQ5cuXeDq6irUQQ/DMHj55ZeFZaVSCUDXDWB4s68N6FuAGDCVLnz0mDpv9S0OteW81X/8/HT3DJVKhQkTJmDevHnIzc3FjRs3sHDhQly+fBmArgVmxowZQitUeXBzcyuzPvrrISMjA++//z6+++47JCQk4Nq1a5g1a5bR/vXXUd26dctdJ0sIDQ3FggULsHnzZixYsKDKhI9h3CX9b6VSialTp4LneYwePdpoJFTTpk3RtWtXACjhI1O8LFNl79u3T/heuHCh0LqUmZmJp0+fAjCePb20mdT1ZZqKHbVli64rff/+/QCAiRMnAgD69OmD0NBQ8DyPwYMH43//+x+WLl0qnJP2hoofG5CrzjVaJlBCiwQQKA1SNcjXPkUjLxf4uEggMnibUWp5JOWpEJulQIZCDY6vHpFob968iUmTJhndlJ88eQJfX19MnjwZQJGfQnJyMpKTk3H8+HEcOXIEGo0G0dHRWLhwoTAaJDc3F3FxcUbbJSYm4vz584iPjy9xgcrlcsFheOPGjfjwww/x66+/4j//+Y/J+urfsItHWda/QXIcBz8/PyxevBiAbjROWb4Chr4Fcrlc2Hd0dDTUajVSU1Px5ptvIjg4WMin33+HDh1qlL+PrZjSagpujLtRJcIHMH3eJiYm1qrztjiTJk3CwYMHMWDAADz33HNo1aoVPvnkE7Rp0wY3btzA+++/j59//lkYyWnqYWlYH8C4O9CagIkajQbDhg3DqVOn0K1bNzz33HNo06YNNm3aJDi9AkX/R6dOnYy2L+7v4wgcPnxYGBoOAPPnz0dkZCS6dOkCANi5cyd+++23EuJ70qRJcHNzM3II13f76tm4cSPWrVtntKxWqzFu3Dh4eHiAZVmEhYVhzpw5kMlkuHDhAkQiEY4cOYIlS5YI2/34448mu42PHj2KW7duAQAOHDgg+A7pIYSgTZs22L59O9577z0hTIRcLseePXvQs2dPJCQk4P/+7/+g1WpLOL7bDasiDDkQtgxyeP7aeXLj2Q1yK/VWqZ/H2Y+FoE4cz5MshZrEZRaQ+2l5Rp8HaXkkOU9JVOUIjmgrYmNjyZtvvkkWLVpEhgwZQt555x0yYcIEMnr0aBIXFyfky8nJIX369CEuLi5k2LBhRKFQkHv37pHg4GDi7+9Pvv76a3L+/Hni5+dHGjRoQE6ePEkIIeTmzZskIiKCuLm5kf/+978kOzubjB49WgietWTJEkIIIWq1msyYMYN4eXkRDw8P8vbbb5OcnByTdc7MzCRyuZwMHTpUSEtISCDPP/88AUC8vLzIuXPnyL1794hYLCYASEhICLl27ZrJ8nieJxzHGQXi4nmezJs3j7z00kvk9ddfJ7NmzSJqtdpou3/++YcAIKtWrSrfn08pN6bO27feeou8+eabJDY2VsjnyOdtcRYsWGAykF/jxo0JIYRkZ2eTpk2bEj8/P9KsWTOi0WjI2LFjhXzLli0jp0+fJh4eHgQAadeuHblz5w4ZPny4kGfNmjUW22jy5Mkm69OzZ0+jfL/88gsBQA4cOCCkmbomazPZ2dlGQVarC7GxsYJdDa87PeW1oy2DHDKEVHWM6apB7xl/+/btCpWjVCoRGxsL9wB3weenNCQiCXxdfOHp5AmWYUEIgULLI1OhQb6m5NuTXCKCl4sELgZ+QRTzfP311/jhhx+QnJxs9ciT4pBio70sZcaMGdi/fz9u3rxZ5TMXU8pvx8rEludtebl06RJ++OEHbN68uUr2X5xBgwYhJycHx44dE9Jqgi3tTVpaGlauXInp06fj8OHD8PHxKTFSrqqJi4sTWvFiY2ONWsaB8ttR/7xt1KiR2RZAS5/tNun2unLlCj755BP89NNP2L59e4mhibUBHxcf1JHVMblOwkqE3xpOg8S8RMRkxiBdkQ4CAplEhCB3ZwR7usDDSWzkF5Sv4fA0R4kn2UrkqDTga6dWtZhPP/0UrVu3rrIAg2lpafjrr78QFRVFhQ/FYqr6vCWEYM2aNfjiiy+qZP/FuXv3Lq5cuWIUW4uiY+PGjfjiiy+wc+dOHD9+vNoJH8B0t2l1wybip23btpg5cyaePXuGkSNHonPnzrYotsbhJ/MrIYDqyOog3DscwR7BRgHeNLwGSflJiM6MRpoiDTzhIRWx8Hd1QmMvGXxlxn5BKo5HUp4asZkKpBdUH7+g6oZYLMaePXtw8eJFwaGvskhLS8P06dPx559/VsroCYrjUJXnLQCsWrUKH374YaWMsimL2NhYzJkzB4cPH0b9+vWrujrVjn79+qFhw4b49ttvK88/xgp4njcK67B06dIyg3FWBTbv9tqwYQPefvvtaqv29Ni628uwGS6lIAWpBamoI6sDP5nxCK0CTQFSFanIUxtHFhWxIvg4+8Db2RsiVhcPgScEeWoOmQoNVMXiAjEA3J3E8HKWQCqmfuumuH79utVzNxlCDIa6W9I0GxMTg6CgoBo3n5ejY60dq5qKnrc1nbt37yIsLMzkYIGaZkuKacprR1t2e9nF56devXrCULnqij3FjyUotAqkFqSWGCkmYkXwdvaGj7OPIIL0fkFZSg3y1Kb9gjydJZBJqF8QhUKhUBwTW4ofu4zDbdy4sT2KrTEQQoQgeObEiIvYBQ3cG0CpVSJVkYocVQ4AgOM5pBakIl2RDm8XnQgSs2LIJCLIJCKoOZ0IylZqoVet+RoO+RoOTiIWns5iuDmJrZpLjGIaS+xIqf5QOzoO1JaOQXWwo0X9JYZj/S2hNsY2KY5hkLXScBY7o75bfYR6hsLDqWhOE57wSCtIQ3RmNJLyk6DldTE1pCIWfvIivyAxa+wXlJxf5BekNTFnDcU6LLUjpXpD7eg4UFs6BlVtR4vEz9KlS60qNNvEjOSU0nESO6GeWz2EeYXBy9kLTOGYL57wSFek40HmAyTmJ0LD6aJsilgG3i5SNPJ0QaCrE5wN/H44QpCu0CA2U4GkPBVUWiqCKBQKhULRY1ETTWxsLLp27YqQkJAym6iSk5PLnG+GYh6pSIq6rnXh6+KLNEUaslRZIISAEIIMRQYylZnwdPKEr4svpCIpGIaBm5Ouq0uh4ZBp4BdEAOSotMhRaSGTiODlLC6ceZ42F1MoFAql9mJx/9SZM2eEKehLgxBCH66wbA6g0tCLoDoudZCmTEOmMlMQQZnKTGSpsoxEEAC4SERwkYig4XhkKjXIUWmhHxFfoOFQoOEgFTHwcpZQvyALqagdKdUDakfHgdrSMahqO1osfmppIOhywTCMzaK0SkQSBMoD4evii3RFOjKVmeAJL4ggw5YgJ7FT4TY6vyAfFylyVFpkKjXQFqogNUeQnK9GWoEGHs5ieDqLIaY3E5PY0o6UqoPa0XGgtnQMqoMdLRY/o0ePRuPGjcts1cnPz8eGDRsqWq8aDSEEHMdBJLJdF5OElSBAHiCIoAxlBnii8+XJUmUhS5UFDycP+Lr4wlmsGwIoYhl4uUjg6SxGnppDllIDRaH/D0cIMhQaZCo0cHMSw8tZDCexyCZ1dRTsYUdK5UPt6DhQWzoG1cGOFomfpk2bWhVm3MvLq9wVchQ0Gg1EonKKiax4oCC9ZLrMB2LP+vCX++tEkDIdGYoMcETn45Otyka2KhvuUnf4ynzhItYF2zP0C1IW+gXlmvALcpGw8HKWQO4AfkEcx+HYsWPo1atXhcqpkB2rmMOHD6NHjx6VVv+UfBWyldoS6Z7OEtSRV+1UHzXFjrY6b2sy586dQ7NmzeDu7m5yfU2xJaV0qtqOFvV3rF692qpC33zzzXJVhgKd8FnWDljdreRnWTvdeuiCIfrJ/BDmFQY/mZ8QEBEActQ5eJT1CE9ynqBAU2BUvLNEhEA3ZzTydIGXswQGI+Wh0PB4lqvC42yFrpVIocSXX36J1157DePGjcPIkSPx66+/4tNPPy1R7bNnz1p9qBzH4cKFC8JyXFwcGjRogJ49e4KvwDD9pKQkDB48GD4+PkhKSkLnzp3BMAy6d+9e7jIN4TgOW7duxQsvvIDjx4/bpMyKkJOTg8WLF6Nhw4ZG6T4+PhgyZEilhJZXczym/XMH75n4TP3nDtRc5Y04VKlURudtZGQk1q9fX6vP24KCAnz44YcICAiAl5cXJkyYgIKCgrI3tBNpaWl466234OPjA39/f8yePVv470JDQzFhwgSj/5hCsTUWiR9L5upavnw5tmzZgqtXr8Lb27vCFau1FKQDWpXpdVpViRYhEStCHVkdhHmGwV/uDzFb1JiXq85FbHYsHuc8Rr4m32g7iYhFHbkUjT1l8JNLITFQQWqOICVfjfGT38Xfu3Zj+46/sXHjRmzatAnnzp3Db7/9ZlTW/v378fnnn1t9qJ9//jn++ecfYfn69euIj4/HiRMnyh0uIS8vDy+//DLGjh2LNm3aICAgAC+//HK5yioOIQTr1q1D69atMWLEiCqfwDc9PR3fffcdGjVqhFmzZuHJkydG69u0aYMhQ4agT58+UCqVdq2LhGVQRy5F8fZCBkAducTo/LI306ZNw549e7Br1y5s3LgRGzduxIULF/D7778b5atN5+2oUaPw4MEDeHt7IysrC+vXr8e8efNsUr61KJVKDB48GOnp6XB3d0dKSgoWLVqEVatWAQB8fX2xcOFCvPbaa7h//36V1JHi+FjU7TVhwgQAuu6Ttm3bYurUqSXyjBs3Dt9//z0iIyPBsiy02pLN37UJkUgErO4O5KVYtyFXRuCn34cAopJdCCIAvgB8oIsNpPMHKnJS18p8EDd6C3xdfCGXyIVuLZZl4OksgYeTGPka3TxiCi0PpUKBvzb/jogWLfE4RwV3Jw5eLhKsWLEC/fv3F8o9e/YsIiMjrZ6LaPny5Vi4cCHmzJkjpPXv3x8//PADGjVqVO6u008++QTZ2dl44403hLSKjCowbJZlGAbjxo1Dy5Yt0aFDh3KXaSs8PT3x8ccfg2VZzJ4922SeyMhIfPjhh/jiiy/w/fffl1nme3tvI1OpKVd91ByP4sMiCICkPBVG/XXd6vK8nCX45bXmVm2jUCiwYcMGtG7dWrC7VCrF8uXLMXjwYCGfo5+3hly5cgXffPMNmjdvDp7n0atXLxw7dgz37t2zSfnWcvr0aWzevBlBQUFQKpVo3bo17t+/b1SfkJAQvPjiixgzZgzOnz9v1A1Pu7wcg6q2o0VX14YNG3Dz5k3MnDnTpPABAFdXV8ybNw9ffPFFrR8ZxjAMpFIpmLwUIPeZdZ+CtNILL0grdXsm9xlEeUmQ5KdAkp8qfMQF6cjX5ONxzmPE5sQiV51rZCeGYeAqFaO+hwsaeDjDmeHBcRxuXbuCKaOG4cade3iSrURSgRYTJk0BIQRnz57F8OHDkZWVhYsXL6JFixb44YcfAOhucPouBx8fHwwbNgwZGRkAgBUrVuDjjz8GIQS//PILWrRogZMnT2L8+PGYNWuW0UMKABYtWoRevXqhY8eO6N69u9m3wWfPnmHVqlXo0aNHqQ+Oy5cvIzg4GI0bN8amTZtw/PhxMAxT4sOyLJycnMCyLMaPHw9Ad8H6+vqWdQoAALKystC3b18wDIPg4GAsX74cLVu2hFwux8SJExEfH49x48bB1dUV4eHhuHr1KgBg7ty5Jutj+NmwYYNw8yitPmKxGL169bJ4ZuVMpQZpBeX75KhMT2aco+LKVV55RJharQbHcbh06RIGDBiABw8egGEYyOVy4d7l6Oet4Wf8+PFo166dMN8Ry7J47rnnIBaLzd7LNRoNxowZI5Tx559/4vnnn4dMJsOgQYPw7NkzvP/++/D29kb9+vVx4MABALrnRFn1mTt3Lnr16oWgoCAAgLOzM5o0aQK5XI63337bqB79+vXDxYsXsXv3biFNuLfWcJ/E2k51sKNFLT8ikQjbtm0r4VNgilmzZmHRokUVrlhNhhACrVYLsatfiW6AMuHUpQsgma/Jlh+zdQFAwINzKXojVWgUeKJ5AhexC3xdfOEmdTM6CZ3FIoQH+WHY8OHYumULjh/aj5NHDuKVAa/j/U8+Q5vufRCXpUDTNh3w9ttv46uvvkKHDh0E/5d79+6hZ8+emDVrFhYsWIAZM2bg559/ho+PD1auXIl3330XW7ZswYkTJ/Dee+9h7ty5AHQ33eJdEz/99BNmz56Ns2fPIj8/H71798akSZNw4sSJEse6fft2aLVahIWFlfqfNGnSBE2bNsX69esREBAAjUZjUhgIdhSLyzVTu6enJ4YNG4YDBw4gISEB9evXx4kTJxAUFIS1a9ciOTkZmzdvRr169TB//nx8/vnn2Lt3Lz7++GNMmzat1LLd3NwsrkfTpk2xZcsW/PXXX5g8eXKpeb2cJRaXawo1xxuJIHcnEaSi8rVglKcuHh4eGDFiBKKiorB3717s27cPQ4cOxeeff44BAwYAAF588UVMnDgR8+bNc8jz1pDikz9euHABGzduxKBBg9C1a1eT20gkEowfP144prS0NJw+fRqhoaHYtWsXkpKSsGvXLrRs2RKTJk3CzJkzcfv2bURGRhq1CptCJpMZLe/Zswf79u3DlClT0KJFC6N1TZs2BQBs3rwZAwcOBGB8TVIBVHOpDna0SPw0a9ZMED6LFy/GmTNnEBsbK6wPDg5Gt27dMGPGDLi7uyM4ONgula1JaLVaiCcdB6w17LNrOudmc4zeDtRtbXFxTOHHiRAEqbORVpAGFafzKVJoFYjPjYez2Bm+Lr5wl7obnYgb1q+HzMUFGzZsAM/z2LfzLxz+Zzdmfj4PE6ZOR2qBWng7N2zsi4+Ph0ajwZEjRwAUjf57+PBhqXUt3gyqVqvxzTffAABat24NjuPw/PPPl7hJ6rl48SKA0ltClEol3nnnHaxduxYBAQEAdDd7U9sQQqBUKuHs7FzuC1R/TEFBQcIN3NfXF/Hx8RgyZAhcXV0REhICoOj/kclkJR4SFaFOnToAgPPnz5cpfqztZioOIQTT9t3Bg/QChPvIsKxfs0q/ua1btw7Ozs7Cebt161bs2LED8+fPx0cffWR2O0c5b82xfft2vPfee8jOzsb27duhVCqxZ8+eMo/p3XffBaC7z8fHx6Nfv37w9/cvcd46OTlZFbtl2bJl+Oyzz6DRaLB06VJwHIfly5cL6w3PW0P0D01Kzaaq7WjRK5mhA/PMmTOxbds2DB06FNeuXcPQoUPx119/YcaMGUIef39/29e0tiDzAcRmbiBiJ936csAwDDydPBHiGYJ6bvWEWEAAoNQq8TT3KR5mPRSm01AqldBoNFi/fj0uXryI1157DYDuLXfhl//B2RPHABSJHqWWQ2KuEgoNh969e+PSpUuIiorCd999JzRbW+sH9vDhQ+HNluM4uLq64vz580Y3SEOSk5MBwGwrjVqtxuDBg7FlyxY8evRISD916hRcXV1LfNzc3FCnTh24ublhypQpVtW9NIp3beiXVSqdKJ0/f77J+hh+/vjjD4v3p3/7T0xMtNERmIdhGLzdph4aeDjj7Tb1Kl34lHbezp49G4cPHza7raOct4Yfw/N2yJAhePTokeBXtHfvXty9e9fi4yrrvP3jjz/KrM/8+fOF7adNm4aYmBhhQM3KlSuRn180MKMyz1tK7cMi2SWRGDc/MwyDTz/9FEuXLsV//vOfEvnT003EqKFYhmd9YNpls3F+4Fm/QsUzDAMPJw+4S92Rq85FqiIVSq1uJJCKUyEhNwGpolQUpBTg5MGTeP/999G+fXvs2bMHp06dwuDBg5GWloZLxw6ib5/eRmXnqjnkqjk4i1nEJSRi0KBB+OqrrzBgwABcuXLFal8w/U0VAG7cuIEXX3yx1Pz6m7G5/Tx48ABt27YFIQQTJ07EtWvX4OzsjPbt25ucj44QApVKBScnJ3h4eFhV9/Kgr/eUKVMwfPjwUvNa84KhH0JcWUKkbaAH1g58rlL2VZykpCTs2bMH06ZNE87bkydPYsiQIUhLS8Pu3btLjaGTkpJS489bQ4rHypHL5fjtt98QGhqKpKQkI7FRUQYOHIiOHTuWmqf4SOA6depgy5YtCAkJgUqlgkKhgFwuB1D55y2ldmGR+Ll06RJ69uxZIl2lUhmlE0KQmppq1duEo1IhT3bP+hUWOWXBMAzcndzhJnVDniYPqYpUKDQKAICaUyM5PxnLVi7DsHHD4OfmB5Zh0aVLFyxatAjjx4+Ht5cnAlyd4CN30hcolH316jVEDh2M0CYReCNyDH789r8l9m/JSJawsDA4OztDqVRi9erVwkMkLy8Pcrm8xE2xXr16AHQjfkzRokUL/P7772jatCnu37+PefPmYcGCBXBxcUFoaGiJ/IQQaDQaSCQSi27AHMdh/vz5KCgowGeffQZXV9cytzGFt7e3TcNF6Ie5161b12ZlVmdWr16NSZMmQSrV+cZ16dIF3377LSZOnCiIWFPn37Vr1zBo0CA0a9YMEyZMEHx6DKkJ521xFAoFeJ4XRIVcLseLL76IkydPomXLlgB0XVDR0dH4z3/+U+6Wezc3N4t80XJzcyGVSoUusqCgIDRv3hxardaoG8/ceVvVo4QotqGq7WhRt1dWVhZOnDhR4pOdnW20fPLkSdy5c8feda72VAdPdkthGAZuUjc0cm+EYPdgyCVyYd2DOw8wZdIU3Hx2E+mKdPCEx5MnT+Dr6yv4jvgV9svnpKeCycvElX9P49+Tx6HRaBD36CG++fZb7P5nvy5Pbi7i4uIAFPk3JCYm4vz584iPjwfHFTnKchwHuVyO6dOnAwA2btyIDz/8EL/++qvJ1kYAwkMmJcU4vID+DZLjOPj5+WHx4sUAdKNxLl26VOp/Y8qOhjFzDN/y9+7dizlz5uDbb78VHpz6YzI8NsP6AEXdKoZ5rMFcffTo/49OnTqVq/yaxs2bNzFp0iRBTDAMg2fPnhmdt/rzLzk5GcnJyTh+/DiOHDkCjUaD6OhoLFy4UBjFlFvDztvi9OnTB/Xr18fff/8NQCeG7ty5g5UrV0IqleLGjRt4//338fPPPwsjwIofU/H6AMbdgdacu82aNUNYWBhOnz4tHHdSUhJWrlxplM/UeVuT7q0U81QLOxILYBjGqg/LspYUW6U0a9aMNGvWrMLlKBQKcufOHaJQKIQ0nueJSqUiPM9XuPyqIE+dR07dOEVeG/oa+WjeR6R3/95k6JihZMibQ8iwyGHk4aOHQt6cnBzSp08f4uLiQoYNG0YKCgrIlRu3SP0GDYmvnx+Z8ekX5M+Dx4lPnTqkbr365K/9h0iBWktu3LhBIiIiiJubG/nvf/9LsrOzyejRo3WD0wCyZMkSQggharWazJgxg3h5eREPDw/y9ttvk5ycHJP1zszMJHK5nAwdOlRIS0hIIM8//zwBQLy8vMi5c+fIvXv3iFgsJgBISEgIuXbtmsnyTNlx586dZMSIEUI9e/fuTfbu3UsIISQ2NpbUq1eP+Pn5kVdffZVkZWWRfv36EQCEZVmyc+dOsmPHDiISiQgA8sorr5A7d+6QHj16EABEJBKRffv2WWynrKwssnnzZtK6dWuhPtOnTyeXLl0yyjd8+HAik8lIRkaGxWXXVGJjY8mbb75JFi1aRIYMGULeeecd8tZbb5FRo0aR2NhYIV/x81ahUJB79+6R4OBg4u/vT77++mty/vx54ufnRxo0aEBOnjxJCCHk5s2b1f68Lc6vv/5KGjduTCQSCenSpQuZMmUKOXPmjLA+OzubNG3alPj5+ZFmzZoRjUZDxo4dKxzTsmXLyOnTp4mHhwcBQNq1a0fu3LlDhg8fLuRZs2aNxTb673//S4KCgohUKiV9+/Yl06ZNI7dv3y6R75dffiEAyIEDB4S0mn5vpegorx1NPW+LY+mznSGk7A7tiIgIzJo1S2hGLo28vDwsXry4zBESVY0+7sXt27crVI5SqURsbCwaNWokOOgRG4wSqg4UaAqQpkhDrjrXKF3EiuDj7ANvZ2+jaTWKo9LyyFJqkKPSlgh+5yxm4eksgZvUtvOIff311/jhhx+QnJxc4VmDy2vHbdu24fLly1iwYEGF9m8LNBoNAgMD8f777+PLL7+s6upUCTXherTleVteLl26hB9++AGbN2+ukv0XZ9CgQcjJycGxY8eEtJpgS0rZlNeOpp63xbH02W6Rz8///d//4a233rKqgpSaj0wiQwNJAyi0CqQVpCFHnQMA4HgOKQUpSFekw9vFGz7OPiZFkJOYhb+rE3xkEmQrtchSasEVam2llkdSngppLANPZzE8nCQQ2WAKhE8//RRHjhzBmjVryoyVYw/UajX++usvLFmypNL3bYqNGzeiRYsW+Oyzz6q6KpRSqOrzlhCCNWvW4Isvvqj0fZvi7t27uHLlSrnmXqNQLMEin5/ikUvLQj8dBsUxcBG7oL57fYR4hsDDqWjUE0c4pBak4kHmAyTnJ0PLmx4SLGZZ+MikaOTlggC5FE4GQe+0PEFagQaPMguQkq+q8ASYYrEYe/bswcWLF7Fv374KlWUtKpUKK1euxPfffw8/P79K3bcpDh06hJMnT2LPnj00Lko1pyrPWwBYtWoVPvzwQzRr1qzS912c2NhYzJkzB4cPH0b9+vYd+EGpvVjU7WUJDx8+RH5+Plq0aGGzOWnsib27vao6eqU9UWlVSFOkIUuVZZTOMiy8nL3g4+IDCWs+Oi8hBAotj0yFBvmako6ScokIXi4SuIjZCv1/169ft3rupuL1rMl2vHHjhjCapzZT0+xY0fO2pnP37l2EhYWZFOw1zZYU05TXjrbs9rJYpdy5cwfjxo1Dz549MXXqVFy4cMFoff369bFs2TJ4eHige/fulhbrkDAMY/Hw6JqIk9gJQW5BCPMKg5ezl3CcPOGRrkhHdGY0EvMToeFMz83EMAxkEhGC3J0R7OkCD2ex0TQg+RoOT3OUeJKtRI5KA76c+ryiD5CabkcqfHTUNDvWZuED6Ka1MNdSWdNsSTFNdbCjRS0/Fy5cQI8ePUr48owYMQIrV64UAmnduHEDrVu3BsMw5R62W1nYu+XHmvgwNR01p0a6Ih2ZqswSk6V6OnnC18UX0jLmI+N4gmyVBllKLbS88SkpYnR+QZ7OtvELspTaZkdHhdrRcaC2dAzKa8dKb/n55JNPoFAoQAgx+kRFRaFDhw6IiYkBgCobpVAdKK4hq7v4syVSkRSBroEI8wyDt4u3cDITQpCpzERMZgwS8hKg5tRmyxCxDLxdpGjk6YIAVyc4iYtOTY4QpCt0fkHJeSqotRXzC7KG2mRHR4ba0XGgtnQMymNHG3npALBQ/Fy4cAEMw6Bx48Y4deoUCgoKEB0dje+//x4ajQadO3fGlStXbFapmoR+6o+CgoIqrknVIxFJECgPRLhXOHxcfMAyhWH7QZClzEJ0ZjSe5j6FSlsyEJ8eXeRpMRq4O6O+uzNcpUWjyAiAbJUWcdkKJOQoka/W2vRioFAoFEr1Rf+cLT7lVnmwaAiIn58fHj9+jB9//FGYhC4kJASzZs3CtGnT8Omnn6JXr17VZnhvZSISieDp6SlEI9XPxq2PtFtbm2Y9RZ5wdXFFlioL2cps8NC11mRqMpGZlwlXqSu8nbzhZG4SV+hmo/eWAK4sg1yVFrkG8YJy1EBOPiAVsXB3EkEuFYO18X9NCuf2AmqvHR0BakfHgdrSMbDWjoQQFBQUICUlBZ6enjaZGsMi8TNy5EgsXLgQgYGBJdY5OTlh8eLF6N69e60d4h4QEADAODw9z/M1YtRbpUAAhUaBfE0+eKITQSlIwSM8grPYGW4SN0hEZSt5vnCUmELDgSvmF8QyDFwkLGQSkU1FELWjY0Dt6DhQWzoG5bGjp6en8LytKBY5PBcUFGDo0KEICAjAunXrzOZ78OABBg0ahAcPHpS7X3b//v1YvHgx3nzzTYwbN67UvCkpKVi+fDn27dtXYvRZWdjK4dkQjuOg0Zge4UTRRYz+J/Yf7IzZiWxVttG69gHtMaLJCDTxblJmORxPcDkxGwcfpuFRpvFkkGKWQad6nugT4osgd9MOcRQKhUKpWUgkEotafCx9tlsc54fneWzbtg2urq549dVXzebLysrCyJEjsX//fkuKFdi2bRt++uknYbK79evXY/z48SbzPnnyBL/++isWLVoEhUKBhg0bChMPWoo9xA+y4oGCdPCE4NmzZ6hbt66uFULmY/dZ2msSBZoCbHuwDRtub0CqItVoXafATpjcajLa+bezqKw7qXn4624STj3JRLHGILQLdMeQpgFoX9e9XE3kPM8jLi4OwcHB9E2zBkPt6DhQWzoG9rSjzcWPveE4DpmZmahTOEt4aeKH4ziIRCJMmzYNy5cvrx7iJyseWNYOMOXMK3YCpl2mAqgYKk6FHdE7sPbWWiTlJxmta+/fHpNbTUbHgI4WCZfkPBX+vp+Mf6LTUFAscGIDD2cMaRqAlxv5GI0iKwuO4xAdHY2wsDCb9DFTqgZqR8eB2tIxsKcdbTq3lyV89913IIQgPDwcYWFhaNGihVXbi0Qi+Pr6WpwXgMX5K4WCdNPCB9ClF6RT8VMMJ5ETRkaMxJCwIdj5cCd+vfkrEvISAACXki/h0sFLaFWnFSa3nIyXgl4qVQT5uzphcrsGGNMyCAdi0vDXvWQk5ens8SRbiR/PxWHd1afoH14HA5v4w9ul4qMFKBQKhVIzsUj89OzZE4BuJFO/fv0wderUEnlmz56NDRs2YOTIkeA4Dlqt6XmeqgqVSiV4lwO6ZrfiwRgZhgHLsuB5vkSwPlPpLKubfoHneRCeR2n6lT/+LZg2bwKNu4MXy4zW6Zv9eN44fo1IJAIhxChdXxdz6ZbW3aJjMpFe3JfLXN2tOSYRI8LQ8KEYGDIQex/uxdpba/E49zEA4Hrqdbx35D00826Gd557B93rdQfLsmaPSSYRYVCTOngt1AfnErKx414KbqXmAdANk//jZiK23k5Ct4ZeGNIsAKHecrPHxHEceJ4X1td2O9XUY9LbEYDDHJMeR7KTNcek34cjHVN5614Tj0l/TfI8D5FIZLdjKg2LxM/x48fRt29fbNiwwWxrC8MweOutt5Cfn48ZM2ZYXIHKYsGCBZg3b55Rmo+PD6Kjo4VlDw8PBAYGIjk5GdnZRQ65vr6+8PX1RUJCAvLz84X0gIAAeHp6Ii4uDkzSEzQqZf/sg33Ag30gIikUddogv25n5AV2hsatHsLCwqDVahEbG1uUn2URHh6O/Px8PH36VEiXSqVo3LgxsrOzkZRU1FUkl8tRv359ZGRkIC0tzSbHpFYXBSWsV68eXF1d8fDhQ6OTulGjRhCLxUb/I4ByHVNBbgGa8k2xsOlCnMs4hx2JO/A4XyeC7mTcwYcnPkRDWUOMCR2DYa2HlXlMfgAmBzPIj6iPg/H5OP44AzwBNDzB4dgMHI7NQOsAN7zgzqGpOyuMEtMf08OHD6HVavHw4UMwDEPtVEOPSX8jZlnWYY4JcDw7WXJMubm5RtekIxyTI9qprGPSz+2VlpZm82NSqVQWBVy2yOfH2dkZ8fHxgj9OaahUKvj6+iI3N7fMvCYrVPgAKs3nR8/cuXMxb948i3x+irf8dOyo8yW5efOm0b7LrayfXYPo1x5WHKkO4hMGhL8ChL8CPuh5wGDId21/WyAgOPb0GFZdX4X7mfeNymns0RgTW0xEn4Z9IGbFFh1Tcp4Su+6n4J+YNOSpjY8jyM0JrzfxQ+/G3sjTEGQrS84p5u0iRR25lL7V1bBjyrtwCc8WL0G9j2bC9fn2DnFMehzJTvSY6DHZ4pj0cxraxOG5Xbt2uHz5MgBg8eLFOHXqFE6ePAlCCBiGQZcuXdCjRw+hxadVq1a4fv16WcWarpCdxE9xbO7w/OwasLqb+fV9FwLp0cCDA0B2vOk8Th5AaE8g7BUgrDcgr0Y+TVUIIQQnnp7AquurcCv9ltG6Bm4NMPG5iegf0r/UmeQNUWg4HHqUjr/uJiEh19hPy1XCQssDSq7kFBpezhL8PrglpCI6yqQ6QzgOXEEB+PwCcPn5iPvkM6jiHkPasAEafPEfsGIxIBaDEYnAiEVghN9iQGSwLBKDEYt0aTSgXrWA4zg8fPgQISEh1OG5BmNPO9rU4dnDw0P4PXPmTMycORO///47xo4di40bN2LMmDFG+X18fKytb6msX78ef/75J+bNm4cOHTrYtGybIfPRjeoyN9or4jWdw/Ori4CUu8CD/UD0QSD+PFAY+A+qbOD2Dt0HDFCvvU4Ihb8CBDwH1NIbMMMw6F6/O7rV64azz85i1Y1VuJpyFQDwJPcJ5pydg1U3VmFCiwl4PfT1MidRdZGIMLCJH/qH18GFhGxsv5OEa8m6lso8jel5wxgAdeQSSCpxYtXaBK/RCGKFLygwEi98QQG4/ALw+fm6dIN1wnJBAbg8XV6+2ATMetSPnyBm4pTyVVAvlAoFkWmxVCytWH4YiCyT+Q22K5Fm8G1UfvE0kQkxZ2H+miDy8i5cguLb75D3ycfw6NSxqqtDqQDFW5IqG4tafvr06YODBw+WSG/cuDEePXpklKbRaNCiRQvcv3+/RP6yUCqVcHFxAQCsXLkSkydPBgC4ubkhLy8PAwYMwK5du4T8n3zyCRYuXIiAgAAkJiZatS97xvnheB5PnjxBgwYNIGLZ0uP8FGQAMUeA6ANA9CFAmWU6n1tdILyPTgw17gZI5bardw2DEIJLyZew8vpKXEgyDm7pL/PHWy3ewpCwIXAWWx7kMCajAH/dTcKxuIwSs8rrmd8zDB2CPCtSdYeBEAKiUulESUGhSMkvFC0F+YViRS9i8ovEjJllQoODVg9MtIYZCTdT4spQ5JkRhKaFXun5UVwQsiye/bwc6vinkDaoj3qfzAarF20sC4Zlhd9gWV0ZLAtGxAJsYR79b1FhHlYEiNjCdYX5Wdqya2+y/z2PuG+/Q7AdRKxN4/zIZDKTIaWTkpKM0gkhyM7ORnZ2ttURno8cOYK///4by5YtAwC0bdsWH3/8MUaMGIFJkyYhKioKy5Ytw9ixY5GYmIjDhw/jiy++wOPHOofYr776CsOGDUNERIRF+7OL+Cmk3DEMOC3w9GJRq1DKHdP5RE5Aoy5AeF8grA/g1dA2Fa+BXE25ilXXV+HMszNG6b4uvhjffDyGhQ+DTCIzs3VJ0gvU2HU/GVG3k0oETYzwkSHyubp4oZ6nzecRqwwIz4NXKAoFS6FYyS8AV5Bv1Jqib3nh8vStKoViJa9AaGnhCgqA6jK7tkgEkVwGViaDSC4v/JaBUyhRcP1GiezuXV+CpE4dEK0WRMsBnBaE40C0HAhnkKbldOn631oO0OrzFn4X/oZhmlYLVPFbLaWCmBJRLGORiNKn68RY4TorRJjx9ob1qOj2RfUwVSehrnoxaFhmsW1KbF+WmDRoVSSE4MG4t6G4ew8uTSMQvnGtTVscbSp+9M5ElqD3Ayrv9BaVhT3FDyEEarUaUqm0YkbNeqLzEXpwAIg9CXBm4gjVidB1jYW9AtTvCIhsFr6pxnAz9SZW31yN4/HHjdK9nLwwtvlYjGwyEq5SV4vLOxufiS+Px5hcF+zpgsgWgejW0BsiO3eDEa22SHDkGXYJ5Re1uhRfNuwqMvjmC2dErg4wTlKIZDrBwsrkELnKhGW9gGHlujSRXA5WL25kMrByuZHYYUxcZ4QQPBg/EYq79wDDWxzD6G64G361axcP4XmA5wWBRYqJpuJiiXAcYCKfIKwMxZhBmabWwYQ4s1i46dO0hqLPfH4q8igWwzAAy+q+DULhNP55Mdw7vWCz3dhc/FgDFT9FQ2ttdoNVF+gEkL5VKCfBdD5nDyC0V5HTtMzbNvuvIdzLuIfVN1bj0ONDRunuUneMbjoao5qOgoeTh5mtiyCE4N0/L+KhioG/mMBF7oK4bGNfkkBXJ4xoHoDeIb6CEzQhBEStLiY+TPutlL2cD6JSm6pelcC6uOiEh16YmBMkJZblBvl16YzYvgKdV6txZ8BgaDMySqwT+3ij2a6/wEpL9w2jlA3heWMxpzUl3KwVesXWaTkoHz1Cxs7dJfbv8XIPSP39i8RmoSAjPK8ri+cBjgfhjX/r8vIAz4FwfMW2F36X3J5SBiwLl4gmNn0Zsan4eeGFF/D1119DasHNIi8vD59//jmuXr1qYVWrhmrZ7WUphADJt3QtQtEHgfgLAEyYkWGBeh2KWoX8m9cap+mYzBisvrkaB+IOCDPJA4CrxBWREZEY02wMvJy9zG5PCMHOaf/Bn2EvYsjNo+jUtS2uqiTYJa6DhxJ3o7weyjx0v3cOL9z+F5LsLN1NvDrAsoIYMWo9MegaKvouFCtyA7GiFzEyGVgXZ10zdg1CnZQMbVYWeI7Dk/h4NKhfH6xIBLGXF6T+flVdPYqFVHUrXkUQRJWBuCpNhOnyGv+GXpyZEmGCcDOzvQkxZyjaSheDhmVWdHtdXbU5uVAbxAXSY8vWH5uKn99++63EiK7S+PnnnzF9+nSL81cFNVr8FCc/HYg5rGsVengEUGabzudeT+c0Hd4XCO4CSC33hampxGXHYc3NNdj7aC84UvQm5iJ2wYgmIzCu+Tj4uhiHFNCkZ+DJ198g98y/JcojAB4FheJIh96IbmDsXyZT5OOl6yfQ+fopyFTl62JixOKiVhO98NALlFKXDQSLTAaRqxyMk1O1fShUJnQ+qJoNbcVzDCpLxNpU/Gi1WoitaKbWaDSQSKr33EkOJX6Mdq7RDZ/X+wqlmRl1J3YGGnUrGkHm4POOxefGY+3Ntdj5cCe0fFHLjJPICUPDh+Kt5m+hjtgTqZu3IGn9RpACBf5ur8L2jmoMOS/F65dKRgyN92uAo+174VZoK6N0J60G3dIfonduPHycRMW6iuQGXUMlW2HoTdz2UPFT86GteDWfyhKxNW5W98rGYcVPcTLjgAcHda1CcacAzowPiV/zolaheh0A1jEfEkn5SVh7cy3+iv4Lar7ov5BAhG4P5XjtNAffXFYnfF4oWj/knBTvPj8dru3bGbe0uLjgSZ4GUbcTcTQ23WiEmIRl0DfUF8OaBSLQrexw6xT7UK2uR0qFoLas2VSGiKXipwxqnMOzLVDlAbEninyFcs3ERnLx0jlNh/cFQno6pNN0akEq1t9ej613t0BFikSOiAPqpbN47FdyFMuIR0H4bO4+szZNzFXhzztJ2B+TCo2BCmIZoEewD0a2CESwp4vtD4ZSKtX2eqRYDbWlY2BPO1LxUwY1Yqi7PSEESLpR1CqUcBlmnabrv1DUKlQnwiGcplVPE5C4fAUenzmM/a01OPycGkoLWlzfe24K3m07tdQ8GQoNtt9Nwu77KVBojUVU5/qeiGwRiCa+lg+7p1SMGnE9UiyC2tIxsKcdqfgpg1rT7WUpealAzCFdq9DDo4Aqx3Q+jwbCRKwI7gJILI+iXB3Q5uYied1GpG350yiqsCaiAZYO0OCq4kGZZUxtPRVTWpU9TUKuSoud91Pw190k5BabSLVtgDsinwtEK383ehO3MzXyeqSYhNrSMbCnHan4KQMqfkqB0wBP/i1ymk6PNp1P7AI07l7kNO0RVKnVtAai1SLtr7+RtHotuOyi0XBiby8ETpkE7wGvodUfbUFMtX4VgwGDG+NKRg42h0LD4Z/oVPx5JwnpCuNpHJr6yhHZoi461vOokVGjawI1/nqkCFBbOgbVQfzYNNLYnj17sGbNGkyZMgX9+vWzZdGUykQkARp11X1e+QZIf6jzEXpwAIg7DfCFD3CtAniwT/cBAP/nilqFgtpVC6dpQghyTp/Fs5+WQvX4iZDOOEnhN2ok/MaNgUiumyftvdbvYfm15WWWyTIsvjjzBUZGjERzn+Zl5neRiDCkWQAGNPHD4Ufp2HI7Ec8KZ5O/m5aPOcej0cjTBSMrKWo0hUKh1HZs2vLj6+uLzMxM+Pr6Ijk52VbF2gV7t/w8fPgQISEhjvd2osoFHh0vjDR9CMgzY2eZDxDaW9cqFPIy4OJZmbUEABTcf4BnS5Yi79Jlo3Svvn0QOHUKpCbmq1t5faVFAkhPS9+WGBkxEq8Ev1LmbPJ6OJ7gxOMMbL6ViLgshdG6um5OGNE8EL0a+whRoykVw6Gvx1oGtaVjYE87Vkm3V4cOHXD58mV06NAB58+ft1WxdsGe4qfWwPNA0vWi7rFnV0znY0RAg05FrUK+4XZ1mtakpiJx5Rpk7N5rFExL3roVgj54H7LmzUrd3pwAejPiTTAMg50xO5GryTVa5+3sjcFhgzE8fDgCXQMtqidPCM4/zcbmW89wNy3faJ2PiwRDmwXgtbA6cJHQmzyFQqFYQpWIn6ysLBw9ehQ9e/aEp6enrYq1C/Ye7ZWfnw+5XF67nFlzkwudpvcDD48B6jzT+byCdT5C4X2Ahi/ZzGmaUyiQ+vtmpGz6HbyyaB4uaVBd1J0+FR49ultsj+ICyNDJuUBTgL2xexF1LwoPMo0dpFmGRbd63TAyYiQ6BXayaH+EENxIzsX/biXiSqKxo7mbVIQ3mvpjUBN/uDvVvglrbUGtvR4dEGpLx8CedqxSh+cHDx4gPDzc1sXaFOrwbGe0auDxmUJfof1AxiPT+STyQqfpV4CwPoC7Za0mhhCeR+Y/+5H4y0poUtOEdNbVFQET34LvsCHlihy64uoK/HLjF7zX8j282+bdkvslBFdTriLqXhQOPT4ELTGe0yvYPRgjmozAoNBBcJO6WbTP+2l52HwrEWfis4zSXcQsBoT7YXBTf/jIaBRoa6DXo+NAbekYVAeH53KLn7y8PDx48AD5+fkwLCIrKwuTJ09GYqKZAHrVBCp+Kpm0GCD6gE4IPT4L8GYm/wxoqYsnFP4KULctwJbu95J7+QqeLVkKxT2DaTxEIvgOHYyAiRMg9ix7BndzWGPH1IJUbIvehm33tyFFkWK0zkXsgv6N+2NkxEiEe1n2UhCXpcAWGjXaJtDr0XGgtnQMaqz4+d///od33nkHSoOuheJwHGd2XXWAip8qRJkDPDpWFGk6P9V0PnmdQqfpV4CQHoBzkZBRPn6CZ0uXI+fEKaNN3Lt1Qd33p8K5YYMKV7M8dtTwGhx7cgxR96NwMeliifVt/doiMiISLzd8GRK27PnvdFGjE7E/Jq1E1OiejXwwsnkgGtKo0aVCr0fHgdrSMaix4qdBgwZ4amJaeqFQhqnV4ofnecTFxSE4OBhsGS0XtR6eB55dLWoVSrxuOh8rBhp0AtegO1IvZSLpr5OAwTnmEh6Guh9Oh1v7djasWsXsGJMZg6j7Udj9cDcKtMazvPu6+GJY+DAMDR8KP1nZc9qkF6jx191k7H5Ao0ZbC70eHQdqS8fAnna0q/iRy+WYMGEC2rRpU0K1paSkYO7cucjPzzezdfWAjvaqpuQk6lqDog/qnKY1ps8jVb4UOSmuyFfVg1vkR/Du3x9MNX0TzFPnYdfDXYi6H4XY7FijdWJGjJ4NemJkxEi0929fpvNfjkqLnfeTseNucsmo0YHuGNUiEC1p1GgKhVJLsav46du3L3bu3AknJ9M+B7t378aAAQOsLbZSsfdor+zsbHh4eNCHUEXQqkDiTkN9dB2Y2COQOilM55O66rrFwgqdpt38bbJ7W9uREIILSRcQdS8Kx+KPgSPG4iXUMxQjm4zEgJABkElkpZZlSdToF+rR8w+g16MjQW3pGNjTjnYVP5cuXUJUVBQWLVpUYl16ejrat2+P2NhYE1tWH6jPT/Wn4PYdJPy0FPlXrwMgcJKr4e6fB5+mEjixiWDMOU3XbVM4lP4VILB1mU7T5rCnHZPyk/Dngz+x7cE2ZCgzjNbJJXIMChmEEREj0NijcanlqDkehx+lI+pWIhLzVEbraNRoHfR6dByoLR2DGuvz8++//2LAgAHIzMw0m6c2+/zQC7RiqJOSkfjLSmTuO2CU7tq+Lep+MB2yJuGAIks3Aau+i6wg3XRhcj9da5DeadrJsiHnQOXYUc2pcejxIUTdi8K11Gsl1ncM7IjIJpHoVr8bxKz5OD80arR56PXoOFBbOgY1Vvy0bNkSt27dMl9oLXd4phdo+eDy85Gy6Xek/LEZRKUW0p0aNEDdGdPg3qWz6SZSngMSrhROuXEASLppegesBAjuXNQq5BNSen0q2Y73Mu4h6l4U9j7aCyVnPJIyQB6A4eHDMThsMHxcfMyWoY8a/b9bz3DPRNToYc0C8GotixpNr0fHgdrSMaix4sfZ2Rnh4eFo1aoVxGLjt9G0tDT8888/tVr88DyPhIQEBAUF0REJFkA4Dhm79iBx5RpoM4q6gEQeHgiY9DZ8B78ORmxFdOPshKIWoUfHAU2B6Xw+obqYQmF9dNNviAuDB2bFAwXp4AlBSkoK/Pz8dDOuy3wAz/rlP1BLq6/Kxt8xf2PL/S2Iz403WidhJegT3Acjm4xEqzqtzPaXE0JwPTkXm28m4kqScdRodycx3ojwx6AmfnCrBVGj6fXoOFBbOgb2tKNdxU/Tpk1x5coVuLiYji/y3//+F59//rm1xVYqdLRX9SDn3Hk8+2kZlDEPhTRGLIbvyOHwnzAOYjfLu6lMolHqZqLXtwplPTGdz8ld1y0W1AE4+jXAqUrmETsB0y5XigACAJ7wOPvsLKLuReHk05MgML5Um3o3RWREJPo26gsXsflYP/fS8hBlLmp0Ez8MaRoAb5eyYw5RKBRKdceu4mfNmjWQy+UYNWqUyfVTpkzBypUrrS22UrF3y09GRga8vb3p24kZlI9ikfDTMuSe/dco3ePlHqg77V041atn+50SAqTeKwqu+OQcQKxsoZx0Aqjb2vZ1K4OnuU+x9f5W/BXzF7JV2Ubr3KXueCP0DYxoMgL13c0Ls7gsBaJuJeJYXO2KGk2vR8eB2tIxsKcd7Sp+evTogXPnzuGFF14o0eyenp6OW7du1epuL9ovbR5NRgaSVq9F+t+7jIIUypo1Rd0Pp8O1davKq4wiE4g5ohNDMYd0y2UxahsQ3tv+dTODUqvE/rj9iLoXhdvpxucuAwadgzojMiISLwW9BJYxfVOpbVGj6fXoOFBbOgY11ueHZdlSfQ2owzO9QIvDq1RIjdqK5PUbwecX+eBIAvxRd+q78OzTC0xVvsnxHPD0InBlE3Dtj9Lz+jYBQnrquskadgacqiay8s3Um4i6H4V9sfug4Y1j/dRzrYcRTUbgjbA34OFken6z2hI1ml6PjgO1pWNQo8VPYGAgpCZmys7JyUFWVhYVP/QCBaATw1mHDuPZshXQJCYJ6axMBv/xY1EncgRY52rU1fLsGrC6m+X5WQlQv6NOCIX0KIwrVLk2z1Bm4K/ov7D1/lYk5htPKOwkckK/Rv0wMmIkmvs0N7m9o0eNptej40Bt6RjUWPGzevVqTJo0yeQ6QggGDx6MHTt2WFtspWJvn5/k5GT4+/vX6n7p/Bs3kbDkZxTcNPiPWRY+rw9EwKSJkPh4V13lzFGW+PFrrvMbMucr5OIFNOpW1DLkWfEJVi2F4zmcfHoSUfejcPbZ2RLrW/q2xMiIkXgl+BVIRSVfXBQaDnsLo0ZnFIsa3ayOLmp0x6CaF1mXXo+OA7WlY2BPO9pV/OTm5uLevXto3bo1JJKaOUqEjvayH6qEZ0hctgJZh48Ypbu90BF1Z0yDS2jp8XWqlKx4YFk7QFvKaC8nNyDulG7usYdHgcxSopn7hAKNe+jEUPBLgLO7/epuQFx2HLbc34KdMTuRq8k1Wuft7I3BYYMxPHw4Al0DS2yr5ngcepiGLbeTSkSNbuzlgpHNA9G1lkeNplAo1RO7ip+wsDA8evQI/fr1w549e8pXwyqGtvzYHm1uLlLWb0Jq1FYQTVHLgXPjRqg74324v/hCFdbOCgzi/KSnp8PHx6f0OD8ZscCjYzoxFHsCUGaXzAMAjAio/3yRGKrbBhDZN85OgaYAe2P3IupeFB5kPjBaxzIsutXrhpERI9EpsFOJFh1HiRpdW69HR4Ta0jGosS0/ERERiI6OxqxZs/Ddd9+Vr4ZVDPX5sR1Eq0XaXzuRtGYtuKwsIV3s7YWAye/AZ2B/64IUVhPKZUdOCyRe07UIPTwGPL0AmJuDzMkDaNy1SAx5N7JZ3YtDCMHVlKuIuheFQ48PQUuM6xTsHowRTUZgUOgguEmNYyvxhODc0yxsvpVYI6NG17br0ZGhtnQMaqzPz+nTp9G/f388fvwYHh4lR5L8/fffeP31160ttlKh4qfiEEKQc+Ysnv20DKq4x0I6I5WizqiR8B83BiJXeRXWsGLYxI6qXF2QRb0YSo82n9crWCeCGvcAGnUFXDzLt88ySC1Ixbbobdh2fxtSFClG61zELujfuD9GRoxEuFe40bqaGjW6tlyPtQFqS8egxoqfkydPIjo6Gps3b8bgwYMRFhYGJyfdiJ38/HyMHTsWqamp5ah25UHFT8VQPIhGwpKlyLt4ySjd65U+CJw6GdLAkr4kNQ272DErvrCL7Khu6g1zsYUYFghqVySG6rUHRLb1r9PwGhx7cgxR96NwMeliifVt/doiMiISLzd8GRLWeN81KWp0bbgeawvUlo5BjRU/pcX50VObh7o7chRSTVoaElesRsbuvbqIyYXIWz6Huh9Oh7yF6eHUNRG725HngMTrRf5CT84BxeL1CEjdgEZdisSQTwhgw1FXMZkxiLofhd0Pd6NAazwXmq+LL4aFD8PQ8KHwk/kZrSs9anQdDG8egADXqg1l4MjXY22D2tIxqLERnsuqbG0PcuiI8EolUn7fjJRNv4NXFDm/SuvWRd3p78GjZ48aNwS62qHKAx6fLWoZSr1nPq9HAyCku04MNeoGyGwTNiBPnYddD3ch6n4UYrONR7GJGTF6NuiJkREj0d6/vZG9E3OV2HonCQdMRI1+uZEPRjhY1GgKhVI9sav4adWqFd5///0Sw9wJIUhNTcVXX32F3NxcM1tXD+is7pZBeB6Z+w4g8ZeV0KQUdWWyrq4IeHs8fIcPBWsi2KUjUOV2zE7QdY3pu8gK0sxkZHQjx0IKHafrPV80Q305IYTgQtIFRN2LwtH4o+CJcQToUM9QREZEon/j/pBJZEJ6eoEa2wujRitNRY1+ri6a+FSuH1iV25FiM6gtHYMaO6v7nTt30KxZM7PrDx06hN69q27+I0ugPj9lk3f5KhKW/AzFvftFiSIRfIe8gYB3JkDs6VlldasMqpUdeR5IvlkUW+jJOdMzzwOARK6LKaQXQ77hFeoiS8pPwtb7W7E9ejsylBlG61wlrhgYMhAjIkagsUdjIT1HpcXOe8nYca/qo0ZXKztSKgS1pWNQY31+DOE4DhkZGahTp05Fiql0qPgxj+pJPJ4tXY7s4yeN0t27vIS609+Dc3Bw1VSskqnWdlQXAE/OFoqhY0BKKeexW92iiNONuwNy3/LtklPj0ONDiLoXhWup10qs7xjYEZERkehWrxvErG7EV3WIGl2t7UixCmrLGk5hDDWO5/HkyRM0aNAAIpY1H0OtHNhd/MTExGD27Nn4559/oNVq4eTkhFdeeQXz589H06ZNy1NkpULFT0m02TlI+nUd0v7cbjTjukt4GOp+8D7cOrSvwtpVPjXKjrlJhV1kx3Q+Q3nJ5vMGtiqKLdTgBV3kaiu5m34XUfej8M+jf6DklEbrAuQBGB4+HIPDBsPHxQdA1UaNrlF2pJQKtWUNxpLo+TYQQHYVPzExMXj++eeRnZ2N4pu7u7vj5MmTaNmypbXFVir2FD+EEGRnZ8PDo2bMg8RrNEj78y8kr10HLqfIV0vs64vAdyfB+7V+YGrhjaam2VGAECDlTlFsocdnAK3SdF6xCxDcuUgM+TW1qossW5WNv2P+xpb7WxCfG2+0TsJK0Ce4D0Y2GYlWdVrpBkLoo0bfTERcduVEja6xdqSUgNqyBvP4X2B9X/PrJ50A6rau8G7sKn5GjhyJQ4cOoUOHDnB3dwfDMFCpVMjIyMCNGzfQpUsX7N69u3w1ryToaK/CG8nxk3i2dDnU8U+FdMbJCX5j34Tf6FEQyWSllECpEWiUQPy5IjGUdMN8XteAwu6xwi4yN3+LdsETHmefnUXUvSicfHoSBMa3labeTREZEYm+jfrCRexSFDX6ZiLupRtHjfaV6aJG9wutvlGjKRRKMTgtkPMUyIwDMh/rvrMeFy2bHbBRSE0QP61bt8apU6fg5uZWYl12djaef/553L9/38SW1Qd7j/aKi4tDcHBwtR2RUHDnLhKWLEX+1WtFiQwDr1f7IfC9yZD61SwfLntQE+xYLvJSdXOQ6cVQ7jPzef1bFImhhi8CkrKHqz/NfYqt97fir5i/kK0ynufMXeqON0LfwIgmI1DfvT4IIbiWlIvNtxJx1UTU6MER/hhYwajRDmvHWgi1ZRVCCJCfZiBo4ozFTfZTgFQgxE0li59y3VE4joPMTIuATCaD1EGHPlsKIQRqtbpEl2B1QJ2UjMQVq5D5z36jdNd2bVH3g/chi2hSRTWrflRnO1YI1zrAc0N1H0KA1PtFsYXiTgMagyCHybd0n7NLAZET0LBTUaBF/xaAiQdQPbd6mNl+Jt5r/R72x+1H1L0o3E7X3Yhy1DnYeGcjNt3ZhM5BnREZEYmXgl5Cm8AmuJuqixp99mmWLq9Kiw3XE7D1TiL6h5c/arTD2rEWQm1pZ9T5QNYT8603mvwyCjAFA7jX1Tk1l9bqXMmUS/z4+PggJCQEnTp1gq+vL5ycnIRRX+fPn4efn1/ZhVAqFa6gACkbf0fKH/8DUamFdKcG9VF3+jS4d32J9qHXRhgG8IvQfV54V+eMGH+hSAw9uwbou7A4lc6p+tFx3bK8jq5rTC+G3I2nNHEWO+P10NfxeujruJl6E1H3o7Avdh80vAYEBKcTTuN0wmnUc62HEU1G4I2wNzCvRxhiMwuw5XYijsVlgCdAgYbH1ttJ2HE3udpEjaZQaiQ8B+QkmBc3+SllFGAGJw/Aq6FufkL9t2dw4Xd9nUPzs2vA6m62OQ4bUK5ur1OnTqF3797QaEqG4mdZFgcOHEDPnj1tUkF7UVtGexGOQ8aef5C4YjW06elCusjDHQETJ8BnyBtgJda/TdcGqpMdq4yCjELBUzikPjvefN46TYtiCzV8EZCWDGaYoczAX9F/Yev9rUjMTzRa5yRyQr9G/TAyYiSa+zQvO2p0i0A09Ci7G47a0XGgtiwDQnTXbFacaYGT/RTgtdaXK5ICng0Az4YG4sZA7Lh4lV2GI4z2AnQCaNq0abh586aQFhERgZ9++qnaBzgE7D/aKz8/H3K5vEpbU3LPX0DCT8ugjI4R0hixGL7Dh8L/7fEQu7tXWd1qAtXFjtUGQoD0mKJAi3GnAHWe6bwiKVC/Y5EYCmhl1EXG8RxOPj2JqPtROPvsbInNW/q2xMiIkXgl+BXkqIC/TESNZgB0buCFkS0CS40aTe3oOFBbAtAoSu+aUpdzdgW3QGNBYyhw3AJNdnFbTWGcHwIChUIJFxdnMGBqVpwfPbGxsUhMTISfnx9CQ0MrUlSl4sijvZSPYvHs52XIOfOvUbpHz+6oO+09ONWvV0U1ozgUnAZ4erFIDD27AhSbBkPAxbuwi6zQedrgRheXHYct97dgZ8xO5GqMb9zezt4YHDYYw8OHQy6pYzZqdLtAd0Q+F4iWfpUTNZpCsRs8B+Q8KxQ0JsRNXlL5ynVyN265MRQ3nvUtGsxQE7Cp+Pnuu+/w8ccf26Zm1QR7d3s9fPgQISEhldo0q83MRNLqtUjbsdM4SGHTCAR9OB2ubVpXWl0cgaqyY41FkQnEniwSQ1mPzef1CSuKOh38EuDkhgJNAfbG7kXUvSg8yHxglJ1lWHSr1w0jI0aile/z+CcmDdtMRo12xagWgXjeIGo0taPj4BC2JER3rRgKGkOBkxUP8CVdSsqEFRt0TQWXbL1x8arQNDe2xJ52tKn4kcvluHnzJho3blxW1hqDI/n88CoVUrf8ieR1G8HnF3njS/z8EDjtXXi90hsMHRZqNdS/oIJkPCoaTh97ElDlmM7HinWTsRaKIRLYGlfTbiDqXhQOPT4ELTH2UQh2D8bIiJHoG9wf/8arsOV2EpJMRI1+NbQOmvjKAUIQ/+QJ6heG0vd0lqCOvHaPSK2p1JhrUqPU+cfph4Qbtd48AYqFgLAYV3/z4sa9LsBW4//EgBVXV+CXG7/gvZbv4d0279q0bJuKH5ZlIZVK0bp1a2GIu34znucRH2/sBNm8efNaHeSwsi5QQgiyDh3Bs2W/QJNY1BTKymTwGzcafqNGgnV2ttv+HZ0ac6OtCXBaXbeYXgw9vWg+JoizJ9CoKxDSE6lBrbAt5Ty23d+GFIXxSBQXsQv6N+6PYeEj8CzbF1G3SkaNNoWXswS/D25p0yjSlMqh2lyTPA/kJhq33hj+Li12VmlIXQ0ETTFx49kAkNb8oLMrr6/E8mvLheWpradiSqspNivf5i0/ly5dKjFnV3p6OkaMGIGjR4+CYRgQQvDKK69g69atJgMgVidquvjJv3ETCUt+RsFNg/qzLHwG9kfA5Hcg8fWxy35rE9XmRuuIKLN1MYX0Yijjofm83o2hadQNx7z9EZVzFxdTrpbI0tavLUZGRELOtseft1NKRI02xE0qQreG3nB1EkMuEek+UtPfLhIR2GrSVUCxb4tBCRRZpXdNcSZGLZUFI9L515RovQnWfcu8q03XlD0oLnz02FIA2VT8TJ8+HT///LNR2tWrVzF48GA8efIEgK4VYtq0aViyZEmNiLxp79FearUaUqnU5s6XqmeJSFz2C7IOHTFKd+vYAXU/mA6X0BCb7q82Y087UoqR+bgottCjE4Ayy3Q+RoToeq2wxdMLuxVPUFDsAVTHpQ6GhA1FM6/XsOVWHh5mFpguxwpkErZQJIkh04sjA4EkKy6cjESUTmDZY8LW2obNWwy0Kp2IyYoz7Vhs7hwsC3mdUrqmggBR+aOV2xNCCHjCgyMctLzW6DdHOHA8p/su/K0lhXkKfxdfb1iOlmhxMO4gDj0+ZHb/thJAdh3ttWHDBkydOhVKpRKEEIhEIixZsgRTp04tX22rAHuLH57nwbKszR6aXF4ektdvRGrUnyDqoiCFzo0aoe6MaXB78QX6gLYx9rAjxQJ4ThcQ7VFhq1D8eZOxSfIYBrs8fRDl5YVYYiyCxIwYDeR1kZM/CSIEVrn9nEWskXAyJ5hkQpq4xLra3E238vxCLL/3e4n0qRGjMaXj/5neiOeBvGTzrTc5z8CDgAOgZRjwALQMwIEBV+xbn84zgFbsDM69LjjXAHBu/uBc/cDJ60DrWgeczBu8SFqqGOAIpxMEBqLCGiFhJEgMRYm+HL4wT2E5luxLL1CqGlsIILuIH61WixkzZmDlypWCz4+7uzu2bt2KPn36VKC6lU9N6fYiWi3Sd+xE4uq14LKyhHSxlycCJr8Dn0EDwIir55tETYd2e1UTVLlA3JmilqE045FgBMAFZydsdnfDMZkMvIHOkaI5vNlZwnIWvwIaPMYLdTqhZUBXqLSAWstCxQFqjoVKy0DFMVBrGag4FmotAzXHQs3pvrV81QkQluEhZjlIRBzErLbwm4NYpIWY1Rr81uh+s1qIRVqIGC1ErAZikQYsw0MfsZuAgBAiTEJr6rfhsqXblMhHUKKsMvdZuA0AxGXG4HF+gtn/xU/qAR+xHJxWCY5TgeM04HgNOF4LLQj4QhGjFcQMwDEMOACEvtRUKxgwuDGuYlNg2Hxur6SkJAwdOhT//vuvcCE0atQIu3fvRrNmzSpQVWP279+PxYsX480338S4cePM5nv27BmmTZsGLy8vJCYmYsqUKRg4cKDN6lHVEEKQe/ZfJPy0DKrYOCGdkUpRZ+Rw+L81FiJX16qrIIVSWTi5AU366j6ALkrtw2NC1GlGkYGOShU6KlVIEonwSR0fXHbROfqrcRtq8ghSpjHU5BGUuAgAOJO6E2dSd5ajMiIwcAYLGRi4GP1m4QIGMjCMC1g4g4GsMM2lcH1hPqZ88VR4whYKsfJHZCeEA4ECPBQghR8eBYXfShAUgJCi9bp1uvSibZQQpjypJFh4gUVJP1IeuUhRZyJFnV18gxoz8snWsAwLESOCmBUb/RYxIrAMK/wWsSLdd+FvMSOGiC3MU/jbXL7SyjHcn375fOJ5nHl2plQ78sjEe63fq7T/yaKWnzNnzmDYsGFITk4GoHswd+7cGTt27ICvr69NKrJt2zb89NNPOH36NABg/fr1GD9+vMm8Go0GrVu3hrOzMy5fvoy1a9di8uTJOHToEHr06GHR/uzV8hMdHY1ff/0Vt27dQosWLTBx4kSEhYVZVYYiOgbPflqK3PMXjdI9+/RC4NR34VQ30MyWFFthCztSKgGeB5KuF8UWij+PlvX9hTd6VZIKOadEIGl1wPimwr0LB6eAqp4XjAEDZyPBZCySXMAwxukl1kMGhqmaVihC+EJBVFxEKYpEElEYrdcLLMM0wExAzBKIUYf5HqrkbDw7uRuKtES4+AaibtcBcPJ3Ryr5GCAaOBECEQAR0b3VixgWLCuGmJVAJJJAJHKCSCSFSOICESsxKwj0D/cSgkCfx1BYlCIaLBEfpvZlSkiYFSTF9q/fR3Vk+dVV2H4zxKwdhzz3CFPbTK7wfmza7SWVSsFxnNDiM2bMGKxZs8bs7O1jx47Fpk2brKowx3HIzMxEnTp1AJQufv744w+MHj0agwcPxvbt23Hs2DH07NkTPXv2xJEjR0xuUxx7iJ/169dj4sSJwsg3/ffatWvNHoshmrR0JK5cjYzde3U39UJkz7VA0IfTIX+uhc3qSjFPRe1IqULU+Vh5ei6Wx+9H5qlMJKxL0M2DQSB8B00IglcXL3QpKEBnhRIM0a0y/OhhQHRppCjd8LvoU3gbNVOW8E2I+XX6Dykqz9S+hEOFM9SMC1SsHGpGBhUrh5KVQcXIoWTlUDEyKA3SlUzhNyuHktF9c0zVzesn5ZWQ8fmQ8flwIfmFvwuENBmfj9tSDv+6EOSccsb9dUtLXJNN3p4Kl5ceYrhbOIbW7aabhsG9rk0D+lXF/PFVMmd9xSZ7sKB4gjfnfIMrq74vYccO787G+WULbOKbZ9NuL61WC4ZhwLIsvv76a3z66adm8z548AA7duywoqo6RCKRxa1IBw8eBAA4F8aw0f9hp0+fFuZ9qWyio6MxceJE8HzJt5m3334bL730ktnpP3ilEil/bEbKxt/BK4rilEjrBiJw2nvw7NWzyh02awsVsSOlGiCVY0rP75GyWYkv1y3TPUX09/TC74R1CZjUvDHmNCvsJmcKZQVjIDVK/c0Yb2fut3DJ2qo8U2XAyvI4gMkFkAcwDNQ8g3xOhHwiQj7H6j68CPk8iwJO961LZ3TpHIsCjinKyzFQkfK1NKhZZ6hZZ2Sh9LAckqQnuL9uOEB44fms/76/djlebPInjrL1cTRav0VS4YdSnShIeoIrq743acfLK7/Hww8nVuq91WKfH7FYjEaNGuHgwYM4dMj0cLWCggJcvXoVWq19vcbv3r0r1MkQtVqNx48fm/RBUqlUUKmKRoTwPA+GYcAZTAOhF3g8z8OwQcxcun4UEM/z+PXXX80KFJ7n0aZNG3h4eJRcp1SCz88H4QwetgwDkVwGNvEJ8Nb5Mv4Nii3Jzs42KXyA0u1IqV5kZ2Waf30mwPdfXMZqz0eVWidHhtc7NRPdA03/m4fekbkwvfC3UX6U3uigVeSZnzOO8Dj/xRiIXaj/Y3WnNDsyDIM1a9Zg/vz5wnJZz1xT6YbP87KwSPxIJBIcPnwYXbp0KTNvdHQ02rRpY3EFykNmZiYAmBQbWQYjogxZsGAB5s2bZ5Tm4+OD6GjhdQEeHh4IDAxEcnIysrOLHOh8fX3h6+uLhIQE5BtMHxEQEABPT0/ExcXh1q1bKK0HMS8vD3l5ZmbANoVaBRQeJ6X6YLUdKdWSvPwC5OVXPAYQperhlAXglNSWNRlCCG7duiU8jy155qoNQr7Uq1cPrq6uePjwIVQqFZycyvbrs0j8jBkzxiLhAwBhYWEYMWKERXnLS2ndWu7u7ibTP/30U8ycOVNY7tixIxiGMXJi1Yspf39/+Pn5lUgPCgoqoTYBIDg4GC1atMCBAwfM1svV1RUeHh4gHAc+Lw+8Sm20nnWSgpXL6bD1KiY7O7tUcaO3I6V6Q+3oOFBbOgal2ZFhGLRo0UJ4HlvyzDWVHhISYpHwASwUP7/++qtFhelZu3atVfmtJSIiAtevXy/RPSGVSs1Ovurk5GT0p+j/LFPxW8xFqC4tfeLEiVi0aJHZ9RdPnoTbsZNI+3M7iEG3oHNYKIJmvA+3jh1MbkupXKKjoxEREWGy64tlWVy9epX6/NQAqB0dB2pLx6A0OxJC8M4775R4Hlv7LLYmHlv1HBNXjPXr1+PVV1/FxYu6od+vvvoqAJRQkZ07dxYmXq1swsLCsHbtWrAsC5FIZPS95J1J0Hz0CVI3bxGEj9jHB/W/+A+a/LaeCp9qRGl2XLt2Lb3J1hCoHR0HakvHoLrZsVzTW9gLpVIJFxddALCVK1di8mTdmH83Nzfk5eVhwIAB2LVrF9RqNdq1awcAuHnzJv744w+MHTsW+/fvR+/evS3al73i/MTExGDF1//FvWPH0Lh5c7zKAYGZWcJ6xskJfqNHwW/smxBVkVCjlE1MTAzWrl2LuLg4BAcH4+2336Y32RoItaPjQG3pGNjbjnad28seHDlyBH///TeWLVsGAGjbti0+/vhjjBgxApMmTUJUVBSWLVuGsWPHAgCePn2KSZMmQSaTITMzEx999BH69etn8f7sJX4IIbg34k2jqMx6vF7rh8B3J0Pq71dyQ0q1gxAihE6goQZqLtSOjgO1pWNgTzvWOPFT2dhL/MR+/B9kHztulCZv2wZBH7wPWdMIm+6LYl/o3F6OAbWj40Bt6RjY0442n9uLUjaEEBTcu2eUJq0XhJAVS806aFEoFAqFQqlc6BPZhuSeOw9NonFkUfXTBOSdv1BFNaJQKBQKhVIcKn5sBCEEiSvXlJxPhmGQuHJNqQEQKdUThmEglUqpb0ENh9rRcaC2dAyqgx1pt5eNIBoNNEnJJeO0EwJNcjKIRgPGzESwlOoJy7Jm40ZRag7Ujo4DtaVjUB3sSMWPjWClUoRvXAttVhYIIcjLy4OrqysYhoHYywssFT41DkIIsrOz4eHhQd80azDUjo4DtaVjUB3sSMWPDZEG+EMa4A+O4xAfHQ1fOiKhRsPzPJKSkuDm5kbtWIOhdnQcqC0dg+pgR+rzQ6FQKBQKpVZBxQ+FQqFQKJRaBRU/doBhGBqB1AGgdnQMqB0dB2pLx6A62JH6/NgBlmVRv379qq4GpYJQOzoG1I6OA7WlY1Ad7EhbfuwAz/NIS0sDz/NVXRVKBaB2dAyoHR0HakvHoDrYkYofO0AIQVpaGg1sWMOhdnQMqB0dB2pLx6A62JGKHwqFQqFQKLUKKn4oFAqFQqHUKqj4sQMMw9AIpA4AtaNjQO3oOFBbOgbVwY50tJcdYFkWgYGBVV0NSgWhdnQMqB0dB2pLx6A62JG2/NgBnueRmJhIRyTUcKgdHQNqR8eB2tIxqA52pOLHDugnbaMjEmo21I6OAbWj40Bt6RhUBztS8UOhUCgUCqVWwZBaKqHd3Nyg0WgQEhJil/JVKhWcnJzsUjal8qB2dAyoHR0HakvHwF52fPjwISQSCXJzc0vNV2tbfuRyOSQSiV3KJoQgJyeHNs3WcKgdHQNqR8eB2tIxsKcdJRIJ5HJ5mflqbcuPPcnJyYGHhweys7Ph7u5e1dWhlBNqR8eA2tFxoLZ0DKqDHWttyw+FQqFQKJTaCRU/FAqFQqFQahVU/FAoFAqFQqlVUPFjB5ycnPDll1/SEQk1HGpHx4Da0XGgtnQMqoMdqcMzhUKhUCiUWgVt+aFQKBQKhVKroOKHQqFQKBRKrYKKHwqFQqFQKLUKKn7Kybp169CrVy+8/fbbGD9+PHJycszmzcnJwVtvvYXIyEgMGDAAa9eurcSa1m6ssROgs9XixYvRsGHDEuuSkpIQGRkJLy8vBAQE4LPPPgPHcUZ51q5dC4ZhjD79+/e36TFRrLPrpUuX0LVrV8jlcjRp0gR//PFHiTxjxowpYbdFixbZ8xBqJdbYLTY2FoMHD4aHhwfq1auHH374wWh9165dS9iMYRh0795dyHPkyJES65977jl7HR7FAGtsnZubC7lcbmQniUSCpKQk+1WQUKzm999/JwDIrl27CCGE1K9fn/Ts2dNs/t69exNfX1/CcRw5fPgwAUA2btxYWdWttVhjp7S0NLJw4ULi7e1NAJDil4ZGoyHt2rUjIpFIWA+AzJ071yhfly5djNYDIH/++ad9DrCWYo1dHz16RDw9PY3sxjAMOXbsmJAnNzeXyGQyI5uJRCKSmJhYGYdTa7DGbklJSaRdu3Zk4MCBxN/fX7DLP//8QwghRKVSEWdn5xLXGgCyfPlyoZwxY8aUWP/999/b/2BrOdY+I9euXVvCTq+99ppd60jFTzkIDQ0lAMiNGzcIIYR07dqVACAnT54skff06dMEAGnbti0hRHczBkAaN25cqXWujVhjJ61WSwgh5Pvvvzcpfnbs2EH++OMPwnEcuXDhAvHy8iIASPPmzYU8jx49IqNGjSLR0dFGH41GY8ejrH1YY9f58+eTS5cuEY7jyLp16wTbTp06Vcizfv16smTJEiObxcXFVdrx1BassduOHTtIdnY2IYSQ1NRU4uPjQwCQxYsXE0IIOXv2LHn99dfJrl27yMWLF8nVq1fJ//73PyISiUhSUhIhhJC8vDzSr1+/EtejQqGopCOuvVhja0IIGThwILl586aRnTIyMuxaR9rtZSWxsbGIiYkBADg7OwMAGIYBAOzfv79E/oMHD5rM++jRI0RHR9u9vrUVa+0kEokAAL6+vibL69u3L0aNGgWWZdGhQweMGTMGABAQECDk+e2337Blyxa88MILmDx5Mk6cOIFGjRpBLBbb7sBqOdba9cMPP0S7du3AsizeeusttGzZEoCx3TZt2oSPP/4YPXr0wCeffILHjx+b7PaklB9r7fb6668Lcz75+voiKCgI/v7+GDFiBADAx8cH27Ztw4ABA9C+fXu0bt0ad+/eRdeuXeHv7w8A2L59O/bv348OHTpg/Pjx2L17N+rVqyfsn2IfrLX148ePsWfPHrzwwgsYPHgwVq1aBRcXF3h5edm1nlT8WMndu3eF38UfaqbEjD6/qQcgFT/2w1o7lUXxG6ZarQYAjB07Vkj77bffwHEc0tPTcfToUUycOBG9evVCfn6+1fujmMZau5qym0gkwqhRowAA8fHxOH78ONRqNZ4+fYrt27ejV69emD17th1qX3upyPW4evVq3LhxAx999BHq1q0LAAgPDxdeWPRs3boVw4cPF5Y3bdoEQgiysrJw5swZzJw5Ex06dEBKSkpFD4dSCtba+rfffgPP88jPz8fNmzexaNEitGjRAmfOnLFrPan4sZLMzEzht17N6snKyjKbv3hec/kptsFaO1kDIQRHjhxB9+7dMXr0aACAQqHA559/jvnz52Ps2LGQy+UAgOPHj+Obb76p0P4oRVTEro8fP8aDBw/w2WefoXHjxgAAjuOwevVqfPnll3j11VfBsrpb4qJFi4RWW0rFKa/d/vOf/2DGjBkAgNmzZ+P77783me/69euIiYnBkCFDhLS33noLCxcuxOTJk+Ht7Q0AuHXrFj744INyHgXFEqy1dadOnbBkyRLMmjUL4eHhQr7IyEhotVq71ZOKHyvRP9RMoW+mrUh+im2w5/++detWEEKwdetW4WHp4uKCcePG4dNPP8XGjRvx7NkzvPvuuwCAPXv2VGh/lCIqYtdvv/0WgwYNwpdffimkBQcHY+LEiZg7dy727t2LmJgYdO7cGQC1my0pr93mz5+P27dvIyIiAgDMjsDbsmULevTogTp16ghpb775Jj7++GOsXLkSCQkJ+OqrrwBQu9oba2398ssvY8aMGVi0aBHu3buH7du3w83NDfHx8bhx44bd6knFj5XoL0IA4HneaF3Tpk3N5i+e11x+im2w1k6WkpCQgO+++w6HDx8WbrSmhnC6u7vjl19+wUsvvQSpVFru/VGMKa9d9+3bh9jYWGzevBksy0KhUECj0ZTI16hRI+zevRtubm7UbjakItdj48aN8fvvvwOA2S7k4l1exXF2dsYXX3yB0aNHU7vamYrYmmEYDB48GD/++CMA2NVWVPxYSZMmTYQm87y8PKN1vXv3xt69e9GvXz/s27cPAPDqq6+azNuoUSOEhIRUQo1rJ9bayRJUKhUmTJiAefPmITc3Fzdu3MDChQtx+fJlAMDTp09L7KtTp040zo8NKY9dHz16hG+//Rb//e9/ER0djStXrmDy5MnCjTk6Otqoed3LywsRERHUbjbEWrtlZmYa2aRdu3bw9vbGyy+/XKLsy5cv4/Hjxxg8eLBRenJyslEXDECvx8rAWlvn5+fjyZMnRvk6deqExo0bo1mzZvarqF3Hkjko//vf/wgAsm3bNkKIblhfly5dCCGEtGjRggAgzz33nJC/T58+xNPTk2i1WmHo+6+//lolda9NWGsnQghZsWKFMBxaqVQarRs7dqzJuCKZmZkkOzubSKVS4uHhQZYvX060Wi3JzMwkkZGRJC8vr3IOuJZgjV2zs7OFNMNP69atCSGE7Nu3jwAg4eHh5ODBg4QQQq5fv240FJ5iGyy1W3Z2NpHJZOS5554jt27dIoQQcvfuXRIQEECio6NLlDt79mzSp0+fEun+/v7E2dmZzJs3jygUCqJQKMjYsWPJs2fP7HiUFEKsu0ZHjBhBAJBRo0aRhIQEQgghc+fOJYcPH7ZrHan4KScrVqwgnTp1IsOHDyfjxo0jubm5hBBCvv76ayKXy8k333wj5M3MzCSjRo0ir776KunduzfZsGFDVVW71mGpnbKyssjmzZtJ69athQfk9OnTyaVLlwghhCxYsMCk8DGM1/T555+ToKAgIpVKyQsvvEDmz59PhY+dsNSur7zyikm7TZgwgRCiuzZHjBhBvLy8iIuLCxk4cCBZv3494Xm+yo7NkbHEbjzPk2nTphE/Pz/i4uJCXn/9dfLhhx+SJ0+emCyzYcOGJl8mly5dSho1akSkUil57rnnyOeff05SUlLsenyUIiy9Ro8ePUratWtHnJ2dSd26dcnUqVPJ1atX7V4/hhBC7NeuRKFQKBQKhVK9oD4/FAqFQqFQahVU/FAoFAqFQqlVUPFDoVAoFAqlVkHFD4VCoVAolFoFFT8UCoVCoVBqFVT8UCgUCoVCqVVQ8UOhUCgUCqVWQcUPhUKhUCiUWgUVPxQKhUKhUGoVVPxQKBSbw/M8tm7digEDBiA0NBQvvfQSWrVqha5du2Lx4sUlJjwsjd69e0Mmk4FhGOHj4eGBMWPGmMx/5coVzJkzB2KxWMj/0ksvoV+/fmjWrBkCAgLQtWtXrFq1qsSs0xVFpVKhd+/e8Pb2xo4dO2xaNoVCsSF2n0CDQqHUKpKSkkjXrl0JANKrVy+SmZlJCCGE4zjy/fffEwAkKCiI/PvvvxaXeeTIEaO5uR4+fFjmNh06dBDyHzt2TEhfvHixkD527FhrD8+I999/n8TGxgrLly5dEsoeMGBAhcqmUCj2g7b8UCgUm5GXl4dXXnkFJ0+ehLu7O6KiouDp6QkAYFkWH330EV599VUkJCSgT58+uHnzpkXlNmrUqNRlU8hkMpPpH374IerWrQsA2LRpE65fv25RHYqzZcsWLF261CitdevWGDNmDFq0aIFZs2aVq1wKhWJ/qPihUCg245tvvhHExJAhQ+Dj41Miz8SJEwEAubm5eOeddywql2GYUpetpX79+sLve/fuWb39b7/9hrFjx5ZIF4lE2LRpE27evIlu3bpVqI4UCsV+UPFDoVBsAsdxWL16tbD8wgsvmMzXpk0b4ff58+dx7do1YXn8+PFwc3PDF198Ybd6arVaxMbGCstNmzY1Wn/x4kW8+eab6N+/P7y9vdGsWTP8/vvvwvrt27djzpw5UKvVAICRI0eie/fuuHnzJurWrSv4Gc2dO9eo3L///hvt27dH69at0bx5c7zzzjtITk6223FSKBTzUPFDoVBswoMHD5CRkSEs16tXz2Q+f39/o+V///0XAJCeno6NGzciLy8PS5YssUsd8/LyMHPmTKSkpAAAPvjgA7Rs2VJYf/LkSXTu3BmhoaHYs2cPtm7dirt372LMmDE4evQoAF2L1rhx44RtoqKicPz4cTz33HPYs2ePyf1GRUVh8ODBkEgkuHr1Kvbu3Yv169ejQ4cOSEtLs8uxUigU81DxQ6FQbIKh8AEAZ2dnk/mcnJyMljMzMwEAPj4+GDduHORyOT744AOb1u2DDz5A/fr14enpiaVLl6J58+Y4evQofvzxR6N827Ztg0ajwfLlywEAISEhwrrz58+XuR9vb+8SaSqVCjNmzAAhBF27dgXDMAgODkZISAji4+Px9ddfV/DoKBSKtYirugIUCsUxKO7fo1AoTObLzc01u92GDRuwYcMGm9dtyZIluHDhAv7v//4PAPDw4UP4+vqWyDdt2jRkZGTghRdegEajMWrJ0XdzWcuZM2eElibDfbq7uwMAdu7ciZ9++qlcZVMolPJBW34oFIpNCA8PNxIyT58+NZkvNTXVaLlz5852rZeejz76CC+99BIAQKlUIjIyEkql0ihPeHg4Nm3aBCcnJ3Tq1AmEEGGd4W9rSExMFH4btnrpnbap3w+FUvlQ8UOhUGwCy7KYNGmSsGyum+jcuXPC765du6JFixZ2rxugq9/GjRvh6uoKALh9+3aJ4ejp6eno1KkT3n//fWzYsAEDBw6s8H79/PyE3xzHCb9VKhUA45FnFAqlcqDih0Kh2IzPP/8czZo1AwDs2LGjhB8QAKxbtw4A4ObmhhUrVhitMzfaq3iriyWtMKZabRo3bozFixcL6b/88gt27dolLM+YMQMXLlxAs2bN0KJFC7P7EYst9xjo3LkzvLy8ABj7Rel/9+3b1+KyKBSKbaDih0Kh2AyZTIajR4+iffv2yMrKwvjx44WpLHiex4IFC3Ds2DEEBATg4MGDglACSh/tFRcXZ7T8+PHjUuuhVqsRHx8vLD98+FD4/c477+C1114Tlt966y3ExMQAgBB08erVqxg1apSR4/WDBw+EVitDR+js7Gz8+++/yMrKEpy3gaLuPZlMhkWLFgEATp06BUIIHj16hISEBAQEBOCzzz4r9VgoFIodqLLY0hQKxWHhOI5s2rSJvPrqqyQiIoJ07dqVtGzZknTs2JHMnz+fZGdnm9xu3LhxRC6Xkzlz5ghpvXv3JjKZzGh6Cw8PDzJ69GiTZSxfvpw0aNDAKL9EIiEdOnQgWVlZhBBCEhMTiY+Pj7De1dWV7Nq1i/z555/E19eXBAYGki+++IIUFBSQN954gzg5OZGuXbuS+Ph4QgghWq2WTJ48mcjlcvLSSy+Rbdu2kejoaOLv7y+UKRaLyezZs4V6RUVFkTZt2pBWrVqRRo0akeHDh5NHjx7Z6i+nUChWwBBSTi8+CoVCoVAolBoI7faiUCgUCoVSq6Dih0KhUCgUSq2Cih8KhUKhUCi1Cip+KBQKhUKh1Cqo+KFQKBQKhVKroOKHQqFQKBRKrYKKHwqFQqFQKLUKKn4oFAqFQqHUKqj4oVAoFAqFUqug4odCoVAoFEqtgoofCoVCoVAotQoqfigUCoVCodQq/h+6lC0YfwrLVQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "import matplotlib.font_manager as fm\n",
    "\n",
    "# 学术风格设置（Times New Roman，字体统一，线条简洁）\n",
    "mpl.rcParams.update({\n",
    "    \"font.family\": \"Times New Roman\",\n",
    "    \"font.size\": 12,\n",
    "    \"axes.labelsize\": 14,\n",
    "    \"axes.titlesize\": 14,\n",
    "    \"xtick.labelsize\": 12,\n",
    "    \"ytick.labelsize\": 12,\n",
    "    \"legend.fontsize\": 12,\n",
    "    \"axes.linewidth\": 1.2,\n",
    "    \"lines.linewidth\": 2,\n",
    "    \"lines.markersize\": 7,\n",
    "})\n",
    "\n",
    "font_path = '/mnt/sda/2022-0526/home/gtyinstinct/fonts/timesbd.ttf'\n",
    "fm.fontManager.addfont(font_path)\n",
    "plt.rcParams['font.sans-serif'] = 'Times New Roman'  # 备选字体列表\n",
    "\n",
    "# 调色板（来自图像）\n",
    "# colors = ['#cf3439', '#f1c544', '#8ccf79', '#44a2ca', '#000000']\n",
    "colors = ['#cf3439', '#ff7f0e', '#2ca02c','#44a2ca', '#000000']\n",
    "\n",
    "# 画布尺寸\n",
    "fig, ax = plt.subplots(figsize=(6, 2.5))\n",
    "\n",
    "# 数据配置\n",
    "metric = 'share_avg_e2el'\n",
    "norm_df_0 = df_0[metric] / df_dynamic[metric]\n",
    "norm_df_1 = df_1[metric] / df_dynamic[metric]\n",
    "norm_df_2 = df_2[metric] / df_dynamic[metric]\n",
    "norm_df_3 = df_3[metric] / df_dynamic[metric]\n",
    "norm_dyn = df_dynamic[metric] / df_dynamic[metric]\n",
    "\n",
    "dp_labels = ['0.0', '0.125', '0.25', '0.375', '0.5']\n",
    "x_vals = [1, 2, 3, 4, 5]\n",
    "selected_output_lens = [1, 64, 128, 192, 256]\n",
    "# markers = ['s', '*', '^', 'v', 'o']\n",
    "markers = ['^', 's', 'D', 'v','o']\n",
    "linestyles = ['-', '-', '-', '-', '-']\n",
    "linewidths = [2, 2, 2, 2, 2]\n",
    "\n",
    "ms = 5\n",
    "\n",
    "# 绘制曲线\n",
    "ax.plot(x_vals, norm_df_0.loc[selected_output_lens], ms=ms, marker=markers[0], color=colors[0], linestyle=linestyles[0], linewidth=linewidths[0], label='Static (k=0)')\n",
    "ax.plot(x_vals, norm_df_1.loc[selected_output_lens], ms=ms, marker=markers[1], color=colors[1], linestyle=linestyles[1], linewidth=linewidths[1], label='Static (k=1,m=1)')\n",
    "ax.plot(x_vals, norm_df_2.loc[selected_output_lens], ms=ms, marker=markers[2], color=colors[2], linestyle=linestyles[2], linewidth=linewidths[2], label='Static (k=2,m=2)')\n",
    "ax.plot(x_vals, norm_df_3.loc[selected_output_lens], ms=ms, marker=markers[3], color=colors[3], linestyle=linestyles[3], linewidth=linewidths[3], label='Static (k=3,m=3)')\n",
    "ax.plot(x_vals, norm_dyn.loc[selected_output_lens],  ms=ms, marker=markers[4], color=colors[4], linestyle=linestyles[4], linewidth=linewidths[4], label='DynaPipe')\n",
    "\n",
    "# 轴标签\n",
    "ax.set_xlabel('O:I Ratio', fontsize=14)\n",
    "ax.set_ylabel('Norm. E2EL', fontsize=14)\n",
    "\n",
    "# 坐标轴刻度\n",
    "ax.set_xticks(x_vals)\n",
    "ax.set_xticklabels(dp_labels)\n",
    "ax.grid(True, linestyle='--', alpha=0.5)\n",
    "\n",
    "# 边框美化\n",
    "# ax.spines['top'].set_visible(False)\n",
    "# ax.spines['right'].set_visible(False)\n",
    "\n",
    "# 图例放置在右侧\n",
    "# ax.legend(loc='center left', bbox_to_anchor=(1.02, 0.5), frameon=False)\n",
    "ax.legend(loc='upper right',ncol=3,columnspacing=0.5)\n",
    "ax.set_ylim(0.96,1.2)\n",
    "\n",
    "# 紧凑布局与展示\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"dp_ratio.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gllm",
   "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.10.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
