{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib notebook\n",
    "import os\n",
    "import csv\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from context import *\n",
    "from helpers.utils import load_perf_metrics, configure_plot_axes, load_adaptation_metrics\n",
    "from helpers.constants import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_loglike_results(base_direc, source_ch, target_ch, n_adapt, n_trials=50, index_col=1):\n",
    "    methods = ['no_adaptation', 'transfer', 'transfer_last_layer', 'proposed', 'retrained_target']\n",
    "    loglike = {m: [] for m in methods}\n",
    "    fname = os.path.join(base_direc, '{}_to_{}'.format(source_ch, target_ch), \n",
    "                         '{}_to_{}_{:d}'.format(source_ch, target_ch, n_adapt), 'loglike_comparison.csv')\n",
    "    fp = open(fname, mode='r')\n",
    "    cr = csv.reader(fp, delimiter=',')\n",
    "    for i, row in enumerate(cr):\n",
    "        if i == 0:\n",
    "            continue\n",
    "\n",
    "        loglike[row[0]].append(float(row[index_col]))\n",
    "\n",
    "    fp.close()\n",
    "    mean_loglike = dict()\n",
    "    median_loglike = dict()\n",
    "    CI_loglike = dict()\n",
    "    for m in methods:\n",
    "        vals = np.array(loglike[m])[:n_trials]\n",
    "        if vals.shape[0] != n_trials:\n",
    "            print(\"WARNING: method {} calculates using {} trials.\".format(m, vals.shape[0]))\n",
    "        \n",
    "        mean_loglike[m] = np.mean(vals)\n",
    "        p = np.percentile(vals, [2.5, 50, 97.5])\n",
    "        median_loglike[m] = p[1]\n",
    "        CI_loglike[m] = (p[0], p[2])\n",
    "        \n",
    "    return mean_loglike, median_loglike, CI_loglike"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_dir = '/Users/jr/Documents/research/code/domain_adaptation/expts_icml22/mdn_simulated_new'\n",
    "source_ch = 'AWGN'\n",
    "target_ch = 'fading_ricean'\n",
    "methods = ['no_adaptation', 'transfer', 'transfer_last_layer', 'proposed', 'retrained_target']\n",
    "n_adapt_list = np.array([2, 4, 6, 8, 10, 12, 14, 16, 18, 20])\n",
    "\n",
    "plots_dir = os.path.join(base_dir, 'plots')\n",
    "if not os.path.isdir(plots_dir):\n",
    "    os.makedirs(plots_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_sizes = n_adapt_list.shape[0]\n",
    "mean_loglike = {m: np.zeros(n_sizes) for m in methods}\n",
    "median_loglike = {m: np.zeros(n_sizes) for m in methods}\n",
    "CI_loglike = {m: np.zeros((n_sizes, 2)) for m in methods}\n",
    "for i, n_adapt in enumerate(n_adapt_list):\n",
    "    means_, medians_, CI_ = read_loglike_results(base_dir, source_ch, target_ch, n_adapt)\n",
    "    for m in methods:\n",
    "        mean_loglike[m][i] = means_[m]\n",
    "        median_loglike[m][i] = medians_[m]\n",
    "        CI_loglike[m][i, 0] = CI_[m][0]\n",
    "        CI_loglike[m][i, 1] = CI_[m][1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "legend_names = {\n",
    "    'no_adaptation': 'No adapt',\n",
    "    'transfer': 'Finetune',\n",
    "    'transfer_last_layer': 'Finetune last',\n",
    "    'proposed': 'Affine adapt (ours)',\n",
    "    'retrained_target': 'Retrained MDN'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "/* global mpl */\n",
       "window.mpl = {};\n",
       "\n",
       "mpl.get_websocket_type = function () {\n",
       "    if (typeof WebSocket !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof MozWebSocket !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert(\n",
       "            'Your browser does not have WebSocket support. ' +\n",
       "                'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "                'Firefox 4 and 5 are also supported but you ' +\n",
       "                'have to enable WebSockets in about:config.'\n",
       "        );\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = this.ws.binaryType !== undefined;\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById('mpl-warnings');\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent =\n",
       "                'This browser does not support binary websocket messages. ' +\n",
       "                'Performance may be slow.';\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = document.createElement('div');\n",
       "    this.root.setAttribute('style', 'display: inline-block');\n",
       "    this._root_extra_style(this.root);\n",
       "\n",
       "    parent_element.appendChild(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen = function () {\n",
       "        fig.send_message('supports_binary', { value: fig.supports_binary });\n",
       "        fig.send_message('send_image_mode', {});\n",
       "        if (fig.ratio !== 1) {\n",
       "            fig.send_message('set_device_pixel_ratio', {\n",
       "                device_pixel_ratio: fig.ratio,\n",
       "            });\n",
       "        }\n",
       "        fig.send_message('refresh', {});\n",
       "    };\n",
       "\n",
       "    this.imageObj.onload = function () {\n",
       "        if (fig.image_mode === 'full') {\n",
       "            // Full images could contain transparency (where diff images\n",
       "            // almost always do), so we need to clear the canvas so that\n",
       "            // there is no ghosting.\n",
       "            fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "        }\n",
       "        fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "    };\n",
       "\n",
       "    this.imageObj.onunload = function () {\n",
       "        fig.ws.close();\n",
       "    };\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_header = function () {\n",
       "    var titlebar = document.createElement('div');\n",
       "    titlebar.classList =\n",
       "        'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n",
       "    var titletext = document.createElement('div');\n",
       "    titletext.classList = 'ui-dialog-title';\n",
       "    titletext.setAttribute(\n",
       "        'style',\n",
       "        'width: 100%; text-align: center; padding: 3px;'\n",
       "    );\n",
       "    titlebar.appendChild(titletext);\n",
       "    this.root.appendChild(titlebar);\n",
       "    this.header = titletext;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = (this.canvas_div = document.createElement('div'));\n",
       "    canvas_div.setAttribute(\n",
       "        'style',\n",
       "        'border: 1px solid #ddd;' +\n",
       "            'box-sizing: content-box;' +\n",
       "            'clear: both;' +\n",
       "            'min-height: 1px;' +\n",
       "            'min-width: 1px;' +\n",
       "            'outline: 0;' +\n",
       "            'overflow: hidden;' +\n",
       "            'position: relative;' +\n",
       "            'resize: both;'\n",
       "    );\n",
       "\n",
       "    function on_keyboard_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.key_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    canvas_div.addEventListener(\n",
       "        'keydown',\n",
       "        on_keyboard_event_closure('key_press')\n",
       "    );\n",
       "    canvas_div.addEventListener(\n",
       "        'keyup',\n",
       "        on_keyboard_event_closure('key_release')\n",
       "    );\n",
       "\n",
       "    this._canvas_extra_style(canvas_div);\n",
       "    this.root.appendChild(canvas_div);\n",
       "\n",
       "    var canvas = (this.canvas = document.createElement('canvas'));\n",
       "    canvas.classList.add('mpl-canvas');\n",
       "    canvas.setAttribute('style', 'box-sizing: content-box;');\n",
       "\n",
       "    this.context = canvas.getContext('2d');\n",
       "\n",
       "    var backingStore =\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        this.context.webkitBackingStorePixelRatio ||\n",
       "        this.context.mozBackingStorePixelRatio ||\n",
       "        this.context.msBackingStorePixelRatio ||\n",
       "        this.context.oBackingStorePixelRatio ||\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        1;\n",
       "\n",
       "    this.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n",
       "        'canvas'\n",
       "    ));\n",
       "    rubberband_canvas.setAttribute(\n",
       "        'style',\n",
       "        'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n",
       "    );\n",
       "\n",
       "    // Apply a ponyfill if ResizeObserver is not implemented by browser.\n",
       "    if (this.ResizeObserver === undefined) {\n",
       "        if (window.ResizeObserver !== undefined) {\n",
       "            this.ResizeObserver = window.ResizeObserver;\n",
       "        } else {\n",
       "            var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n",
       "            this.ResizeObserver = obs.ResizeObserver;\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n",
       "        var nentries = entries.length;\n",
       "        for (var i = 0; i < nentries; i++) {\n",
       "            var entry = entries[i];\n",
       "            var width, height;\n",
       "            if (entry.contentBoxSize) {\n",
       "                if (entry.contentBoxSize instanceof Array) {\n",
       "                    // Chrome 84 implements new version of spec.\n",
       "                    width = entry.contentBoxSize[0].inlineSize;\n",
       "                    height = entry.contentBoxSize[0].blockSize;\n",
       "                } else {\n",
       "                    // Firefox implements old version of spec.\n",
       "                    width = entry.contentBoxSize.inlineSize;\n",
       "                    height = entry.contentBoxSize.blockSize;\n",
       "                }\n",
       "            } else {\n",
       "                // Chrome <84 implements even older version of spec.\n",
       "                width = entry.contentRect.width;\n",
       "                height = entry.contentRect.height;\n",
       "            }\n",
       "\n",
       "            // Keep the size of the canvas and rubber band canvas in sync with\n",
       "            // the canvas container.\n",
       "            if (entry.devicePixelContentBoxSize) {\n",
       "                // Chrome 84 implements new version of spec.\n",
       "                canvas.setAttribute(\n",
       "                    'width',\n",
       "                    entry.devicePixelContentBoxSize[0].inlineSize\n",
       "                );\n",
       "                canvas.setAttribute(\n",
       "                    'height',\n",
       "                    entry.devicePixelContentBoxSize[0].blockSize\n",
       "                );\n",
       "            } else {\n",
       "                canvas.setAttribute('width', width * fig.ratio);\n",
       "                canvas.setAttribute('height', height * fig.ratio);\n",
       "            }\n",
       "            canvas.setAttribute(\n",
       "                'style',\n",
       "                'width: ' + width + 'px; height: ' + height + 'px;'\n",
       "            );\n",
       "\n",
       "            rubberband_canvas.setAttribute('width', width);\n",
       "            rubberband_canvas.setAttribute('height', height);\n",
       "\n",
       "            // And update the size in Python. We ignore the initial 0/0 size\n",
       "            // that occurs as the element is placed into the DOM, which should\n",
       "            // otherwise not happen due to the minimum size styling.\n",
       "            if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n",
       "                fig.request_resize(width, height);\n",
       "            }\n",
       "        }\n",
       "    });\n",
       "    this.resizeObserverInstance.observe(canvas_div);\n",
       "\n",
       "    function on_mouse_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.mouse_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousedown',\n",
       "        on_mouse_event_closure('button_press')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseup',\n",
       "        on_mouse_event_closure('button_release')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'dblclick',\n",
       "        on_mouse_event_closure('dblclick')\n",
       "    );\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousemove',\n",
       "        on_mouse_event_closure('motion_notify')\n",
       "    );\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseenter',\n",
       "        on_mouse_event_closure('figure_enter')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseleave',\n",
       "        on_mouse_event_closure('figure_leave')\n",
       "    );\n",
       "\n",
       "    canvas_div.addEventListener('wheel', function (event) {\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        on_mouse_event_closure('scroll')(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.appendChild(canvas);\n",
       "    canvas_div.appendChild(rubberband_canvas);\n",
       "\n",
       "    this.rubberband_context = rubberband_canvas.getContext('2d');\n",
       "    this.rubberband_context.strokeStyle = '#000000';\n",
       "\n",
       "    this._resize_canvas = function (width, height, forward) {\n",
       "        if (forward) {\n",
       "            canvas_div.style.width = width + 'px';\n",
       "            canvas_div.style.height = height + 'px';\n",
       "        }\n",
       "    };\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n",
       "        event.preventDefault();\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus() {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'mpl-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'mpl-button-group';\n",
       "    for (var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'mpl-button-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        var button = (fig.buttons[name] = document.createElement('button'));\n",
       "        button.classList = 'mpl-widget';\n",
       "        button.setAttribute('role', 'button');\n",
       "        button.setAttribute('aria-disabled', 'false');\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "\n",
       "        var icon_img = document.createElement('img');\n",
       "        icon_img.src = '_images/' + image + '.png';\n",
       "        icon_img.srcset = '_images/' + image + '_large.png 2x';\n",
       "        icon_img.alt = tooltip;\n",
       "        button.appendChild(icon_img);\n",
       "\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    var fmt_picker = document.createElement('select');\n",
       "    fmt_picker.classList = 'mpl-widget';\n",
       "    toolbar.appendChild(fmt_picker);\n",
       "    this.format_dropdown = fmt_picker;\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = document.createElement('option');\n",
       "        option.selected = fmt === mpl.default_extension;\n",
       "        option.innerHTML = fmt;\n",
       "        fmt_picker.appendChild(option);\n",
       "    }\n",
       "\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.request_resize = function (x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', { width: x_pixels, height: y_pixels });\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.send_message = function (type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function () {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({ type: 'draw', figure_id: this.id }));\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_save = function (fig, _msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function (fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] !== fig.canvas.width || size[1] !== fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1], msg['forward']);\n",
       "        fig.send_message('refresh', {});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n",
       "    var x0 = msg['x0'] / fig.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n",
       "    var x1 = msg['x1'] / fig.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / fig.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0,\n",
       "        0,\n",
       "        fig.canvas.width / fig.ratio,\n",
       "        fig.canvas.height / fig.ratio\n",
       "    );\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function (fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function (fig, msg) {\n",
       "    fig.rubberband_canvas.style.cursor = msg['cursor'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_message = function (fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function (fig, _msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function (fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_history_buttons = function (fig, msg) {\n",
       "    for (var key in msg) {\n",
       "        if (!(key in fig.buttons)) {\n",
       "            continue;\n",
       "        }\n",
       "        fig.buttons[key].disabled = !msg[key];\n",
       "        fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n",
       "    if (msg['mode'] === 'PAN') {\n",
       "        fig.buttons['Pan'].classList.add('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    } else if (msg['mode'] === 'ZOOM') {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.add('active');\n",
       "    } else {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function () {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message('ack', {});\n",
       "};\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function (fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            var img = evt.data;\n",
       "            if (img.type !== 'image/png') {\n",
       "                /* FIXME: We get \"Resource interpreted as Image but\n",
       "                 * transferred with MIME type text/plain:\" errors on\n",
       "                 * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "                 * to be part of the websocket stream */\n",
       "                img.type = 'image/png';\n",
       "            }\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src\n",
       "                );\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                img\n",
       "            );\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        } else if (\n",
       "            typeof evt.data === 'string' &&\n",
       "            evt.data.slice(0, 21) === 'data:image/png;base64'\n",
       "        ) {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig['handle_' + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\n",
       "                \"No handler for the '\" + msg_type + \"' message type: \",\n",
       "                msg\n",
       "            );\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\n",
       "                    \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n",
       "                    e,\n",
       "                    e.stack,\n",
       "                    msg\n",
       "                );\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "};\n",
       "\n",
       "// from https://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function (e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e) {\n",
       "        e = window.event;\n",
       "    }\n",
       "    if (e.target) {\n",
       "        targ = e.target;\n",
       "    } else if (e.srcElement) {\n",
       "        targ = e.srcElement;\n",
       "    }\n",
       "    if (targ.nodeType === 3) {\n",
       "        // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "    }\n",
       "\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    var boundingRect = targ.getBoundingClientRect();\n",
       "    var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n",
       "    var y = e.pageY - (boundingRect.top + document.body.scrollTop);\n",
       "\n",
       "    return { x: x, y: y };\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * https://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys(original) {\n",
       "    return Object.keys(original).reduce(function (obj, key) {\n",
       "        if (typeof original[key] !== 'object') {\n",
       "            obj[key] = original[key];\n",
       "        }\n",
       "        return obj;\n",
       "    }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function (event, name) {\n",
       "    var canvas_pos = mpl.findpos(event);\n",
       "\n",
       "    if (name === 'button_press') {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * this.ratio;\n",
       "    var y = canvas_pos.y * this.ratio;\n",
       "\n",
       "    this.send_message(name, {\n",
       "        x: x,\n",
       "        y: y,\n",
       "        button: event.button,\n",
       "        step: event.step,\n",
       "        guiEvent: simpleKeys(event),\n",
       "    });\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (_event, _name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.key_event = function (event, name) {\n",
       "    // Prevent repeat events\n",
       "    if (name === 'key_press') {\n",
       "        if (event.key === this._key) {\n",
       "            return;\n",
       "        } else {\n",
       "            this._key = event.key;\n",
       "        }\n",
       "    }\n",
       "    if (name === 'key_release') {\n",
       "        this._key = null;\n",
       "    }\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.key !== 'Control') {\n",
       "        value += 'ctrl+';\n",
       "    }\n",
       "    else if (event.altKey && event.key !== 'Alt') {\n",
       "        value += 'alt+';\n",
       "    }\n",
       "    else if (event.shiftKey && event.key !== 'Shift') {\n",
       "        value += 'shift+';\n",
       "    }\n",
       "\n",
       "    value += 'k' + event.key;\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, { key: value, guiEvent: simpleKeys(event) });\n",
       "    return false;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function (name) {\n",
       "    if (name === 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message('toolbar_button', { name: name });\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function (tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "\n",
       "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n",
       "// prettier-ignore\n",
       "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pgf\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";/* global mpl */\n",
       "\n",
       "var comm_websocket_adapter = function (comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.binaryType = comm.kernel.ws.binaryType;\n",
       "    ws.readyState = comm.kernel.ws.readyState;\n",
       "    function updateReadyState(_event) {\n",
       "        if (comm.kernel.ws) {\n",
       "            ws.readyState = comm.kernel.ws.readyState;\n",
       "        } else {\n",
       "            ws.readyState = 3; // Closed state.\n",
       "        }\n",
       "    }\n",
       "    comm.kernel.ws.addEventListener('open', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('close', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('error', updateReadyState);\n",
       "\n",
       "    ws.close = function () {\n",
       "        comm.close();\n",
       "    };\n",
       "    ws.send = function (m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function (msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        var data = msg['content']['data'];\n",
       "        if (data['blob'] !== undefined) {\n",
       "            data = {\n",
       "                data: new Blob(msg['buffers'], { type: data['blob'] }),\n",
       "            };\n",
       "        }\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(data);\n",
       "    });\n",
       "    return ws;\n",
       "};\n",
       "\n",
       "mpl.mpl_figure_comm = function (comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = document.getElementById(id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm);\n",
       "\n",
       "    function ondownload(figure, _format) {\n",
       "        window.open(figure.canvas.toDataURL());\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy, ondownload, element);\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element;\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error('Failed to find cell for figure', id, fig);\n",
       "        return;\n",
       "    }\n",
       "    fig.cell_info[0].output_area.element.on(\n",
       "        'cleared',\n",
       "        { fig: fig },\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function (fig, msg) {\n",
       "    var width = fig.canvas.width / fig.ratio;\n",
       "    fig.cell_info[0].output_area.element.off(\n",
       "        'cleared',\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "    fig.resizeObserverInstance.unobserve(fig.canvas_div);\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable();\n",
       "    fig.parent_element.innerHTML =\n",
       "        '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "    fig.close_ws(fig, msg);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.close_ws = function (fig, msg) {\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function (_remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width / this.ratio;\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] =\n",
       "        '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function () {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message('ack', {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () {\n",
       "        fig.push_to_output();\n",
       "    }, 1000);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'btn-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'btn-group';\n",
       "    var button;\n",
       "    for (var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'btn-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        button = fig.buttons[name] = document.createElement('button');\n",
       "        button.classList = 'btn btn-default';\n",
       "        button.href = '#';\n",
       "        button.title = name;\n",
       "        button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message pull-right';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = document.createElement('div');\n",
       "    buttongrp.classList = 'btn-group inline pull-right';\n",
       "    button = document.createElement('button');\n",
       "    button.classList = 'btn btn-mini btn-primary';\n",
       "    button.href = '#';\n",
       "    button.title = 'Stop Interaction';\n",
       "    button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n",
       "    button.addEventListener('click', function (_evt) {\n",
       "        fig.handle_close(fig, {});\n",
       "    });\n",
       "    button.addEventListener(\n",
       "        'mouseover',\n",
       "        on_mouseover_closure('Stop Interaction')\n",
       "    );\n",
       "    buttongrp.appendChild(button);\n",
       "    var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n",
       "    titlebar.insertBefore(buttongrp, titlebar.firstChild);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._remove_fig_handler = function (event) {\n",
       "    var fig = event.data.fig;\n",
       "    if (event.target !== this) {\n",
       "        // Ignore bubbled events from children.\n",
       "        return;\n",
       "    }\n",
       "    fig.close_ws(fig, {});\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (el) {\n",
       "    el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (el) {\n",
       "    // this is important to make the div 'focusable\n",
       "    el.setAttribute('tabindex', 0);\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    } else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (event, _name) {\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which === 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_save = function (fig, _msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "};\n",
       "\n",
       "mpl.find_output_cell = function (html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i = 0; i < ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code') {\n",
       "            for (var j = 0; j < cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] === html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "};\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel !== null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target(\n",
       "        'matplotlib',\n",
       "        mpl.mpl_figure_comm\n",
       "    );\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAAHgCAYAAAA10dzkAAAAAXNSR0IArs4c6QAAIABJREFUeF7sXQeYVNXZfrcvvfdepNddOgICIk005o9JxBKjJtjjb4wxxth+Y4lREyXGGls0pqgREEEQpNddOtJ7lbosyxa2/M93Z+8wOzuzc+4999x75/Adn3XZmVO+732/c+adc09JKCsrKwMnRoARYAQYAUaAEWAEGIGLBoEEFoAXDdfsKCPACDACjAAjwAgwAgYCLAA5EBgBRoARYAQYAUaAEbjIEGABeJERzu4yAowAI8AIMAKMACPAApBjgBFgBBgBRoARYAQYgYsMARaAFxnh7C4jwAgwAowAI8AIMAIsADkGGAFGgBFgBBgBRoARuMgQYAF4kRHO7jICjAAjwAgwAowAI8ACkGOAEWAEGAFGgBFgBBiBiwwBFoAXGeHsLiPACDACjAAjwAgwAiwAOQYYAUaAEWAEGAFGgBG4yBBgAXiREc7uMgKMACPACDACjAAjwAKQY4ARYAQYAUaAEWAEGIGLDAEWgBcZ4ewuI8AIMAKMACPACDACLAAVxEBpaSkOHTqEWrVqISEhQUELXCUjwAgwAowAI8AIXMwIlJWVITc3F82bN0diYqJlKFgAWoYsdoEDBw6gVatWsTNyDkaAEWAEGAFGgBFgBCQQ2L9/P1q2bGm5BhaAliGLXSAnJwd169YFkVK7du3YBWzkoFnGL7/8EuPHj7el/G006UoRXf0i8HT1jf1ypWs42ghz5iicrlTGnLkCs6ONqObszJkzxmTT6dOnUadOHcu2swAMgWzbtm34+9//jq+++go7d+5EQUEBOnTogGuvvRb33XcfatSoIQQwkUJkkBBUJQCFDOFMjAAjwAgwAowAI6AlArJagwVgSFg89NBDmDp1KiZNmoTBgwcjNTUV8+fPx7/+9S/06tULy5cvR7Vq1WIGkiwpMRsAQM/+aZ0hPfvXaZ2hrn4Rp7r6xn6J9Fh/5WHO/MWHiDXMmQhK/sqjmjNZrcECMCReVq9ejY4dOxqPb0PTI488gt///veGOLzrrrtiRpgsKTEbKH+cOH36dEOs2ln8KdKGF3loylxHvwhLXX1jv7zoKXJtMmdy+HlRmjnzAnW5NlVzJqs1WAAK8Lt+/Xr07t0bU6ZMwWuvvRazhCwpMRtgMSECke/yqB4MvHKY/fIKefvtMmf2sfOqJHPmFfL221XNmazWYAEowC1ttpgwYQJ+97vf4cknn4xZQpaUmA2wABSByHd5VA8GXjnMfnmFvP12mTP72HlVkjnzCnn77armTFZrsACMwW1JSQkuvfRS0OPhjRs3onPnzpVKFBYWgn7MZO7MOXXqVHATCK3Tox8KiNBEj29pnQD9mEkkL+XfsmULunbtajwCdqreWDaY6w1F7I2Ul+qPZK+Zl/wgv7p06WLgVVXeUBti1SubNxJH1GakeqPxSbEU7psd7mNxZDemYtUbjXsqt3nz5iBn9LfqOJHlM7y/RLKX2ti6davhV2iqKq6diBM3+nJVvsmOU15yHzoukh1uxIk59qjm3qsx38p4Yof70DGf2ooUf3Y+S/zAfaTPMyfjhLRGvXr1bG84ZQEYQwDSmr9XX30VTz31FH77299GzP3444/jiSeeqPTeRx99hOrVqxuvZ2RkGNu1p02bFhyUaEPJFVdcge3btxsfoGaix81t27bFF198geLiYuNl2pBCR77s2rULGzZsCObt0aOHsVN59uzZxq5lSklJSbjyyiuxb98+rFmzJpiXPshIwM6dOxd5eXnB16+++mocPHjQELlmuuSSS9CtWzdjEwwFmZkmTpyI48ePY8WKFcHX2rdvj549e2LRokU4efJk8PVx48YZh1QuWbIk+FqbNm3Qp08fLF26FMeOHQu+PmbMGENEL1y4MPganWuUmZlptHXkyJHg6yNHjjT+TbaZqWnTphg4cCCysrJA5zCaafjw4UhLS8OcOXOCrzVq1AhDhgzB2rVrsXfv3uDrQ4cONQ7vnjVrVvC1+vXrY9iwYQbmhL2ZqK2GDRsaHJmJdnyTbcQlcWqmfv36oUWLFvj888+Dr9GO8ssvv9wQGCQKzdS3b1+0bt0aM2bMAAlGSunp6Rg7dqyxM52+hJiJMCfsaYa6qKjIeDk5ORnE0Z49e7Bu3bpgXuKSOKUd7vn5+cbrNKheddVVxnFF2dnZwbwUIxQr8+bNM/gzE603PXr0KFauXBl8jdbMdu/eHQsWLDCOIjATzZjTF6Bly5YFX6OYpthevHgxTpw4EXyd+sC5c+eM181EfYX6DG28ojbNNHr0aAOXb775JvgabYTq378/Vq1aZWyMMtNll11m9IWvv/46+FqTJk0waNAgw1/y20z0JY/6KuFjpgYNGhhf/ghHwtNMtEGMBt2ZM2cGX6N1wyNGjMCmTZuwY8eO4OsDBgwAtUnrWs1EMTZq1CiDd+LfTDxGBJDgMSKAA48RPEbEGiNo3Jw8eTILwOAo6uA/zM0ft912G954442ou229mAGkbxYkluhDhz7k3Jg1IGjtfMOz8k2MPtzJLxJu9G1QpxlAEvPhvukwA0g+kCAzOXMjTqzElN281KfoSw35FbrTXocZwKp8i+cZwNBx0Zy5Cv1IUDmeODmzY9ocOvvm1ZivegYwdMynzzKdZgAjfZ45GSc8A+ig4AutypzVu+mmm/DOO+9Y2mkr+1xexCXVawtEbFCRR1e/CCtdfWO/VPQEtXUyZ2rxVVE7c6YCVbV1quZMVmvwI+AI/NPjXBKAN9xwA9577z1L4o+qkyVFJCRVB5aIDSry6OoXC0AV0aK2To5FtfiqqJ05U4Gq2jqZM/v4ymoNFoBh2NMu38ceewzXX3+9If5oStpqkiVFpD1dO42ufrEAFIlqf+XhWPQXHyLWMGciKPkrD3Nmnw9ZrcECMAT7v/zlL7j77ruNRfgkBMPFHy3mps0KsZIsKbHqp/dpHQGtLzDXTIiUiYc8uvrFnMVD9FW0kWOROfMTArrGo65+uTHmy2oNFoAhPfzmm282Zv2iJdpwEbr7MFo+WVJEBh3qNLQ7kkSpblfB6eiXORjo6BvHokiP9Vce5sxffIhYw5yJoOSvPKo5k9UaLAAVxIssKSIm6TptrqtfxKmuvrFfIj3WX3mYM3/xIWINcyaCkr/yqOZMVmuwAFQQL7KkiJikOrBEbFCRR1e/WACqiBa1dXIsqsVXRe3MmQpU1dbJnNnHV1ZrsAC0j33UkrKkiJika6fR1S8WgCJR7a88HIv+4kPEGuZMBCV/5WHO7PMhqzVYANrH3lMBSGsL6FYIuglEtzWAOvpFwcKcKehsCqvUlS+ORYVBo7BqXeNRV7/c6GcsABV2OLtVy5Jit10uxwgwAowAI8AIMAIXBwKyWoNnABXEiSwpIiblrMzBmtvXoO9rfVFnQB2RInGRR1e/CHxdfWO/4qJrVTCSOWPO/IKArrHoxpgvqzVYACroBbKkiJi07Z5tODT1EJrf0xydXu4kUiQu8ujqF4Gvq2/sV1x0rQpGMmfMmV8Q0DUW3RjzZbUGC0AFvUCWlGgmFewtwPnj54EEYP349Tj/3XmkNE5Bry97AWVASsMUpLdJV+CR2ip19YtQ09U39kttn1BRO3OmAlW1dTJnavFVUbubnMlqDRaACiJAlpRoJn2T8E1Ma2sPqR0zj98ynFl6JqZJtYcG/Iq64SUhShUWX3e6/tNfn47pW73L6wXyRLPV5ntVbg6SbOvkFydj+lV/Qv1AnrKQrKH/Lt8YU6GiKvJWqCe8bFi9dtvMWZgT0686wyIsuagKT7NGgTxCG7oE6okUS6fnxY7FuqPrxvQ/UgYhu0VqFvEtrJ5Tc07FrJn6GG02CCbBeIlaporyQmWq6gch7+WuzI3pW+1B5WM+YWfiV/7b4CXsNfo7yFfoe6FlzDEnVn12ygA4/unxmH41/H7DC2NHWWATXYXxhP40X6L3TNxCflcoE/a+8Z5smdD2y8e6iJwRTiG8XlZ2WUz/RTLIag0WgCIoW8wjS0q05o5+eBRbbt6CsuLw0QdAEtDqgVaoN7pcTFi0ucrsEZpzsvpT805h/x/3AyURaiW/ftkK9UYF/KowuIZmr8pGm+9FbStc1FRhx+lvTuPAywei+tby3paoMzzKGs5odlt83VHMytvOWZyDg389GNWvFne0QAWhFPrBHvYhX0k8VJE3XNhUKBsuHmy0eWr+KRx4qQq+7m+JeiOj9DEr/cRC3irjMLzLVFGvEYt/rjoW614WQwBasLtCtwgVX6KDh2BbpxecxsGpVcTiPS1Qd0TALzvxErVMFfEmVKaqflD+3qm5p7DvD/uij42/Kh/zQ8SQJVFkjmURhEy4OKokmOyUKW8vZ2kODr91GCiNEAyJQLPbmqHO0PJxMUSExhSuscRuLEFbLnwrtBOrTJgIPvV1dM4SkhPQ5d0uaHJ9E9FeUGU+Wa3BAtARGipWIktKVSblZuciKzOrUpbMrEzUyqilwBt3qtTVL0JPV9/YL3f6hpOtMGdOoulOXcyZOzg72YpbnMlqDRaATrJeXpcsKUICMJHuFgNQ/lsbAaiZXxUEoGa+BQc59kvBKKKmSuZMDa4qa2XOVKKrpm63OJPVGiwAFfAvS0pVJhUcKEBW/yyktUzDsf7H0GhVIxQeKETmqkykt4y/DSCmr7r6Rf7p6hv7pWDwUFwlc6YYYAXVM2cKQFVcpVucyWoNFoAKAkGWlFgmlRaWoiy5DDNmzMCVV16JhOIEJKbRNEx8J139IlZ09Y39ir8+x5wxZ35BQMdY3FdQgOPnz6OssBSlyWVYtGgRhg0bhsTiBCSkJaJhSgpapzszWSOrNVgAKugJsqSImET3J65fvx69evVCYmL8iz/TZ139MkQgcyYS2r7JoytfHIu+CTFLhugajzr5ReKv88qVKCiNtLslQHd6YiK2DhjgiAiU1RosAC11QbHMsqSItcK5GAFGQCUCc3fNxb1f3ouXx7+My9tfrrIp1+vW2TfXwXSpQZ04M2fJCLoVB1fgD0uex4NDf4WBLQYaaDo5S+YSPUYz2bm5yMyqvEkz3IaszExk1JLftCmrNVgAKogOWVJETKJvTcuXL8egQYO0mwHU0S9z1kVH33SMRTryYsCbA7D68Gr0a9YPK3+2MvoZlCId1kd5dPbtqx1fYcp/p+D1772OKzpe4SPU7ZkSfJxYVoYbP7sJ3x7fjK4Nu+GDa9434jEehZLbs2T2kLdXigWgPdy0KuWWAJw+fTomTZqknQDU0S8KcPpwuvU/t+LtH7ytxYeT2Wl19Gv2jtkY9+G44Lg06/pZGNtxrBbjlK6+6SZsdRVKboskJzvt+dJSnCstRX5JifH7XMjv/NJSbMzJwYP79sVsMqtnT2Q0aBAzX6wMslqDZwBjIWzjfVlSRJqkWRcdhZKOYoL41O3DyYzRePSruLQYhcWFKCwprPC7qKTIeK3gfAFum34btp/cjtKyUiQmJKJ9vfZ4YcwLSEpMMmZejP8i/Ka80d4zX4+Vx3hfoo2qyhNv4/4+Dhu+24CSshIkJSShd9PeWHTzIiQnJRt/m+VFxiE/5DFnyZbuX4Z7vrw7aNIr46diSKvBjs2SUSxQjIT+UByFvxbpb4oroXxUX2mgjaMJdTC//o9jQtzrwF9Qq+hwMF/oIdQUc2YyX4/0GuWx+3qs9sLrPpPaBEsa/SSmX8OPf4i6xd8F7YrUDr0WOI86CSUJyShJTEEJklGakIJi+jsh9N8pgTzmDy78HcibhBJcKGe8Vl4v/bsYySijvllWCvorqYxaKkYy/S6jd0tQUpaAYymNY/qWlZGBjNryt3bJag0WgDGpsp5BlhSRFnUUgPEoJkS4ojy6zrrE8iua2AoVX4bwiiDIwgWa+bcp1KK9H6tu+iCnlJKYgrTkNKQlpQV/pyalGh++u0/vrkRtrya9UC+9niEKy+i/MuP/lX4b70d5z3w9Vh7ZNqKVLy4pNgRGrERigMQuCUL6TaLQ/Lcnr5XbYQpU07a8xBp4I2mY8eEdLdEH9Q/zpiO1+LTBrYgYiyTsSDCbYobihmLF/KEYCv070r+DZRIvlKsq36GyGngst1ksqvBK4yJckhqQQRSPZgq9QcbJ10vKAheTFJeWoQQJKAZAr5m/6b3zZUCp8VoCissC+QJlgENFwPsFUW4/CvG2f/I5pCYCRUhAYVkCisrKfyPw79C/S5GARJQhDWVITShFakIZUo1/0+/A3ynlvyv8jVKkUH7KG/LvQN7SQBl6vfy9lLJSJBHGCeV4l99wY+K7ryQdLxR1iskZrwGMCVH8ZnBDAFLnzs/PR7Vq1bRZmxRLTIhGBGFzvvQ8zpecd/w3fYAI1R3SflFxEZbsX4Lcogv3etZMrYk+TfoE7+mMNFibr0UavM3XqioX+oEgW1ckG0hk7D29FwUlBUFqkhOTUT25uoERfdCaYos+6EKFlvlhGP5apTyJqZVEWiTRFv5apL9DbaB/k6gJT4TTwLcGIvtwtjFDZiYSHhnNMrDithVx29+q8q1v075YfMtigy/6Id9LSmlGI/A7/DXj75D3KZ/q1yLZdbCsBt5OHBBzaLg/ZQvap5RcEGxhAi6aeIsk7Eh8Op2Im8LSUuTRT0mJ8ZOVm4sbt2yJ2dSUZs3QODUV541xr9T4TaLL+Lv8tQp/m++X562QP0r50DyhN/SlJCSAfpLLf6ckJhp/R3rNzEOPT1edPRvTr/tbtkSn6tVRPTER1ZOSUI1+l/+7wmtJScbr1LarqaQEOHeuwo/xeLvgwngYzR4WgK4y5W5jbgnA06dPo27dunH7gWSykluYi03fbcJ1n15nCApTbNROrY2+zfqCZpGiia5Igiz8gzslKcWY7ZH+HVYHfWiI1Lvp2CY8s/iZSkH4f5f9HzKbZwb5Mx/BRHvUYc4+GL/pkvfyFF7O6XpC2wute9n+Zbh31r2V/Prgmg8wtsPYCrNqle77dbdLCrcW/iUkvGA8rwX8YMts3PTFPVGxeH/iK7ixS3ytc3RzPZnxpTtEoIWKNUO0hb4X4++z5SLPLENryejrBgmnGklJqJGYSNe7Y19R7NnayQ0bokW1akHhZYqwoCgjQZaYeEGkhYi1Cnmi5DPyhAg7U9wl0TKFkHFItJMp54xm5c6fDwizvLxKIi1ctAX/tpKX6i4sDLhcvXrgp0YNZHfujMzf/CYmFCwAY0IUvxncEIDx+Ai4oLgAW45vwcbvNho/JIzo94EzB9CkRhMczD1YifTHRzyOgS0HCgktU+AZwiwpBTQbFWmWx83I0nVGSUe/TJ+yDmWhNMIt9YlINAR7PM4C7s3PR7tli1GWmBI1/BNKz2P34EvRplo1N7uIVFuiYuLVjh3RPD09OLtmVbBRflr0T7NfdI4bCTRDqJk/Dv0dOouVlZODfmvWxMRndd++yKwT+5FqzIpUZqDZMhJMhYXIOn0a/fbujdna6q1bkXnyZGUBJyLUqL2UlAvizBRpsX7XqGGtDB3oHCKC3e5nslqD1wDGDEPrGWRJEWnRzwKQHr3SAnpD5H23CRuPBQTfrlO70LJ2S/Ro3AM9GvVA98bdjX93btAZI94doeVjN11nlHT0i9Z9tflTGxzNOxq1Czat2RR7frHHmN2Mp7T89AkMXrshpsnL+vTEoLryuxNjNlSegUQ3iavc8h+aGTP+XVwcfI3+Nl4Pe43+PlpUhC35+TGb61G9uvGYVFaw0aNImvlyI0lxRgcRlwsu4zc9lgz9W/S9WGVjvW+2S4KMUkoKsrp1Q78//SkmhCu/mIH+ReetCbJQgUcC0OVEY0jLVzOMm0AG7Qf+MvOCAXdNAJa3AhqlpGL/nVmOjCGyWoMFoIIAkSVFxCQ/CEBak7P71O7gjB4JPRJ8NMvXqEYjdG8UEHjmT9eGXVErrfLhlzqKCeJQ1xklXf0izvbn7Mexc8eMLkh9bOHChRg+fHjwqKXGNRobX2LiLYnOlMV6NEXc00xYqBizKtqCgq5c2NGsWs2kJNQK+TH+Tk6u8Jr5d2jefQV5uGtH5Q074fy4LWwtxQc9sjxzBqDZrpCf7HPnkNmuXcyqsh5/HBnbtlUUeMW0JYM2xyYBNEuVlhb5x857dsukpgKJiaBd251WrEBh+QaKSA6mJSRg28CBjtyWERNAhzMEx5CyMnSecBNqrNuMvN7dsHXm+8ZsoZNjiKzWYAHoMPlUnSwpIibRh9OaNWvQt29f5ecA0qBPj2lDH9vSvzcf24zqKdWDAs8UfDSzV79afRE3tBVJ5LyuM0q6+hUesG72MaHOIpFJVAD+T8OGxiNOc0bOnI0zRR79pj3U9Ag0kiALF20iQo5m5RJtzqplnziBzA2xZzadOnetSgpIdJ0+XUnIhQu7Sn9TGUr161/4qVcP+1q1Qudrr0UBibgoiW6U3VqnDlrTzFckYVZFWYlwki4avAlk2TLg7gtH92DqVGCwc0f3SBsqWUHpV1+h8Pbbkfbaa0i8wvmDyWW1BgtASYIjFZclRYFJwlV+l/fdhRm9kHV6JAJpJi90Vo+EHq3ds7MQ2DRIdzEROqMUiQQnvw0Kk+xARl39cgAaz6ugXZa7CwqwMz8/8FNQYFxRtZRmmWKke1u0QNfq1SPOvpkzbyTY3HoMGsve7DNnkJmdHSsbLJ27Ro81T52yLuRycgCa5aIDfkPFnMi/6VqwCCLYEEq0EeQnPwG+/ZampY1ZNHTtCrz3HhqmpsblLFmQMJoFHDgQWLUK6N8fWLEiIg4xCb5IM8hqDRaACgJHlhQRk2SvPDqVfyq4CSN0nd7ZorPo1qhbpXV6rWq3khJ6VfkU/tht06ZN6N69e9w/dgv3mWaUVq1ahf79+yuftRWJIafysF9OISlez8nz5ysIvKDYy8/H4aIiNEtNRYdq1YI/iWVleHjPnpgNxHoEHLMClzMYt2UsW4aCKmYQ00tLsTUhAa3p8aqIsKNNBjVrRhZx9epVLe5oA43N2cwqoZs9Gxh34WYazJoFjI2vHdvR/KNZsoIpU5D++utKZslcDskKzakeG2W1BgtABdEhS0osk6wcmJxXlGc8qjV33prr9Gimr3PDzpXW6bWr2844+NWr5Ie1jap819U39sv5iCktK8OhwkJj9i5U3O0on9GjjRNt09PR0RR56elBsdcuPR3Vwh79+epRqRW46DgP87GqKd7Cfu8rLMRxmjmKdLZcYiIa1qyJ1iTKRGbiKA+JPJrJ81Oig8UHDEDC6tUo69cPCStXqhGaHvis6/hBUKr2TVZrsABUEPCypMQyKdKByZe1vSx4xIp5vAqJvn05+4xrrEI3Y9Bj3EsaXGIciuq3pLrDeOmvrr7p5FdwbVKUTSANU1Ice+RGB//uCRN4puCjR7h03poxixci7sy/W6WnW3oMq+RRqWhnoseW9Pg5koCLIuqCeUnU0ayaOfNGv0P/bQq2/fuB556rbJFmM2Vnb70VNd9+W6uZMp3Gj0hPfVRe2SqrNVgAig5iFvLJklJVU8EdmIezjJP36WBeOq2eDko2j1gJXafXpWEXVEuJn3O9eDCwEGg+yaoLZ8bjxJUrUUCCJUqiDRJbBwwQFoFniouNGTxj5q589s6c0TtQWGgcTRJJ4JHQI7Eps7421AWhR6VlZdg6eHBk32itFh23EvoYlcRbLAFH79MMnjkDF03AmULO/B0q8mhzQ6xUvpasLDsbCSUlKEtKQkJGhlZrynTpZ26LpFiho/J91ZzJag0WgArYlyWlKpOiHZnyyQ8/wfe7fl+BN+5WSQI3NzcXtWrVcuzDz10Poremq2+6+CW6UzZ0nRz5fqSoqJK4M8Xe6eJitElLq7AezxR87atVM86lcyvty8/H8cmTL2wmMBumTQWNG6Ph+PFoffRodFFHmxHowOFIIq0qAUfv0Zo6FWvjQsHTeJ0cualLPwuPd139coMzWa3BAlDB6CtLSjSTdLx9gQcDBQHocpW6DOCiAvD6xo2Ng4npce2u8kOIgxsuQh7X0vq81mlpSHb7jtJw/mkGbvVqgNaNzZgB0NEb4YmOqOjRo2pxV7du4Fw5vyaN18m5ISa8olWX8SMSfqp9k9UaLAAVRL0sKdFM0vXA5FB/VU+ZK6BbuEpdfdPFL1EB+LOmTXFp3brB9XlNUlP9M1tNNy+sWxcQe+YP7f7t2TNwzAb9vPgiyrZs0fJRKe0o1XGdHA0yuvSz8AFTV7/c4ExWa7AAFP74Fs8oS0q0bxID3xoIHe8pZQEoHlt+zBnPAzjtpl155gyW5ORg5smTWCZwVp5vjkqh67W2bq0o9uhQ5DZtgAEDLvz06RM4JNhMGj8qjedYjNW3dfVNV79YAMaKaE3fVyEAdT8w2QwFHgzir1PEE2dHCgux5MwZLM7JMUTfurNn0bl6dVxapw6ap6bid349K482ORw4EBB7dGgu/abHunQDBB2kawq+fv0Cu2SrSho/Ko2nWLTa03X1TVe/WABajXBN8qsQgATNxXBgsuqDM70MMV1986tfdJbet+fOGUKPfkj00YaNAbVrY2jt2oboG1S7NuqWXxov+gjYlRlA2j1LQs8UeyT46EgUeoRrij36d8uWtjZX6Hr4rl9j0YlxR1ffdPXLFIAqD/+X1Rr8CNiJnhlWhywpCkziKhkB7RGgK9BW5+YGZ/fo6rPUhARD6A0t/+lbsyZSomzK8EwA0rq9tWsrPsrduxfo1Ssg9kzR17mzvzdhaB9h7CAj4C8EZLUGC0AFfMqSImISfWtas2YN+vbtq921Yjr6ZX4b1NE3r2LxWFFRYHav/JHumtxcY2NGqOBrn54uvEFDxTmAlfoyrdvbsqWi2Nu4EWjXruLsXu/eFdftiQwKFvJ4xZkFE21l1dUvHj9shYPnhVTHo6zWYAGoIERkSRExSdd1E7r65cZ6EJG4UZHHDc7oOIVt+fnB2T0SfnQFWP9atYzZPRJ9g2vXRv3yx7l2/dy3axeOnzhhFCe/srOzkZGREfyS1bBhQ7TiiQvjAAAgAElEQVQmsSaSaN0e3VBh7salx7m0bq9WrYqbNGjdHh2x4mJygzMX3Qk2patfPH54EU3ybaqOR1mtwQJQnuNKNciSImKS6sASsUFFHl394gHcWrTQNWlZubnBtXv0OJeSMbtHa/jq1EFGrVpIc/KMvcLCwA5aOgw5WmraFKCNImlplXPQLRnh6/bOnas4s0ePdFu0sAaGgty69jNd/eLxQ0EncKFK1fEoqzVYACoIAllSRExSHVgiNqjIo6tfug3gTt+Ze+L8eSwt36xBj3RpLR/doGHO7tHvS6pVE36cays2y68TQ1YWTf9VroLEZmZm4HqxSOv29u0D6NFt6CYNWrfnpEi15VjlQrr2M1390m38CI1I5sx+p5bVGiwA7WMftaQsKSIm0SOx06dPo27dumo/FEWMcTCPrn4RRLr4JrtWjnCgq9JCj2OhGzUyyx/nktgbUrs2GqWmOhhZglWFn5EXXmzCBODwYYDW7XXoUHGTBom/SDODgk27mU2XWAzHTFe/dBo/mDPnerqs1mAB6BwXwZpkSRExiQa6/Px8VFM9KyJijIN5dPXLHMB14Mzqbtki2rB09mzwOBZav3e+rAxDytfu0SPdfrVqId0P14yZs4DZ2QBt2AhNtE7vV78KnLtH6/boXtw4Tbr2M1390mn8iCQAdRgXIw0FquNRVmuwAAxj7R//+Af++Mc/YvPmzahRowbGjBmDZ599Fm1obZBgkiVFpBldp8119Ys41cU3UQF4S9OmxkzfytxctKDHueVr92gdHx2+nJiQIBLq7ub57jvggQeADz6o3O6sWcDYse7ao6g1XWIxHB5d/dJp/GDOnOvUslqDBWAIF1OnTsU999yDoUOH4oYbbsDx48fxpz/9CWlpaaDDHJs3by7EnCwpIo3oOtDp6pdOA7ioALy+cWN8v1Ej43FuU78/Gl2zBnj5ZeA//wGuvNK4T7ds2zYt78vVKRZZTIh8Wvg7D4/59vmR1RosAMuxP3HiBNq2bYtOnTphxYoVSE5ONt5ZvXo1BgwYgFtuuQVvvfWWEFOypIg0omun0dUvnT50RQWgKzdmiHSWaHmKi4HPPwf+/Gfg22+BKVOAO+4I7NLV+L5cnWKRBaBMB/BHWR7z7fMgqzVYAJZj/7e//Q233nor3n33XfzkJz+pwMhll11mnAdGM4KpAgvTZUkRCQfqNMuXL8egQYO0OwhaR7/MD9149Y3WstCxLJ8dP45/fPcddtMu2BjJtwKQrlmjL3NTpwbO3/vFL4DrrgOqVbvgkcb35cZ7LFYVdrqOi8xZrNHGn++rjkdZrcECsDxubr/9drz++uvYtm0bLrnkkgrR9PDDD+OZZ57BunXr0IuuZ4qRZEmJVT+/zwi4gcD50lIsyskxRN9/jx83mvxew4boXr067ti+PaYJvhOANMtHj3k//BAYPTog/EaMiH6X7ty5wL33BspcfnlMfzkDI8AIMAJuIiCrNVgAlrM1adIkzJgxA+fOnTN21oamV199FXfddRe++OILTKBjIMJSYWEh6MdMREqrVq1w6tQp1K5d23g5ISHB+KFvBKEpMTHROB6Efswkkpfq2bBhgyFIk5KSHKs3lg1kGyUReyPlpbLkczgOZt6SkhLDr549exr5qsobakOsemXzRuIoHAfThmh8FhcXV/LNDvexOLIbU1RvXkkJ5pw+bQi+GSdOoFlqKq5u0MAQfrRTl3jKOnMG/WnNXIy0OiMDdPduLHvtxIkwn6WlKJs5EwmvvBI4pPmWW5Bw990oDdvUFckGitGNGzcasWi+b/ZlK9xbyevkGFEV7lX5JmuD6jGiKu5Dx0WzH4SPt9HGHuGYChv/qur3TnLv1ZhvZTyxw33omE+fZZHiT+kYEYVPK3ES7fMh0ueZE58lpm2kNerVq4ecnJyg1og1Loe+zwKwHI3Ro0dj3rx5IMIo4EOT+Xj43//+N37wgx9Uwvfxxx/HE088Uen1jz76CNWrVzdep+ukSBROmzYtKJ5IaF5xxRXYvn27sevYTL179zbWI5LgJNFAiR49jx8/Hrt27TJEhJm6d++Ojh07Yvbs2SgofyxHnejKK6/Evn37jPuCzdSlSxd07twZc+fORV5eXvD1q6++GgcPHjTWO5qJZkG7deuG+fPng4LMTBMnTjQehdM6STO1b9/e+JBctGgRTtJtCOVp3LhxyKXbHJYsCb5Gu6n79OmDpUuX4tixY8HXabc1ieiFCxcGX2vZsiUyMzONto4cORJ8feTIkca/yTYzNW3aFAMHDkRWVhYOHDgQfH348OHGJp45c+YEX2tEGxOGDMHatWuxd+/e4Ou0+adWrVqYRbs9y1P9+vUxbNgwA3PC3kzUFl0LRhyZicQ+2UZcEqdm6tevH1q0aIHPab1ZeaId5pdffjm2bt2KLXQ3bHmiu51bt25tfBmhWKSUnp6OsWPHYufOnYYgMRNhTth/+eWXKCoqMl6mtavE0Z49e4wZazMRl8TpV199ZRwfRIkG1auuugrr9+zBW5s3Y0VKCtYlJ6NLaiomt2qFJjt2oG5ubrAO+pJ09OhRfLFqFe6sVQvnq9jFm56QgCUdO2J/SExRTFNsL168GLTm1kzUB+iLF71uJuor1GfokTm1aSbqp4TLN998E3yNNmf179/f2Kh16NChAA75+Ri1bx/S3ngDeQUF2DVxIvaPHImGbdsayyZoScd+uqatPF166aVGXyV8zNSgQQPDTrKb8DTT4MGDjUF35syZwdfoPM4RI0Zg06ZN2LFjR/B1Wj/cpEkTTJ8+PfgaxdioUaMM3ol/M6kaI3r06IEOHTpUGiMIR+qL1A/MpMsYQct2KL51HCOIMxpH3RwjqK9QnzETfY5QrNBnJo3xZjLHiJV0/WF5os8n+pxasGCBcXatmWgyhSZJli1bFnzNzTGCGqU4oc/Lr7/+OmgD9VcrYwSNHTTWejFG0Lg5efJkFoBB9mz+o6oZwL/85S+4++67fTcDSOKDhJ5uM4DkF4kYHWcAw33zagZwb0EBpp04gf+eOIEVZ85gWJ06xkwf/TRPT4/5Ldy8CYQ+ZMkHEu6XDhsWPNqFDnFunZ6ubKY46mzNrl1IoLV9774LDB5sPMItGzOmwm0corPK9C3b7GM6zgBG8y3eZwBNv3ScAfRizHdjBtAcF3WcARQZ80m2RBrTYn0+8AygTcEXXize1gDqunNKV78o3rz0jQaSTXl5wfV82/LzMb5+fVzTsKHxu25Kiu2e5KVfhtG0fIJmg2k3L/2+8UbgnnuALl1s++Q1X1KGCxT2nDMBG+1k0dUvneORObMT6YEyvAbQPnYVSr799tu47bbbou4CpkeL9DjIL7uA6QOd7KHHVKGzEw7B4Vk1uvplfsNzk7PSsjIsO3PGWM/32bFjOFNSgqsbNjTW842uW9exmzc844weZf/974FNGmfPBkTfLbcEdvY6kDzzywHbY1Whq2+6+uXF+BErhpx6nzmzjyQLQPvYVShJ69poXQWta4h0DuBPf/pTkEgUSbKkiLRBnYbWfZEg1U0A6uiXOYCr9q2wtBTzTp0yZvqmHT+O6klJxiwfiT66ei1Jwe0brscirfH8y1+AN98EevYM7OadNAlw+Co51/0S6fgO5dHVN139cmv8cCi8LFXDnFmCq0JmWa3Bm0BC4Pzzn/+M++67z7gJ5MYbbzQ2O7z00ktISUkxNkjQQn6RJEuKSBu6Tpvr6hdxqsq3M8XFmEnr+Y4fx8yTJ9GhWjVD8JHw61mjhvIvCKr8qtAP6DEvLRanx7y0+eKHPwwc0dK7t0h3sZXHFb9sWSZfSFffdPVL5fghH01yNTBn9vGT1RosAMOw//DDD/HCCy/g22+/NXYF0u5UOgOwXbt2wizJkiLSkK6dRle/nB7AjxQWGps4aKZvwenT6F+rliH46BFvu7BjjETiSSaPUs5od/O//hUQfrTD9847gZ//HGjUSMZkobJK/RKyQF0mXX3T1S+nxw91kWW9ZubMOmZmCVmtwQLQPvZRS8qSImKSrp1GV7+cGMB3nDsXWM93/DjWnj2L0fXqGTN9kxo0AO269Sop4YyOfnnttcAPndlHj3npCCaJzSpW8VHil1UjFOXX1Tdd/XJi/FAUStLVMmf2IZTVGiwA7WPvuQCk8/XocXX4uYUKXHKtShoMdPLLPC7FHMDXrluHPr17BzlrmJJiHJcSKdHamDVnzwZ37u4vKMCVDRrgmkaNMLZePdQsv6/aNXKiNOQoZ3TWGM32ffopcNVVgce8Awd64qKjfnniQfRGdfVNV7/M8UOnsdGMTubM/uDAAtA+dspKypKizDCu2FUESPx1XrkSBWG3v4QakZ6YiK0DBgRFYHHY9WslZWXGLB/9jKhbF6lhh5S76pCqxuiw8//+NyD86GDkKVOAO+4AmjdX1SLXywgwAoxA3CMgqzV4BlBBCMiSImISzQ7RrRB0yr9uu4B18Ss7NxeZWVkx6Vzcty+OFRUZj3ennziBRikpxiwfremj69cSFezcjWmUhQy2Y5FujXnrrcCO3nr1Ao95r7uOrj6x0Lq6rLb9UmeSYzXr6puufhHxuvqmq19ucCarNVgAOjakXqhIlhQRk3RdN6GTX6ICkK5N61WzZnDnbpcaNURCwDd5LHO2aVPg7L6PPgLolg4SfsOH0910vvGJDLHsl6+sr9oYXX3T1S+d45E5sz9wyGoNFoD2sY9aUpYUEZN07TQ6+SUqAGf27InxDRqI0O6fPHSPbvldzsQZXQVH9y4H16M2bgy0bHnBXnoMTse30GNemhW99VbgrruAtm3941OYJTrFYjjIuvqmq18sAH07TFRpmOp4lNUaLAAVxJUsKSImqQ4sERtU5NHJL1EBmJWZiYxatVTAqabOwsLAzlzaqRstNW0K7NkDUF66l/eVVwDatEKbOuiqtpo11djmYK06xSILQAcDw6OqdI1HXf1yQ7TLag0WgAo6sywpIibRuomjR4+iSZMm2q0B1MUvbQUgHcpMO3NpJi/SBhfaqNK9OzByJPDee8CQIYHHvPS4N442sejax2h80dU3Xf1izkQ+Ff2XR3U8ymoNFoAKYkaWFBGTKLBKSkqQlJSknQDUxS9tBSAF6OzZwLhx0UOVDqOme3npft7OnUVC2nd5dO1jppjQpZ+FBg5z5rtuFNMg5iwmRFEzyGoNFoD2sVdGiohJuk6b6+TX0pwcDF2zJiadcfcIOKAgArOAdG5fSUlFH1u1AtatC+zsjeOkUyzyI+A4DsRy03WNR1394kfA8d/nbHkgq8pFGtW10+jiF53fN3H9esw5dQqlVRAafg6gCPe+yUObOiZOrGzOrFnA2LG+MdOuIbrEYiT/dfVNV7/cEBN2+4lsOebMPoKyWoNnAO1jzzOACrDTYTCgRxp3b9+OrNxcvNelC/LK18lF2i1b1U0gCuB1pkqa/SPx9+CDwO7dKCssREJpKcpoOUJGBrBihe+OdLHjuA6xGM1vXX3T1S8WgHZ6sPdlVMcjC0DvOa5kgSwpIi5RYC1YsAAjRozQ7iq4ePfrmb178e6RI1jSty8ahtzRqwVnK1cGhN/evcBTTwH16wMTJlwIWU1m/8wP3HiPxaoEoI6+adHHopCmq2+6+uXGGCKrNXgGUERtWcwjS4rF5ji7jxB478gR/GbXLkP8taONELqkHTuAhx8G5s0Dfvtb4M47gbS0C2sBV60C+vfXZvZPF9rYD0aAEdAXAVmtwQJQQWzIkiJiEj1m/Pbbb9G1a1ftdgHHq1+zTpzA5G+/xde9e6NvhHP94pKz774D/u//gPffD4i+X/8aqFu3QoiWzZmDottvR+prryGBjnrRJMUlX4LY6+qbrn4Rrbr6pqtfbnAmqzVYAAoOmFayyZIi0pbqtQUiNqjIE69+rT5zBlesX49/duuGMfRYNEKKK9/y8oAXXwReeAH4/veBJ5+seLNHiH9x5ZeFoNXVL4JAV9909Ys5s9BxfZRVdTzKag0WgAqCRZYUEZNUB5aIDSryxKNfO/PzMTQ7Gy907IjrmzSJCktc+FZcDLz9NvD440BmJvDss0CPHlVSHRd+2QhWXf1iMWEjGHxQRNd41NUvN/qZrNZgAaigY8uSImKSrp0m3vz6rqgIQ7KzMaV5c/yqdev4FUq0s/fzz4Hf/Aagx9fPPw+MGCESijybJISSvzLFWz8TRU9Xv9wQE6IYO52PObOPqKzWYAFoH/uoJWVJETGJ1k0cOnQIzZs3124NYLz4dba4GCPXrcOQ2rXxp44dY/LgW86WLgV+9avA3b5PPw1ce62lY1x865dIR6oij65+kcu6+qarX8yZZGf2qLjqeJTVGiwAFQSGLCkKTOIqHUbgfGkprt64ETWTkvBxt25ITEhwuAUXqtuyJTDjt2QJ8OijwM9/DoQcW+OCBdwEI8AIMAKMgE0EZLUGC0CbwFdVTJYUEZN0nTaPB7/oW90tW7did34+ZvXqhfSkJBHK/POo9PDhwBq/jz8GfvEL4IEHgNq1hXyIlCkeOLPjnK5+ERa6+qarX8yZnR7sfRnV8SirNVgAKogRWVJETFIdWCI2qMgTD349smsXPj9xAov69EHdlBRhGDz3LTc3sLbvz38GfvzjgAhs1kzY/mgZPfdL2oPIFejqF4sJRQGjuFpd41FXv9zoZ7JagwWggk4rS4qISbp2Gr/79deDB/HMvn1Y2rcvWqani1AVzOOZb0VFwBtvBM7zGzIEeOYZoEsXS7ZXldkzvxzzgAWgYihdq17XWHRDTLhGUlhDzJl95GW1BgtA+9hHLSlLiohJ1GnmzZuHUaNGaXcVnF/9+u+xY7ht61Ys6NsX3WvUEKGpQh7XOaOdvf/5T2CdHx1P84c/AEOHWrY7VgHX/YplkEPv6+qXKSb82s9k6GPOZNDzpixzZh93Wa3BAtA+9p4KQAVmc5VVILAkJwdXbtiAaT16YFjYTRi+BG7BgsCdvTk5gbP8rr7a0s5eX/rERjECjAAjwAgEEWAB6MNgkCVFxCXaiLBt2zZ06tQp5vEjIvX5JY8f/fo2Lw/D167F65064fuNGtmGyhXfNm4EHnoIyMoKrPG79VYgOdm2zSIFXfFLxBCH8+jqF8Gkq2+6+sWcOdy5XapOdTzKag2eAVQQCLKkiJik67oJv/l1qLAQg7Oz8atWrXB3y5Yi1ETNo9S3AweAxx4DPvkE+OUvgfvvB2w8prbjoFK/7BjkUBld/SJ4dPVNV7+YM4c6tcvVqI5HWa3BAlBBQMiSImKS6sASsUFFHj/5lVNcjOFr1mBCgwZ4pn17aXeV+Hb6NPDcc8CrrwI33hg4z69xY2lbrVSgxC8rBijKq6tfLCYUBYzianWNR139cqOfyWoNFoAKOq0sKSIm6dpp/OJXYWkpxq9fj1ZpaXi3SxdHHrM76lthYUD0/f73wKhRgd+XXCISOo7ncdQvx62zX6GufrnxwWQfdbmSzJkcfl6UZs7soy6rNVgA2sc+aklZUkRMorUF+/fvR6tWrRwRJyJtupHHD36VlpVh8ubNOF1cjOk9eyIlMdER1x3xrbQU+Mc/gEceAdq0CezsHTDAEfvsVuKIX3YbV1hOV78IMl1909Uv5kxhR1dYtep4lNUaLAAVkC9LigKTuEoLCNy/YwcWnj6N+X36oJbiDRQWzALmzg3s7KVz/eix74QJvLPXEoCcmRFgBBgBfRCQ1RosABXEgiwpIibRtPnMmTMxYcIE7c4B9NKvF/bvx6sHD2JpRgaaOHwvrm3O1q4Ffv1rYNMm4MkngZ/8BBC8fk4klmTz2PZLtmHF5XX1i2DT1Tdd/WLOFHd2RdWrjkdZrcECUAHxsqSImKTrugkv/frH0aO4b8cOLO7bF5dUry5Cg6U8ln3buzfwqPeLLwIzf/feCyiwy5ITETJb9ku2QZfK6+qXKSamT5+OSZMmafcFUke/mDOXOr3DzageQ2S1BgtAhwmn6mRJETFJdWCJ2KAij1d+fX3qFH6waRNm9+qFAbVrq3BN/OiNkyeBp58G3nwzcI7fb38LNGigxCYnKvWKMydsr6oOXf1iMaE6ctTUr2s86uqXG/1MVmuwAFTQV2VJETGJOs2cOXMwZswY7b7Bu+3X2txcjF63Dh907Woc+aIqxeQsPx945ZXAzR3jxwNPPQW0a6fKHMfqjemXYy25W5GufpkfTG73MzfYY87cQNnZNpgz+3jKag0WgPaxj1pSlhQFJnGVURDYk5+PIWvW4Kl27XBLs2bO47R/P3DsWPR66cw+aveDDwJn+HXuHNjgkZHhvC1cIyPACDACjIA2CMhqDRaACkJBlhQRk2h7+a5du9C+fXvtjoFxy68T589jaHY2rm/SBL9r21YEdmt56Kw+Oqrl6NHo5erVA5o3D1zXRke6XHGFtTZ8kJtj0QckWDSBObMImA+yM2c+IMGiCao5k9UaLAAtEiqSXZYUkTZ0XTfhll/nSkpw+bp16FWjBv6q6j7lsjJg4MDAvbx0fl+kRDuNaa3fDTcADp03KBI/TuZxizMnbRapS1e/yHddfdPVL+ZMpMf6L4/qeJTVGiwAFcSMLCkiJqkOLBEbVORxw6/i0lL8z6ZNSADwSY8eSEqgfylKs2cD48ZFr3zaNGDSJEWNu1OtG5y540nFVnT1i8WEF9Ek36au8airX270M1mtwQJQvl9WqkGWFBGTdO00qv2iKfk7tm3D+rw8zO3dG9VVn6dnzgJmZwMlJReopXZpnd+KFXF/mLNqzkT6g4o8uvrlxgeTCj5E6mTORFDyVx7mzD4fslqDBaB97KOWlCVFxCQSMrt370a7du20WwOo0q//27MHH333nXHWX4OUFBGo5fNEmwWcNQsYO1a+fo9r4Fj0mAAbzTNnNkDzuAhz5jEBNppXzZms1mABaIPUWEVkSYlVP79vD4G/HT6MR3bvxrKMDLRJT7dXiZ1SNAtYty6Qm0uXsAZu8dBk9s8OHFyGEWAEGAFGQB4BWa3BAlCeg0o1yJIiYhJNm8+ePRtjx47V7hxAFX59ceIEbvr2W3zduzf61KolArFzeRYvDqzzO336Qp2azP6RQxyLzoWKWzUxZ24h7Vw7zJlzWLpVk2rOZLUGC8DySDh48CDef/99zJo1C9u2bTNu82jbtq1x1+5DDz2EBhYOCJYlRSQ4dV03ocKvlWfOYOz69fike3eMomNX3Ew04zdyJPD976Psgw+QsHo1yvr1Q8LKlXG/9s+EUQVnblIUrS1d/TJFu45XpjFnfug51mxgzqzhFZpbVmuwACxH87XXXsMvfvELjBs3DsOHD0ft2rWxcuVKvPvuu2jWrJnx76ZNmwoxJUuKSCO6dhqn/dp27hwuXbMGf+7YEdc1aSICrbN55swBbrsN2LYNpQsW4Oytt6Lm228jMQ7P+7vYhJLTsehsYMnVpqtvuvrFol0u3r0qrToeZbUGC8DyyNi0aRPq169viL3Q9NZbb+FnP/sZHnjgATz//PNCcSRLikgjFFhffvklxo8fr90jYKf8OlpUhMHZ2birRQv8slUrEVidzWPuAJ4yxbjTlzlzFl7VtenKlykmnOpnqnmwUj9zZgUtf+RlzuzzIKs1WADGwN4EmNba0eNhkSRLikgbnKdqBHKLi3HZ2rUYUbcuXuzY0Ru4Pv8ceOABYPNmwK0dx954yq0yAowAI8AIuIyArNZgARiDsG+//RbdunXDjTfeaKwRFEmypIi0QdvL9+7dizZt2mh3DIysX0WlpZi0YQPqJSfjo27dkKjyoOdoZNHNH336AA89BEyebORizkQi2z95dOWLY9E/MWbFEl3jUVe/3OhnslqDBWCMHnjttdfiP//5D+bOnYvRo0dHzF1YWAj6MROR0qpVK5w6dcpYS0gpISHB+KHp7tCUmJhoCAP6MZNIXqrniy++wJVXXomkpCTH6o1lA9lmBradvFSGfA7Hway3pKTE8GvixIlGvqryhmJm1kvlb966FQcLC/FFz55ILz/oOVLeaDZEyhuJo3AcTBuMvP/4BxKeeQZla9YgISnJ4L64uLiSb3a4j4W73ZiKVW807skH2lBgcmbGu8o4keVThPvQPmb6Hs23CtyH9eUq48Riv4/FkSj3VfkmO06pHiOq4j7ULxOL8PFWhPtY45QjY4RF7r0a80Vjym6/Dx3z6bMsUvxFiik7HLnNfaTPM8ufJVXECWmNevXqIScnJ6g1rHyp0E4AFhUV4emnnxbG4OabbzZ2+0ZKtObvwQcfxG233YY36b7WKOnxxx/HE088Uendjz76CNWrVzdez8jIMEThtGnTgmKvWrVquOKKK7B9+3ZspseE5al3796GTSSESDRQSk1NNdb77dq1Cxs2bAjm7d69Ozp27GgcCVNQUGC8Tp2IhOG+ffuwZs2aYN4uXbqgc+fOhpjNy8sLvn711VeDdkGvXr06+Noll1xizHzOnz/f2BFtJvqQP378OFbQDRblqX379ujZsycWLVqEkydPBl+nDTW5ublYsmRJ8DWasezTpw+WLl2KY8eOBV8fM2aMIaIXLlwYfK1ly5bIzMw02jpy5Ejw9ZG0qxYwbDMTbdAZOHAgfrp0Kb7Jz8fvz55FDcDY0JOWloY5tBmjPDVq1AhDhgzB2rVrjVlUMw0dOhS1atWq8Kif1oUOGzbMwJywNxO11bBhQ4MjM5HYJ9s2r1+P1uPHY9NNN+HIoEHo168fWrRogc/pkXB5qlGjBi6//HJs3boVW7ZsCb7et29ftG7dGjNmzAANHpTS09ON43527tyJjRs3BvMS5oQ9reWiuKeUnJxsCLE9e/Zg3bp1wbzEJXH61VdfIT8/33idBtWrrroK+/fvRzbdVFKeKEYoVubNm2fwZ6ZJkybh6NGjxoYoM1Hsde3a1RCAoYl2z9MXoGXLlgVfppim2F68eDFOnDgRfJ36wLlz54zXzUR9hfrM8uXLjTbNRF/CCJdvvi+uC5wAACAASURBVPkm+Frz5s3Rv39/rFq1CocOHQq+ftlllxl94euvvw6+1qRJEwwaNMjwl/w206WXXmr0VcLHTLTzn+wkuwlPMw0ePNgYdGfOnBl8rW7duhgxYgRoLfGOHTuCrw8YMADUZig+FGOjRo0yeCf+zaRqjOjRowc6dOhQaYwgHKkvUj8wky5jBHFP8R1pjMjKysKBAweCPnsyRmzebIz7ZrIyRhBnNI7G0xhBn1MLFizA6ZCjsHQZI2jsoLHWizGCxs3JkyezADQ70tmzZ40PcdFEAwQNFuGJBN+UKVOMXcH//e9/DQEWLfEMYOTZTTvf2mRmAF89dAjP79+PJX36oHlamkGXHRukv92//Tbw2msoW77cOOrFnNHlGUDn4oRnAOWeKPAM4IXR3JMxIo6e+vAMYCBWqoqTaLN6PAMoqsR8lO9vf/ubMetHsw30zZ1mYKwk2efyIm1RwNFMA83AhD6eEinr5zx2/frk2DHcvm0bFvbpg641aO7Po0RLATp1At54o9I1b3Z988gT4WbZL2GofJOROfMNFcKGMGfCUPkmo2rOZLWGdo+AZZl/5513DPFHs4I0xU6Paa0mWVKstnex5190+jSu2rgRM3r2xNA6dbyFY+pU4F//AhYs0OagZ28B5dYZAUaAEWAEIiEgqzVYAIagSoc+33rrrVLij6qTJUUk1OkRDq3lo3VkNEWvS7Lq16a8PIxYswZvde6M7zVq5C0M584BHToEBOCwYZVsseqbt86It85+iWPll5zMmV+YELeDORPHyi85VXMmqzVYAJZHCm3OuOaaa4ydNH/4wx8qzfzVrFkT3/ve94TiSpYUkUZUnzAuYoOKPFb8OlBQgMFr1uDh1q1xR4sWKsyxVicdFE4bDqKcF2nFN2sNe5ub/fIWfzutM2d2UPO2DHPmLf52WlfNmazWYAFYzmq0nbwm6bTrKnSXT1XBIEuKSKCpDiwRG1TkEfXr9PnzGLZ2La5u0ABPtW+vwhRrddJOabKDxF+/fhHLivpmrWHvc7Nf3nNg1QLmzCpi3udnzrznwKoFqjmT1RosAK0yKpBflhSBJoxz9GiNIh33otsj4Fh+FZSUYOz69WhfrRr+1rmzPzbB0DFAdJzGZ59Fpe9i5kwkpv2WR1e+CGddfdPVL+bMb6ODmD2q41FWa7AAFOPRUi5ZUiw1dpFlLikrw483b0ZeSQk+79EDKX5Y/0hn2tF1c4sWAT16XGSMsLuMACPACDACXiAgqzVYACpgTZYUEZNoezkdZkqHJet2DEw0v8jnX+zYgWVnzmB+796omZwsApX6PHTdGx0q/OGHVbZ1MXKmHnx1LejKFyGmq2+6+sWcqevnKmtWHY+yWoMFoAL2ZUkRMUn12gIRG1TkqcqvP+zbhzcPH8aSvn3RuIqDuVXYFbVOuqGkc2cgKyswC1hFuhg5c5ULhxvTlS+CSVffdPWLOXO4c7tUnep4lNUaLAAVBIIsKSImqQ4sERtU5Inm1wdHjuBXO3diSUYGOtg4m1GFrUad994L0NVqVVwVaLZ9sXGmDHOXKtaVLxYTLgWQw83oGo+6+uVGP5PVGiwAHe6kVJ0sKSIm6dppIvk15+RJ/HDzZszp1Qv9atcWgcedPPv2Bdb80f28rVvHbPNi4iwmGHGQQVe+3Phg8ope5swr5O23y5zZx05Wa7AAtI991JKypIiYRGsL6CL5zn7ZBStidJQ8+woKcPz8eeNd8mvP3r1o26aNsbbx23PncNe2bfi4WzeMa9BAohUFRW+7DaheHXj5ZaHKdeIs1GH2S4h+X2ViznxFh5AxzJkQTL7KpJozWa3BAlBBuMiSosAk31ZJ4q/zypUoKC2NamNKQgJ2DByI1hbvZFbq9PbtgfP+tm4FmjZV2hRXzggwAowAI8AIhCMgqzVYACqIKVlSREyiafNvvvnGuLYuns8BzM7NRSZtoIiRsjIzkVGrVqxs7r1//fVAq1bAs88Kt6kLZ+EOs1/CIeCbjMyZb6gQNoQ5E4bKNxlVcyarNVgAKggVWVJETNJl3URcCkBa80d3/e7cCdSvL0KXkUcXziIJwOnTp2PSpElx/WXkYvGLY1G4y/oqI48fvqJDyBjVnMlqDRaAQjRayyRLikhrqgNLxAYn8sSlALzmGqBvX+DRRy1BoAtnF4tQ0pUvFoCWuq1vMusaj7r65UY/k9UaLAAVdG9ZUkRM0qXTxJ0AXLUKGD8e2LULsLgjWRfOWACK9FB/5+FY9Dc/kaxjzpizcARktQYLQAUxJUuKiEm0u4h+aKdsPN8EEncCcNw4YPRo4Fe/EqGpQh5dOAt3nP2yHAqeF2DOPKfAsgHMmWXIPC+gmjNZrSEtAG+55RbLIJNgefvtty2Xi5cCsqSI+EmBdeTIETRt2pQFoAhgTuShu35/9CNgx47A8S8Wky6cRRKAOsTixeIX+cmxaLHz+iA7c+YDEiyaoJozWa0hLQAj7UA1Z6TI+dBEr5uzViUlJRahjJ/ssqSIeKrL44C4mQGkWB4xIiAA77pLhKJKeXThLNwx9stWOHhaiDnzFH5bjTNntmDztJBqzmS1hrQADEf3+PHjGDduHFq0aIGHHnoI3bp1M2aoNm7ciGeffRaHDx/GrFmz0MBvh/o6GCaypIiYojqwRGxwIo/IOYDpiYnYOmCAt+cAzp4NTJkSOPcvLc2W67pwxgLQFv2+KsSx6Cs6hIxhzoRg8lUm1ZzJag3HBeDNN9+MgwcPYs6cOZWIoNm/MWPGoFWrVnjnnXd8RZSTxsiSImKL6sASscGpPCQCb9myBZ2qVcMtTZti4cKFGD58ePBIkYYpKd6KP5r9GzAAuOMOwMaSBxMnnTgL5Z79cqonuFcPc+Ye1k61xJw5haR79ajmTFZrOC4AGzVqhMcffxx3RXlMNnXqVDzxxBM4duyYeyy43JIsKSLmkpjevHlzcIZVpIxf8+zMz0ff1auxe9Ag1E9O9p9fn30GPPQQsGkTkJxsG0adOAsFgf2yHRKeFWTOPIPedsPMmW3oPCuomjNZreG4AKxevToefPBBQwRGSo899hj++Mc/Ii8vzzNSVDcsS4pq+/xWP931m5SQgJcvucRvpgG0VrV3b+CRR4Af/9h/9rFFjAAjwAgwAhclArJaw3EBSI/uaGZq0aJF6Nq1awVS6PVhw4ahZ8+exjVmuiZZUkRwoallwpjwjOer4I4XFaHdihVY368f2lWrZtyW4Su/PvoIeO45YM0aIDFRhJqoeXznm5Q3FwqzXw4B6WI1zJmLYDvUFHPmEJAuVqOaM1mt4bgAXLZsGUaPHo3i4mLjaqguXboYm0BI/M2YMQMpKSmYN28eBg4c6CIN7jYlS4qItarXFojY4ESeJ/fswaa8PPyze3ejOl/5df480K0b8MILwFVXSbvrK9+kvakoAPkqOAcBdaEqjkUXQHa4CebMYUBdqE41Z7Jaw3EBSJiuWLEC//u//4vly5dXgHjIkCF48cUXMYAW1GucZEkRgUZ1YInYIJsnv6QEbZYvx8yePdGv/FYNX/n11lvAm28CFMcJCbLu+kvcSnvDAtBBCF2vylf9zEHvdfXLd1+OmTMhBFTHo6zWUCIATWRoo8cuujILQIcOHdCwYUMh0OI9kywpIv6rDiwRG2TzvH7oED7+7jvM79MnWJVv/CosBGhNIh1YPmaMrKtGed/45og3LAAdhtHV6jgWXYXbkcaYM0dgdLUS1ZzJag2lAtBVpH3UmCwpIq7Q7iJ6zJ6cnByXN4GUlJWh68qVeKljR0wMORPSN3698grwySfA/PmOzP4Rp77xTSTALORhvyyA5ZOszJlPiLBgBnNmASyfZFXNmazWUCYA6fHvp59+WmEG8JprrsGgQYN8Qo06M2RJEbGMAotmWOnYnXi8C/izY8fwyO7d2NC/PxJDHq/6wi/aod6hQ0AADh0qQodQHl/4JmSptUzslzW8/JCbOfMDC9ZsYM6s4eWH3Ko5k9UaSgTg7bffjjfffNOY8QhNJFR+/vOf469//asfuFFmgywpIoapnloWsUEmz5DsbPysWTP8tFmzCtX4wi/a9btgATBzpoyLlcr6wjdHPQpUxn4pAFVxlcyZYoAVVM+cKQBVcZWqOZPVGo4LQDro+d577zWug3v44YeNI18obdiwAc8884xxDdzLL78c9aBoxXy4Ur0sKSJGqg4sERvs5lmak4MfbNpkHPycFna0iud+5eQA7dsDX30FZGbadTFiOc99c9SbC5WxX4qAVVgtc6YQXEVVM2eKgFVYrWrOZLWG4wKwT58+qFu3LubPn1/p0STNCI4cORKnTp3CunXrFMLubdWypIhYrzqwRGywm+eajRsxsFYtPNSmTaUqPPfrsceAjRsDj38dTp775rA/ZnXslyJgFVbLnCkEV1HVzJkiYBVWq5ozWa3huACkm0Cee+453HPPPRFhfeWVV/DrX/8a586dUwi7t1XLkiJiPYnp9evXo1evXnG1BnDbuXPon5WFvYMGoW5KSiVXPfXr+HGgY0dgyRKg/FxCES5E83jqm6iRNvKxXzZA87gIc+YxATaaZ85sgOZxEdWcyWoNxwVgvXr1cP/99+N3v/tdROiffPJJvPTSS8YsoK5JlhRdcSG/bt+6FdWTkvAiCS2/pQcfBA4fBj74wG+WsT2MACPACDACjEAFBGS1huMCkNb+0Xq/1atXo1nYAv/Dhw+jX79+xqzVl19+qS2VsqSIAENTy0uXLgUdrh0vV8F9V1SEDitWYFP//midnh7RTc/8IuHXpQuQnR3YAawgeeabAl9Cq2S/FAOsoHrmTAGoiqtkzhQDrKB61ZzJag3HBeCSJUuMdX70KPinP/0putFVWgA2bdqE9957z3j0S+sDSbjommRJEcFF9doCERus5nl0927szM/Hh+UxEam8Z37dfTdAV7+9/rpVt4Tze+absIX2MrJf9nDzshRz5iX69tpmzuzh5mUp1ZzJag3HBSCBPXPmTNx5553Yt29fBezbtGmDV199FePHj/eSE+Vty5IiYqDqwBKxwUqePLr2bdkyzO3dG31q1Ypa1BO/9uwBevWibylAq1ZW3LKU1xPfLFloLzP7ZQ83L0sxZ16ib69t5swebl6WUs2ZrNZQIgAJcHI8OzvbOAiaFkLSVXAZGRlx87hSJmhkSRFpW3VgidhgJc9fDh7Ef48fx5zevass5olft9wC0F3Ef/qTFZcs5/XEN8tWWi/AflnHzOsSzJnXDFhvnzmzjpnXJVRzJqs1lAlAr4H3sn1ZUkRsJ1FdUFCA9PR03+8CpmvfOq1YgVc7dcLY+vWrdM91v7ZtA/r3B+h3kyYi0NvO47pvti21VpD9soaXH3IzZ35gwZoNzJk1vPyQWzVnslpDmQA8cOAApk2bVuEquEmTJqFly5Z+4EWpDbKkiBhHgXXy5EnUr1/f9wLw3999h6f27sXafv1i2uq6X9ddB7RrBzz9tAjsUnlc903KWvHC7Jc4Vn7JyZz5hQlxO5gzcaz8klM1Z7JaQ4kAfPbZZ/HYY4+huLi4wnVwKSkpoGNg6BxAnZMsKSLYqJ5aFrFBJA91gIHZ2binRQvc2LRpzCKu+rV+PXDZZcDOnUC9ejFtk83gqm+yxlooz35ZAMsnWZkznxBhwQzmzAJYPsmqmjNZreG4APz4448xefJk46iXBx54wLgKjkTAxo0b8cILLxiHF3/00Uf40Y9+5BOKnDdDlhQRi1QHlogNInkWnj6NyZs3G9e+pYRd+xapvKt+XX010K8fEOXMShH/rORx1TcrhknmZb8kAfSgOHPmAeiSTTJnkgB6UFw1Z7Jaw3EBOHDgQJw/f944o47Wp4WmwsJCDKL7X9PSsHz5cg/ocKdJWVJErFQdWCI2iOSZtGEDRtSpgwdatxbJbmwemj59Omi5gNLzDVesAK68Eti1C6hiV7KQ0YKZXPNN0B6nsrFfTiHpXj3MmXtYO9USc+YUku7Vo5ozWa3huACsWbOm8ZiXbgOJlF588UU8+uijOHv2rHssuNySLCki5lJgrV27FnT3slKhJGJMlDyb8/IwJDsb+wYPRu3kZKGaXPPriiuAsWOBX/5SyC4nMrnmmxPGWqiD/bIAlk+yMmc+IcKCGcyZBbB8klU1Z7Jaw3EBWLt2bTz88MN46KGHIlJA9wQ/9dRTyM3N9QlFzpshS4rzFnlT421btqB+Sgr+oOhmDdteLVgATJ4M7NgBVKtmuxouyAgwAowAI8AIeIWArNZwXAAOGzYMx44dM66Co9nA0ESir3///mjcuDEWLlzoFWbK25UlRcRA+maxcuVKDBgwwJczgIcLC9Fp5UpsGTAALdLSRFwy8ij3q6wMGDYMuP564I47hO1yIqNy35ww0kYd7JcN0Dwuwpx5TICN5pkzG6B5XEQ1Z7Jaw3EBSOu3rr76arRv3x733HNPhavgpk6dit27d+Pzzz/HlbT+StMkS4oILKrXFojYUFWeh3ftwsHCQrzXtaulqpT7RXdQ33knsHUrkJpqyTbZzMp9kzXQZnn2yyZwHhZjzjwE32bTzJlN4DwsppozWa3huAAkrN944w388pe/RF5eXvDcN9oJXKNGDWMn8M9//nMPKVHftCwpIhaqDiwRG6LlyS0uRpvly7GgTx/0DJsFjlWvUr9o9o92/d5zD3DzzbFMcfx9pb45bq14heyXOFZ+ycmc+YUJcTuYM3Gs/JJTNWeyWkOJACTwc3JyMGfOnApXwY0ZMwZ16tTxCzdV2kHEDR061NitPHbsWMyaNUvYbllSRBpSHVgiNkTL8+cDBzDr5El8SffrWkxK/fr0U+Dhh4GNGwHBTSkWzY8ZU67scHbSaIG6lHIm0L6qLLr6RXjp6puufjFnqnq52npVx6Os1lAmANXCqr52elxNG1loFtOPApBmVMk2mlVNSEhQD4hgC8Wlpei4YgX+1qULRtk4XFmZXyUlAAnSxx4DfvhDQW+czabMN2fNtFwb+2UZMs8LMGeeU2DZAObMMmSeF1DNGQtABRQfPHjQWLtIx9XQYdZ+FYBEPu269pMA/MfRo3h+/35kZWbasos6jBK//v534I9/BLKzAYEDqRWElXEguhLfVBhroU72ywJYPsnKnPmECAtmMGcWwPJJVtWc+VIA0m0gr7zyCrZv344TJ05UooIEC10T59f0ve99z9iskpWVBbq+zo8CUPXUsh1uKNj7ZWXhgVatcF2TJnaqUPNo6vx5oEsX4E9/AiZNsmWXE4X8yBn7FR0BXfkij3X1TVe/mDMnRir361Adj74TgM8//7zx6LRBgwbGrR/0O1J655133GdDoMVPPvkE1157LZYsWYLBgwcbs1gsAAWAAzDv1CncsmULdgwciGSbs2xKOswbbwB/+xuwbBng4eNyJb6JUaM0F/ulFF4llTNnSmBVWilzphReJZWr5sx3ArBt27Zo3rw5vv76a1SLs0N2aeMKPfqlI2pef/11IyBEBCBdcUc/ZiJSWrVqhVOnThmPaM16qC4KiNBEt3jQzBn9mInyxcpL9XzxxReGrUlJSY7VG8sG83FzJHvHrVuHcfXr494WLYI+0z9C89Lf5HM4Dma9JSUlhl8TJ0408lWVV6he4qVTJ5SRABw9Ooix1XojcRTNt2h80qx3uG92uI/Fkd2YilVvNO7JB9rcYnJmxns4PtHiOlK9seJEiPtysW83b2gfC11mUZW9TsSJU2NEVXxW5VusscdunESq12nuQ/0y+0H4eBtt7LEbJ2asqubeqzHfynhS1eeDyJhPn2VuxEloDFv9jIoUJ9G4j/R55mSckNaoV6+esenW1BpWlKzjm0Do/l+67u1OOmvNg1RUVISnn35auOWbb74ZJFop3XHHHfj000+xZcsWA1TzgyzWDODjjz+OJ554olKbH330EapXr268npGRYYjCadOmBQURCeQrrrjCeFS+efPmYPnevXsbNpFYMB+Vp6amYvz48cau6g0bNgTzdu/eHR07dsTs2bNRUFBgvE6diIThvn37sGbNmmDeLl26oHPnzpg7d66xgcRMdG4jrXukw7vNdMkllxhieP78+ca6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KPeIgNwn3xe96yD1fqvDvcenn7ph3COyce/nnp/rWs73PSJdTHlxknzP57MsW93k504Qjvzw6aduJu7TPc/CjBNqjYoVK4L7Fzyt4Uffhi4AKZSyFZJbpkwZ8FvAPXr0QPPmzf3Ym7MuN23obtZgZ2eddRZq166N8847Twk8grhgwQIlBL0bd6dOnTBhwgR8/fXXaNiw4W428Gsot99++26/M4u41157qd9btmypROF7772XEE/EgRhwt/FcroXbWbj+kDZ98MEHoGhgKVmyJHr37o1FixZh9uzZibqHHHII6tati5EjR6qMJQsvIq4N5HeaZ86cibv22gtNt27FtXXqqC+HcEf27zyCZWc57rjjsHz5ckybNi3x28EHH4zGjRtj7NixYJB55eijjwan9adMmZL4jVPnhx56qMLot99+S/zeq1cvrF27VmVUvVJn771x6LHHYtoLL2B5sWKJ37n5hiJ6/Pjxid+4w5kbcTjWjz/+mPi9c+fO6u+0zStVq1ZFu3btMH36dLU72isdO3ZUG3goULxCbg8//HB88cUX4NS/V4444ggl+j/88MPEb/vuuy86dOigMCf2XuFYlStXVhx5hbFD28glOfVK69atceCBB2Lo0KGJ38qWLavEO7968s033yR+b9Gihbo2uL7T+1xi6dKl0bNnT7UZ6auvvkrUJebEfsSIEWqzEguz1OTou+++w6xZsxJ1ySU5/eijj7Bhwwb1O6/FY489FkuXLsWMGTMSdRkjjHOKH/LnlWOOOQbc1T916tTEb9wh36RJE4wbNw6rV69O/N6nTx/1AjSJn/nbWRjTjO1PP/0Uv/76a+J3XgNcbsHfvcJrhdfM5MmT1ZheoRgjLvwOtleqVaumlpl8/vnnWLFiReJ3fieb1wJfKLzCjH779u2Vv/TbK0ceeaS6VomPVypVqgT+ThyJp1d4nBVvunwx9ApfGnmf4AYy3j+8wiOwOOb777+f+I0xxhMRyDv590qU9wjPBvIe9T2iVq1a6rnAtdg///xzAh+5R+yAQu4RO3CQe8R2dd/s169ffARg8reBU9V66psh///000/H888/r7WRIXEnyPKXdevWqYe4bqGI4IOCa/8GDhyowOSZhcnlueeeUxnAQYMGqeng1BJFBpDYUhDwAZwuS+a94c1Ztw4d+ABr2xZ7lyhhnIU0fru/5x4UnT0b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+GI8+eSTu8RMnz598PHHH2PdunVa08CmpOgErNXA4rl/PXoAl12mY0qodaz6Faql/jtz1Tfxy38sRN1COIuaAf/jC2f+MYu6hW3OTLWGCMCdEbJ161YcfPDB6usajz/+OLp16wb+9uabb+LGG2/E7bffjpu4K1ajmJKiMQS4u4hrFkuWLBnuLuB584B27YClS4Hy5XVMCbWONb9CtTJYZ676Jn4Fi4coWwlnUaIfbGzhLBhuUbayzZmp1hABmBQdX375Jc4880x8wW/e7iylSpVSGcFz+Sm0DGXTpk3gH6+QlBo1amDVqlXYe++91c9FihRRf/hGkFy40YRBwj9e0anL+r/++isqV66sNoGE1W+RSy4BSpUC/vWvtPbSNhYde9PVZdt09np16Qf9qlSpkho/W91kG3L1a1o3HUepOHg2ZOKTa0pTfQvCvZ84CbNuJu45xi+//IJ999038TJiO05M+Uy9XtLZyzF4DdOv5JItrsOIk7Cu5WzcZ/PN9D4VJffJ90XakY84yXbd+71HZOPe1j0/H/eIdDGV7p7P+322uvnkU+cekYv7dM+zMO8R1BoVK1bEmjVrElrDj+B1TgAyK3bPPfdoY8AdvrVr11b1v/vuO9xyyy0oV64cunTpgg0bNuDll1/G6NGjMWTIkIwi8LbbblMZwtTy6quvJtYMtmzZUonC9957L3FTKlOmDHr06IFvv/0Wc+fOTTRv1qyZsumDDz5QWUgWZvp69+6tdifPnj07UbdJkyaoV68eRo4ciY0bN6rfixUrhr59+2LJkiWYOXNmom7Dhg3RoEED5c/vv/+e+P24447D8uXLMeuTT9D9/PPxyaOP4sAjj0Tjxo3VBhgGmVeOPvpo9bCfMmVK4rc6derg0EMPxYQJE/Dbb78lfu/Vq5daN8ndyl6pVasWmjdvjs8++ww///xz4vfu3bsrET1+/PjEb9WrV0erVq3UWD/++GPi986dO6u/0zavVK1aFe3atcP06dOxjGcX7iwdO3YERfyoUaMSv+233344/PDDldD/np+421m4o7p8+fL48MMPE7/x4d+hQweFObH3Csei+CZHXqHYp23kkpx6hWtIub506NChid/Kli2rsszz5s0Dlx94pUWLFqhZsyaGDRumNiGxlC5dGj179sTChQvV2Y9eIebEfsSIESobzFK8eHGQI8Yy1616hVwy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sfjf//6Hpk2bYvLkyeohXOjl6quvxuDBg0GBUegCkF9q6dy5s7qRnX322WjcuDEocL/55hslIC677LKCpItfu+nQoYOKubPOOkuJBT6EXnrpJXXjvvnmm3HHHXfE2rciRYpg3333RcuWLZUI5OHcmQQgv7XZpk0bLF++XL1sHXTQQRg6dKgSg7fddhtuvfXW2Piq6xdfIHm/4L2jb9++qFOnjhJGfOGiGHzxxRdjJ+R1fUslg/40atRIfUOd95W4CUC/flEg3XDDDerewucBY5ciY/z48epFky+ZcSl+fBs+fLjyp169ejjnnHNQqVIlzJo1C//+97+Vj7Nnz0aVKlUid83PszjO9w4RgJGHkr4BfEvnhVGhQoVdGt100024++67lTj03nD1e41XTYoHPmjvv/9+UAgWugA86qijMG/ePEydOtWp70NPmjQJhx9+uBJDzEJ4ZcOGDUpIMLv0448/xiu4UqxZtGiRspWFGWcKg0wCkJk/ZnHfeustnHjiiYmejj32WHz44YeKY4rCOBRdv7Zu3YoJEyYoEZFcyBvxKF68uBKCRYsWjYNbygZd31INJmfM8tIvzqLETQD68WvMmDHo1q2bykbzvh/34se3nj17qqSGl432fHv00UdxxRVXYNCgQejfv3/kLvt5Fsf53iECMPJQMjfgyy+/RLNmzQpeLG3btk1lkviG9+STT6oHaiELQD5cO3bsqAQShRIfuDwXyoWpeoqe3r1744EHHlBT2cmFWU5ml3jjL5SSSwDWrFlTCaJUnz755BMloJiRYVYgbiWXX5nspWB65513YieUku3V9e3dd9/FSSedhM8++0wJiBdeeKGg/eratavKhDEbXaJECfXiwkxusWLF4hZ+u9mTi7P27dtj7ty5YNYs+cWDs1ynnnqq4u7vf/97bP1M9yyO871DBGBsQ0nfsBEjRqBPnz4FMe2WzauHH35Y+TBnzhxw2qDQBaD35sepQq7Lef/995UI5DoWZjcvueQSfZJjVpNT2uSHyxC4too3bj6IhgwZgscffxzPPfdcrG/UqXBmezAxI8b1Vf369VNr5pILBT0fvscff7yaeotbyfXAzWQvX8S++OILtdaxdOnScXNL2aPjG78ywRcSTitS/HG5QiELQC6z4PfE+fLF9cO33347lixZoj4GwOwZXza9rHYcScvFmTebxTXEvEdy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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the log-likelihood vs number of target samples\n",
    "fs = 13\n",
    "fig = plt.figure()\n",
    "y_vals = []\n",
    "for i, m in enumerate(['no_adaptation', 'proposed', 'transfer', 'transfer_last_layer', 'retrained_target']):\n",
    "    plt.plot(n_adapt_list, mean_loglike[m], linestyle='-', linewidth=0.75, color=COLORS[i], \n",
    "             marker=POINT_STYLES[i], label=legend_names[m])\n",
    "    y_vals.extend(mean_loglike[m])\n",
    "\n",
    "# plt.yscale('log')\n",
    "# Increase the upper y-limit a bit\n",
    "y_bot, y_top = plt.ylim()\n",
    "plt.ylim((y_bot, 1.1 * y_top))\n",
    "\n",
    "plt.xticks(n_adapt_list, fontsize=fs)\n",
    "plt.yticks(fontsize=fs)\n",
    "plt.xlabel('#target samples per-class', fontsize=fs, fontweight='normal')\n",
    "plt.ylabel('Log-likelihood', fontsize=fs, fontweight='normal')\n",
    "# plt.ticklabel_format(axis='y', style='sci', scilimits=(0,0), useMathText=True)\n",
    "plt.grid(True, axis='both', linestyle='dashed', linewidth=0.75, alpha=1.)\n",
    "# plt.legend(loc='best', ncol=1, fontsize=10)\n",
    "# plt.legend(loc='upper center', frameon=True, bbox_to_anchor=(0.5, 1.15), ncol=3, \n",
    "#            fontsize=10, fancybox=False)\n",
    "# Save the figure\n",
    "plot_filename = os.path.join(plots_dir, 'plot_loglike_{}_to_{}'.format(source_ch, target_ch))\n",
    "fig.tight_layout()\n",
    "fig.savefig(plot_filename + '.png', dpi=600, bbox_inches='tight')\n",
    "fig.savefig(plot_filename + '.pdf', dpi=600, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.7.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
