{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "kernelspec": {
      "display_name": "Python 3",
      "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.8"
    },
    "livereveal": {
      "rise": {
        "height": "90%",
        "width": "90%"
      },
      "scroll": true,
      "theme": "sky",
      "transition": "zoom"
    },
    "widgets": {
      "application/vnd.jupyter.widget-state+json": {}
    },
    "colab": {
      "name": "ADSP_06_Sampling.ipynb",
      "provenance": []
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "RRl--UQN4z7W",
        "colab_type": "text"
      },
      "source": [
        "<center>\n",
        "    <img src=\"https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/adsp_logo.png?raw=1\">\n",
        "</center>\n",
        "\n",
        "### Prof. Dr. -Ing. Gerald Schuller <br> Jupyter Notebook: Renato Profeta\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "S66YOqXN4z7X",
        "colab_type": "text"
      },
      "source": [
        "# Sampling"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "_-3BCfm14z7Y",
        "colab_type": "code",
        "colab": {},
        "outputId": "c8db3efa-025d-4268-cbf2-2e5a87e364f0"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/jAdkpMC4ZGo\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/jAdkpMC4ZGo\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "YQzDIw744z7g",
        "colab_type": "text"
      },
      "source": [
        "To see what happens when we sample a signal, lets start with the analog signal s(t). Sampling it means to sample the signal at sample intervals T (example: 1/8000 s in the ISDN example), or the sampling frequency $f_s$ (8kHz in the ISDN example). \n",
        "\n",
        "Mathematically, sampling can be formulated as multiplying the analog signal with a Dirac impulse at the sampling time instances nT, where n is the number of our sample (n=0,… for causal systems). "
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "5J8XDZwK4z7h",
        "colab_type": "code",
        "colab": {},
        "outputId": "9a18b8d3-e81e-4bb9-f262-72a9a6fc1328"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/_YclokYvRk4\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/_YclokYvRk4\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "uK7vX6Kt4z7l",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# Imports\n",
        "%matplotlib notebook\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "from matplotlib.ticker import FuncFormatter\n",
        "from IPython.display import display, HTML"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "kP7T30hG4z7o",
        "colab_type": "code",
        "colab": {},
        "outputId": "2193e7cc-b196-439f-ffa9-e81423a39cfa"
      },
      "source": [
        "# Format local\n",
        "CSS = \"\"\"\n",
        ".output {\n",
        "    align-items: center;\n",
        "}\n",
        "\"\"\"\n",
        "HTML('<style>{}</style>'.format(CSS))"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/html": [
              "<style>\n",
              ".output {\n",
              "    align-items: center;\n",
              "}\n",
              "</style>"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 4
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "ff1Jvjby4z7r",
        "colab_type": "code",
        "colab": {},
        "outputId": "c3ad081b-283b-4a6d-876e-b9d47b7928a5"
      },
      "source": [
        "\n",
        "# Signal\n",
        "dirac_sequence = np.ones(4)\n",
        "\n",
        "# Plot\n",
        "fig = plt.figure(figsize=(10,6))\n",
        "ax = fig.add_subplot(111)\n",
        "plt.stem(dirac_sequence, use_line_collection=True)\n",
        "plt.xlim(right=5)\n",
        "plt.ylim(top=3)\n",
        "plt.yticks([])\n",
        "plt.title('Dirac Sequence', loc='left')\n",
        "plt.xlabel('time', horizontalalignment='right', x=1.0)\n",
        "xmin, xmax = ax.get_xlim() \n",
        "ymin, ymax = ax.get_ylim()\n",
        "ax.xaxis.set_major_formatter(FuncFormatter(\n",
        "   lambda val,pos: '{:.0g}T'.format(val) if val !=0 else '0'\n",
        "))\n",
        "\n",
        "# Arrowed Axis\n",
        "\n",
        "for side in ['bottom','right','top','left']:\n",
        "    ax.spines[side].set_visible(False)\n",
        "    \n",
        "\n",
        "dps = fig.dpi_scale_trans.inverted()\n",
        "bbox = ax.get_window_extent().transformed(dps)\n",
        "width, height = bbox.width, bbox.height\n",
        " \n",
        "\n",
        "hw = 1./20.*(ymax-ymin) \n",
        "hl = 1./20.*(xmax-xmin)\n",
        "lw = 1. \n",
        "ohg = 0.3 \n",
        " \n",
        "yhw = hw/(ymax-ymin)*(xmax-xmin)* height/width \n",
        "yhl = hl/(xmax-xmin)*(ymax-ymin)* width/height\n",
        " \n",
        "ax.arrow(xmin, 0, xmax-xmin, 0., fc='k', ec='k', lw = lw, \n",
        "         head_width=hw, head_length=hl, overhang = ohg, \n",
        "         length_includes_head= True, clip_on = False) \n",
        " \n",
        "ax.arrow(0, ymin, 0., ymax-ymin, fc='k', ec='k', lw = lw, \n",
        "         head_width=yhw, head_length=yhl, overhang = ohg, \n",
        "         length_includes_head= True, clip_on = False) \n",
        " \n",
        "# Annotation\n",
        "plt.text(3.5, 0.5, r'$\\cdots$',\n",
        "         {'color': 'black', 'fontsize': 24, 'ha': 'center', 'va': 'center'});\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"864\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ulCQ7ceh4z7v",
        "colab_type": "text"
      },
      "source": [
        "The sequence or train of Dirac impulses can be written as:\n",
        "<br>\n",
        "$$ \\large\n",
        "\\Delta _{T}(t):= \\sum_{n=0} ^\\infty \\delta(t-nT) $$\n",
        "<br>\n",
        "Remember that the integral over a Dirac impulse is 1:<br>\n",
        "$$\\int _{t=-\\infty} ^\\infty \\delta(t) dt=1$$"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ApPJFyYb4z7v",
        "colab_type": "text"
      },
      "source": [
        "The integral over the product of a function with a Dirac impulse is the value of the function at the position of the impulse:\n",
        "\n",
        "$$ \\large\n",
        "\\begin{equation} \\int_{t=-\\infty} ^\\infty s(t) \\delta(t-nT)dt = s(nT)\\end{equation}$$ \n",
        "\n",
        "This is the mathematical formulation of sampling at time-point nT. We can now use this description to compute the resulting **spectrum** with the **Fourier transform**."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "PCBsoMJb4z7w",
        "colab_type": "code",
        "colab": {},
        "outputId": "aa941e53-3efb-48c4-cdfc-a0f220cc39fd"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/9wODoG_H-jg\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/9wODoG_H-jg\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "D-2uuwjy4z7z",
        "colab_type": "text"
      },
      "source": [
        "First, if we look at the Fourier transform of the analog signal or system, we get<br>\n",
        "\n",
        "$$ {S ^{c} }  ( ω ) = \\int _{ {t= -  \\infty } }^ { { \\infty } }  {s ( t )  \\cdot e ^{{ - jωt} }  dt} $$\n",
        "\n",
        "where the superscript c denote the continuous version, with $w=2\\pi f$ the angular frequency. If we now compute the Fourier Transform for the sampled signal $s(t)\\cdot \\Delta _T (t)$, with the replacement\n",
        "<br>\n",
        " $$s(t) \\leftarrow s(t) \\cdot \\Delta_T(t)$$\n",
        " \n",
        " we obtain the following sum (since only at the sampling time instances the integral is non-zero, as we see in eq. (1)),<br>\n",
        " $$\n",
        " {S ^{d} }  ( ω ) = \\sum _{ {n= -  \\infty } } ^ { { \\infty } }  {s (  nT)  \\cdot e ^{ { - jω nT} } }  \n",
        " $$\n",
        "<br>\n",
        "with the superscript d now denoting the discrete time version. Now we can see that the frequency variable only appears as $wnT$, and T is the inverse of the sampling frequency. Hence we get\n",
        "<br>\n",
        "$$\\omega T=\\frac{\\omega}{f_s}=:\\Omega $$"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "TarmzgFe4z70",
        "colab_type": "text"
      },
      "source": [
        "This is now our **normalized frequency**, it is without a physical unit, since the unit Hertz in $\\omega$ and $f_s$ cancel. In the normalized frequency $2\\pi$ represents the sampling frequency and $\\pi$ is the so called **Nyquist frequency** (the upper limit of our usable frequency range, defined as **half** the sampling frequency). \n",
        "\n",
        "Observe that we use the capital $\\Omega$ to signify that this is the normalized frequency. The capitalized version is commonly used to distinguish it from the continuous, non-normalized, version, if both are used. Otherwise, also the small $\\omega$ is used in the literature, for the normalized frequency, if that is all we need, if there is no danger of confusion, as we did before. \n",
        "\n",
        "To convert a normalized frequency back to the non-normalized one, we simply multiply it with the sampling frequency: $\\omega=\\Omega \\cdot f_s$.\n",
        "\n",
        "To indicate that we are now in the discrete domain, we rename our signal to x(n)=s(nT).\n",
        "\n",
        "Its spectrum or frequency response is then\n",
        "$$\n",
        "X(\\Omega)=\\sum_{n=-\\infty}^\\infty x(n)e^{-j\\Omega n}\n",
        "$$\n",
        "\n",
        "We call this the **“Discrete Time Fourier Transform” (DTFT)**, because we apply it to discrete time signals x(n). This can be distinguished from the Discrete Fourier Transform, because the above time signal has infinite length.\n",
        "\n",
        "Because n is integer here (no longer real valued like t), we get a $2\\pi$ **periodicity** for $X(\\Omega)$. This is the first important property for discrete time signals. "
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "7SLJbNy-4z70",
        "colab_type": "code",
        "colab": {},
        "outputId": "acc0b7d6-5772-4a9e-c22a-36131b84aa10"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/qqbWmiwMC3Q\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/qqbWmiwMC3Q\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "mmX0MUde4z76",
        "colab_type": "code",
        "colab": {},
        "outputId": "2623870d-34ca-4b99-91a0-9ff8c2cc4096"
      },
      "source": [
        "# Plot Poles and Zeros\n",
        "from  matplotlib import patches\n",
        "plt.figure(figsize=(10,6))\n",
        "ax = plt.subplot(111)\n",
        "r = 1.5; plt.axis('scaled'); plt.axis([-r, r, -r, r])\n",
        "ticks = [-1, 1]; plt.xticks(ticks); plt.yticks(ticks)\n",
        "# Unit Circle\n",
        "uc = patches.Circle((0,0), radius=1, fill=False, color='black', ls='dashed')\n",
        "ax.add_patch(uc)\n",
        "ax.spines['left'].set_position('center')\n",
        "ax.spines['bottom'].set_position('center')\n",
        "ax.spines['right'].set_visible(False)\n",
        "ax.spines['top'].set_visible(False)\n",
        "plt.xlabel('Re', horizontalalignment='right', x=1.0)\n",
        "plt.ylabel('Im',  y=1.0)\n",
        "plt.title('Complex z-Plane', loc='right')\n",
        "# Annotations\n",
        "ax.annotate('$\\omega=0$', xy=(1, 0),  xycoords='data',\n",
        "            xytext=(1.1, 0.35), textcoords='axes fraction',\n",
        "            arrowprops=dict(facecolor='black', shrink=0.05, width=0.5),\n",
        "            horizontalalignment='right', verticalalignment='top',\n",
        "            )\n",
        "ax.annotate('$\\omega=\\pi$', xy=(-1, 0),  xycoords='data',\n",
        "            xytext=(0.05, 0.6), textcoords='axes fraction',\n",
        "            arrowprops=dict(facecolor='black', shrink=0.05, width=0.5),\n",
        "            horizontalalignment='right', verticalalignment='top',\n",
        "            )\n",
        "ax.annotate('$e^{-j\\omega}$', xy=(0.7, 0.7),  xycoords='data',\n",
        "            xytext=(1, 0.7), textcoords='axes fraction', size=15,\n",
        "            arrowprops=dict(facecolor='black', width=0.5),\n",
        "            horizontalalignment='right', verticalalignment='top',\n",
        "            );"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"892\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "hide_input": false,
        "id": "lcbkBBbR4z78",
        "colab_type": "text"
      },
      "source": [
        "Here we can see that in general we obtain a $2\\pi$ periodicity in the frequency domain, because of the $2\\pi$ periodicity of the exponential function $e^{jw}$.\n",
        "\n",
        "Also observe that for **real valued** signals, the spectrum of the negative frequencies is the conjugate complex of the positive frequencies,\n",
        "\n",
        "$$\n",
        "X(-\\Omega)=X^*(\\Omega)\n",
        "$$\n",
        "\n",
        "where * denotes the conjugate complex operation, because in our DTFT, $e^{-j(-\\Omega )n}=(e^{-j\\Omega n})^*$.\n",
        "\n",
        "(we also have to use the fact that the conjugate complex of a real valued signal does not change it, to draw the conjugation out of the Fourier sum).\n",
        "\n",
        "This also means that for real valued signals we only need to look at the frequency range between 0 and $\\pi$, since the negative frequencies are conjugate symmetric (and because of the 2pi periodicity the range between -pi and pi is sufficient to look at). This is also again what the Nyquist Theorem tells us, that the frequencies between 0 and $\\pi$ (the Nyquist frequency) are sufficient to completely describe a (real valued) signal."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "paAL37QM4z79",
        "colab_type": "text"
      },
      "source": [
        "## Sampling a Discrete Time Signal"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "iXDnc7Je4z7-",
        "colab_type": "code",
        "colab": {},
        "outputId": "62b20353-f324-411e-f36a-adbfce7b74e8"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/uZFKOUfibt4\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/uZFKOUfibt4\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "W7WZpkFJ4z8B",
        "colab_type": "text"
      },
      "source": [
        "So what happens if we further downsample an already discrete signal x(n), to reduce its sampling rate?\n",
        "\n",
        "**Downsampling by N** means we only keep every Nth sample and discard every sample in between. Observe that this results in a **normalized frequency which is a factor of N higher**.\n",
        "\n",
        "This downsampling process can also be seen as first multiplying the signal with a sequence of **unit pulses** (a 1 at each sample position), zeros in between, and later dropping the zeros. This multiplication with the unit pulse train can now be used to mathematically analyse this downsampling, looking at the resulting spectra, first still including the zeros. The frequency response now becomes\n",
        "\n",
        "\n",
        "$$\\large X^d(\\Omega)=\\sum_{n=mN} x(n)e^{-j \\Omega n}$$\n",
        "$$\\large =\\sum_{m=- \\infty}^ \\infty x(mN)e^{-j \\Omega mN}$$\n",
        "for all integers m.\n",
        "\n",
        "Again we can write down-sampling as a multiplication of the signal with a sampling function. In continuous time it was the sequence of Dirac impulses, here it is a **sequence of unit pulses** at positions of multiples of N,\n",
        "\n",
        "$$ \\Delta_N ( n ) = \\left ( \\matrix {{1 , if n = m N} \\\\ {0 , e l s e}} \\right) $$\n",
        "\n",
        "Then the sampled signal, with the zeros still in it, becomes\n",
        "\n",
        "$$x^d(n)=x(n)\\Delta _N (n)$$\n",
        "\n",
        "This signal is now an intermediate signal, which gets the zeros removed before transmission or storage, to reduce the needed data rate. The decoder upsamples it by re-inserting the zeros to obtain the original sampling rate.\n",
        "\n",
        "Observe that this is then also the signal  that we obtain after this upsampling in the decoder. Hence this signal looks interesting to us, because it appears in the encoder and also in the decoder.\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "uesIF7rc4z8C",
        "colab_type": "text"
      },
      "source": [
        "What does its **spectrum or frequency response** look like?\n",
        "\n",
        "We saw that the downsampled signal $x^d(n)$ can be written as the **multiplication** of the original signal with the unit pulse train $\\Delta_N (n)$. In the spectrum or frequency domain this becomes a **convolution with their Fourier transforms**. \n",
        "\n",
        "The Fourier transform of the unit pulse train is a dirac impulse train. But that is not so easy to derive, so we just apply a simple trick, to make it mathematically more easy and get converging sums.  We have a **guess** what the Fourier transform of the unit pulse train is: we get Dirac impulses at frequencies of $\\frac{2\\pi}{N}k$ (fundamental frequency $2 \\pi / N$ and its harmonics). The fundamental (angular) frequency is $2 \\pi / N$, because our original sampling frequency was $2 \\pi$, and now we reduced it by a factor N.\n",
        "\n",
        "With a constant factor that becomes clear later, we get our guess to\n",
        "\n",
        "$$ \\large\n",
        "\\delta_{\\frac{2\\pi}{N}} \\left ( Ω \\right )=\\sum_{ k=0 } ^ { N-1 } \\frac{2 \\pi} { N} \\delta( \\Omega-\\frac{2 \\pi}{N} \\cdot k)\n",
        "$$\n",
        "\n",
        "Where $\\delta_{2\\pi/N} \\left ( Ω \\right )$ is (guessed to be) the Fourier transform of the unit impulse train (the Dirac impulse train). We just need to verify it. Its **inverse Discrete Time Fourier Transform** is\n",
        "\n",
        "$$\\large\n",
        "\\Delta_N \\left ( n \\right )  =\\frac{1}  {2 π}  \\int _ 0^ {2 π} {\\delta_{2\\pi/N} \\left ( Ω \\right )  e^{j n Ω} d Ω}$$\n",
        "\n",
        "$$\\large\n",
        "=\\frac{1}  {2 π}  \\int_ 0 ^{2 π} \\sum_ { k=0 } ^ { N-1 } \\frac{2 \\pi} { N} \\delta( \\Omega-\\frac{2 \\pi}{N }\\cdot k ) e^{jn\\Omega} d\\Omega    \n",
        "$$\n",
        "\n",
        "\n",
        "$$\\large\n",
        "=\\frac{1}{N}  \\sum_{k = 0}^ {N - 1} e^{j \\frac{2 π} {N} \\cdot k \\cdot n}$$"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "bhPlqNgc4z8C",
        "colab_type": "text"
      },
      "source": [
        "Now we have to prove that this is indeed our unit pulse train. To do that, we can look at the sum. It is a geometric sum (a sum over a constant with the summation index in the exponent),\n",
        "\n",
        "$S= \\sum _{k = 0} ^ {N - 1} c^k$ , $S \\cdot c = \\sum _{k = 1} ^ N c^k$ , $S c -S =c^N -1$, hence we get\n",
        "\n",
        "$$S =\\frac{c^N - 1}  {c - 1}$$\n",
        "\n",
        "Here we get $c=e^{j\\frac {2 \\pi}{N}n}$, and the sum can hence be computed in a closed form,\n",
        "\n",
        "$$ \\large\n",
        " \\sum _{k = 0}^{N - 1} {e^{j \\frac{2 π} { N} \\cdot n \\cdot k} } =\\frac{e^{j \\frac{2  π} { N} \\cdot n \\cdot N} - 1}  {e^{j \\frac{2  π} {N }\\cdot n} - 1}\n",
        "$$\n",
        "\n",
        "In order to get our unit pulse train, this sum must become N for n=mN. We can check this by simply plugging this into the sum. The right part of the sum is undefined in this case (0/0), but we get an easy result by looking at the left hand side: $e^{j \\frac{2 π}{N} \\cdot m N \\cdot k} =1$. Hence the sum becomes N, as desired!<br>\n",
        "For $n  \\neq m N$ we need the sum to be zero. Here we can now use the right hand side of our equation. The denominator is unequal zero, and the numerator becomes zero, and hence the sum is indeed zero, as needed!\n",
        "\n",
        "This proves that our **assumption was right**, and we have\n",
        "\n",
        "$$\\large\n",
        "\\Delta_N \\left ( n \\right ) =\\frac{1}{ N } \\sum _{k = 0} ^ {N - 1} e^{j \\frac{2 π} {N} \\cdot k \\cdot n}$$<br>"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "5_LxHKbZ4z8E",
        "colab_type": "code",
        "colab": {},
        "outputId": "c4e5105d-6877-476a-a370-2976c68384f7"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/KeT2i-ARZ7c\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/KeT2i-ARZ7c\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "iDCXlvRf4z8G",
        "colab_type": "text"
      },
      "source": [
        "Now we can use this expression for the unit pulse train in the time domain and compute the Fourier transform,\n",
        "\n",
        "$$\\large\n",
        "x^d \\left ( n \\right )  =x \\left ( n \\right )  \\cdot \\Delta_N \\left ( n \\right ) $$$$ =x  ( n  ) \\cdot \\frac{1}{N}  \\sum _ {k = 0} ^{N - 1} e^{j \\frac{2 π} {N} \\cdot k \\cdot n}\n",
        "$$\n",
        "\n",
        "Taking its Discrete Time Fourier transform now results in\n",
        "\n",
        "$$\\large\n",
        "X^d \\left ( Ω \\right )  = \\sum _ {n = - ∞} ^ ∞ {x  (  n  ) \\cdot} \\frac{1}{ N}  \\sum _ {k = 0} ^{N - 1} e^{j \\frac{2π}{ N}\\cdot k \\cdot n} \\cdot e^{- j Ω n} = $$\n",
        "\n",
        "$$\\large\n",
        "=\\frac{1} { N}  \\sum _ {k = 0}^ {N - 1}\\sum _{n=-\\infty}^{\\infty} {x  ( n )\\cdot e^{-j(- \\frac{2\\pi}{N}\\cdot k +\\Omega)}}$$\n",
        "\n",
        "$$\\large\n",
        "=\\frac{1} {N}  \\sum _{k = 0} ^{N - 1} {X  (  - \\frac{2 π}{ N} k + Ω  )}\n",
        "$$\n",
        "\n",
        "This shows, that sampling, still including the zeros, leads (in the frequency domain) to **multiple shifted versions** of the signal spectrum, the so-called **aliasing components**,\n",
        "\n",
        "\n",
        "$$\\large\n",
        "X^d (\\Omega)= \\frac{1} {N} \\sum _{k=0} ^{N-1} X(- \\frac{2 \\pi}{N} \\cdot k + \\Omega)$$\n",
        "<center>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/aliasing_components.PNG?raw=1'>\n",
        "</center>\n"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "PVIGkc044z8H",
        "colab_type": "text"
      },
      "source": [
        "**Observe:** The aliasing components **periodify** the spectrum now according to the **new sampling rate**, which is 1/N of the old sampling rate, hence the new period is 1/N the old period (of $2 \\pi$).\n",
        "\n",
        "**Observe:** The spectral components don't overlap if their bandwidths are below $\\dfrac {2\\pi}{N}$ for complex signals, or for a real low pass signal, it should be below $ \\dfrac{\\pi}{N}$! If we want to reconstruct the original signal, hence we need to make sure the aliasing components don't overlap by suitable filtering at the high sampling rate, to prepare for the down-sampling. Observe that the term „Aliasing“ in the literature is sometime only used for overlapping alias components, and sometimes more broadly, like we do here, to mean any additional shifted frequency component.\n",
        "\n",
        "Next is an **example**, also including the negative frequencies that now show up above normalized frequency 1 (**1** being the Nyquist frequency here), and showing 2 sine signals at different strength at normalized frequencies 0.4 and 0.35. This can also be seen as a narrow band signal, resulting e.g. from a passband filter."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "qh8xR1JA4z8H",
        "colab_type": "code",
        "colab": {},
        "outputId": "c9a82ab8-f067-4f5e-b656-04f848fe86a0"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/sB5HRZgqgIg\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/sB5HRZgqgIg\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "qt098m_G4z8K",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# Signal Processing Parameters\n",
        "Fs = 32000\n",
        "T=1/Fs\n",
        "t = np.arange(Fs//32)*T\n",
        "\n",
        "# Signals\n",
        "w35 = 0.35*Fs/2\n",
        "sine_35 = np.sin(2*np.pi*w35*t)\n",
        "w40 = 0.4*Fs/2\n",
        "sine_40 = 100*np.sin(2*np.pi*w40*t)\n",
        "signal=sine_35+sine_40\n",
        "\n",
        "# FFT\n",
        "from numpy.fft import fft\n",
        "signal_fft = fft(signal)\n",
        "freqs = np.fft.fftshift(np.fft.fftfreq(signal.size,d=T))+Fs/2"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "Dzfmuw7J4z8M",
        "colab_type": "code",
        "colab": {},
        "outputId": "15112680-0839-46aa-94dc-6180e4af8fc2"
      },
      "source": [
        "plt.figure(figsize=(10,6))\n",
        "plt.plot(freqs/(Fs/2),20*np.log10(np.abs(signal_fft)))\n",
        "plt.grid()\n",
        "plt.ylabel('Magnitude [dB]')\n",
        "plt.xlabel(r'$\\dfrac{Frequency}{Nyquist}$');"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"853\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "FVikpnHZ4z8Q",
        "colab_type": "text"
      },
      "source": [
        "After sampling by a factor of N=4, still including the zeros, we get the following spectrum"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "QpT2bWGh4z8Q",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "unit = np.zeros(Fs//32)\n",
        "unit[::4]=1\n",
        "signal_downsampled = signal*unit"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "my4GeWEr4z8T",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "signal_ds_fft = fft(signal_downsampled)"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "txElxJMy4z8W",
        "colab_type": "code",
        "colab": {},
        "outputId": "22f3d247-f8c0-4eac-8add-6a8855a2ef49"
      },
      "source": [
        "from matplotlib.patches import Rectangle\n",
        "\n",
        "plt.figure(figsize=(12,8))\n",
        "plt.plot(freqs/(Fs/2),20*np.log10(np.abs(signal_ds_fft)))\n",
        "plt.grid()\n",
        "plt.ylabel('Magnitude [dB]')\n",
        "plt.xlabel(r'$\\dfrac{Frequency}{Nyquist}$')\n",
        "plt.ylim((-270,120))\n",
        "\n",
        "# Annotations\n",
        "plt.annotate(s='', xy=(0,100), xytext=(1,100), arrowprops=dict(arrowstyle='<->'))\n",
        "plt.text(0.5, 110, 'Positive Freqs.', horizontalalignment='center', verticalalignment='center')\n",
        "\n",
        "plt.annotate(s='', xy=(1,100), xytext=(2,100), arrowprops=dict(arrowstyle='<->'))\n",
        "plt.text(1.5, 110, 'Negative Freqs.', horizontalalignment='center', verticalalignment='center')\n",
        "\n",
        "ax = plt.gca()\n",
        "rect = Rectangle((0.3,-220),0.15,310,linewidth=1,edgecolor='r',facecolor='none')\n",
        "ax.add_patch(rect)\n",
        "rect = Rectangle((1.55,-220),0.15,310,linewidth=1,edgecolor='r',facecolor='none')\n",
        "ax.add_patch(rect)\n",
        "\n",
        "plt.annotate(s='', xy=(0.37,-150), xytext=(0.85,-150), arrowprops=dict(arrowstyle='<-'))\n",
        "plt.annotate(s='', xy=(0.37,-125), xytext=(1.35,-125), arrowprops=dict(arrowstyle='<-'))\n",
        "plt.annotate(s='', xy=(0.37,-100), xytext=(1.85,-100), arrowprops=dict(arrowstyle='<-'))\n",
        "\n",
        "plt.annotate(s='', xy=(1.63,-50), xytext=(1.15,-50), arrowprops=dict(arrowstyle='<-'))\n",
        "plt.annotate(s='', xy=(1.63,-25), xytext=(0.65,-25), arrowprops=dict(arrowstyle='<-'))\n",
        "plt.annotate(s='', xy=(1.63,0), xytext=(0.15,0), arrowprops=dict(arrowstyle='<-'))\n",
        "\n",
        "plt.annotate(s='Original', xy=(0.37,-220), xytext=(0.37,-250), arrowprops=dict(arrowstyle='<-'))\n",
        "plt.annotate(s='Original', xy=(1.63,-220), xytext=(1.63,-250), arrowprops=dict(arrowstyle='<-'));"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"877\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "cUI3WNfW4z8b",
        "colab_type": "text"
      },
      "source": [
        "The picture shows that the spectrum still contains the **original spectrum, plus** the spectral **copies** at frequency shifts of $k\\cdot \\dfrac{ 2 \\cdot \\pi}{N}$ from the originals.\n",
        "\n",
        "**Observe:** Since we have a real valued signal (the sinusoids), the spectrum of negative and positive frequencies are **symmetric** around frequency zero. This then leads to the **mirrored appearance** between the neighbouring spectral images or aliasing components.\n",
        "\n",
        "Nyquist tells us to sample in such a way, that the shifted spectra of our signal do not overlap. Otherwise, if they overlap, we cannot separate those parts of the spectrum anymore, and we loose information, which we cannot reconstruct.\n",
        "\n",
        "**In conclusion:** Sampling a signal by a factor of N, with keeping the zeros between the sample points, leads to N-1 aliasing components or spectral copies."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "16AJqjvN4z8g",
        "colab_type": "text"
      },
      "source": [
        "**Example:**\n",
        "\n",
        "Make a sine wave which at 44100 Hz sampling rate has a frequency of 400 Hz at 1 second duration. Hence we need 44100 samples, and 400 periods of our sinusoid in this second. Hence we can write our signal in Python as:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "sYUeJNpp4z8h",
        "colab_type": "code",
        "colab": {},
        "outputId": "89c3b039-f17e-49e2-b884-1ddd4250b5df"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/GpiB5cDa5to\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/GpiB5cDa5to\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "hN1W1Qa64z8k",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "import numpy as np\n",
        "fs = 44100\n",
        "f = 400.0\n",
        "s=np.sin(2*np.pi*f*np.arange(0,1,1.0/fs))\n",
        "Omega = 2*np.pi*f/fs\n",
        "s1=np.sin(Omega*np.arange(0,fs,1))"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "WTDg9Jvd4z8m",
        "colab_type": "code",
        "colab": {},
        "outputId": "b822f599-2a69-414a-d1dc-4969d48c7c69"
      },
      "source": [
        "import IPython.display as ipd\n",
        "display(ipd.Audio(s, rate=fs))"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "\n",
              "                <audio  controls=\"controls\" >\n",
              "                    <source src=\"data:audio/wav;base64,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\" type=\"audio/wav\" />\n",
              "                    Your browser does not support the audio element.\n",
              "                </audio>\n",
              "              "
            ],
            "text/plain": [
              "<IPython.lib.display.Audio object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "ehj2axdR4z8o",
        "colab_type": "code",
        "colab": {},
        "outputId": "f56f925b-6e4f-45ea-c3b0-098e2cd42999"
      },
      "source": [
        "# Plot the first 1000 samples\n",
        "plt.figure()\n",
        "plt.plot(s[0:1000])\n",
        "plt.plot(s1[0:1000])\n",
        "plt.grid()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"640\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ls64qDie4z8q",
        "colab_type": "text"
      },
      "source": [
        "Now we can multiply this sine tone signal with a unit pulse train, with N=8.\n",
        "We generate the unit impulse train,"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "HTmfqdGQ4z8q",
        "colab_type": "code",
        "colab": {},
        "outputId": "05065278-b5e6-4ca9-c7d2-16168d1a8b9d"
      },
      "source": [
        "unit = np.zeros(44100)\n",
        "unit[0::8] = 1\n",
        "plt.figure()\n",
        "plt.stem(unit[0:100], use_line_collection=True)\n",
        "plt.xlabel('n')\n",
        "plt.ylabel('unit(n)');"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"640\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "PtzvEuG24z8t",
        "colab_type": "code",
        "colab": {},
        "outputId": "7c5529a1-f337-49a6-d436-2e9a550766c3"
      },
      "source": [
        "ipd.Audio(unit,rate=44100)"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/html": [
              "\n",
              "                <audio  controls=\"controls\" >\n",
              "                    <source src=\"data:audio/wav;base64,UklGRqxYAQBXQVZFZm10IBAAAAABAAEARKwAAIhYAQACABAAZGF0YYhYAQD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAAAAAAAAAAAAP9/AAAAAAAAAAAAAAAAAAD/fwAAAAAAAAAAAAAAAAAA/38AAAAAAAA=\" type=\"audio/wav\" />\n",
              "                    Your browser does not support the audio element.\n",
              "                </audio>\n",
              "              "
            ],
            "text/plain": [
              "<IPython.lib.display.Audio object>"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 12
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "1nWSDt_l4z8w",
        "colab_type": "text"
      },
      "source": [
        " The multiplication with the unit impulse train:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "mxNeViWJ4z8w",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "sdu=s*unit"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "rSiVaufe4z8z",
        "colab_type": "text"
      },
      "source": [
        "(This multiplication is also called „frequency mixing“).\n",
        "Now plot the result, the first 100 samples:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "MEPU804h4z8z",
        "colab_type": "code",
        "colab": {},
        "outputId": "78599eef-0286-4d36-d416-f4bf88af64a7"
      },
      "source": [
        "plt.figure(figsize=(10,8))\n",
        "plt.plot(s[0:100], label='Original Signal')\n",
        "plt.stem(sdu[0:100],linefmt='r',markerfmt='r.', use_line_collection=True, label='Downsampled with zeros')\n",
        "plt.legend();"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"790\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "kbwbnJ_J4z82",
        "colab_type": "text"
      },
      "source": [
        "This is our signal still with the zeros in it.\n",
        "Now take a look at the magnitude spectrum (in dB) of the original signal s:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "h_Pv5Ehx4z82",
        "colab_type": "code",
        "colab": {},
        "outputId": "3cb23b4d-4d69-410a-8ed7-517677709fd6"
      },
      "source": [
        "from scipy.signal import freqz\n",
        "w,H=freqz(s)\n",
        "plt.figure(figsize=(10,8))\n",
        "plt.plot(w, 20*np.log10(abs(H)+1e-3))\n",
        "plt.xlabel('Normalized Frequency')\n",
        "plt.ylabel('dB')\n",
        "plt.title('Magnitude Frequency Response')\n",
        "plt.grid()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"764\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "L2Dozqlb4z84",
        "colab_type": "text"
      },
      "source": [
        "The plot shows the magnitude of the frequency spectrum of our signal. Observe that the frequency axis (horizontal) is a *normalized* frequency, normalized to the Nyquist frequency as $\\pi$, in our case 22050 Hz. Hence our sinusoid should appear as a peak at normalized frequency 400.0/22050*pi=0.05699, which we indeed see.\n",
        " \n",
        "Now we can compare this to our signal with the zeros, sdu:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "GdYhcqQg4z85",
        "colab_type": "code",
        "colab": {},
        "outputId": "31850d5b-76da-423b-99b9-85858add49c4"
      },
      "source": [
        "plt.figure(figsize=(10,8))\n",
        "w,H=freqz(s)\n",
        "plt.plot(w, 20*np.log10(abs(H)+1e-3))\n",
        "plt.xlabel('Normalized Frequency')\n",
        "plt.ylabel('dB')\n",
        "plt.title('Magnitude Frequency Response')\n",
        "\n",
        "w,H=freqz(sdu)\n",
        "plt.plot(w, 20*np.log10(abs(H)+1e-3))\n",
        "plt.legend(('Original Sinusoid','Sampled Sinusoid with Zeros'))\n",
        "plt.grid();"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"858\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "M5421xO_4z87",
        "colab_type": "text"
      },
      "source": [
        "Here we can see the original line of our 400 Hz tone, and now also the 7 new aliasing components. Observe that always 2 aliasing components are close together. This is because the original 400 Hz tone also has a spectral peak at the negative frequencies, at -400 Hz, or at normalized frequency -0.05699.\n",
        "\n",
        "Now also listen to the signal with the zeros:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "1fCrD2P24z88",
        "colab_type": "code",
        "colab": {},
        "outputId": "297033ca-49c1-4665-8a91-eadea7466bb8"
      },
      "source": [
        "ipd.Audio(sdu,rate=44100)"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/html": [
              "\n",
              "                <audio  controls=\"controls\" >\n",
              "                    <source src=\"data:audio/wav;base64,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\" type=\"audio/wav\" />\n",
              "                    Your browser does not support the audio element.\n",
              "                </audio>\n",
              "              "
            ],
            "text/plain": [
              "<IPython.lib.display.Audio object>"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 26
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "9v-z5w-s4z8_",
        "colab_type": "text"
      },
      "source": [
        "### Real-Time Python Example"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "D-LaGr_94z9A",
        "colab_type": "text"
      },
      "source": [
        "Here you can hear that it sounds quite different from the original, because of the strong aliasing components!\n",
        " \n",
        "**Python** real time audio **example**: This example takes the microphone input and samples it, without removing the zeros, and plays it back the the speaker in real time.\n",
        "\n",
        "It constructs a unit pulse train, with a 1 at every N'th sample, using the modulus function „%“, \n",
        "\n",
        "```s=(np.arange(0,CHUNK)%N)==0```"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "onmXvGph4z9A",
        "colab_type": "code",
        "colab": {},
        "outputId": "b0723d44-adc5-49a9-fd4b-7087e914afdf"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/hbIQOeD4N2k\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/hbIQOeD4N2k\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "nruLk4L_4z9D",
        "colab_type": "code",
        "colab": {
          "referenced_widgets": [
            "58af0e2b243b46b8beb32885f671b62b",
            "85e6d70dffce42e6a4aa4b78d1ea1b06"
          ]
        },
        "outputId": "af09f9a3-c46e-4909-b75b-22a72a040dfd"
      },
      "source": [
        "\"\"\"\n",
        "PyAudio Example: Make a sampling between input and output \n",
        "(i.e., record a few samples, multiply them with a unit pulse train,\n",
        "and play them back immediately).\n",
        "Using block-wise processing instead of a for loop\n",
        "Gerald Schuller, Octtober 2014\n",
        "\n",
        "Updated and Ported to Jupyter Notebooks by: Renato Profeta, November 2019\n",
        "Using PyAudio Callback Mode, Matplolib\n",
        "\"\"\"\n",
        "\n",
        "import time\n",
        "import numpy as np\n",
        "from pyaudio import PyAudio, paFloat32, paContinue, paInt16, paComplete\n",
        "from ipywidgets import ToggleButton, Checkbox\n",
        "import threading\n",
        "\n",
        "sampling_on=False\n",
        "\n",
        "button_stop= ToggleButton(description='Stop')\n",
        "box_sampling = Checkbox(False, description='Downsampling with Zeros')\n",
        "\n",
        "def on_button_stop(change):\n",
        "    if change['new']==True:\n",
        "        stream.stop_stream()\n",
        "        stream.close()\n",
        "        pa.terminate()\n",
        "        button_stop.disabled=True\n",
        "        print('PyAudio terminated...')\n",
        "button_stop.observe(on_button_stop, 'value')\n",
        "display(button_stop)\n",
        "\n",
        "def box_sampling_changed(box_sampling):\n",
        "    global SamplingOn\n",
        "    if box_sampling['new']: \n",
        "        SamplingOn=True\n",
        "    else:\n",
        "        SamplingOn=False       \n",
        "box_sampling.observe(box_sampling_changed, names='value')\n",
        "display(box_sampling)\n",
        "\n",
        "N=8\n",
        "s=(np.arange(0,1024)%N)==0\n",
        "SamplingOn=False\n",
        "\n",
        "\n",
        "def callback(in_data, frame_count, time_info, flag):\n",
        "    global SamplingOn\n",
        "    audio_data = np.frombuffer(in_data, dtype=np.int16)\n",
        "    audio_data_s = audio_data\n",
        "    if SamplingOn:\n",
        "        audio_data_s=audio_data*s\n",
        "    if button_stop.value==True:\n",
        "        return (audio_data_s, paComplete)\n",
        "    return (audio_data_s, paContinue)\n",
        "\n",
        "pa = PyAudio()\n",
        "\n",
        "stream = pa.open(format = paInt16,\n",
        "                 channels = 1,\n",
        "                 rate = 44100,\n",
        "                 output = True,\n",
        "                 input = True,\n",
        "                 frames_per_buffer = 1024,\n",
        "                 stream_callback = callback)\n",
        "\n",
        "\n",
        "def keep_alive(button_stop):\n",
        "    while stream.is_active():\n",
        "        if button_stop.value==True:\n",
        "            break\n",
        "        time.sleep(0.1)\n",
        "\n",
        "# Create a Thread for run_spectrogram function\n",
        "thread = threading.Thread(target=keep_alive, args=(button_stop,))\n",
        "stream.start_stream()\n",
        "thread.start()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "58af0e2b243b46b8beb32885f671b62b",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "ToggleButton(value=False, description='Stop')"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "85e6d70dffce42e6a4aa4b78d1ea1b06",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "Checkbox(value=False, description='Downsampling with Zeros')"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "stream",
          "text": [
            "PyAudio terminated...\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "sLmiWjaZ4z9F",
        "colab_type": "text"
      },
      "source": [
        "## Removing the Zeros"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "scKzsUxO4z9F",
        "colab_type": "text"
      },
      "source": [
        "The final step of downsampling is now to omit the zeros between the samples, to obtain the lower sampling rate. Let's call the signal without the zeros  $y(m)$ where the time index m denotes the **lower sampling rate** (as opposed to n, which denotes the higher sampling rate). \n",
        "\n",
        "In our Python example this is:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "RFSgMQ4A4z9F",
        "colab_type": "code",
        "colab": {},
        "outputId": "32537ffa-36bc-4833-abbd-a25df6b787ce"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/XGKfAm1-Mek\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/XGKfAm1-Mek\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "__4hUY1W4z9H",
        "colab_type": "code",
        "colab": {},
        "outputId": "00b4d27f-b302-479d-df0e-8cde95be28ed"
      },
      "source": [
        "sd = sdu[0:44100:8]\n",
        "plt.figure(figsize=(10,8))\n",
        "plt.stem(sd[0:int(100/8)],linefmt='r',markerfmt='r.', use_line_collection=True, label='Downsampled without zeros')\n",
        "plt.legend()\n",
        "plt.grid();"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"762\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ytABmewr4z9J",
        "colab_type": "text"
      },
      "source": [
        "We can now take a look at the spectrum with :"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "yPdaSA2W4z9K",
        "colab_type": "code",
        "colab": {},
        "outputId": "a1be4b74-b937-44b3-d692-99514bb78705"
      },
      "source": [
        "w,H=freqz(sd)\n",
        "plt.figure(figsize=(10,8))\n",
        "plt.plot(w, 20*np.log10(abs(H)+1e-3))\n",
        "plt.xlabel('Frequency')\n",
        "plt.ylabel('dB')\n",
        "plt.title('Magnitude Frequency Response')\n",
        "plt.grid()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"773\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Fbrl0xV84z9L",
        "colab_type": "text"
      },
      "source": [
        "Observe that the sine signal now appear at normalized frequency of 0.455, a **factor of 8 higher** than before, with the zeros in it, because we **reduced the sampling rate by 8**. \n",
        "\n",
        "This is because we now have a new Nyquist frequency of 22050/8 now, hence our normalized frequency becomes $400*3.14 / 22050 * 8 \\approx 0.455$. This means removing the zeros scales or stretches our frequency axis.\n",
        "\n",
        "    \n",
        "Observe that in our time-domain plot, we only have $100/8 \\approx12$ samples left."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "MqyDFEi74z9M",
        "colab_type": "text"
      },
      "source": [
        "How are the frequency responses or spectra of $y(m)$ and $x^d(n)$ connected? \n",
        "\n",
        "We can simply take the Fourier transforms of them,\n",
        "\n",
        "$$ \\large\n",
        "X^d (\\Omega)=\\sum _ {n=- \\infty}^ \\infty x^d (n) \\cdot  e^{-j \\Omega n} \n",
        "$$\n",
        "\n",
        "still with the zeros in it. Hence most of the sum contains only zeros. Now we only need to let the sum run over the non-zeros entries (only every Nth entry), by replacing n by mN, and we get\n",
        "\n",
        "$$ \\large\n",
        "X^d (\\Omega)=\\sum _ {n=mN} x^d (n) \\cdot  e^{-j \\Omega n} \n",
        "$$\n",
        "\n",
        "for all integer m, now without the zeros. Now we can make the connection to the Fourier transform of y(m), by making the index substitution m for n in the sum,\n",
        "\n",
        "\n",
        "$$ \\large\n",
        "X^d (\\Omega)= \\sum _{m=- \\infty} ^ \\infty y(m) \\cdot  e^{-j \\Omega \\cdot N m} = Y(\\Omega \\cdot N) \n",
        "$$\n",
        "\n",
        "This is now our result. It shows that the downsampled version (with the removal of the zeros), has the same frequency response, but the frequency variable $\\Omega$ is scaled by the factor N. \n",
        "\n",
        "For instance, the normalized frequency $\\pi /N$ before downsampling becomes $\\pi$ after removing the zeros! It shows that a small part of the spectrum before downsampling becomes the full usable spectrum after downsampling.\n",
        "\n",
        "Observe that we don't loose any frequencies this way, because by looking at eq. (1) we see that we obtain multiple copies of the spectrum in steps of $2\\pi /N$, and hence the spectrum already has a periodicity of $2\\pi /N$. This means that the spectrum between $-\\pi/N$ and $\\pi/N$ for instance (we could take any period of length $2\\pi /N$) contains a unique and full part of the spectrum, because the rest is just a periodic continuation. "
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "-qEMAodW4z9M",
        "colab_type": "text"
      },
      "source": [
        "This can be seen in following pictures,\n",
        "\n",
        "<center>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/Lecture6-6.PNG?raw=1' width=\"600\" ><br>\n",
        "    <cite>Figure: The magnitude spectrum of a signal. The 2 boxes symbolize the passband of an ideal bandpass, here a high pass.</cite>\n",
        "</center>\n",
        "<center>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/Lecture6-8.PNG?raw=1' width=\"600\"><br>\n",
        "    <cite>Figure: The signal spectrum after passing through the high pass.\n",
        "    </cite>\n",
        "</center>\n",
        "<center>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/Lecture6-7.PNG?raw=1' width=\"600\"><br>\n",
        "    <cite>Figure: Signal spectrum after multiplication with the unit pulse train, for N=2, hence setting every second value to zero (the zeros still in the sequence). Observe that we shift and add the signal by multiples of $2\\pi /2=\\pi$, and in effect we obtain „mirrored“ images of the high frequencies to the low frequencies (since we assume a real valued signal). Observe that the mirrored spectra and the original spectrum don't overlap, which makes reconstruction easy.</cite>\n",
        "</center>\n",
        "<center>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/Lecture6-9.PNG?raw=1' width=\"600\" ><br>\n",
        "    <cite>Figure: Signal spectrum after downsampling (removing the zeros) by N (2 in this example). Observe the stretching of the spectrum by a factor of 2. </cite>\n",
        "</center>"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "PW3kLqwc4z9M",
        "colab_type": "text"
      },
      "source": [
        "## Upsampling"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "weiOkO4p4z9N",
        "colab_type": "code",
        "colab": {},
        "outputId": "8983d4ed-e172-4017-b3fd-1fc42f57e7a6"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/Ow_FOJS82gc\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/Ow_FOJS82gc\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "y04ZGema4z9P",
        "colab_type": "text"
      },
      "source": [
        "What is still missing in our system is the upsampling, as the opposite operation of downsampling, for the case where we would like to increase our sampling rate. One of the first (**wrong!**) approaches to upsampling that often comes to mind if we want to do upsampling by a factor of N, is to simply repeat every sample N-1 times. \n",
        "\n",
        "**But** this is equivalent to first inserting N-1 zeros after each sample, and then filter the resulting sequence by a **low pass** filter with an impulse response of N ones. This is a very special case, and we would like to have a more general case. \n",
        "\n",
        "In our case, we actually a high pass filter, not a low pass. Hence we assume that we upsample by always first inserting N-1 **zeros** after each sample, and then have some interpolation filter for it (can also be a **high or band pass**, as needed to reconstruct a signal).\n",
        "\n",
        "Again we take the signal at the lower sampling rate as $y(m)$, with index m for the lower sampling rate, and the signal at the higher sampling rate, with the zeros in it, as $x^d(n)$ with index n for the higher sampling rate. Here we can see that this is simply the reverse operation of the final step of removing the zeros for the downsampling.\n",
        "\n",
        "Hence we can take our result from downsampling and apply it here:\n",
        "\n",
        "$$X^d(\\Omega)=Y(\\Omega \\cdot N)$$\n",
        "$$or$$\n",
        "$$X^d(\\Omega /N)=Y(\\Omega )$$\n",
        "\n",
        "We are now just coming from y(m), going to the now upsampled signal $x^d(n)$.\n",
        "\n",
        "For instance if we had the frequency $\\pi$ before upsampling, it becomes $\\pi /2$ for the upsampled signal, if we have N=2. In this way we now get an „extended“ frequency range.\n",
        "\n",
        "Since we now have again the signal including the zeros, $x^d(n)$, we again have the periodic spectrum, as before, as we progress through the same steps backwards now. We can also see that the result of upsampling is periodic in frequency, because the signal was $2\\pi$ periodic before upsampling anyway, and after upsampling the  frequency scale replaces $2\\pi \\cdot N$ by $2\\pi$. "
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "d0s3T4v44z9P",
        "colab_type": "text"
      },
      "source": [
        "## Reconstruction"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "m-LfxHvp4z9P",
        "colab_type": "code",
        "colab": {},
        "outputId": "6c43a142-c19c-40ad-d359-6527e9508369"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/bIYXoAUISNs\" frameborder=\"0\" allow=\"accelerometer; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/bIYXoAUISNs\" frameborder=\"0\" allow=\"accelerometer; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "VGuJFU6M4z9U",
        "colab_type": "text"
      },
      "source": [
        "Observe that if the **aliasing components don't overlap**, we can **perfectly reconstruct** the signal by using a suitable filter. We can make sure that they don't overlap by **filtering** the signal at the **higher sampling rate**, before they can overlap (as we did in our high pass example). If they already overlap at the lower sampling rate, it would be too late to separate the different components, the signal would already be „destroyed“.\n",
        "\n",
        "We can perfectly reconstruct the high pass signal in our example if we use ideal filters, using upsampling and ideal high pass filtering.\n",
        "\n",
        "In this way we have for the analysis and synthesis the following picture:\n",
        "\n",
        "<center>\n",
        "    <br>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/Lecture6-10.PNG?raw=1'>\n",
        "</center>\n",
        "\n",
        "Observe that we violate the conventional Nyquist criterium, because our high pass passes the high frequencies. But then the sampling mirrors those frequencies to the lower range, such that we can apply the traditional Nyquist sampling theorem. This method is also known as bandpass Nyquist. This is an important principle for filter banks and wavelets. It says that we can perfectly reconstruct a bandpass signal in a filter bank, if we sample with twice the rate as the **bandwidth** of our bandpass signal (assuming ideal filters, to avoid spectral overlap of aliasing components).\n",
        "\n",
        "In genereal this is true for **complex** filters.<br>\n",
        "For **real** valued filters observe that this simple assumption only works if we have bandpass filters which start at frequencies $\\pi/N\\cdot k$(integer k) .  Otherwise we could have overlap to the aliased components!\n",
        "\n",
        "**Example:** We have a real valued bandpass filter which starts its passband at $\\epsilon$ and ends at $\\epsilon+\\pi /N$(since it is real values the the passband also appears at the same negative frequencies, $-\\epsilon$ to $-\\epsilon-\\pi /N$). After multiplication with the unit pulse train, we get one (out of N) aliasing component by shifting the negative passband by $2\\pi /N$ to the positive frequencies, which results in the range of $\\pi / N-\\epsilon$ to $2\\pi /N-\\epsilon$. Hence we have an overlap from $\\pi / N-\\epsilon$ to $\\pi/N+\\epsilon$ and we could not perfectly reconstruct our signal!\n",
        "\n",
        "Hence, sampling of twice the bandwidth for real valued signals and filters only works if the bandwidth are aligned with $\\pi /N \\cdot k$. What could we do otherwise to avoid overlapping aliasing components? We could simply increase the sampling rate, for instance to twice the usual sampling rate (4 times the bandwidth), to have a \"safety margin\".\n",
        "\n",
        "Another possibility would be to shift the bandpass signals in frequency, such that they are now aligned with the above mentioned grid.\n",
        "\n",
        "Observe that this restriction is not needed for complex signals or filter banks. That is also why complex filter banks are used for instance in acoustic echo cancellation, because there the sampling rate can be increased by a certain fraction (less than a factor of 2) to reduce aliasing artifacts, and still have a lower complexity.\n",
        "\n",
        "<center>\n",
        "    <br>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/Lecture6-11.PNG?raw=1'>\n",
        "</center>\n",
        "\n",
        "**Summary:** if our band boarders are alligned with multiples of $\\pi/N$ then we can donwsample by N, otherwise we are on the safe side by using N/2 as downsampling rate for real valued signals.  For complex signals we can always downsample by N, regardles of the exact placement of the bandpass filter.\n",
        "\n",
        "Compare with the standard Nyquist case: here we have a lowpass signal which we downsample and reconstruct:\n",
        "<center>\n",
        "    <img src='https://github.com/GuitarsAI/ADSP_Tutorials/blob/master/images/Lecture6-12.PNG?raw=1'>\n",
        "</center>"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "WQsCQLI94z9V",
        "colab_type": "text"
      },
      "source": [
        "## Python Example: Live Spectrogram: Sampling, LP Filtering"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "hide_input": true,
        "id": "SN6hProM4z9W",
        "colab_type": "code",
        "colab": {},
        "outputId": "1adccb31-2b3e-4eb2-9a5c-55d109b254f4"
      },
      "source": [
        "%%html\n",
        "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/6WJQ3KCBN7w\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<iframe width=\"560\" height=\"315\" src=\"https://www.youtube.com/embed/6WJQ3KCBN7w\" frameborder=\"0\" allow=\"accelerometer; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>\n"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "EuBXv0rf4z9Z",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# Imports and Configuration\n",
        "\n",
        "import pyaudio\n",
        "import numpy as np\n",
        "import scipy.signal as signal\n",
        "import struct\n",
        "import matplotlib.pyplot as plt\n",
        "from matplotlib.mlab import window_hanning,specgram\n",
        "from matplotlib.colors import LogNorm\n",
        "from matplotlib.ticker import FuncFormatter, MultipleLocator\n",
        "from ipywidgets import ToggleButton, Checkbox, Button\n",
        "from ipywidgets import HBox, interact\n",
        "import threading"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "x43cNPTu4z9e",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "CHUNK_SIZE = 2048 #Blocksize\n",
        "CHANNELS = 1 # Audio Channes\n",
        "RATE = 32000  #Sampling Rate in Hz\n",
        "N=8.0     #Downsampling/Upsampling Rate\n",
        "FORMAT = pyaudio.paInt16 #conversion format for PyAudio stream\n",
        "NFFT = 1024 #NFFT value for spectrogram\n",
        "OVERLAP = 512 #overlap value for spectrogram"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "nGIljmRP4z9g",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# LP Filter\n",
        "[b,a]=signal.iirfilter(8, 1900.0/16000,rp=60,btype='lowpass')\n",
        "#Memory for the filter:\n",
        "zd=np.zeros(8)\n",
        "zu=np.zeros(8)\n",
        "LPFilterOn=False"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "9sAiqYjY4z9k",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# Function to Plot Spetrogram\n",
        "SamplingOn=False # Turn Donwsampling/Upsampling On/Off\n",
        "ctr=0 # Control for plotting\n",
        "def run_spectrogram(toggle_run):\n",
        "    global zd, zu, ctr, SamplingOn, LPFilterOn\n",
        "    while(True):\n",
        "        if toggle_run.value==True:\n",
        "            break\n",
        "            \n",
        "        #Reading from audio input stream into data with block length \"CHUNK\":\n",
        "        data_stream = stream.read(CHUNK_SIZE)\n",
        "        shorts = (struct.unpack( 'h' * CHUNK_SIZE, data_stream ));\n",
        "        samples=np.array(list(shorts),dtype=float);\n",
        "\n",
        "        #start block-wise signal processing:\n",
        "        #Low pass filter *before downsampling*:\n",
        "        if LPFilterOn==True:\n",
        "            [samples,zd]=signal.lfilter(b, a, samples, zi=zd)\n",
        "\n",
        "        #Compute a block/an array of a unit pulse train corresponding a downsampling rate of N:\n",
        "        #make unit pulse train with modulus function \"%\": \n",
        "        s=(np.arange(0,CHUNK_SIZE)%N)==0\n",
        "        #The sampling:\n",
        "        #multiply the signal with the unit pulse train:\n",
        "        if SamplingOn == True:\n",
        "            samples=samples*s;\n",
        "\n",
        "\n",
        "        #Lowpass filtering *after upsampling*:\n",
        "        #filter function:\n",
        "        if LPFilterOn==True:\n",
        "            [samples,zu]=signal.lfilter(b, a, samples, zi=zu)\n",
        "\n",
        "        #end signal processing\n",
        "\n",
        "        #play out samples:\n",
        "        samples=np.clip(samples, -32000,32000)\n",
        "        samples=samples.astype(int)\n",
        "        #converting from short integers to a stream of bytes in \"data\":\n",
        "        data=struct.pack('h' * len(samples), *samples);\n",
        "        #Writing data back to audio output stream: \n",
        "        stream.write(data, CHUNK_SIZE)\n",
        "\n",
        "        # Update Plot\n",
        "        if (ctr%4 ==0):\n",
        "            arr2D,freqs,bins = specgram(samples,window=window_hanning,\n",
        "                                        Fs = RATE,NFFT=NFFT,noverlap=OVERLAP)\n",
        "            im_data = im.get_array()\n",
        "            if ctr < 16:\n",
        "                im_data = np.hstack((im_data,arr2D))\n",
        "                im.set_array(im_data)\n",
        "            else:\n",
        "                keep_block = arr2D.shape[1]*(16 - 1)\n",
        "                im_data = np.delete(im_data,np.s_[:-keep_block],1)\n",
        "                im_data = np.hstack((im_data,arr2D))\n",
        "                im.set_array(im_data)\n",
        "            fig.canvas.draw()\n",
        "        ctr+=1"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "kFDJ_Tqz4z9n",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# GUI\n",
        "toggle_run = ToggleButton(description='Stop')\n",
        "button_start= Button(description='Start')\n",
        "box_sampling = Checkbox(False, description='Downsampling/Upsampling')\n",
        "box_LPFilter = Checkbox(False, description='LP Filters')\n",
        "\n",
        "def start_button(button_start):\n",
        "    thread.start()\n",
        "    button_start.disabled=True\n",
        "button_start.on_click(start_button)\n",
        "\n",
        "\n",
        "def on_click_toggle_run(change):\n",
        "    if change['new']==False:\n",
        "        stream.stop_stream()\n",
        "        stream.close()\n",
        "        p.terminate()\n",
        "        plt.close()\n",
        "toggle_run.observe(on_click_toggle_run, 'value')\n",
        "\n",
        "def box_samping_changed(box_sampling):\n",
        "    global SamplingOn\n",
        "    if box_sampling['new']: \n",
        "        SamplingOn=True\n",
        "    else:\n",
        "        SamplingOn=False       \n",
        "box_sampling.observe(box_samping_changed, names='value')\n",
        "\n",
        "def box_LPFilter_changed(box_LPFilter):\n",
        "    global LPFilterOn\n",
        "    if box_LPFilter['new']: \n",
        "        LPFilterOn=True\n",
        "    else:\n",
        "        LPFilterOn=False       \n",
        "box_LPFilter.observe(box_LPFilter_changed, names='value')\n",
        "\n",
        "box_buttons = HBox([button_start,toggle_run])\n",
        "box_checkbox = HBox([box_sampling,box_LPFilter])"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "voRW9wbz4z9o",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# Create a Thread for run_spectrogram function\n",
        "thread = threading.Thread(target=run_spectrogram, args=(toggle_run,))"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "4F1vJTAQ4z9q",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "# Start Audio Stream\n",
        "# Create \n",
        "p = pyaudio.PyAudio()\n",
        "    \n",
        "stream = p.open(format=FORMAT,\n",
        "                channels=CHANNELS,\n",
        "                rate=RATE,\n",
        "                input=True,\n",
        "                output=True,\n",
        "                frames_per_buffer=CHUNK_SIZE)\n",
        "\n",
        "\n",
        "\n",
        "input_data = stream.read(CHUNK_SIZE)\n",
        "samples = np.frombuffer(input_data,np.int16)"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "AM46-UOj4z9s",
        "colab_type": "code",
        "colab": {
          "referenced_widgets": [
            "e1e25ba72c6a4321bcef7f3aecc60a29",
            "621d72d9ceb64f6b9f572825a27fda66"
          ]
        },
        "outputId": "bf53c828-1f1b-42fe-9e6b-9a3c136750fd"
      },
      "source": [
        "# Initialize Plot and Display GUI\n",
        "\n",
        "display(box_buttons)\n",
        "display(box_checkbox)\n",
        "\n",
        "fig, ax = plt.subplots()\n",
        "arr2D,freqs,bins = specgram(samples,window=window_hanning,\n",
        "                                Fs = RATE,NFFT=NFFT,noverlap=OVERLAP)\n",
        "\n",
        "\n",
        "extent = (bins[0],bins[-1]*32,freqs[-1],freqs[0])\n",
        "im = plt.imshow(arr2D,aspect='auto',extent = extent,interpolation=\"none\",\n",
        "                     norm = LogNorm(vmin=.01,vmax=1))\n",
        "plt.xlabel('Time')\n",
        "plt.ylabel('Frequency (Hz)')\n",
        "plt.title('Live Spectogram')\n",
        "plt.gca().invert_yaxis()\n",
        "plt.xticks([])\n",
        "\n",
        "def handle_close(evt):\n",
        "    # When everything done, release the capture\n",
        "    stream.stop_stream()\n",
        "    stream.close()\n",
        "    p.terminate()\n",
        "    plt.close()\n",
        "plt.connect('close_event', handle_close);"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "e1e25ba72c6a4321bcef7f3aecc60a29",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "HBox(children=(Button(description='Start', style=ButtonStyle()), ToggleButton(value=False, description='Stop')…"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "621d72d9ceb64f6b9f572825a27fda66",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "HBox(children=(Checkbox(value=False, description='Downsampling/Upsampling'), Checkbox(value=False, description…"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "/* Put everything inside the global mpl namespace */\n",
              "window.mpl = {};\n",
              "\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('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",
              "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 = $('<div/>');\n",
              "    this._root_extra_style(this.root)\n",
              "    this.root.attr('style', 'display: inline-block');\n",
              "\n",
              "    $(parent_element).append(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 (mpl.ratio != 1) {\n",
              "                fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\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 = $(\n",
              "        '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
              "        'ui-helper-clearfix\"/>');\n",
              "    var titletext = $(\n",
              "        '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
              "        'text-align: center; padding: 3px;\"/>');\n",
              "    titlebar.append(titletext)\n",
              "    this.root.append(titlebar);\n",
              "    this.header = titletext[0];\n",
              "}\n",
              "\n",
              "\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_canvas = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var canvas_div = $('<div/>');\n",
              "\n",
              "    canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
              "\n",
              "    function canvas_keyboard_event(event) {\n",
              "        return fig.key_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    canvas_div.keydown('key_press', canvas_keyboard_event);\n",
              "    canvas_div.keyup('key_release', canvas_keyboard_event);\n",
              "    this.canvas_div = canvas_div\n",
              "    this._canvas_extra_style(canvas_div)\n",
              "    this.root.append(canvas_div);\n",
              "\n",
              "    var canvas = $('<canvas/>');\n",
              "    canvas.addClass('mpl-canvas');\n",
              "    canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
              "\n",
              "    this.canvas = canvas[0];\n",
              "    this.context = canvas[0].getContext(\"2d\");\n",
              "\n",
              "    var backingStore = this.context.backingStorePixelRatio ||\n",
              "\tthis.context.webkitBackingStorePixelRatio ||\n",
              "\tthis.context.mozBackingStorePixelRatio ||\n",
              "\tthis.context.msBackingStorePixelRatio ||\n",
              "\tthis.context.oBackingStorePixelRatio ||\n",
              "\tthis.context.backingStorePixelRatio || 1;\n",
              "\n",
              "    mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
              "\n",
              "    var rubberband = $('<canvas/>');\n",
              "    rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
              "\n",
              "    var pass_mouse_events = true;\n",
              "\n",
              "    canvas_div.resizable({\n",
              "        start: function(event, ui) {\n",
              "            pass_mouse_events = false;\n",
              "        },\n",
              "        resize: function(event, ui) {\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "        stop: function(event, ui) {\n",
              "            pass_mouse_events = true;\n",
              "            fig.request_resize(ui.size.width, ui.size.height);\n",
              "        },\n",
              "    });\n",
              "\n",
              "    function mouse_event_fn(event) {\n",
              "        if (pass_mouse_events)\n",
              "            return fig.mouse_event(event, event['data']);\n",
              "    }\n",
              "\n",
              "    rubberband.mousedown('button_press', mouse_event_fn);\n",
              "    rubberband.mouseup('button_release', mouse_event_fn);\n",
              "    // Throttle sequential mouse events to 1 every 20ms.\n",
              "    rubberband.mousemove('motion_notify', mouse_event_fn);\n",
              "\n",
              "    rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
              "    rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
              "\n",
              "    canvas_div.on(\"wheel\", function (event) {\n",
              "        event = event.originalEvent;\n",
              "        event['data'] = 'scroll'\n",
              "        if (event.deltaY < 0) {\n",
              "            event.step = 1;\n",
              "        } else {\n",
              "            event.step = -1;\n",
              "        }\n",
              "        mouse_event_fn(event);\n",
              "    });\n",
              "\n",
              "    canvas_div.append(canvas);\n",
              "    canvas_div.append(rubberband);\n",
              "\n",
              "    this.rubberband = rubberband;\n",
              "    this.rubberband_canvas = rubberband[0];\n",
              "    this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
              "    this.rubberband_context.strokeStyle = \"#000000\";\n",
              "\n",
              "    this._resize_canvas = function(width, height) {\n",
              "        // Keep the size of the canvas, canvas container, and rubber band\n",
              "        // canvas in synch.\n",
              "        canvas_div.css('width', width)\n",
              "        canvas_div.css('height', height)\n",
              "\n",
              "        canvas.attr('width', width * mpl.ratio);\n",
              "        canvas.attr('height', height * mpl.ratio);\n",
              "        canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
              "\n",
              "        rubberband.attr('width', width);\n",
              "        rubberband.attr('height', height);\n",
              "    }\n",
              "\n",
              "    // Set the figure to an initial 600x600px, this will subsequently be updated\n",
              "    // upon first draw.\n",
              "    this._resize_canvas(600, 600);\n",
              "\n",
              "    // Disable right mouse context menu.\n",
              "    $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\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 nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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",
              "            // put a spacer in here.\n",
              "            continue;\n",
              "        }\n",
              "        var button = $('<button/>');\n",
              "        button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
              "                        'ui-button-icon-only');\n",
              "        button.attr('role', 'button');\n",
              "        button.attr('aria-disabled', 'false');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "\n",
              "        var icon_img = $('<span/>');\n",
              "        icon_img.addClass('ui-button-icon-primary ui-icon');\n",
              "        icon_img.addClass(image);\n",
              "        icon_img.addClass('ui-corner-all');\n",
              "\n",
              "        var tooltip_span = $('<span/>');\n",
              "        tooltip_span.addClass('ui-button-text');\n",
              "        tooltip_span.html(tooltip);\n",
              "\n",
              "        button.append(icon_img);\n",
              "        button.append(tooltip_span);\n",
              "\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    var fmt_picker_span = $('<span/>');\n",
              "\n",
              "    var fmt_picker = $('<select/>');\n",
              "    fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
              "    fmt_picker_span.append(fmt_picker);\n",
              "    nav_element.append(fmt_picker_span);\n",
              "    this.format_dropdown = fmt_picker[0];\n",
              "\n",
              "    for (var ind in mpl.extensions) {\n",
              "        var fmt = mpl.extensions[ind];\n",
              "        var option = $(\n",
              "            '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
              "        fmt_picker.append(option);\n",
              "    }\n",
              "\n",
              "    // Add hover states to the ui-buttons\n",
              "    $( \".ui-button\" ).hover(\n",
              "        function() { $(this).addClass(\"ui-state-hover\");},\n",
              "        function() { $(this).removeClass(\"ui-state-hover\");}\n",
              "    );\n",
              "\n",
              "    var status_bar = $('<span class=\"mpl-message\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\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",
              "\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",
              "\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]);\n",
              "        fig.send_message(\"refresh\", {});\n",
              "    };\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
              "    var x0 = msg['x0'] / mpl.ratio;\n",
              "    var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
              "    var x1 = msg['x1'] / mpl.ratio;\n",
              "    var y1 = (fig.canvas.height - msg['y1']) / mpl.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, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\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",
              "    var cursor = msg['cursor'];\n",
              "    switch(cursor)\n",
              "    {\n",
              "    case 0:\n",
              "        cursor = 'pointer';\n",
              "        break;\n",
              "    case 1:\n",
              "        cursor = 'default';\n",
              "        break;\n",
              "    case 2:\n",
              "        cursor = 'crosshair';\n",
              "        break;\n",
              "    case 3:\n",
              "        cursor = 'move';\n",
              "        break;\n",
              "    }\n",
              "    fig.rubberband_canvas.style.cursor = 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.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",
              "            /* 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",
              "            evt.data.type = \"image/png\";\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",
              "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
              "                evt.data);\n",
              "            fig.updated_canvas_event();\n",
              "            fig.waiting = false;\n",
              "            return;\n",
              "        }\n",
              "        else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\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(\"No handler for the '\" + msg_type + \"' message type: \", msg);\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(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
              "            }\n",
              "        }\n",
              "    };\n",
              "}\n",
              "\n",
              "// from http://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",
              "    if (e.target)\n",
              "        targ = e.target;\n",
              "    else if (e.srcElement)\n",
              "        targ = e.srcElement;\n",
              "    if (targ.nodeType == 3) // defeat Safari bug\n",
              "        targ = targ.parentNode;\n",
              "\n",
              "    // jQuery normalizes the pageX and pageY\n",
              "    // pageX,Y are the mouse positions relative to the document\n",
              "    // offset() returns the position of the element relative to the document\n",
              "    var x = e.pageX - $(targ).offset().left;\n",
              "    var y = e.pageY - $(targ).offset().top;\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",
              " * http://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",
              "    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",
              "    {\n",
              "        this.canvas.focus();\n",
              "        this.canvas_div.focus();\n",
              "    }\n",
              "\n",
              "    var x = canvas_pos.x * mpl.ratio;\n",
              "    var y = canvas_pos.y * mpl.ratio;\n",
              "\n",
              "    this.send_message(name, {x: x, y: y, button: event.button,\n",
              "                             step: event.step,\n",
              "                             guiEvent: simpleKeys(event)});\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",
              "\n",
              "    // Prevent repeat events\n",
              "    if (name == 'key_press')\n",
              "    {\n",
              "        if (event.which === this._key)\n",
              "            return;\n",
              "        else\n",
              "            this._key = event.which;\n",
              "    }\n",
              "    if (name == 'key_release')\n",
              "        this._key = null;\n",
              "\n",
              "    var value = '';\n",
              "    if (event.ctrlKey && event.which != 17)\n",
              "        value += \"ctrl+\";\n",
              "    if (event.altKey && event.which != 18)\n",
              "        value += \"alt+\";\n",
              "    if (event.shiftKey && event.which != 16)\n",
              "        value += \"shift+\";\n",
              "\n",
              "    value += 'k';\n",
              "    value += event.which.toString();\n",
              "\n",
              "    this._key_event_extra(event, name);\n",
              "\n",
              "    this.send_message(name, {key: value,\n",
              "                             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",
              "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\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
              "\n",
              "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
              "\n",
              "mpl.default_extension = \"png\";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.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",
              "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
              "        ws.onmessage(msg['content']['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 = $(\"#\" + id);\n",
              "    var ws_proxy = comm_websocket_adapter(comm)\n",
              "\n",
              "    function ondownload(figure, format) {\n",
              "        window.open(figure.imageObj.src);\n",
              "    }\n",
              "\n",
              "    var fig = new mpl.figure(id, ws_proxy,\n",
              "                           ondownload,\n",
              "                           element.get(0));\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.get(0);\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",
              "\n",
              "    var output_index = fig.cell_info[2]\n",
              "    var cell = fig.cell_info[0];\n",
              "\n",
              "};\n",
              "\n",
              "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
              "    var width = fig.canvas.width/mpl.ratio\n",
              "    fig.root.unbind('remove')\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).html('<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/mpl.ratio\n",
              "    var dataURL = this.canvas.toDataURL();\n",
              "    this.cell_info[1]['text/html'] = '<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 () { fig.push_to_output() }, 1000);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._init_toolbar = function() {\n",
              "    var fig = this;\n",
              "\n",
              "    var nav_element = $('<div/>');\n",
              "    nav_element.attr('style', 'width: 100%');\n",
              "    this.root.append(nav_element);\n",
              "\n",
              "    // Define a callback function for later on.\n",
              "    function toolbar_event(event) {\n",
              "        return fig.toolbar_button_onclick(event['data']);\n",
              "    }\n",
              "    function toolbar_mouse_event(event) {\n",
              "        return fig.toolbar_button_onmouseover(event['data']);\n",
              "    }\n",
              "\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) { continue; };\n",
              "\n",
              "        var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
              "        button.click(method_name, toolbar_event);\n",
              "        button.mouseover(tooltip, toolbar_mouse_event);\n",
              "        nav_element.append(button);\n",
              "    }\n",
              "\n",
              "    // Add the status bar.\n",
              "    var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
              "    nav_element.append(status_bar);\n",
              "    this.message = status_bar[0];\n",
              "\n",
              "    // Add the close button to the window.\n",
              "    var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
              "    var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
              "    button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
              "    button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
              "    buttongrp.append(button);\n",
              "    var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
              "    titlebar.prepend(buttongrp);\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._root_extra_style = function(el){\n",
              "    var fig = this\n",
              "    el.on(\"remove\", function(){\n",
              "\tfig.close_ws(fig, {});\n",
              "    });\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._canvas_extra_style = function(el){\n",
              "    // this is important to make the div 'focusable\n",
              "    el.attr('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",
              "    }\n",
              "    else {\n",
              "        // location in version 2\n",
              "        IPython.keyboard_manager.register_events(el);\n",
              "    }\n",
              "\n",
              "}\n",
              "\n",
              "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
              "    var manager = IPython.notebook.keyboard_manager;\n",
              "    if (!manager)\n",
              "        manager = IPython.keyboard_manager;\n",
              "\n",
              "    // Check for shift+enter\n",
              "    if (event.shiftKey && event.which == 13) {\n",
              "        this.canvas_div.blur();\n",
              "        event.shiftKey = false;\n",
              "        // Send a \"J\" for go to next cell\n",
              "        event.which = 74;\n",
              "        event.keyCode = 74;\n",
              "        manager.command_mode();\n",
              "        manager.handle_keydown(event);\n",
              "    }\n",
              "}\n",
              "\n",
              "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
              "    fig.ondownload(fig, null);\n",
              "}\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('matplotlib', mpl.mpl_figure_comm);\n",
              "}\n"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "text/html": [
              "<img src=\"\" width=\"640\">"
            ],
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ]
          },
          "metadata": {
            "tags": []
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "mTAIrsGQ4z9v",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        ""
      ],
      "execution_count": null,
      "outputs": []
    }
  ]
}