diff --git a/Analyse.ipynb b/Analyse.ipynb index 77ad720d5db2cb6f80ca78bad19d8d3b4e29cb25..482444716cc73234bb3a665d4ffa9a6277515e2e 100644 --- a/Analyse.ipynb +++ b/Analyse.ipynb @@ -2,12 +2,12 @@ "cells": [ { "cell_type": "code", - "execution_count": 107, + "execution_count": 1, "id": "ec5a5281", "metadata": {}, "outputs": [], "source": [ - "%matplotlib inline\n", + "%matplotlib nbagg\n", "import pandas as pd\n", "import matplotlib.pyplot as plt\n", "import numpy as np" @@ -15,22 +15,147 @@ }, { "cell_type": "code", - "execution_count": 8, + "execution_count": 2, "id": "d50e7f08", "metadata": {}, "outputs": [ { "data": { + "text/html": [ + "<div>\n", + "<style scoped>\n", + " .dataframe tbody tr th:only-of-type {\n", + " vertical-align: middle;\n", + " }\n", + "\n", + " .dataframe tbody tr th {\n", + " vertical-align: top;\n", + " }\n", + "\n", + " .dataframe thead th {\n", + " text-align: right;\n", + " }\n", + "</style>\n", + "<table border=\"1\" class=\"dataframe\">\n", + " <thead>\n", + " <tr style=\"text-align: right;\">\n", + " <th></th>\n", + " <th>Jahr</th>\n", + " <th>Bundesland</th>\n", + " <th>1</th>\n", + " <th>2</th>\n", + " <th>3</th>\n", + " <th>4</th>\n", + " <th>5</th>\n", + " <th>6</th>\n", + " <th>7</th>\n", + " <th>8</th>\n", + " <th>...</th>\n", + " <th>44</th>\n", + " <th>45</th>\n", + " <th>46</th>\n", + " <th>47</th>\n", + " <th>48</th>\n", + " <th>49</th>\n", + " <th>50</th>\n", + " <th>51</th>\n", + " <th>52</th>\n", + " <th>53</th>\n", + " </tr>\n", + " </thead>\n", + " <tbody>\n", + " <tr>\n", + " <th>0</th>\n", + " <td>2021</td>\n", + " <td>Schleswig-Holstein</td>\n", + " <td>803</td>\n", + " <td>794</td>\n", + " <td>849</td>\n", + " <td>826</td>\n", + " <td>777</td>\n", + " <td>797</td>\n", + " <td>819</td>\n", + " <td>677</td>\n", + " <td>...</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " </tr>\n", + " <tr>\n", + " <th>1</th>\n", + " <td>2021</td>\n", + " <td>Hamburg</td>\n", + " <td>451</td>\n", + " <td>437</td>\n", + " <td>462</td>\n", + " <td>396</td>\n", + " <td>416</td>\n", + " <td>363</td>\n", + " <td>405</td>\n", + " <td>346</td>\n", + " <td>...</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " </tr>\n", + " <tr>\n", + " <th>2</th>\n", + " <td>2021</td>\n", + " <td>Niedersachsen</td>\n", + " <td>2164</td>\n", + " <td>2092</td>\n", + " <td>2166</td>\n", + " <td>2164</td>\n", + " <td>2179</td>\n", + " <td>2133</td>\n", + " <td>2061</td>\n", + " <td>1945</td>\n", + " <td>...</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " <td>NaN</td>\n", + " </tr>\n", + " </tbody>\n", + "</table>\n", + "<p>3 rows × 55 columns</p>\n", + "</div>" + ], "text/plain": [ - "Index(['Jahr', 'Bundesland', '1', '2', '3', '4', '5', '6', '7', '8', '9', '10',\n", - " '11', '12', '13', '14', '15', '16', '17', '18', '19', '20', '21', '22',\n", - " '23', '24', '25', '26', '27', '28', '29', '30', '31', '32', '33', '34',\n", - " '35', '36', '37', '38', '39', '40', '41', '42', '43', '44', '45', '46',\n", - " '47', '48', '49', '50', '51', '52', '53'],\n", - " dtype='object')" + " Jahr Bundesland 1 2 3 4 5 6 7 8 \\\n", + "0 2021 Schleswig-Holstein 803 794 849 826 777 797 819 677 \n", + "1 2021 Hamburg 451 437 462 396 416 363 405 346 \n", + "2 2021 Niedersachsen 2164 2092 2166 2164 2179 2133 2061 1945 \n", + "\n", + " ... 44 45 46 47 48 49 50 51 52 53 \n", + "0 ... NaN NaN NaN NaN NaN NaN NaN NaN NaN NaN \n", + "1 ... NaN NaN NaN NaN NaN NaN NaN NaN NaN NaN \n", + "2 ... NaN NaN NaN NaN NaN NaN NaN NaN NaN NaN \n", + "\n", + "[3 rows x 55 columns]" ] }, - "execution_count": 8, + "execution_count": 2, "metadata": {}, "output_type": "execute_result" } @@ -40,13 +165,13 @@ "# 22.11.2021\n", "df = pd.read_csv('sterbefaelle.csv')\n", "df.head(3)\n", - "df.columns\n", + "#df.columns\n", "#df = df.set_index('Bundesland')" ] }, { "cell_type": "code", - "execution_count": 14, + "execution_count": 3, "id": "dd29c69e", "metadata": {}, "outputs": [ @@ -588,7 +713,7 @@ "[16 rows x 52 columns]" ] }, - "execution_count": 14, + "execution_count": 3, "metadata": {}, "output_type": "execute_result" } @@ -603,31 +728,989 @@ }, { "cell_type": "code", - "execution_count": 72, + "execution_count": 4, "id": "ab1f10bc", "metadata": {}, "outputs": [ { "data": { + "application/javascript": [ + "/* Put everything inside the global mpl namespace */\n", + "/* global mpl */\n", + "window.mpl = {};\n", + "\n", + "mpl.get_websocket_type = function () {\n", + " if (typeof WebSocket !== 'undefined') {\n", + " return WebSocket;\n", + " } else if (typeof MozWebSocket !== 'undefined') {\n", + " return MozWebSocket;\n", + " } else {\n", + " alert(\n", + " 'Your browser does not have WebSocket support. ' +\n", + " 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n", + " 'Firefox 4 and 5 are also supported but you ' +\n", + " 'have to enable WebSockets in about:config.'\n", + " );\n", + " }\n", + "};\n", + "\n", + "mpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n", + " this.id = figure_id;\n", + "\n", + " this.ws = websocket;\n", + "\n", + " this.supports_binary = this.ws.binaryType !== undefined;\n", + "\n", + " if (!this.supports_binary) {\n", + " var warnings = document.getElementById('mpl-warnings');\n", + " if (warnings) {\n", + " warnings.style.display = 'block';\n", + " warnings.textContent =\n", + " 'This browser does not support binary websocket messages. ' +\n", + " 'Performance may be slow.';\n", + " }\n", + " }\n", + "\n", + " this.imageObj = new Image();\n", + "\n", + " this.context = undefined;\n", + " this.message = undefined;\n", + " this.canvas = undefined;\n", + " this.rubberband_canvas = undefined;\n", + " this.rubberband_context = undefined;\n", + " this.format_dropdown = undefined;\n", + "\n", + " this.image_mode = 'full';\n", + "\n", + " this.root = document.createElement('div');\n", + " this.root.setAttribute('style', 'display: inline-block');\n", + " this._root_extra_style(this.root);\n", + "\n", + " parent_element.appendChild(this.root);\n", + "\n", + " this._init_header(this);\n", + " this._init_canvas(this);\n", + " this._init_toolbar(this);\n", + "\n", + " var fig = this;\n", + "\n", + " this.waiting = false;\n", + "\n", + " this.ws.onopen = function () {\n", + " fig.send_message('supports_binary', { value: fig.supports_binary });\n", + " fig.send_message('send_image_mode', {});\n", + " if (fig.ratio !== 1) {\n", + " fig.send_message('set_dpi_ratio', { dpi_ratio: fig.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 = document.createElement('div');\n", + " titlebar.classList =\n", + " 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n", + " var titletext = document.createElement('div');\n", + " titletext.classList = 'ui-dialog-title';\n", + " titletext.setAttribute(\n", + " 'style',\n", + " 'width: 100%; text-align: center; padding: 3px;'\n", + " );\n", + " titlebar.appendChild(titletext);\n", + " this.root.appendChild(titlebar);\n", + " this.header = titletext;\n", + "};\n", + "\n", + "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n", + "\n", + "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n", + "\n", + "mpl.figure.prototype._init_canvas = function () {\n", + " var fig = this;\n", + "\n", + " var canvas_div = (this.canvas_div = document.createElement('div'));\n", + " canvas_div.setAttribute(\n", + " 'style',\n", + " 'border: 1px solid #ddd;' +\n", + " 'box-sizing: content-box;' +\n", + " 'clear: both;' +\n", + " 'min-height: 1px;' +\n", + " 'min-width: 1px;' +\n", + " 'outline: 0;' +\n", + " 'overflow: hidden;' +\n", + " 'position: relative;' +\n", + " 'resize: both;'\n", + " );\n", + "\n", + " function on_keyboard_event_closure(name) {\n", + " return function (event) {\n", + " return fig.key_event(event, name);\n", + " };\n", + " }\n", + "\n", + " canvas_div.addEventListener(\n", + " 'keydown',\n", + " on_keyboard_event_closure('key_press')\n", + " );\n", + " canvas_div.addEventListener(\n", + " 'keyup',\n", + " on_keyboard_event_closure('key_release')\n", + " );\n", + "\n", + " this._canvas_extra_style(canvas_div);\n", + " this.root.appendChild(canvas_div);\n", + "\n", + " var canvas = (this.canvas = document.createElement('canvas'));\n", + " canvas.classList.add('mpl-canvas');\n", + " canvas.setAttribute('style', 'box-sizing: content-box;');\n", + "\n", + " this.context = canvas.getContext('2d');\n", + "\n", + " var backingStore =\n", + " this.context.backingStorePixelRatio ||\n", + " this.context.webkitBackingStorePixelRatio ||\n", + " this.context.mozBackingStorePixelRatio ||\n", + " this.context.msBackingStorePixelRatio ||\n", + " this.context.oBackingStorePixelRatio ||\n", + " this.context.backingStorePixelRatio ||\n", + " 1;\n", + "\n", + " this.ratio = (window.devicePixelRatio || 1) / backingStore;\n", + "\n", + " var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n", + " 'canvas'\n", + " ));\n", + " rubberband_canvas.setAttribute(\n", + " 'style',\n", + " 'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n", + " );\n", + "\n", + " // Apply a ponyfill if ResizeObserver is not implemented by browser.\n", + " if (this.ResizeObserver === undefined) {\n", + " if (window.ResizeObserver !== undefined) {\n", + " this.ResizeObserver = window.ResizeObserver;\n", + " } else {\n", + " var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n", + " this.ResizeObserver = obs.ResizeObserver;\n", + " }\n", + " }\n", + "\n", + " this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n", + " var nentries = entries.length;\n", + " for (var i = 0; i < nentries; i++) {\n", + " var entry = entries[i];\n", + " var width, height;\n", + " if (entry.contentBoxSize) {\n", + " if (entry.contentBoxSize instanceof Array) {\n", + " // Chrome 84 implements new version of spec.\n", + " width = entry.contentBoxSize[0].inlineSize;\n", + " height = entry.contentBoxSize[0].blockSize;\n", + " } else {\n", + " // Firefox implements old version of spec.\n", + " width = entry.contentBoxSize.inlineSize;\n", + " height = entry.contentBoxSize.blockSize;\n", + " }\n", + " } else {\n", + " // Chrome <84 implements even older version of spec.\n", + " width = entry.contentRect.width;\n", + " height = entry.contentRect.height;\n", + " }\n", + "\n", + " // Keep the size of the canvas and rubber band canvas in sync with\n", + " // the canvas container.\n", + " if (entry.devicePixelContentBoxSize) {\n", + " // Chrome 84 implements new version of spec.\n", + " canvas.setAttribute(\n", + " 'width',\n", + " entry.devicePixelContentBoxSize[0].inlineSize\n", + " );\n", + " canvas.setAttribute(\n", + " 'height',\n", + " entry.devicePixelContentBoxSize[0].blockSize\n", + " );\n", + " } else {\n", + " canvas.setAttribute('width', width * fig.ratio);\n", + " canvas.setAttribute('height', height * fig.ratio);\n", + " }\n", + " canvas.setAttribute(\n", + " 'style',\n", + " 'width: ' + width + 'px; height: ' + height + 'px;'\n", + " );\n", + "\n", + " rubberband_canvas.setAttribute('width', width);\n", + " rubberband_canvas.setAttribute('height', height);\n", + "\n", + " // And update the size in Python. We ignore the initial 0/0 size\n", + " // that occurs as the element is placed into the DOM, which should\n", + " // otherwise not happen due to the minimum size styling.\n", + " if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n", + " fig.request_resize(width, height);\n", + " }\n", + " }\n", + " });\n", + " this.resizeObserverInstance.observe(canvas_div);\n", + "\n", + " function on_mouse_event_closure(name) {\n", + " return function (event) {\n", + " return fig.mouse_event(event, name);\n", + " };\n", + " }\n", + "\n", + " rubberband_canvas.addEventListener(\n", + " 'mousedown',\n", + " on_mouse_event_closure('button_press')\n", + " );\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseup',\n", + " on_mouse_event_closure('button_release')\n", + " );\n", + " // Throttle sequential mouse events to 1 every 20ms.\n", + " rubberband_canvas.addEventListener(\n", + " 'mousemove',\n", + " on_mouse_event_closure('motion_notify')\n", + " );\n", + "\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseenter',\n", + " on_mouse_event_closure('figure_enter')\n", + " );\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseleave',\n", + " on_mouse_event_closure('figure_leave')\n", + " );\n", + "\n", + " canvas_div.addEventListener('wheel', function (event) {\n", + " if (event.deltaY < 0) {\n", + " event.step = 1;\n", + " } else {\n", + " event.step = -1;\n", + " }\n", + " on_mouse_event_closure('scroll')(event);\n", + " });\n", + "\n", + " canvas_div.appendChild(canvas);\n", + " canvas_div.appendChild(rubberband_canvas);\n", + "\n", + " this.rubberband_context = rubberband_canvas.getContext('2d');\n", + " this.rubberband_context.strokeStyle = '#000000';\n", + "\n", + " this._resize_canvas = function (width, height, forward) {\n", + " if (forward) {\n", + " canvas_div.style.width = width + 'px';\n", + " canvas_div.style.height = height + 'px';\n", + " }\n", + " };\n", + "\n", + " // Disable right mouse context menu.\n", + " this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n", + " event.preventDefault();\n", + " return false;\n", + " });\n", + "\n", + " function set_focus() {\n", + " canvas.focus();\n", + " canvas_div.focus();\n", + " }\n", + "\n", + " window.setTimeout(set_focus, 100);\n", + "};\n", + "\n", + "mpl.figure.prototype._init_toolbar = function () {\n", + " var fig = this;\n", + "\n", + " var toolbar = document.createElement('div');\n", + " toolbar.classList = 'mpl-toolbar';\n", + " this.root.appendChild(toolbar);\n", + "\n", + " function on_click_closure(name) {\n", + " return function (_event) {\n", + " return fig.toolbar_button_onclick(name);\n", + " };\n", + " }\n", + "\n", + " function on_mouseover_closure(tooltip) {\n", + " return function (event) {\n", + " if (!event.currentTarget.disabled) {\n", + " return fig.toolbar_button_onmouseover(tooltip);\n", + " }\n", + " };\n", + " }\n", + "\n", + " fig.buttons = {};\n", + " var buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'mpl-button-group';\n", + " for (var toolbar_ind in mpl.toolbar_items) {\n", + " var name = mpl.toolbar_items[toolbar_ind][0];\n", + " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n", + " var image = mpl.toolbar_items[toolbar_ind][2];\n", + " var method_name = mpl.toolbar_items[toolbar_ind][3];\n", + "\n", + " if (!name) {\n", + " /* Instead of a spacer, we start a new button group. */\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + " buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'mpl-button-group';\n", + " continue;\n", + " }\n", + "\n", + " var button = (fig.buttons[name] = document.createElement('button'));\n", + " button.classList = 'mpl-widget';\n", + " button.setAttribute('role', 'button');\n", + " button.setAttribute('aria-disabled', 'false');\n", + " button.addEventListener('click', on_click_closure(method_name));\n", + " button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n", + "\n", + " var icon_img = document.createElement('img');\n", + " icon_img.src = '_images/' + image + '.png';\n", + " icon_img.srcset = '_images/' + image + '_large.png 2x';\n", + " icon_img.alt = tooltip;\n", + " button.appendChild(icon_img);\n", + "\n", + " buttonGroup.appendChild(button);\n", + " }\n", + "\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + "\n", + " var fmt_picker = document.createElement('select');\n", + " fmt_picker.classList = 'mpl-widget';\n", + " toolbar.appendChild(fmt_picker);\n", + " this.format_dropdown = fmt_picker;\n", + "\n", + " for (var ind in mpl.extensions) {\n", + " var fmt = mpl.extensions[ind];\n", + " var option = document.createElement('option');\n", + " option.selected = fmt === mpl.default_extension;\n", + " option.innerHTML = fmt;\n", + " fmt_picker.appendChild(option);\n", + " }\n", + "\n", + " var status_bar = document.createElement('span');\n", + " status_bar.classList = 'mpl-message';\n", + " toolbar.appendChild(status_bar);\n", + " this.message = status_bar;\n", + "};\n", + "\n", + "mpl.figure.prototype.request_resize = function (x_pixels, y_pixels) {\n", + " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n", + " // which will in turn request a refresh of the image.\n", + " this.send_message('resize', { width: x_pixels, height: y_pixels });\n", + "};\n", + "\n", + "mpl.figure.prototype.send_message = function (type, properties) {\n", + " properties['type'] = type;\n", + " properties['figure_id'] = this.id;\n", + " this.ws.send(JSON.stringify(properties));\n", + "};\n", + "\n", + "mpl.figure.prototype.send_draw_message = function () {\n", + " if (!this.waiting) {\n", + " this.waiting = true;\n", + " this.ws.send(JSON.stringify({ type: 'draw', figure_id: this.id }));\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_save = function (fig, _msg) {\n", + " var format_dropdown = fig.format_dropdown;\n", + " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n", + " fig.ondownload(fig, format);\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_resize = function (fig, msg) {\n", + " var size = msg['size'];\n", + " if (size[0] !== fig.canvas.width || size[1] !== fig.canvas.height) {\n", + " fig._resize_canvas(size[0], size[1], msg['forward']);\n", + " fig.send_message('refresh', {});\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n", + " var x0 = msg['x0'] / fig.ratio;\n", + " var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n", + " var x1 = msg['x1'] / fig.ratio;\n", + " var y1 = (fig.canvas.height - msg['y1']) / fig.ratio;\n", + " x0 = Math.floor(x0) + 0.5;\n", + " y0 = Math.floor(y0) + 0.5;\n", + " x1 = Math.floor(x1) + 0.5;\n", + " y1 = Math.floor(y1) + 0.5;\n", + " var min_x = Math.min(x0, x1);\n", + " var min_y = Math.min(y0, y1);\n", + " var width = Math.abs(x1 - x0);\n", + " var height = Math.abs(y1 - y0);\n", + "\n", + " fig.rubberband_context.clearRect(\n", + " 0,\n", + " 0,\n", + " fig.canvas.width / fig.ratio,\n", + " fig.canvas.height / fig.ratio\n", + " );\n", + "\n", + " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_figure_label = function (fig, msg) {\n", + " // Updates the figure title.\n", + " fig.header.textContent = msg['label'];\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_cursor = function (fig, msg) {\n", + " var cursor = msg['cursor'];\n", + " switch (cursor) {\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.handle_history_buttons = function (fig, msg) {\n", + " for (var key in msg) {\n", + " if (!(key in fig.buttons)) {\n", + " continue;\n", + " }\n", + " fig.buttons[key].disabled = !msg[key];\n", + " fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n", + " if (msg['mode'] === 'PAN') {\n", + " fig.buttons['Pan'].classList.add('active');\n", + " fig.buttons['Zoom'].classList.remove('active');\n", + " } else if (msg['mode'] === 'ZOOM') {\n", + " fig.buttons['Pan'].classList.remove('active');\n", + " fig.buttons['Zoom'].classList.add('active');\n", + " } else {\n", + " fig.buttons['Pan'].classList.remove('active');\n", + " fig.buttons['Zoom'].classList.remove('active');\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.updated_canvas_event = function () {\n", + " // Called whenever the canvas gets updated.\n", + " this.send_message('ack', {});\n", + "};\n", + "\n", + "// A function to construct a web socket function for onmessage handling.\n", + "// Called in the figure constructor.\n", + "mpl.figure.prototype._make_on_message_function = function (fig) {\n", + " return function socket_on_message(evt) {\n", + " if (evt.data instanceof Blob) {\n", + " /* 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", + "\n", + " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n", + " evt.data\n", + " );\n", + " fig.updated_canvas_event();\n", + " fig.waiting = false;\n", + " return;\n", + " } else if (\n", + " typeof evt.data === 'string' &&\n", + " evt.data.slice(0, 21) === 'data:image/png;base64'\n", + " ) {\n", + " fig.imageObj.src = evt.data;\n", + " fig.updated_canvas_event();\n", + " fig.waiting = false;\n", + " return;\n", + " }\n", + "\n", + " var msg = JSON.parse(evt.data);\n", + " var msg_type = msg['type'];\n", + "\n", + " // Call the \"handle_{type}\" callback, which takes\n", + " // the figure and JSON message as its only arguments.\n", + " try {\n", + " var callback = fig['handle_' + msg_type];\n", + " } catch (e) {\n", + " console.log(\n", + " \"No handler for the '\" + msg_type + \"' message type: \",\n", + " msg\n", + " );\n", + " return;\n", + " }\n", + "\n", + " if (callback) {\n", + " try {\n", + " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n", + " callback(fig, msg);\n", + " } catch (e) {\n", + " console.log(\n", + " \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n", + " e,\n", + " e.stack,\n", + " msg\n", + " );\n", + " }\n", + " }\n", + " };\n", + "};\n", + "\n", + "// from 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", + " }\n", + " if (e.target) {\n", + " targ = e.target;\n", + " } else if (e.srcElement) {\n", + " targ = e.srcElement;\n", + " }\n", + " if (targ.nodeType === 3) {\n", + " // defeat Safari bug\n", + " targ = targ.parentNode;\n", + " }\n", + "\n", + " // pageX,Y are the mouse positions relative to the document\n", + " var boundingRect = targ.getBoundingClientRect();\n", + " var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n", + " var y = e.pageY - (boundingRect.top + document.body.scrollTop);\n", + "\n", + " return { x: x, y: y };\n", + "};\n", + "\n", + "/*\n", + " * return a copy of an object with only non-object keys\n", + " * we need this to avoid circular references\n", + " * 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", + " }\n", + " return obj;\n", + " }, {});\n", + "}\n", + "\n", + "mpl.figure.prototype.mouse_event = function (event, name) {\n", + " var canvas_pos = mpl.findpos(event);\n", + "\n", + " if (name === 'button_press') {\n", + " this.canvas.focus();\n", + " this.canvas_div.focus();\n", + " }\n", + "\n", + " var x = canvas_pos.x * this.ratio;\n", + " var y = canvas_pos.y * this.ratio;\n", + "\n", + " this.send_message(name, {\n", + " x: x,\n", + " y: y,\n", + " button: event.button,\n", + " step: event.step,\n", + " guiEvent: simpleKeys(event),\n", + " });\n", + "\n", + " /* This prevents the web browser from automatically changing to\n", + " * the text insertion cursor when the button is pressed. We want\n", + " * to control all of the cursor setting manually through the\n", + " * 'cursor' event from matplotlib */\n", + " event.preventDefault();\n", + " return false;\n", + "};\n", + "\n", + "mpl.figure.prototype._key_event_extra = function (_event, _name) {\n", + " // Handle any extra behaviour associated with a key event\n", + "};\n", + "\n", + "mpl.figure.prototype.key_event = function (event, name) {\n", + " // Prevent repeat events\n", + " if (name === 'key_press') {\n", + " if (event.which === this._key) {\n", + " return;\n", + " } else {\n", + " this._key = event.which;\n", + " }\n", + " }\n", + " if (name === 'key_release') {\n", + " this._key = null;\n", + " }\n", + "\n", + " var value = '';\n", + " if (event.ctrlKey && event.which !== 17) {\n", + " value += 'ctrl+';\n", + " }\n", + " if (event.altKey && event.which !== 18) {\n", + " value += 'alt+';\n", + " }\n", + " if (event.shiftKey && event.which !== 16) {\n", + " value += 'shift+';\n", + " }\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, guiEvent: simpleKeys(event) });\n", + " return false;\n", + "};\n", + "\n", + "mpl.figure.prototype.toolbar_button_onclick = function (name) {\n", + " if (name === 'download') {\n", + " this.handle_save(this, null);\n", + " } else {\n", + " this.send_message('toolbar_button', { name: name });\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.toolbar_button_onmouseover = function (tooltip) {\n", + " this.message.textContent = tooltip;\n", + "};\n", + "\n", + "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n", + "// prettier-ignore\n", + "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\n", + "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis, CTRL fixes aspect\", \"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\";/* global mpl */\n", + "\n", + "var comm_websocket_adapter = function (comm) {\n", + " // Create a \"websocket\"-like object which calls the given IPython comm\n", + " // object with the appropriate methods. Currently this is a non binary\n", + " // socket, so there is still some room for performance tuning.\n", + " var ws = {};\n", + "\n", + " ws.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 = document.getElementById(id);\n", + " var ws_proxy = comm_websocket_adapter(comm);\n", + "\n", + " function ondownload(figure, _format) {\n", + " window.open(figure.canvas.toDataURL());\n", + " }\n", + "\n", + " var fig = new mpl.figure(id, ws_proxy, ondownload, element);\n", + "\n", + " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n", + " // web socket which is closed, not our websocket->open comm proxy.\n", + " ws_proxy.onopen();\n", + "\n", + " fig.parent_element = element;\n", + " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n", + " if (!fig.cell_info) {\n", + " console.error('Failed to find cell for figure', id, fig);\n", + " return;\n", + " }\n", + " fig.cell_info[0].output_area.element.on(\n", + " 'cleared',\n", + " { fig: fig },\n", + " fig._remove_fig_handler\n", + " );\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_close = function (fig, msg) {\n", + " var width = fig.canvas.width / fig.ratio;\n", + " fig.cell_info[0].output_area.element.off(\n", + " 'cleared',\n", + " fig._remove_fig_handler\n", + " );\n", + " fig.resizeObserverInstance.unobserve(fig.canvas_div);\n", + "\n", + " // Update the output cell to use the data from the current canvas.\n", + " fig.push_to_output();\n", + " var dataURL = fig.canvas.toDataURL();\n", + " // Re-enable the keyboard manager in IPython - without this line, in FF,\n", + " // the notebook keyboard shortcuts fail.\n", + " IPython.keyboard_manager.enable();\n", + " fig.parent_element.innerHTML =\n", + " '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n", + " fig.close_ws(fig, msg);\n", + "};\n", + "\n", + "mpl.figure.prototype.close_ws = function (fig, msg) {\n", + " fig.send_message('closing', msg);\n", + " // fig.ws.close()\n", + "};\n", + "\n", + "mpl.figure.prototype.push_to_output = function (_remove_interactive) {\n", + " // Turn the data on the canvas into data in the output cell.\n", + " var width = this.canvas.width / this.ratio;\n", + " var dataURL = this.canvas.toDataURL();\n", + " this.cell_info[1]['text/html'] =\n", + " '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n", + "};\n", + "\n", + "mpl.figure.prototype.updated_canvas_event = function () {\n", + " // Tell IPython that the notebook contents must change.\n", + " IPython.notebook.set_dirty(true);\n", + " this.send_message('ack', {});\n", + " var fig = this;\n", + " // Wait a second, then push the new image to the DOM so\n", + " // that it is saved nicely (might be nice to debounce this).\n", + " setTimeout(function () {\n", + " fig.push_to_output();\n", + " }, 1000);\n", + "};\n", + "\n", + "mpl.figure.prototype._init_toolbar = function () {\n", + " var fig = this;\n", + "\n", + " var toolbar = document.createElement('div');\n", + " toolbar.classList = 'btn-toolbar';\n", + " this.root.appendChild(toolbar);\n", + "\n", + " function on_click_closure(name) {\n", + " return function (_event) {\n", + " return fig.toolbar_button_onclick(name);\n", + " };\n", + " }\n", + "\n", + " function on_mouseover_closure(tooltip) {\n", + " return function (event) {\n", + " if (!event.currentTarget.disabled) {\n", + " return fig.toolbar_button_onmouseover(tooltip);\n", + " }\n", + " };\n", + " }\n", + "\n", + " fig.buttons = {};\n", + " var buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'btn-group';\n", + " var button;\n", + " for (var toolbar_ind in mpl.toolbar_items) {\n", + " var name = mpl.toolbar_items[toolbar_ind][0];\n", + " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n", + " var image = mpl.toolbar_items[toolbar_ind][2];\n", + " var method_name = mpl.toolbar_items[toolbar_ind][3];\n", + "\n", + " if (!name) {\n", + " /* Instead of a spacer, we start a new button group. */\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + " buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'btn-group';\n", + " continue;\n", + " }\n", + "\n", + " button = fig.buttons[name] = document.createElement('button');\n", + " button.classList = 'btn btn-default';\n", + " button.href = '#';\n", + " button.title = name;\n", + " button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n", + " button.addEventListener('click', on_click_closure(method_name));\n", + " button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n", + " buttonGroup.appendChild(button);\n", + " }\n", + "\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + "\n", + " // Add the status bar.\n", + " var status_bar = document.createElement('span');\n", + " status_bar.classList = 'mpl-message pull-right';\n", + " toolbar.appendChild(status_bar);\n", + " this.message = status_bar;\n", + "\n", + " // Add the close button to the window.\n", + " var buttongrp = document.createElement('div');\n", + " buttongrp.classList = 'btn-group inline pull-right';\n", + " button = document.createElement('button');\n", + " button.classList = 'btn btn-mini btn-primary';\n", + " button.href = '#';\n", + " button.title = 'Stop Interaction';\n", + " button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n", + " button.addEventListener('click', function (_evt) {\n", + " fig.handle_close(fig, {});\n", + " });\n", + " button.addEventListener(\n", + " 'mouseover',\n", + " on_mouseover_closure('Stop Interaction')\n", + " );\n", + " buttongrp.appendChild(button);\n", + " var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n", + " titlebar.insertBefore(buttongrp, titlebar.firstChild);\n", + "};\n", + "\n", + "mpl.figure.prototype._remove_fig_handler = function (event) {\n", + " var fig = event.data.fig;\n", + " if (event.target !== this) {\n", + " // Ignore bubbled events from children.\n", + " return;\n", + " }\n", + " fig.close_ws(fig, {});\n", + "};\n", + "\n", + "mpl.figure.prototype._root_extra_style = function (el) {\n", + " el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n", + "};\n", + "\n", + "mpl.figure.prototype._canvas_extra_style = function (el) {\n", + " // this is important to make the div 'focusable\n", + " el.setAttribute('tabindex', 0);\n", + " // reach out to IPython and tell the keyboard manager to turn it's self\n", + " // off when our div gets focus\n", + "\n", + " // location in version 3\n", + " if (IPython.notebook.keyboard_manager) {\n", + " IPython.notebook.keyboard_manager.register_events(el);\n", + " } else {\n", + " // location in version 2\n", + " IPython.keyboard_manager.register_events(el);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype._key_event_extra = function (event, _name) {\n", + " var manager = IPython.notebook.keyboard_manager;\n", + " if (!manager) {\n", + " manager = IPython.keyboard_manager;\n", + " }\n", + "\n", + " // Check for shift+enter\n", + " if (event.shiftKey && event.which === 13) {\n", + " this.canvas_div.blur();\n", + " // select the cell after this one\n", + " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n", + " IPython.notebook.select(index + 1);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_save = function (fig, _msg) {\n", + " fig.ondownload(fig, null);\n", + "};\n", + "\n", + "mpl.find_output_cell = function (html_output) {\n", + " // Return the cell and output element which can be found *uniquely* in the notebook.\n", + " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n", + " // IPython event is triggered only after the cells have been serialised, which for\n", + " // our purposes (turning an active figure into a static one), is too late.\n", + " var cells = IPython.notebook.get_cells();\n", + " var ncells = cells.length;\n", + " for (var i = 0; i < ncells; i++) {\n", + " var cell = cells[i];\n", + " if (cell.cell_type === 'code') {\n", + " for (var j = 0; j < cell.output_area.outputs.length; j++) {\n", + " var data = cell.output_area.outputs[j];\n", + " if (data.data) {\n", + " // IPython >= 3 moved mimebundle to data attribute of output\n", + " data = data.data;\n", + " }\n", + " if (data['text/html'] === html_output) {\n", + " return [cell, data, j];\n", + " }\n", + " }\n", + " }\n", + " }\n", + "};\n", + "\n", + "// Register the function which deals with the matplotlib target/channel.\n", + "// The kernel may be null if the page has been refreshed.\n", + "if (IPython.notebook.kernel !== null) {\n", + " IPython.notebook.kernel.comm_manager.register_target(\n", + " 'matplotlib',\n", + " mpl.mpl_figure_comm\n", + " );\n", + "}\n" + ], "text/plain": [ - "<AxesSubplot:xlabel='Bundesland'>" + "<IPython.core.display.Javascript object>" ] }, - "execution_count": 72, "metadata": {}, - "output_type": "execute_result" + "output_type": "display_data" }, { "data": { - "image/png": "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\n", + "text/html": [ + "<img src=\"\" width=\"640\">" + ], "text/plain": [ - "<Figure size 432x288 with 1 Axes>" + "<IPython.core.display.HTML object>" ] }, - "metadata": { - "needs_background": "light" - }, + "metadata": {}, "output_type": "display_data" + }, + { + "data": { + "text/plain": [ + "<AxesSubplot:xlabel='Bundesland'>" + ] + }, + "execution_count": 4, + "metadata": {}, + "output_type": "execute_result" } ], "source": [ @@ -655,25 +1738,983 @@ }, { "cell_type": "code", - "execution_count": 79, - "id": "28abfac5", + "execution_count": 5, + "id": "9d77bb4a", "metadata": {}, "outputs": [ { "data": { - "image/png": "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\n", - "text/plain": [ - "<Figure size 432x288 with 1 Axes>" - ] - }, - "metadata": { - "needs_background": "light" - }, - "output_type": "display_data" - } - ], - "source": [ - "df_impf = pd.read_csv('Impfquoten.csv')\n", + "application/javascript": [ + "/* Put everything inside the global mpl namespace */\n", + "/* global mpl */\n", + "window.mpl = {};\n", + "\n", + "mpl.get_websocket_type = function () {\n", + " if (typeof WebSocket !== 'undefined') {\n", + " return WebSocket;\n", + " } else if (typeof MozWebSocket !== 'undefined') {\n", + " return MozWebSocket;\n", + " } else {\n", + " alert(\n", + " 'Your browser does not have WebSocket support. ' +\n", + " 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n", + " 'Firefox 4 and 5 are also supported but you ' +\n", + " 'have to enable WebSockets in about:config.'\n", + " );\n", + " }\n", + "};\n", + "\n", + "mpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n", + " this.id = figure_id;\n", + "\n", + " this.ws = websocket;\n", + "\n", + " this.supports_binary = this.ws.binaryType !== undefined;\n", + "\n", + " if (!this.supports_binary) {\n", + " var warnings = document.getElementById('mpl-warnings');\n", + " if (warnings) {\n", + " warnings.style.display = 'block';\n", + " warnings.textContent =\n", + " 'This browser does not support binary websocket messages. ' +\n", + " 'Performance may be slow.';\n", + " }\n", + " }\n", + "\n", + " this.imageObj = new Image();\n", + "\n", + " this.context = undefined;\n", + " this.message = undefined;\n", + " this.canvas = undefined;\n", + " this.rubberband_canvas = undefined;\n", + " this.rubberband_context = undefined;\n", + " this.format_dropdown = undefined;\n", + "\n", + " this.image_mode = 'full';\n", + "\n", + " this.root = document.createElement('div');\n", + " this.root.setAttribute('style', 'display: inline-block');\n", + " this._root_extra_style(this.root);\n", + "\n", + " parent_element.appendChild(this.root);\n", + "\n", + " this._init_header(this);\n", + " this._init_canvas(this);\n", + " this._init_toolbar(this);\n", + "\n", + " var fig = this;\n", + "\n", + " this.waiting = false;\n", + "\n", + " this.ws.onopen = function () {\n", + " fig.send_message('supports_binary', { value: fig.supports_binary });\n", + " fig.send_message('send_image_mode', {});\n", + " if (fig.ratio !== 1) {\n", + " fig.send_message('set_dpi_ratio', { dpi_ratio: fig.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 = document.createElement('div');\n", + " titlebar.classList =\n", + " 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n", + " var titletext = document.createElement('div');\n", + " titletext.classList = 'ui-dialog-title';\n", + " titletext.setAttribute(\n", + " 'style',\n", + " 'width: 100%; text-align: center; padding: 3px;'\n", + " );\n", + " titlebar.appendChild(titletext);\n", + " this.root.appendChild(titlebar);\n", + " this.header = titletext;\n", + "};\n", + "\n", + "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n", + "\n", + "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n", + "\n", + "mpl.figure.prototype._init_canvas = function () {\n", + " var fig = this;\n", + "\n", + " var canvas_div = (this.canvas_div = document.createElement('div'));\n", + " canvas_div.setAttribute(\n", + " 'style',\n", + " 'border: 1px solid #ddd;' +\n", + " 'box-sizing: content-box;' +\n", + " 'clear: both;' +\n", + " 'min-height: 1px;' +\n", + " 'min-width: 1px;' +\n", + " 'outline: 0;' +\n", + " 'overflow: hidden;' +\n", + " 'position: relative;' +\n", + " 'resize: both;'\n", + " );\n", + "\n", + " function on_keyboard_event_closure(name) {\n", + " return function (event) {\n", + " return fig.key_event(event, name);\n", + " };\n", + " }\n", + "\n", + " canvas_div.addEventListener(\n", + " 'keydown',\n", + " on_keyboard_event_closure('key_press')\n", + " );\n", + " canvas_div.addEventListener(\n", + " 'keyup',\n", + " on_keyboard_event_closure('key_release')\n", + " );\n", + "\n", + " this._canvas_extra_style(canvas_div);\n", + " this.root.appendChild(canvas_div);\n", + "\n", + " var canvas = (this.canvas = document.createElement('canvas'));\n", + " canvas.classList.add('mpl-canvas');\n", + " canvas.setAttribute('style', 'box-sizing: content-box;');\n", + "\n", + " this.context = canvas.getContext('2d');\n", + "\n", + " var backingStore =\n", + " this.context.backingStorePixelRatio ||\n", + " this.context.webkitBackingStorePixelRatio ||\n", + " this.context.mozBackingStorePixelRatio ||\n", + " this.context.msBackingStorePixelRatio ||\n", + " this.context.oBackingStorePixelRatio ||\n", + " this.context.backingStorePixelRatio ||\n", + " 1;\n", + "\n", + " this.ratio = (window.devicePixelRatio || 1) / backingStore;\n", + "\n", + " var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n", + " 'canvas'\n", + " ));\n", + " rubberband_canvas.setAttribute(\n", + " 'style',\n", + " 'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n", + " );\n", + "\n", + " // Apply a ponyfill if ResizeObserver is not implemented by browser.\n", + " if (this.ResizeObserver === undefined) {\n", + " if (window.ResizeObserver !== undefined) {\n", + " this.ResizeObserver = window.ResizeObserver;\n", + " } else {\n", + " var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n", + " this.ResizeObserver = obs.ResizeObserver;\n", + " }\n", + " }\n", + "\n", + " this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n", + " var nentries = entries.length;\n", + " for (var i = 0; i < nentries; i++) {\n", + " var entry = entries[i];\n", + " var width, height;\n", + " if (entry.contentBoxSize) {\n", + " if (entry.contentBoxSize instanceof Array) {\n", + " // Chrome 84 implements new version of spec.\n", + " width = entry.contentBoxSize[0].inlineSize;\n", + " height = entry.contentBoxSize[0].blockSize;\n", + " } else {\n", + " // Firefox implements old version of spec.\n", + " width = entry.contentBoxSize.inlineSize;\n", + " height = entry.contentBoxSize.blockSize;\n", + " }\n", + " } else {\n", + " // Chrome <84 implements even older version of spec.\n", + " width = entry.contentRect.width;\n", + " height = entry.contentRect.height;\n", + " }\n", + "\n", + " // Keep the size of the canvas and rubber band canvas in sync with\n", + " // the canvas container.\n", + " if (entry.devicePixelContentBoxSize) {\n", + " // Chrome 84 implements new version of spec.\n", + " canvas.setAttribute(\n", + " 'width',\n", + " entry.devicePixelContentBoxSize[0].inlineSize\n", + " );\n", + " canvas.setAttribute(\n", + " 'height',\n", + " entry.devicePixelContentBoxSize[0].blockSize\n", + " );\n", + " } else {\n", + " canvas.setAttribute('width', width * fig.ratio);\n", + " canvas.setAttribute('height', height * fig.ratio);\n", + " }\n", + " canvas.setAttribute(\n", + " 'style',\n", + " 'width: ' + width + 'px; height: ' + height + 'px;'\n", + " );\n", + "\n", + " rubberband_canvas.setAttribute('width', width);\n", + " rubberband_canvas.setAttribute('height', height);\n", + "\n", + " // And update the size in Python. We ignore the initial 0/0 size\n", + " // that occurs as the element is placed into the DOM, which should\n", + " // otherwise not happen due to the minimum size styling.\n", + " if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n", + " fig.request_resize(width, height);\n", + " }\n", + " }\n", + " });\n", + " this.resizeObserverInstance.observe(canvas_div);\n", + "\n", + " function on_mouse_event_closure(name) {\n", + " return function (event) {\n", + " return fig.mouse_event(event, name);\n", + " };\n", + " }\n", + "\n", + " rubberband_canvas.addEventListener(\n", + " 'mousedown',\n", + " on_mouse_event_closure('button_press')\n", + " );\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseup',\n", + " on_mouse_event_closure('button_release')\n", + " );\n", + " // Throttle sequential mouse events to 1 every 20ms.\n", + " rubberband_canvas.addEventListener(\n", + " 'mousemove',\n", + " on_mouse_event_closure('motion_notify')\n", + " );\n", + "\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseenter',\n", + " on_mouse_event_closure('figure_enter')\n", + " );\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseleave',\n", + " on_mouse_event_closure('figure_leave')\n", + " );\n", + "\n", + " canvas_div.addEventListener('wheel', function (event) {\n", + " if (event.deltaY < 0) {\n", + " event.step = 1;\n", + " } else {\n", + " event.step = -1;\n", + " }\n", + " on_mouse_event_closure('scroll')(event);\n", + " });\n", + "\n", + " canvas_div.appendChild(canvas);\n", + " canvas_div.appendChild(rubberband_canvas);\n", + "\n", + " this.rubberband_context = rubberband_canvas.getContext('2d');\n", + " this.rubberband_context.strokeStyle = '#000000';\n", + "\n", + " this._resize_canvas = function (width, height, forward) {\n", + " if (forward) {\n", + " canvas_div.style.width = width + 'px';\n", + " canvas_div.style.height = height + 'px';\n", + " }\n", + " };\n", + "\n", + " // Disable right mouse context menu.\n", + " this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n", + " event.preventDefault();\n", + " return false;\n", + " });\n", + "\n", + " function set_focus() {\n", + " canvas.focus();\n", + " canvas_div.focus();\n", + " }\n", + "\n", + " window.setTimeout(set_focus, 100);\n", + "};\n", + "\n", + "mpl.figure.prototype._init_toolbar = function () {\n", + " var fig = this;\n", + "\n", + " var toolbar = document.createElement('div');\n", + " toolbar.classList = 'mpl-toolbar';\n", + " this.root.appendChild(toolbar);\n", + "\n", + " function on_click_closure(name) {\n", + " return function (_event) {\n", + " return fig.toolbar_button_onclick(name);\n", + " };\n", + " }\n", + "\n", + " function on_mouseover_closure(tooltip) {\n", + " return function (event) {\n", + " if (!event.currentTarget.disabled) {\n", + " return fig.toolbar_button_onmouseover(tooltip);\n", + " }\n", + " };\n", + " }\n", + "\n", + " fig.buttons = {};\n", + " var buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'mpl-button-group';\n", + " for (var toolbar_ind in mpl.toolbar_items) {\n", + " var name = mpl.toolbar_items[toolbar_ind][0];\n", + " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n", + " var image = mpl.toolbar_items[toolbar_ind][2];\n", + " var method_name = mpl.toolbar_items[toolbar_ind][3];\n", + "\n", + " if (!name) {\n", + " /* Instead of a spacer, we start a new button group. */\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + " buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'mpl-button-group';\n", + " continue;\n", + " }\n", + "\n", + " var button = (fig.buttons[name] = document.createElement('button'));\n", + " button.classList = 'mpl-widget';\n", + " button.setAttribute('role', 'button');\n", + " button.setAttribute('aria-disabled', 'false');\n", + " button.addEventListener('click', on_click_closure(method_name));\n", + " button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n", + "\n", + " var icon_img = document.createElement('img');\n", + " icon_img.src = '_images/' + image + '.png';\n", + " icon_img.srcset = '_images/' + image + '_large.png 2x';\n", + " icon_img.alt = tooltip;\n", + " button.appendChild(icon_img);\n", + "\n", + " buttonGroup.appendChild(button);\n", + " }\n", + "\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + "\n", + " var fmt_picker = document.createElement('select');\n", + " fmt_picker.classList = 'mpl-widget';\n", + " toolbar.appendChild(fmt_picker);\n", + " this.format_dropdown = fmt_picker;\n", + "\n", + " for (var ind in mpl.extensions) {\n", + " var fmt = mpl.extensions[ind];\n", + " var option = document.createElement('option');\n", + " option.selected = fmt === mpl.default_extension;\n", + " option.innerHTML = fmt;\n", + " fmt_picker.appendChild(option);\n", + " }\n", + "\n", + " var status_bar = document.createElement('span');\n", + " status_bar.classList = 'mpl-message';\n", + " toolbar.appendChild(status_bar);\n", + " this.message = status_bar;\n", + "};\n", + "\n", + "mpl.figure.prototype.request_resize = function (x_pixels, y_pixels) {\n", + " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n", + " // which will in turn request a refresh of the image.\n", + " this.send_message('resize', { width: x_pixels, height: y_pixels });\n", + "};\n", + "\n", + "mpl.figure.prototype.send_message = function (type, properties) {\n", + " properties['type'] = type;\n", + " properties['figure_id'] = this.id;\n", + " this.ws.send(JSON.stringify(properties));\n", + "};\n", + "\n", + "mpl.figure.prototype.send_draw_message = function () {\n", + " if (!this.waiting) {\n", + " this.waiting = true;\n", + " this.ws.send(JSON.stringify({ type: 'draw', figure_id: this.id }));\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_save = function (fig, _msg) {\n", + " var format_dropdown = fig.format_dropdown;\n", + " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n", + " fig.ondownload(fig, format);\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_resize = function (fig, msg) {\n", + " var size = msg['size'];\n", + " if (size[0] !== fig.canvas.width || size[1] !== fig.canvas.height) {\n", + " fig._resize_canvas(size[0], size[1], msg['forward']);\n", + " fig.send_message('refresh', {});\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n", + " var x0 = msg['x0'] / fig.ratio;\n", + " var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n", + " var x1 = msg['x1'] / fig.ratio;\n", + " var y1 = (fig.canvas.height - msg['y1']) / fig.ratio;\n", + " x0 = Math.floor(x0) + 0.5;\n", + " y0 = Math.floor(y0) + 0.5;\n", + " x1 = Math.floor(x1) + 0.5;\n", + " y1 = Math.floor(y1) + 0.5;\n", + " var min_x = Math.min(x0, x1);\n", + " var min_y = Math.min(y0, y1);\n", + " var width = Math.abs(x1 - x0);\n", + " var height = Math.abs(y1 - y0);\n", + "\n", + " fig.rubberband_context.clearRect(\n", + " 0,\n", + " 0,\n", + " fig.canvas.width / fig.ratio,\n", + " fig.canvas.height / fig.ratio\n", + " );\n", + "\n", + " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_figure_label = function (fig, msg) {\n", + " // Updates the figure title.\n", + " fig.header.textContent = msg['label'];\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_cursor = function (fig, msg) {\n", + " var cursor = msg['cursor'];\n", + " switch (cursor) {\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.handle_history_buttons = function (fig, msg) {\n", + " for (var key in msg) {\n", + " if (!(key in fig.buttons)) {\n", + " continue;\n", + " }\n", + " fig.buttons[key].disabled = !msg[key];\n", + " fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n", + " if (msg['mode'] === 'PAN') {\n", + " fig.buttons['Pan'].classList.add('active');\n", + " fig.buttons['Zoom'].classList.remove('active');\n", + " } else if (msg['mode'] === 'ZOOM') {\n", + " fig.buttons['Pan'].classList.remove('active');\n", + " fig.buttons['Zoom'].classList.add('active');\n", + " } else {\n", + " fig.buttons['Pan'].classList.remove('active');\n", + " fig.buttons['Zoom'].classList.remove('active');\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.updated_canvas_event = function () {\n", + " // Called whenever the canvas gets updated.\n", + " this.send_message('ack', {});\n", + "};\n", + "\n", + "// A function to construct a web socket function for onmessage handling.\n", + "// Called in the figure constructor.\n", + "mpl.figure.prototype._make_on_message_function = function (fig) {\n", + " return function socket_on_message(evt) {\n", + " if (evt.data instanceof Blob) {\n", + " /* 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", + "\n", + " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n", + " evt.data\n", + " );\n", + " fig.updated_canvas_event();\n", + " fig.waiting = false;\n", + " return;\n", + " } else if (\n", + " typeof evt.data === 'string' &&\n", + " evt.data.slice(0, 21) === 'data:image/png;base64'\n", + " ) {\n", + " fig.imageObj.src = evt.data;\n", + " fig.updated_canvas_event();\n", + " fig.waiting = false;\n", + " return;\n", + " }\n", + "\n", + " var msg = JSON.parse(evt.data);\n", + " var msg_type = msg['type'];\n", + "\n", + " // Call the \"handle_{type}\" callback, which takes\n", + " // the figure and JSON message as its only arguments.\n", + " try {\n", + " var callback = fig['handle_' + msg_type];\n", + " } catch (e) {\n", + " console.log(\n", + " \"No handler for the '\" + msg_type + \"' message type: \",\n", + " msg\n", + " );\n", + " return;\n", + " }\n", + "\n", + " if (callback) {\n", + " try {\n", + " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n", + " callback(fig, msg);\n", + " } catch (e) {\n", + " console.log(\n", + " \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n", + " e,\n", + " e.stack,\n", + " msg\n", + " );\n", + " }\n", + " }\n", + " };\n", + "};\n", + "\n", + "// from 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", + " }\n", + " if (e.target) {\n", + " targ = e.target;\n", + " } else if (e.srcElement) {\n", + " targ = e.srcElement;\n", + " }\n", + " if (targ.nodeType === 3) {\n", + " // defeat Safari bug\n", + " targ = targ.parentNode;\n", + " }\n", + "\n", + " // pageX,Y are the mouse positions relative to the document\n", + " var boundingRect = targ.getBoundingClientRect();\n", + " var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n", + " var y = e.pageY - (boundingRect.top + document.body.scrollTop);\n", + "\n", + " return { x: x, y: y };\n", + "};\n", + "\n", + "/*\n", + " * return a copy of an object with only non-object keys\n", + " * we need this to avoid circular references\n", + " * 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", + " }\n", + " return obj;\n", + " }, {});\n", + "}\n", + "\n", + "mpl.figure.prototype.mouse_event = function (event, name) {\n", + " var canvas_pos = mpl.findpos(event);\n", + "\n", + " if (name === 'button_press') {\n", + " this.canvas.focus();\n", + " this.canvas_div.focus();\n", + " }\n", + "\n", + " var x = canvas_pos.x * this.ratio;\n", + " var y = canvas_pos.y * this.ratio;\n", + "\n", + " this.send_message(name, {\n", + " x: x,\n", + " y: y,\n", + " button: event.button,\n", + " step: event.step,\n", + " guiEvent: simpleKeys(event),\n", + " });\n", + "\n", + " /* This prevents the web browser from automatically changing to\n", + " * the text insertion cursor when the button is pressed. We want\n", + " * to control all of the cursor setting manually through the\n", + " * 'cursor' event from matplotlib */\n", + " event.preventDefault();\n", + " return false;\n", + "};\n", + "\n", + "mpl.figure.prototype._key_event_extra = function (_event, _name) {\n", + " // Handle any extra behaviour associated with a key event\n", + "};\n", + "\n", + "mpl.figure.prototype.key_event = function (event, name) {\n", + " // Prevent repeat events\n", + " if (name === 'key_press') {\n", + " if (event.which === this._key) {\n", + " return;\n", + " } else {\n", + " this._key = event.which;\n", + " }\n", + " }\n", + " if (name === 'key_release') {\n", + " this._key = null;\n", + " }\n", + "\n", + " var value = '';\n", + " if (event.ctrlKey && event.which !== 17) {\n", + " value += 'ctrl+';\n", + " }\n", + " if (event.altKey && event.which !== 18) {\n", + " value += 'alt+';\n", + " }\n", + " if (event.shiftKey && event.which !== 16) {\n", + " value += 'shift+';\n", + " }\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, guiEvent: simpleKeys(event) });\n", + " return false;\n", + "};\n", + "\n", + "mpl.figure.prototype.toolbar_button_onclick = function (name) {\n", + " if (name === 'download') {\n", + " this.handle_save(this, null);\n", + " } else {\n", + " this.send_message('toolbar_button', { name: name });\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.toolbar_button_onmouseover = function (tooltip) {\n", + " this.message.textContent = tooltip;\n", + "};\n", + "\n", + "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n", + "// prettier-ignore\n", + "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\n", + "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis, CTRL fixes aspect\", \"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\";/* global mpl */\n", + "\n", + "var comm_websocket_adapter = function (comm) {\n", + " // Create a \"websocket\"-like object which calls the given IPython comm\n", + " // object with the appropriate methods. Currently this is a non binary\n", + " // socket, so there is still some room for performance tuning.\n", + " var ws = {};\n", + "\n", + " ws.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 = document.getElementById(id);\n", + " var ws_proxy = comm_websocket_adapter(comm);\n", + "\n", + " function ondownload(figure, _format) {\n", + " window.open(figure.canvas.toDataURL());\n", + " }\n", + "\n", + " var fig = new mpl.figure(id, ws_proxy, ondownload, element);\n", + "\n", + " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n", + " // web socket which is closed, not our websocket->open comm proxy.\n", + " ws_proxy.onopen();\n", + "\n", + " fig.parent_element = element;\n", + " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n", + " if (!fig.cell_info) {\n", + " console.error('Failed to find cell for figure', id, fig);\n", + " return;\n", + " }\n", + " fig.cell_info[0].output_area.element.on(\n", + " 'cleared',\n", + " { fig: fig },\n", + " fig._remove_fig_handler\n", + " );\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_close = function (fig, msg) {\n", + " var width = fig.canvas.width / fig.ratio;\n", + " fig.cell_info[0].output_area.element.off(\n", + " 'cleared',\n", + " fig._remove_fig_handler\n", + " );\n", + " fig.resizeObserverInstance.unobserve(fig.canvas_div);\n", + "\n", + " // Update the output cell to use the data from the current canvas.\n", + " fig.push_to_output();\n", + " var dataURL = fig.canvas.toDataURL();\n", + " // Re-enable the keyboard manager in IPython - without this line, in FF,\n", + " // the notebook keyboard shortcuts fail.\n", + " IPython.keyboard_manager.enable();\n", + " fig.parent_element.innerHTML =\n", + " '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n", + " fig.close_ws(fig, msg);\n", + "};\n", + "\n", + "mpl.figure.prototype.close_ws = function (fig, msg) {\n", + " fig.send_message('closing', msg);\n", + " // fig.ws.close()\n", + "};\n", + "\n", + "mpl.figure.prototype.push_to_output = function (_remove_interactive) {\n", + " // Turn the data on the canvas into data in the output cell.\n", + " var width = this.canvas.width / this.ratio;\n", + " var dataURL = this.canvas.toDataURL();\n", + " this.cell_info[1]['text/html'] =\n", + " '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n", + "};\n", + "\n", + "mpl.figure.prototype.updated_canvas_event = function () {\n", + " // Tell IPython that the notebook contents must change.\n", + " IPython.notebook.set_dirty(true);\n", + " this.send_message('ack', {});\n", + " var fig = this;\n", + " // Wait a second, then push the new image to the DOM so\n", + " // that it is saved nicely (might be nice to debounce this).\n", + " setTimeout(function () {\n", + " fig.push_to_output();\n", + " }, 1000);\n", + "};\n", + "\n", + "mpl.figure.prototype._init_toolbar = function () {\n", + " var fig = this;\n", + "\n", + " var toolbar = document.createElement('div');\n", + " toolbar.classList = 'btn-toolbar';\n", + " this.root.appendChild(toolbar);\n", + "\n", + " function on_click_closure(name) {\n", + " return function (_event) {\n", + " return fig.toolbar_button_onclick(name);\n", + " };\n", + " }\n", + "\n", + " function on_mouseover_closure(tooltip) {\n", + " return function (event) {\n", + " if (!event.currentTarget.disabled) {\n", + " return fig.toolbar_button_onmouseover(tooltip);\n", + " }\n", + " };\n", + " }\n", + "\n", + " fig.buttons = {};\n", + " var buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'btn-group';\n", + " var button;\n", + " for (var toolbar_ind in mpl.toolbar_items) {\n", + " var name = mpl.toolbar_items[toolbar_ind][0];\n", + " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n", + " var image = mpl.toolbar_items[toolbar_ind][2];\n", + " var method_name = mpl.toolbar_items[toolbar_ind][3];\n", + "\n", + " if (!name) {\n", + " /* Instead of a spacer, we start a new button group. */\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + " buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'btn-group';\n", + " continue;\n", + " }\n", + "\n", + " button = fig.buttons[name] = document.createElement('button');\n", + " button.classList = 'btn btn-default';\n", + " button.href = '#';\n", + " button.title = name;\n", + " button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n", + " button.addEventListener('click', on_click_closure(method_name));\n", + " button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n", + " buttonGroup.appendChild(button);\n", + " }\n", + "\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + "\n", + " // Add the status bar.\n", + " var status_bar = document.createElement('span');\n", + " status_bar.classList = 'mpl-message pull-right';\n", + " toolbar.appendChild(status_bar);\n", + " this.message = status_bar;\n", + "\n", + " // Add the close button to the window.\n", + " var buttongrp = document.createElement('div');\n", + " buttongrp.classList = 'btn-group inline pull-right';\n", + " button = document.createElement('button');\n", + " button.classList = 'btn btn-mini btn-primary';\n", + " button.href = '#';\n", + " button.title = 'Stop Interaction';\n", + " button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n", + " button.addEventListener('click', function (_evt) {\n", + " fig.handle_close(fig, {});\n", + " });\n", + " button.addEventListener(\n", + " 'mouseover',\n", + " on_mouseover_closure('Stop Interaction')\n", + " );\n", + " buttongrp.appendChild(button);\n", + " var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n", + " titlebar.insertBefore(buttongrp, titlebar.firstChild);\n", + "};\n", + "\n", + "mpl.figure.prototype._remove_fig_handler = function (event) {\n", + " var fig = event.data.fig;\n", + " if (event.target !== this) {\n", + " // Ignore bubbled events from children.\n", + " return;\n", + " }\n", + " fig.close_ws(fig, {});\n", + "};\n", + "\n", + "mpl.figure.prototype._root_extra_style = function (el) {\n", + " el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n", + "};\n", + "\n", + "mpl.figure.prototype._canvas_extra_style = function (el) {\n", + " // this is important to make the div 'focusable\n", + " el.setAttribute('tabindex', 0);\n", + " // reach out to IPython and tell the keyboard manager to turn it's self\n", + " // off when our div gets focus\n", + "\n", + " // location in version 3\n", + " if (IPython.notebook.keyboard_manager) {\n", + " IPython.notebook.keyboard_manager.register_events(el);\n", + " } else {\n", + " // location in version 2\n", + " IPython.keyboard_manager.register_events(el);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype._key_event_extra = function (event, _name) {\n", + " var manager = IPython.notebook.keyboard_manager;\n", + " if (!manager) {\n", + " manager = IPython.keyboard_manager;\n", + " }\n", + "\n", + " // Check for shift+enter\n", + " if (event.shiftKey && event.which === 13) {\n", + " this.canvas_div.blur();\n", + " // select the cell after this one\n", + " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n", + " IPython.notebook.select(index + 1);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_save = function (fig, _msg) {\n", + " fig.ondownload(fig, null);\n", + "};\n", + "\n", + "mpl.find_output_cell = function (html_output) {\n", + " // Return the cell and output element which can be found *uniquely* in the notebook.\n", + " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n", + " // IPython event is triggered only after the cells have been serialised, which for\n", + " // our purposes (turning an active figure into a static one), is too late.\n", + " var cells = IPython.notebook.get_cells();\n", + " var ncells = cells.length;\n", + " for (var i = 0; i < ncells; i++) {\n", + " var cell = cells[i];\n", + " if (cell.cell_type === 'code') {\n", + " for (var j = 0; j < cell.output_area.outputs.length; j++) {\n", + " var data = cell.output_area.outputs[j];\n", + " if (data.data) {\n", + " // IPython >= 3 moved mimebundle to data attribute of output\n", + " data = data.data;\n", + " }\n", + " if (data['text/html'] === html_output) {\n", + " return [cell, data, j];\n", + " }\n", + " }\n", + " }\n", + " }\n", + "};\n", + "\n", + "// Register the function which deals with the matplotlib target/channel.\n", + "// The kernel may be null if the page has been refreshed.\n", + "if (IPython.notebook.kernel !== null) {\n", + " IPython.notebook.kernel.comm_manager.register_target(\n", + " 'matplotlib',\n", + " mpl.mpl_figure_comm\n", + " );\n", + "}\n" + ], + "text/plain": [ + "<IPython.core.display.Javascript object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + }, + { + "data": { + "text/html": [ + "<img src=\"\" width=\"640\">" + ], + "text/plain": [ + "<IPython.core.display.HTML object>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "df_impf = pd.read_csv('Impfquoten.csv')\n", "df_impf = df_impf[df_impf.Bundesland!=\"Deutschland\"].drop('Datum', axis=1) # Drop column 'Datum', row \"Deutschland\"\n", "df_impf = df_impf.set_index('Bundesland')\n", "#df_impf.columns\n", @@ -684,37 +2725,1048 @@ }, { "cell_type": "code", - "execution_count": 140, - "id": "ff16225f", + "execution_count": 8, + "id": "8e99105a", "metadata": {}, "outputs": [ { "data": { - "image/png": "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p060bduWUaNGAZCfn09ubm6yTdn3+fn5ZGdnc/nll9OlSxfeeOMNRo0aRdu2bWnXrh2//OUv2W+//Zg2bdpGdZ5zzjk89thjyfezZs1iypQpnHzyyYwfP56uXbvSrl07unbtyvjx48tdw+DBgzniiCN45JFHGDx4MKeeeiq9evXi0EMP5eSTT+a770oWuV+xYgXnnHMObdq0oU2bNvzhD39Ini8vL49f//rXHHnkkTRv3py77rqLp59+msMOO4wWLVrw3HPPJduGELjtttvo2LEjLVu25O233+aaa66hffv2tGnThhkzZiTb/uMf/+CSSy4hJyeHo48+mo8//hgoCeB69uxJv379yMnJYerUqYQQuP3225P9Pv/88xt9TpIkqWYxpJIkSUkLCldQXIlRVOsVx8iiNRuvS9W9e3emTJnCkiVLePzxx+nfv39y3x//+EcaNmzIuHHjKCgooFmzZvz+978H4Morr2TXXXdl8uTJTJ48mcGDB5fr9+233+aMM87gn//8J926dSu3b+nSpVx88cUMHTqUiRMn8uqrr3LRRRexdOlSABYtWkTXrl2ZNGkSN954I7/97W+Txy5atIh27doxbtw4/vKXv3D66aezZs2aLV7/1KlTOeOMM3j//fc59thjOf3003nwwQeZMmUKeXl5fPnllxUe179/f15//XWWLFkClIQ4p512Gunp6Zx88snccsstTJkyhVtvvZWTTz6ZtWvXJus8+OCDGT16NBdffDEAo0aN4rHHHmP69Ok0bNiQW265BYBbbrmFRCLB1KlTGTt2LEOGDOGNN95I1vD1118zcuRIPvjgA2688UamTZvG2LFjefbZZ7nqqqvK1bvbbrsxfvx4/vCHP/DTn/6UI444gkmTJtG/f39uu+22ZB3PPvss9913HxMnTmTQoEHlRoaNHj2awYMHM3HiRLKzswFo0KAB48eP54knnuCKK67Y4uctSZJ+2Hy6nyRJSqoVtv7/r2qF9I22hRA49dRTeeaZZ/jnP//JmDFjmDBhAgDDhw9n2bJlDBs2DIA1a9aQlZUFwKuvvsrEiRNJSyupo+xaUf/+97/517/+xb///W+aNWu20TnHjh3L559/zk9+8pNydcycOZMmTZpQr149evfuDZRMufv1r3+dbFe7dm3OOussALp160bdunWTo4A258ADD6Rr164AfPzxx9St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t956i7y8PJ588kkuuOACHnroIdLS0vjrX//K6NGjGTNmTHLK3XqffPIJU6ZMSfaxxx57kJaWRpMmTTjxxBMB2G233XjllVcIIVCrVi169uxJTk4OL730EscccwwvvPAC48ePp2HDhhx//PE89dRTXHDBBfzud7+jQYMGfPTRRyxcuJAOHTok17janDVr1jB8+HByc3MZNGgQ06dPJzc3l1/84hfJRe7XTxl85JFH+O1vf1vuiY8bfi8efvhhHnvsMfIOOpAFd9/FyjGjgQAxQXrD3Whw0s+o1+MY0suM0JB2Vo17dGXm4IqfVrqRtDQaHdae2k02/v14U+69915OOukk9t57b7p160bjxpuetr3ZOhs35tNPP6Vz586sWrWKp59+mtq1a7P33nvz61//mpycHPbff386duzI9OnTK+yjTp06DB06lIsvvphddtmFo48+mqZNm9Kw4daNJpNUcxhSSZJUk4R0qHM4FH8J6z6BuJr/TQFMQPreUOsgSGuQyip3nMTWPvEQSGw8KqFv377EGJk1axYvvvgitWvXBuDwww+nefPmQMmi8eufXDh8+HAmTJiQHEVVVFS0yX+0baqPsoqLixk0aBBvvvkm8+bNY926dcyYMYOHH36YSZMmcfzxxyfXgencuXNyxNQ777zD/fffD0CTJk34v//7v81e+ogRI8jOzk7Wdc0111TY7o033uCBBx5gxYoVm50+BPDmm2/ypz/9ieGXX8bSm24grlsHZaYSFS9exNKnnuC75/7JnrfcRu39W262P6m6S6tdi4Nuv4qPf3MnicLN/B4UAun1dqHldRdvtKui0H7ChAnJr9c/rALgtttuSx6z4XFlw/0WLVokR3uW/frmm2/e6Fw33HADN9xww0bb8/LyytUBJWtfrZ96/M477/DUU0+x9957b3SsJIEhlSRJNU8IkLFfya/EcoiFQBqk1YdQO9XV7Vjpu27lAaHCY9YvYPzcc89x1llnJZ+yVdHC71DyD8Prr7+ec889d4tn3FQfZd19990sWbKEjz76iMzMTC688EKaNWvGT3/6UyZNmrRRH6tXr07WsSmdO3dmzZo11K9fP/no+WOOOYZhw4Zttt758+dz1VVXMX78ePbff3/Gjh2bfOLghiZPnszFF1/Mc1deQZ2R+cRNTEuKa9YQ16xh3nXX0Oye+6jVdM/N1iBVd417dOXAW6/k0+vuJQJxTfmwKm2XTNJ3qUvbR28ns9keqSlyO3n++ee55557SCQSZGZm8vTTT5OW5qozkirm7w6SJNVkafUh/UeQ3rjmBVQAux4KoeInC1YopMOurTa5+5RTTuG4444rtxh8Rfr06cODDz7IkiVLgJLpc5MnT658HRtYunQpe+21F5mZmcyZMye5ttOW9OjRI7lg+6JFi3jxxReT+z744AMKCgqSAVVlrVq1itq1a7PnnnuSSCR46KGHKmw3Z84cTj75ZB5/6K80GfXuJgOqsuKqVSwZ8o+Ntrdo0SK5RlrZbdOmTeP888/f6muAkhEhr7766lYftz0NGDCAv/ylktPCtNP50U+OIvetR2l+0WnU/tHuhPR0Qu1a7HJQC35802V0fOtRdjmgearL/N4GDBjA5MmTmTp1KuPHj+fwww9PdUmSqjFHUkmSpJorszmk1YHijZ/uV6FaTQi1dt9sk9///vfk5ORscioclEzFWbhwYXKh90QiwaWXXkpWVlalSy/riiuu4JRTTqF9+/Y0b96cHj16VOq4G264gXPPPZdDDjmEFi1acNxxx23T+ctq2bIlp5xyCoceeij77rsv3bp14913392o3SOPPMKCBQv4xcUXU7xkKcTIDW0OpmuTJpvuPEZWf/ABxcuXk16//NPOVqxYkXzK4Ibn2VGKiorIyPCv16q82o13Y9+LTmPfi05LdSmSVC0En5hSXm5ubtxwHrWUn59f7ulQkqoH701tD7HwS/j2BYibXzuJUAv2PINQ+0c7prCd1Nbel3Ou+AXrvphd6fahbl2a/OIKdj3if4vXt2jRgsGDB3PzzTfz8ccfU7t2bVq0aMGrr77KL37xCwYOHEjv3r1ZtmwZv/rVr5gyZQqFhYV0796du+++m/T0dD766CPOOecc1q1bxyGHHMLMmTO5/vrr6d27N/PmzePyyy/nyy+/ZPXq1Zx++ulce+21yXOfd955/Oc//6Fly5b85je/YcCAAaxatYri4mIGDBjAwIEDefvtt7n++uspLCykqKiI6667jp///Ocln8GcOVxxxRXJhw+cfvrpXHPNNQwYMIDMzEw++eQTvvrqK7p27co//vEPQgj87W9/45577qFOnTokEgmeffZZWrduzccff8yVV17JwoULWbt2LVdeeSXnnHNOyWcXArfddhsvvvgiixYt4s47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gwYBMH/+fGrVqkXjxo0BCCGQnZ0NwHvvvccRRxxBVlYWLVu2ZN99/zcCa8iQIYQQaNy4cbK+u+66q9xaXvPmzaNv37506tSJtm3bcvvttwMlC+FfeumltG7dmqysLA4//HDuvfderrjiCu68804Ahg4dSgiBQw45hKuuuopevXrx73//m9mzZ5d78uLzzz/PLrvsQsuWLbn99tsJIbBixYpKfR4b+uabb/jZz35Gu3btaNu2LUOGDKmw3c0330zr1q3Jzs6mffv2LF26lMsuuwyAww47jOzsbJYuXcqyZcs4//zz6dSpE+3ateOXv/xlci22vLw8Xn31VaDke3zxxRdz9NFHc+CBB9K/f3+caSMplRxJJUmSpGolbZddSNtll1SXscMkPnwhOWJqi4oKiZ+PI/z48HKbV6xYwRNPPMHZZ5+9TTUUFRWRkVG5fxoUFRWxZvFyCMBW5BmxuJie3Xrw05NOAiArK4tOnTqx7777kpeXxxFHHEG/fv0IIfCzn/2MF154gcMOO4wVK1bQuHFjvvnmG6BkcfrOnTuz++67c/XVVzNgwADy8/PLPQmxf//+3HDDDRx11FGsXbuWHj160LFjR5o0acKIESP473//S1paGkuWLKF9+/Zcd911PP/88wwaNIjnnnuOunXrcuONN3LyySez5557csQRR/Dtt98m+//222+58MILadu2LTfccAOffvrpFq+/b9++5Wr85JNPkl9fccUVtGnThhdffJF58+bRoUMHOnToUG6K35IlS7jrrrv49ttvqVu3LsuXL6du3bo88MADPPjgg4wdOzb5pMnzzz+fbt268cgjj5BIJDjzzDN544036NGjx0Z1TZs2jREjRpCWlkb79u0ZMWIExx57bCW/q5K0fTmSSpIkSUqRuHoZ8esplT9gXSHFBcM32jx48GAGDx680SLpM2fOpEePHrRr144OHTrwr3/9K7kvhMCdd95JXl4eN998M3PmzKFHjx5kZWVx0kknlRuZNGDAAC6//HJ69uxJ586dSUtPI0HkH/G/3Bg/4MY4jrlxZbL9mDiPW+IEbo7j+WP8kHlxJTERefKfQ+nbty8A7777LrNnz6Z79+6899573HDDDRx88MG88cYbHHLIIRx22GFAyRMQO3XqRH5+fvL95ZdfzsyZM2nUqBFffPEFo0ePpk6dOqxbt44rr7ySESNG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\n", + "application/javascript": [ + "/* Put everything inside the global mpl namespace */\n", + "/* global mpl */\n", + "window.mpl = {};\n", + "\n", + "mpl.get_websocket_type = function () {\n", + " if (typeof WebSocket !== 'undefined') {\n", + " return WebSocket;\n", + " } else if (typeof MozWebSocket !== 'undefined') {\n", + " return MozWebSocket;\n", + " } else {\n", + " alert(\n", + " 'Your browser does not have WebSocket support. ' +\n", + " 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n", + " 'Firefox 4 and 5 are also supported but you ' +\n", + " 'have to enable WebSockets in about:config.'\n", + " );\n", + " }\n", + "};\n", + "\n", + "mpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n", + " this.id = figure_id;\n", + "\n", + " this.ws = websocket;\n", + "\n", + " this.supports_binary = this.ws.binaryType !== undefined;\n", + "\n", + " if (!this.supports_binary) {\n", + " var warnings = document.getElementById('mpl-warnings');\n", + " if (warnings) {\n", + " warnings.style.display = 'block';\n", + " warnings.textContent =\n", + " 'This browser does not support binary websocket messages. ' +\n", + " 'Performance may be slow.';\n", + " }\n", + " }\n", + "\n", + " this.imageObj = new Image();\n", + "\n", + " this.context = undefined;\n", + " this.message = undefined;\n", + " this.canvas = undefined;\n", + " this.rubberband_canvas = undefined;\n", + " this.rubberband_context = undefined;\n", + " this.format_dropdown = undefined;\n", + "\n", + " this.image_mode = 'full';\n", + "\n", + " this.root = document.createElement('div');\n", + " this.root.setAttribute('style', 'display: inline-block');\n", + " this._root_extra_style(this.root);\n", + "\n", + " parent_element.appendChild(this.root);\n", + "\n", + " this._init_header(this);\n", + " this._init_canvas(this);\n", + " this._init_toolbar(this);\n", + "\n", + " var fig = this;\n", + "\n", + " this.waiting = false;\n", + "\n", + " this.ws.onopen = function () {\n", + " fig.send_message('supports_binary', { value: fig.supports_binary });\n", + " fig.send_message('send_image_mode', {});\n", + " if (fig.ratio !== 1) {\n", + " fig.send_message('set_dpi_ratio', { dpi_ratio: fig.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 = document.createElement('div');\n", + " titlebar.classList =\n", + " 'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n", + " var titletext = document.createElement('div');\n", + " titletext.classList = 'ui-dialog-title';\n", + " titletext.setAttribute(\n", + " 'style',\n", + " 'width: 100%; text-align: center; padding: 3px;'\n", + " );\n", + " titlebar.appendChild(titletext);\n", + " this.root.appendChild(titlebar);\n", + " this.header = titletext;\n", + "};\n", + "\n", + "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n", + "\n", + "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n", + "\n", + "mpl.figure.prototype._init_canvas = function () {\n", + " var fig = this;\n", + "\n", + " var canvas_div = (this.canvas_div = document.createElement('div'));\n", + " canvas_div.setAttribute(\n", + " 'style',\n", + " 'border: 1px solid #ddd;' +\n", + " 'box-sizing: content-box;' +\n", + " 'clear: both;' +\n", + " 'min-height: 1px;' +\n", + " 'min-width: 1px;' +\n", + " 'outline: 0;' +\n", + " 'overflow: hidden;' +\n", + " 'position: relative;' +\n", + " 'resize: both;'\n", + " );\n", + "\n", + " function on_keyboard_event_closure(name) {\n", + " return function (event) {\n", + " return fig.key_event(event, name);\n", + " };\n", + " }\n", + "\n", + " canvas_div.addEventListener(\n", + " 'keydown',\n", + " on_keyboard_event_closure('key_press')\n", + " );\n", + " canvas_div.addEventListener(\n", + " 'keyup',\n", + " on_keyboard_event_closure('key_release')\n", + " );\n", + "\n", + " this._canvas_extra_style(canvas_div);\n", + " this.root.appendChild(canvas_div);\n", + "\n", + " var canvas = (this.canvas = document.createElement('canvas'));\n", + " canvas.classList.add('mpl-canvas');\n", + " canvas.setAttribute('style', 'box-sizing: content-box;');\n", + "\n", + " this.context = canvas.getContext('2d');\n", + "\n", + " var backingStore =\n", + " this.context.backingStorePixelRatio ||\n", + " this.context.webkitBackingStorePixelRatio ||\n", + " this.context.mozBackingStorePixelRatio ||\n", + " this.context.msBackingStorePixelRatio ||\n", + " this.context.oBackingStorePixelRatio ||\n", + " this.context.backingStorePixelRatio ||\n", + " 1;\n", + "\n", + " this.ratio = (window.devicePixelRatio || 1) / backingStore;\n", + "\n", + " var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n", + " 'canvas'\n", + " ));\n", + " rubberband_canvas.setAttribute(\n", + " 'style',\n", + " 'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n", + " );\n", + "\n", + " // Apply a ponyfill if ResizeObserver is not implemented by browser.\n", + " if (this.ResizeObserver === undefined) {\n", + " if (window.ResizeObserver !== undefined) {\n", + " this.ResizeObserver = window.ResizeObserver;\n", + " } else {\n", + " var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n", + " this.ResizeObserver = obs.ResizeObserver;\n", + " }\n", + " }\n", + "\n", + " this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n", + " var nentries = entries.length;\n", + " for (var i = 0; i < nentries; i++) {\n", + " var entry = entries[i];\n", + " var width, height;\n", + " if (entry.contentBoxSize) {\n", + " if (entry.contentBoxSize instanceof Array) {\n", + " // Chrome 84 implements new version of spec.\n", + " width = entry.contentBoxSize[0].inlineSize;\n", + " height = entry.contentBoxSize[0].blockSize;\n", + " } else {\n", + " // Firefox implements old version of spec.\n", + " width = entry.contentBoxSize.inlineSize;\n", + " height = entry.contentBoxSize.blockSize;\n", + " }\n", + " } else {\n", + " // Chrome <84 implements even older version of spec.\n", + " width = entry.contentRect.width;\n", + " height = entry.contentRect.height;\n", + " }\n", + "\n", + " // Keep the size of the canvas and rubber band canvas in sync with\n", + " // the canvas container.\n", + " if (entry.devicePixelContentBoxSize) {\n", + " // Chrome 84 implements new version of spec.\n", + " canvas.setAttribute(\n", + " 'width',\n", + " entry.devicePixelContentBoxSize[0].inlineSize\n", + " );\n", + " canvas.setAttribute(\n", + " 'height',\n", + " entry.devicePixelContentBoxSize[0].blockSize\n", + " );\n", + " } else {\n", + " canvas.setAttribute('width', width * fig.ratio);\n", + " canvas.setAttribute('height', height * fig.ratio);\n", + " }\n", + " canvas.setAttribute(\n", + " 'style',\n", + " 'width: ' + width + 'px; height: ' + height + 'px;'\n", + " );\n", + "\n", + " rubberband_canvas.setAttribute('width', width);\n", + " rubberband_canvas.setAttribute('height', height);\n", + "\n", + " // And update the size in Python. We ignore the initial 0/0 size\n", + " // that occurs as the element is placed into the DOM, which should\n", + " // otherwise not happen due to the minimum size styling.\n", + " if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n", + " fig.request_resize(width, height);\n", + " }\n", + " }\n", + " });\n", + " this.resizeObserverInstance.observe(canvas_div);\n", + "\n", + " function on_mouse_event_closure(name) {\n", + " return function (event) {\n", + " return fig.mouse_event(event, name);\n", + " };\n", + " }\n", + "\n", + " rubberband_canvas.addEventListener(\n", + " 'mousedown',\n", + " on_mouse_event_closure('button_press')\n", + " );\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseup',\n", + " on_mouse_event_closure('button_release')\n", + " );\n", + " // Throttle sequential mouse events to 1 every 20ms.\n", + " rubberband_canvas.addEventListener(\n", + " 'mousemove',\n", + " on_mouse_event_closure('motion_notify')\n", + " );\n", + "\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseenter',\n", + " on_mouse_event_closure('figure_enter')\n", + " );\n", + " rubberband_canvas.addEventListener(\n", + " 'mouseleave',\n", + " on_mouse_event_closure('figure_leave')\n", + " );\n", + "\n", + " canvas_div.addEventListener('wheel', function (event) {\n", + " if (event.deltaY < 0) {\n", + " event.step = 1;\n", + " } else {\n", + " event.step = -1;\n", + " }\n", + " on_mouse_event_closure('scroll')(event);\n", + " });\n", + "\n", + " canvas_div.appendChild(canvas);\n", + " canvas_div.appendChild(rubberband_canvas);\n", + "\n", + " this.rubberband_context = rubberband_canvas.getContext('2d');\n", + " this.rubberband_context.strokeStyle = '#000000';\n", + "\n", + " this._resize_canvas = function (width, height, forward) {\n", + " if (forward) {\n", + " canvas_div.style.width = width + 'px';\n", + " canvas_div.style.height = height + 'px';\n", + " }\n", + " };\n", + "\n", + " // Disable right mouse context menu.\n", + " this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n", + " event.preventDefault();\n", + " return false;\n", + " });\n", + "\n", + " function set_focus() {\n", + " canvas.focus();\n", + " canvas_div.focus();\n", + " }\n", + "\n", + " window.setTimeout(set_focus, 100);\n", + "};\n", + "\n", + "mpl.figure.prototype._init_toolbar = function () {\n", + " var fig = this;\n", + "\n", + " var toolbar = document.createElement('div');\n", + " toolbar.classList = 'mpl-toolbar';\n", + " this.root.appendChild(toolbar);\n", + "\n", + " function on_click_closure(name) {\n", + " return function (_event) {\n", + " return fig.toolbar_button_onclick(name);\n", + " };\n", + " }\n", + "\n", + " function on_mouseover_closure(tooltip) {\n", + " return function (event) {\n", + " if (!event.currentTarget.disabled) {\n", + " return fig.toolbar_button_onmouseover(tooltip);\n", + " }\n", + " };\n", + " }\n", + "\n", + " fig.buttons = {};\n", + " var buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'mpl-button-group';\n", + " for (var toolbar_ind in mpl.toolbar_items) {\n", + " var name = mpl.toolbar_items[toolbar_ind][0];\n", + " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n", + " var image = mpl.toolbar_items[toolbar_ind][2];\n", + " var method_name = mpl.toolbar_items[toolbar_ind][3];\n", + "\n", + " if (!name) {\n", + " /* Instead of a spacer, we start a new button group. */\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + " buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'mpl-button-group';\n", + " continue;\n", + " }\n", + "\n", + " var button = (fig.buttons[name] = document.createElement('button'));\n", + " button.classList = 'mpl-widget';\n", + " button.setAttribute('role', 'button');\n", + " button.setAttribute('aria-disabled', 'false');\n", + " button.addEventListener('click', on_click_closure(method_name));\n", + " button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n", + "\n", + " var icon_img = document.createElement('img');\n", + " icon_img.src = '_images/' + image + '.png';\n", + " icon_img.srcset = '_images/' + image + '_large.png 2x';\n", + " icon_img.alt = tooltip;\n", + " button.appendChild(icon_img);\n", + "\n", + " buttonGroup.appendChild(button);\n", + " }\n", + "\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + "\n", + " var fmt_picker = document.createElement('select');\n", + " fmt_picker.classList = 'mpl-widget';\n", + " toolbar.appendChild(fmt_picker);\n", + " this.format_dropdown = fmt_picker;\n", + "\n", + " for (var ind in mpl.extensions) {\n", + " var fmt = mpl.extensions[ind];\n", + " var option = document.createElement('option');\n", + " option.selected = fmt === mpl.default_extension;\n", + " option.innerHTML = fmt;\n", + " fmt_picker.appendChild(option);\n", + " }\n", + "\n", + " var status_bar = document.createElement('span');\n", + " status_bar.classList = 'mpl-message';\n", + " toolbar.appendChild(status_bar);\n", + " this.message = status_bar;\n", + "};\n", + "\n", + "mpl.figure.prototype.request_resize = function (x_pixels, y_pixels) {\n", + " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n", + " // which will in turn request a refresh of the image.\n", + " this.send_message('resize', { width: x_pixels, height: y_pixels });\n", + "};\n", + "\n", + "mpl.figure.prototype.send_message = function (type, properties) {\n", + " properties['type'] = type;\n", + " properties['figure_id'] = this.id;\n", + " this.ws.send(JSON.stringify(properties));\n", + "};\n", + "\n", + "mpl.figure.prototype.send_draw_message = function () {\n", + " if (!this.waiting) {\n", + " this.waiting = true;\n", + " this.ws.send(JSON.stringify({ type: 'draw', figure_id: this.id }));\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_save = function (fig, _msg) {\n", + " var format_dropdown = fig.format_dropdown;\n", + " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n", + " fig.ondownload(fig, format);\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_resize = function (fig, msg) {\n", + " var size = msg['size'];\n", + " if (size[0] !== fig.canvas.width || size[1] !== fig.canvas.height) {\n", + " fig._resize_canvas(size[0], size[1], msg['forward']);\n", + " fig.send_message('refresh', {});\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n", + " var x0 = msg['x0'] / fig.ratio;\n", + " var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n", + " var x1 = msg['x1'] / fig.ratio;\n", + " var y1 = (fig.canvas.height - msg['y1']) / fig.ratio;\n", + " x0 = Math.floor(x0) + 0.5;\n", + " y0 = Math.floor(y0) + 0.5;\n", + " x1 = Math.floor(x1) + 0.5;\n", + " y1 = Math.floor(y1) + 0.5;\n", + " var min_x = Math.min(x0, x1);\n", + " var min_y = Math.min(y0, y1);\n", + " var width = Math.abs(x1 - x0);\n", + " var height = Math.abs(y1 - y0);\n", + "\n", + " fig.rubberband_context.clearRect(\n", + " 0,\n", + " 0,\n", + " fig.canvas.width / fig.ratio,\n", + " fig.canvas.height / fig.ratio\n", + " );\n", + "\n", + " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_figure_label = function (fig, msg) {\n", + " // Updates the figure title.\n", + " fig.header.textContent = msg['label'];\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_cursor = function (fig, msg) {\n", + " var cursor = msg['cursor'];\n", + " switch (cursor) {\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.handle_history_buttons = function (fig, msg) {\n", + " for (var key in msg) {\n", + " if (!(key in fig.buttons)) {\n", + " continue;\n", + " }\n", + " fig.buttons[key].disabled = !msg[key];\n", + " fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n", + " if (msg['mode'] === 'PAN') {\n", + " fig.buttons['Pan'].classList.add('active');\n", + " fig.buttons['Zoom'].classList.remove('active');\n", + " } else if (msg['mode'] === 'ZOOM') {\n", + " fig.buttons['Pan'].classList.remove('active');\n", + " fig.buttons['Zoom'].classList.add('active');\n", + " } else {\n", + " fig.buttons['Pan'].classList.remove('active');\n", + " fig.buttons['Zoom'].classList.remove('active');\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.updated_canvas_event = function () {\n", + " // Called whenever the canvas gets updated.\n", + " this.send_message('ack', {});\n", + "};\n", + "\n", + "// A function to construct a web socket function for onmessage handling.\n", + "// Called in the figure constructor.\n", + "mpl.figure.prototype._make_on_message_function = function (fig) {\n", + " return function socket_on_message(evt) {\n", + " if (evt.data instanceof Blob) {\n", + " /* 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", + "\n", + " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n", + " evt.data\n", + " );\n", + " fig.updated_canvas_event();\n", + " fig.waiting = false;\n", + " return;\n", + " } else if (\n", + " typeof evt.data === 'string' &&\n", + " evt.data.slice(0, 21) === 'data:image/png;base64'\n", + " ) {\n", + " fig.imageObj.src = evt.data;\n", + " fig.updated_canvas_event();\n", + " fig.waiting = false;\n", + " return;\n", + " }\n", + "\n", + " var msg = JSON.parse(evt.data);\n", + " var msg_type = msg['type'];\n", + "\n", + " // Call the \"handle_{type}\" callback, which takes\n", + " // the figure and JSON message as its only arguments.\n", + " try {\n", + " var callback = fig['handle_' + msg_type];\n", + " } catch (e) {\n", + " console.log(\n", + " \"No handler for the '\" + msg_type + \"' message type: \",\n", + " msg\n", + " );\n", + " return;\n", + " }\n", + "\n", + " if (callback) {\n", + " try {\n", + " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n", + " callback(fig, msg);\n", + " } catch (e) {\n", + " console.log(\n", + " \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n", + " e,\n", + " e.stack,\n", + " msg\n", + " );\n", + " }\n", + " }\n", + " };\n", + "};\n", + "\n", + "// from 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", + " }\n", + " if (e.target) {\n", + " targ = e.target;\n", + " } else if (e.srcElement) {\n", + " targ = e.srcElement;\n", + " }\n", + " if (targ.nodeType === 3) {\n", + " // defeat Safari bug\n", + " targ = targ.parentNode;\n", + " }\n", + "\n", + " // pageX,Y are the mouse positions relative to the document\n", + " var boundingRect = targ.getBoundingClientRect();\n", + " var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n", + " var y = e.pageY - (boundingRect.top + document.body.scrollTop);\n", + "\n", + " return { x: x, y: y };\n", + "};\n", + "\n", + "/*\n", + " * return a copy of an object with only non-object keys\n", + " * we need this to avoid circular references\n", + " * 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", + " }\n", + " return obj;\n", + " }, {});\n", + "}\n", + "\n", + "mpl.figure.prototype.mouse_event = function (event, name) {\n", + " var canvas_pos = mpl.findpos(event);\n", + "\n", + " if (name === 'button_press') {\n", + " this.canvas.focus();\n", + " this.canvas_div.focus();\n", + " }\n", + "\n", + " var x = canvas_pos.x * this.ratio;\n", + " var y = canvas_pos.y * this.ratio;\n", + "\n", + " this.send_message(name, {\n", + " x: x,\n", + " y: y,\n", + " button: event.button,\n", + " step: event.step,\n", + " guiEvent: simpleKeys(event),\n", + " });\n", + "\n", + " /* This prevents the web browser from automatically changing to\n", + " * the text insertion cursor when the button is pressed. We want\n", + " * to control all of the cursor setting manually through the\n", + " * 'cursor' event from matplotlib */\n", + " event.preventDefault();\n", + " return false;\n", + "};\n", + "\n", + "mpl.figure.prototype._key_event_extra = function (_event, _name) {\n", + " // Handle any extra behaviour associated with a key event\n", + "};\n", + "\n", + "mpl.figure.prototype.key_event = function (event, name) {\n", + " // Prevent repeat events\n", + " if (name === 'key_press') {\n", + " if (event.which === this._key) {\n", + " return;\n", + " } else {\n", + " this._key = event.which;\n", + " }\n", + " }\n", + " if (name === 'key_release') {\n", + " this._key = null;\n", + " }\n", + "\n", + " var value = '';\n", + " if (event.ctrlKey && event.which !== 17) {\n", + " value += 'ctrl+';\n", + " }\n", + " if (event.altKey && event.which !== 18) {\n", + " value += 'alt+';\n", + " }\n", + " if (event.shiftKey && event.which !== 16) {\n", + " value += 'shift+';\n", + " }\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, guiEvent: simpleKeys(event) });\n", + " return false;\n", + "};\n", + "\n", + "mpl.figure.prototype.toolbar_button_onclick = function (name) {\n", + " if (name === 'download') {\n", + " this.handle_save(this, null);\n", + " } else {\n", + " this.send_message('toolbar_button', { name: name });\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.toolbar_button_onmouseover = function (tooltip) {\n", + " this.message.textContent = tooltip;\n", + "};\n", + "\n", + "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n", + "// prettier-ignore\n", + "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\n", + "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis, CTRL fixes aspect\", \"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\";/* global mpl */\n", + "\n", + "var comm_websocket_adapter = function (comm) {\n", + " // Create a \"websocket\"-like object which calls the given IPython comm\n", + " // object with the appropriate methods. Currently this is a non binary\n", + " // socket, so there is still some room for performance tuning.\n", + " var ws = {};\n", + "\n", + " ws.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 = document.getElementById(id);\n", + " var ws_proxy = comm_websocket_adapter(comm);\n", + "\n", + " function ondownload(figure, _format) {\n", + " window.open(figure.canvas.toDataURL());\n", + " }\n", + "\n", + " var fig = new mpl.figure(id, ws_proxy, ondownload, element);\n", + "\n", + " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n", + " // web socket which is closed, not our websocket->open comm proxy.\n", + " ws_proxy.onopen();\n", + "\n", + " fig.parent_element = element;\n", + " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n", + " if (!fig.cell_info) {\n", + " console.error('Failed to find cell for figure', id, fig);\n", + " return;\n", + " }\n", + " fig.cell_info[0].output_area.element.on(\n", + " 'cleared',\n", + " { fig: fig },\n", + " fig._remove_fig_handler\n", + " );\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_close = function (fig, msg) {\n", + " var width = fig.canvas.width / fig.ratio;\n", + " fig.cell_info[0].output_area.element.off(\n", + " 'cleared',\n", + " fig._remove_fig_handler\n", + " );\n", + " fig.resizeObserverInstance.unobserve(fig.canvas_div);\n", + "\n", + " // Update the output cell to use the data from the current canvas.\n", + " fig.push_to_output();\n", + " var dataURL = fig.canvas.toDataURL();\n", + " // Re-enable the keyboard manager in IPython - without this line, in FF,\n", + " // the notebook keyboard shortcuts fail.\n", + " IPython.keyboard_manager.enable();\n", + " fig.parent_element.innerHTML =\n", + " '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n", + " fig.close_ws(fig, msg);\n", + "};\n", + "\n", + "mpl.figure.prototype.close_ws = function (fig, msg) {\n", + " fig.send_message('closing', msg);\n", + " // fig.ws.close()\n", + "};\n", + "\n", + "mpl.figure.prototype.push_to_output = function (_remove_interactive) {\n", + " // Turn the data on the canvas into data in the output cell.\n", + " var width = this.canvas.width / this.ratio;\n", + " var dataURL = this.canvas.toDataURL();\n", + " this.cell_info[1]['text/html'] =\n", + " '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n", + "};\n", + "\n", + "mpl.figure.prototype.updated_canvas_event = function () {\n", + " // Tell IPython that the notebook contents must change.\n", + " IPython.notebook.set_dirty(true);\n", + " this.send_message('ack', {});\n", + " var fig = this;\n", + " // Wait a second, then push the new image to the DOM so\n", + " // that it is saved nicely (might be nice to debounce this).\n", + " setTimeout(function () {\n", + " fig.push_to_output();\n", + " }, 1000);\n", + "};\n", + "\n", + "mpl.figure.prototype._init_toolbar = function () {\n", + " var fig = this;\n", + "\n", + " var toolbar = document.createElement('div');\n", + " toolbar.classList = 'btn-toolbar';\n", + " this.root.appendChild(toolbar);\n", + "\n", + " function on_click_closure(name) {\n", + " return function (_event) {\n", + " return fig.toolbar_button_onclick(name);\n", + " };\n", + " }\n", + "\n", + " function on_mouseover_closure(tooltip) {\n", + " return function (event) {\n", + " if (!event.currentTarget.disabled) {\n", + " return fig.toolbar_button_onmouseover(tooltip);\n", + " }\n", + " };\n", + " }\n", + "\n", + " fig.buttons = {};\n", + " var buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'btn-group';\n", + " var button;\n", + " for (var toolbar_ind in mpl.toolbar_items) {\n", + " var name = mpl.toolbar_items[toolbar_ind][0];\n", + " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n", + " var image = mpl.toolbar_items[toolbar_ind][2];\n", + " var method_name = mpl.toolbar_items[toolbar_ind][3];\n", + "\n", + " if (!name) {\n", + " /* Instead of a spacer, we start a new button group. */\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + " buttonGroup = document.createElement('div');\n", + " buttonGroup.classList = 'btn-group';\n", + " continue;\n", + " }\n", + "\n", + " button = fig.buttons[name] = document.createElement('button');\n", + " button.classList = 'btn btn-default';\n", + " button.href = '#';\n", + " button.title = name;\n", + " button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n", + " button.addEventListener('click', on_click_closure(method_name));\n", + " button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n", + " buttonGroup.appendChild(button);\n", + " }\n", + "\n", + " if (buttonGroup.hasChildNodes()) {\n", + " toolbar.appendChild(buttonGroup);\n", + " }\n", + "\n", + " // Add the status bar.\n", + " var status_bar = document.createElement('span');\n", + " status_bar.classList = 'mpl-message pull-right';\n", + " toolbar.appendChild(status_bar);\n", + " this.message = status_bar;\n", + "\n", + " // Add the close button to the window.\n", + " var buttongrp = document.createElement('div');\n", + " buttongrp.classList = 'btn-group inline pull-right';\n", + " button = document.createElement('button');\n", + " button.classList = 'btn btn-mini btn-primary';\n", + " button.href = '#';\n", + " button.title = 'Stop Interaction';\n", + " button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n", + " button.addEventListener('click', function (_evt) {\n", + " fig.handle_close(fig, {});\n", + " });\n", + " button.addEventListener(\n", + " 'mouseover',\n", + " on_mouseover_closure('Stop Interaction')\n", + " );\n", + " buttongrp.appendChild(button);\n", + " var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n", + " titlebar.insertBefore(buttongrp, titlebar.firstChild);\n", + "};\n", + "\n", + "mpl.figure.prototype._remove_fig_handler = function (event) {\n", + " var fig = event.data.fig;\n", + " if (event.target !== this) {\n", + " // Ignore bubbled events from children.\n", + " return;\n", + " }\n", + " fig.close_ws(fig, {});\n", + "};\n", + "\n", + "mpl.figure.prototype._root_extra_style = function (el) {\n", + " el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n", + "};\n", + "\n", + "mpl.figure.prototype._canvas_extra_style = function (el) {\n", + " // this is important to make the div 'focusable\n", + " el.setAttribute('tabindex', 0);\n", + " // reach out to IPython and tell the keyboard manager to turn it's self\n", + " // off when our div gets focus\n", + "\n", + " // location in version 3\n", + " if (IPython.notebook.keyboard_manager) {\n", + " IPython.notebook.keyboard_manager.register_events(el);\n", + " } else {\n", + " // location in version 2\n", + " IPython.keyboard_manager.register_events(el);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype._key_event_extra = function (event, _name) {\n", + " var manager = IPython.notebook.keyboard_manager;\n", + " if (!manager) {\n", + " manager = IPython.keyboard_manager;\n", + " }\n", + "\n", + " // Check for shift+enter\n", + " if (event.shiftKey && event.which === 13) {\n", + " this.canvas_div.blur();\n", + " // select the cell after this one\n", + " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n", + " IPython.notebook.select(index + 1);\n", + " }\n", + "};\n", + "\n", + "mpl.figure.prototype.handle_save = function (fig, _msg) {\n", + " fig.ondownload(fig, null);\n", + "};\n", + "\n", + "mpl.find_output_cell = function (html_output) {\n", + " // Return the cell and output element which can be found *uniquely* in the notebook.\n", + " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n", + " // IPython event is triggered only after the cells have been serialised, which for\n", + " // our purposes (turning an active figure into a static one), is too late.\n", + " var cells = IPython.notebook.get_cells();\n", + " var ncells = cells.length;\n", + " for (var i = 0; i < ncells; i++) {\n", + " var cell = cells[i];\n", + " if (cell.cell_type === 'code') {\n", + " for (var j = 0; j < cell.output_area.outputs.length; j++) {\n", + " var data = cell.output_area.outputs[j];\n", + " if (data.data) {\n", + " // IPython >= 3 moved mimebundle to data attribute of output\n", + " data = data.data;\n", + " }\n", + " if (data['text/html'] === html_output) {\n", + " return [cell, data, j];\n", + " }\n", + " }\n", + " }\n", + " }\n", + "};\n", + "\n", + "// Register the function which deals with the matplotlib target/channel.\n", + "// The kernel may be null if the page has been refreshed.\n", + "if (IPython.notebook.kernel !== null) {\n", + " IPython.notebook.kernel.comm_manager.register_target(\n", + " 'matplotlib',\n", + " mpl.mpl_figure_comm\n", + " );\n", + "}\n" + ], "text/plain": [ - "<Figure size 1440x720 with 1 Axes>" + "<IPython.core.display.Javascript object>" ] }, - "metadata": { - "needs_background": "light" + "metadata": {}, + "output_type": "display_data" + }, + { + "data": { + "text/html": [ + "<img src=\"\" width=\"1000\">" + ], + "text/plain": [ + "<IPython.core.display.HTML object>" + ] }, + "metadata": {}, "output_type": "display_data" + }, + { + "data": { + "text/plain": [ + "Text(58, 1.01, 'Korrelation = -0.809')" + ] + }, + "execution_count": 8, + "metadata": {}, + "output_type": "execute_result" } ], "source": [ - "#Colors:\n", - "cmap = cm.get_cmap('Spectral')\n", - "\n", - "fig, ax = plt.subplots(figsize=(20,10))\n", - "plot1 = df_total.plot.scatter(x=\"Impfquote\",y=\"Übersterblichkeit\",label=\"Bundesland\",title=\"Übersterblichkeit vs Impfquote\", grid=True,\n", + "fig, ax = plt.subplots(figsize=(10,7))\n", + "plot1 = df_total.plot.scatter(x=\"Impfquote\",y=\"Übersterblichkeit\",title=\"Übersterblichkeit vs Impfquote\", grid=True,\n", " ax=ax, style='o', legend=False, s=150, fontsize=18,\n", " color=range(len(df_total)), colormap='Spectral')\n", "#ax.legend(plot1,[\"1\",\"2\"],fancybox=True)\n", "#df_total.head()\n", + "laender_short={\"Schleswig-Holstein\":\"SH\",\n", + "\"Hamburg\":\"HH\",\n", + "\"Niedersachsen\":\"NI\",\n", + "\"Bremen\":\"HB\",\n", + "\"Nordrhein-Westfalen\":\"NRW\",\n", + "\"Hessen\":\"HE\",\n", + "\"Rheinland-Pfalz\":\"RP\",\n", + "\"Baden-Württemberg\":\"BW\",\n", + "\"Bayern\":\"BY\",\n", + "\"Saarland\":\"SA\",\n", + "\"Berlin\":\"BE\",\n", + "\"Brandenburg\":\"BB\",\n", + "\"Mecklenburg-Vorpommern\":\"MV\",\n", + "\"Sachsen\":\"SA\",\n", + "\"Sachsen-Anhalt\":\"S-AN\",\n", + "\"Thüringen\":\"TH\",\n", + "}\n", + "c=0\n", + "correlation = df_total.corr(method=\"pearson\")\n", + "\n", "for k, v in df_total.iterrows():\n", - " ax.annotate(k, v,\n", + " c += 1\n", + " ax.annotate(laender_short[k], v,\n", " xytext=(9,-3), textcoords='offset points',\n", - " family='sans-serif', fontsize=11, color='black')" + " family='sans-serif', fontsize=11)\n", + "ax.set(title='Übersterblichkeit vs Impfquote',\n", + " ylabel='Todesfälle KW1-42 (2021)\\nverglichen mit Durchschnitt 2016-2019',\n", + " xlabel=\"Impfquote (2 Impfungen, Stand 30.11.2021)\\nDaten von DESTATIS, sowie RKI\\n(c)CC-BY\")\n", + "ax.text(58,1.01,\"Korrelation = %0.3f\"%correlation[\"Übersterblichkeit\"][\"Impfquote\"])" + ] + }, + { + "cell_type": "code", + "execution_count": 171, + "id": "426b3884", + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "-0.808719600395588" + ] + }, + "execution_count": 171, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "\n" ] } ], diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000000000000000000000000000000000000..2f244ac814036ecd9ba9f69782e89ce6b1dca9eb --- /dev/null +++ b/LICENSE @@ -0,0 +1,395 @@ +Attribution 4.0 International + +======================================================================= + +Creative Commons Corporation ("Creative Commons") is not a law firm and +does not provide legal services or legal advice. Distribution of +Creative Commons public licenses does not create a lawyer-client or +other relationship. Creative Commons makes its licenses and related +information available on an "as-is" basis. Creative Commons gives no +warranties regarding its licenses, any material licensed under their +terms and conditions, or any related information. Creative Commons +disclaims all liability for damages resulting from their use to the +fullest extent possible. + +Using Creative Commons Public Licenses + +Creative Commons public licenses provide a standard set of terms and +conditions that creators and other rights holders may use to share +original works of authorship and other material subject to copyright +and certain other rights specified in the public license below. The +following considerations are for informational purposes only, are not +exhaustive, and do not form part of our licenses. + + Considerations for licensors: Our public licenses are + intended for use by those authorized to give the public + permission to use material in ways otherwise restricted by + copyright and certain other rights. Our licenses are + irrevocable. Licensors should read and understand the terms + and conditions of the license they choose before applying it. + Licensors should also secure all rights necessary before + applying our licenses so that the public can reuse the + material as expected. Licensors should clearly mark any + material not subject to the license. This includes other CC- + licensed material, or material used under an exception or + limitation to copyright. More considerations for licensors: + wiki.creativecommons.org/Considerations_for_licensors + + Considerations for the public: By using one of our public + licenses, a licensor grants the public permission to use the + licensed material under specified terms and conditions. If + the licensor's permission is not necessary for any reason--for + example, because of any applicable exception or limitation to + copyright--then that use is not regulated by the license. Our + licenses grant only permissions under copyright and certain + other rights that a licensor has authority to grant. Use of + the licensed material may still be restricted for other + reasons, including because others have copyright or other + rights in the material. A licensor may make special requests, + such as asking that all changes be marked or described. + Although not required by our licenses, you are encouraged to + respect those requests where reasonable. More_considerations + for the public: + wiki.creativecommons.org/Considerations_for_licensees + +======================================================================= + +Creative Commons Attribution 4.0 International Public License + +By exercising the Licensed Rights (defined below), You accept and agree +to be bound by the terms and conditions of this Creative Commons +Attribution 4.0 International Public License ("Public License"). To the +extent this Public License may be interpreted as a contract, You are +granted the Licensed Rights in consideration of Your acceptance of +these terms and conditions, and the Licensor grants You such rights in +consideration of benefits the Licensor receives from making the +Licensed Material available under these terms and conditions. + + +Section 1 -- Definitions. + + a. Adapted Material means material subject to Copyright and Similar + Rights that is derived from or based upon the Licensed Material + and in which the Licensed Material is translated, altered, + arranged, transformed, or otherwise modified in a manner requiring + permission under the Copyright and Similar Rights held by the + Licensor. For purposes of this Public License, where the Licensed + Material is a musical work, performance, or sound recording, + Adapted Material is always produced where the Licensed Material is + synched in timed relation with a moving image. + + b. Adapter's License means the license You apply to Your Copyright + and Similar Rights in Your contributions to Adapted Material in + accordance with the terms and conditions of this Public License. + + c. Copyright and Similar Rights means copyright and/or similar rights + closely related to copyright including, without limitation, + performance, broadcast, sound recording, and Sui Generis Database + Rights, without regard to how the rights are labeled or + categorized. For purposes of this Public License, the rights + specified in Section 2(b)(1)-(2) are not Copyright and Similar + Rights. + + d. Effective Technological Measures means those measures that, in the + absence of proper authority, may not be circumvented under laws + fulfilling obligations under Article 11 of the WIPO Copyright + Treaty adopted on December 20, 1996, and/or similar international + agreements. + + e. Exceptions and Limitations means fair use, fair dealing, and/or + any other exception or limitation to Copyright and Similar Rights + that applies to Your use of the Licensed Material. + + f. Licensed Material means the artistic or literary work, database, + or other material to which the Licensor applied this Public + License. + + g. Licensed Rights means the rights granted to You subject to the + terms and conditions of this Public License, which are limited to + all Copyright and Similar Rights that apply to Your use of the + Licensed Material and that the Licensor has authority to license. + + h. Licensor means the individual(s) or entity(ies) granting rights + under this Public License. + + i. Share means to provide material to the public by any means or + process that requires permission under the Licensed Rights, such + as reproduction, public display, public performance, distribution, + dissemination, communication, or importation, and to make material + available to the public including in ways that members of the + public may access the material from a place and at a time + individually chosen by them. + + j. Sui Generis Database Rights means rights other than copyright + resulting from Directive 96/9/EC of the European Parliament and of + the Council of 11 March 1996 on the legal protection of databases, + as amended and/or succeeded, as well as other essentially + equivalent rights anywhere in the world. + + k. You means the individual or entity exercising the Licensed Rights + under this Public License. Your has a corresponding meaning. + + +Section 2 -- Scope. + + a. License grant. + + 1. Subject to the terms and conditions of this Public License, + the Licensor hereby grants You a worldwide, royalty-free, + non-sublicensable, non-exclusive, irrevocable license to + exercise the Licensed Rights in the Licensed Material to: + + a. reproduce and Share the Licensed Material, in whole or + in part; and + + b. produce, reproduce, and Share Adapted Material. + + 2. Exceptions and Limitations. For the avoidance of doubt, where + Exceptions and Limitations apply to Your use, this Public + License does not apply, and You do not need to comply with + its terms and conditions. + + 3. Term. The term of this Public License is specified in Section + 6(a). + + 4. Media and formats; technical modifications allowed. The + Licensor authorizes You to exercise the Licensed Rights in + all media and formats whether now known or hereafter created, + and to make technical modifications necessary to do so. The + Licensor waives and/or agrees not to assert any right or + authority to forbid You from making technical modifications + necessary to exercise the Licensed Rights, including + technical modifications necessary to circumvent Effective + Technological Measures. For purposes of this Public License, + simply making modifications authorized by this Section 2(a) + (4) never produces Adapted Material. + + 5. Downstream recipients. + + a. Offer from the Licensor -- Licensed Material. Every + recipient of the Licensed Material automatically + receives an offer from the Licensor to exercise the + Licensed Rights under the terms and conditions of this + Public License. + + b. No downstream restrictions. You may not offer or impose + any additional or different terms or conditions on, or + apply any Effective Technological Measures to, the + Licensed Material if doing so restricts exercise of the + Licensed Rights by any recipient of the Licensed + Material. + + 6. No endorsement. Nothing in this Public License constitutes or + may be construed as permission to assert or imply that You + are, or that Your use of the Licensed Material is, connected + with, or sponsored, endorsed, or granted official status by, + the Licensor or others designated to receive attribution as + provided in Section 3(a)(1)(A)(i). + + b. Other rights. + + 1. Moral rights, such as the right of integrity, are not + licensed under this Public License, nor are publicity, + privacy, and/or other similar personality rights; however, to + the extent possible, the Licensor waives and/or agrees not to + assert any such rights held by the Licensor to the limited + extent necessary to allow You to exercise the Licensed + Rights, but not otherwise. + + 2. Patent and trademark rights are not licensed under this + Public License. + + 3. To the extent possible, the Licensor waives any right to + collect royalties from You for the exercise of the Licensed + Rights, whether directly or through a collecting society + under any voluntary or waivable statutory or compulsory + licensing scheme. In all other cases the Licensor expressly + reserves any right to collect such royalties. + + +Section 3 -- License Conditions. + +Your exercise of the Licensed Rights is expressly made subject to the +following conditions. + + a. Attribution. + + 1. If You Share the Licensed Material (including in modified + form), You must: + + a. retain the following if it is supplied by the Licensor + with the Licensed Material: + + i. identification of the creator(s) of the Licensed + Material and any others designated to receive + attribution, in any reasonable manner requested by + the Licensor (including by pseudonym if + designated); + + ii. a copyright notice; + + iii. a notice that refers to this Public License; + + iv. a notice that refers to the disclaimer of + warranties; + + v. a URI or hyperlink to the Licensed Material to the + extent reasonably practicable; + + b. indicate if You modified the Licensed Material and + retain an indication of any previous modifications; and + + c. indicate the Licensed Material is licensed under this + Public License, and include the text of, or the URI or + hyperlink to, this Public License. + + 2. You may satisfy the conditions in Section 3(a)(1) in any + reasonable manner based on the medium, means, and context in + which You Share the Licensed Material. For example, it may be + reasonable to satisfy the conditions by providing a URI or + hyperlink to a resource that includes the required + information. + + 3. If requested by the Licensor, You must remove any of the + information required by Section 3(a)(1)(A) to the extent + reasonably practicable. + + 4. If You Share Adapted Material You produce, the Adapter's + License You apply must not prevent recipients of the Adapted + Material from complying with this Public License. + + +Section 4 -- Sui Generis Database Rights. + +Where the Licensed Rights include Sui Generis Database Rights that +apply to Your use of the Licensed Material: + + a. for the avoidance of doubt, Section 2(a)(1) grants You the right + to extract, reuse, reproduce, and Share all or a substantial + portion of the contents of the database; + + b. if You include all or a substantial portion of the database + contents in a database in which You have Sui Generis Database + Rights, then the database in which You have Sui Generis Database + Rights (but not its individual contents) is Adapted Material; and + + c. You must comply with the conditions in Section 3(a) if You Share + all or a substantial portion of the contents of the database. + +For the avoidance of doubt, this Section 4 supplements and does not +replace Your obligations under this Public License where the Licensed +Rights include other Copyright and Similar Rights. + + +Section 5 -- Disclaimer of Warranties and Limitation of Liability. + + a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE + EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS + AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF + ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS, + IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION, + WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR + PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS, + ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT + KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT + ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU. + + b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE + TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION, + NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT, + INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES, + COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR + USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN + ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR + DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR + IN PART, THIS LIMITATION MAY NOT APPLY TO YOU. + + c. The disclaimer of warranties and limitation of liability provided + above shall be interpreted in a manner that, to the extent + possible, most closely approximates an absolute disclaimer and + waiver of all liability. + + +Section 6 -- Term and Termination. + + a. This Public License applies for the term of the Copyright and + Similar Rights licensed here. However, if You fail to comply with + this Public License, then Your rights under this Public License + terminate automatically. + + b. Where Your right to use the Licensed Material has terminated under + Section 6(a), it reinstates: + + 1. automatically as of the date the violation is cured, provided + it is cured within 30 days of Your discovery of the + violation; or + + 2. upon express reinstatement by the Licensor. + + For the avoidance of doubt, this Section 6(b) does not affect any + right the Licensor may have to seek remedies for Your violations + of this Public License. + + c. For the avoidance of doubt, the Licensor may also offer the + Licensed Material under separate terms or conditions or stop + distributing the Licensed Material at any time; however, doing so + will not terminate this Public License. + + d. Sections 1, 5, 6, 7, and 8 survive termination of this Public + License. + + +Section 7 -- Other Terms and Conditions. + + a. The Licensor shall not be bound by any additional or different + terms or conditions communicated by You unless expressly agreed. + + b. Any arrangements, understandings, or agreements regarding the + Licensed Material not stated herein are separate from and + independent of the terms and conditions of this Public License. + + +Section 8 -- Interpretation. + + a. For the avoidance of doubt, this Public License does not, and + shall not be interpreted to, reduce, limit, restrict, or impose + conditions on any use of the Licensed Material that could lawfully + be made without permission under this Public License. + + b. To the extent possible, if any provision of this Public License is + deemed unenforceable, it shall be automatically reformed to the + minimum extent necessary to make it enforceable. If the provision + cannot be reformed, it shall be severed from this Public License + without affecting the enforceability of the remaining terms and + conditions. + + c. No term or condition of this Public License will be waived and no + failure to comply consented to unless expressly agreed to by the + Licensor. + + d. Nothing in this Public License constitutes or may be interpreted + as a limitation upon, or waiver of, any privileges and immunities + that apply to the Licensor or You, including from the legal + processes of any jurisdiction or authority. + + +======================================================================= + +Creative Commons is not a party to its public +licenses. Notwithstanding, Creative Commons may elect to apply one of +its public licenses to material it publishes and in those instances +will be considered the “Licensor.” The text of the Creative Commons +public licenses is dedicated to the public domain under the CC0 Public +Domain Dedication. Except for the limited purpose of indicating that +material is shared under a Creative Commons public license or as +otherwise permitted by the Creative Commons policies published at +creativecommons.org/policies, Creative Commons does not authorize the +use of the trademark "Creative Commons" or any other trademark or logo +of Creative Commons without its prior written consent including, +without limitation, in connection with any unauthorized modifications +to any of its public licenses or any other arrangements, +understandings, or agreements concerning use of licensed material. For +the avoidance of doubt, this paragraph does not form part of the +public licenses. + +Creative Commons may be contacted at creativecommons.org. diff --git a/README b/README index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..68cd2e6ed7196ca4595d8008011181d9563168ca 100644 --- a/README +++ b/README @@ -0,0 +1,18 @@ +Datenquellen +============ + +Daten zur �bersterblichkeit +Datasource https://www.destatis.de/DE/Themen/Gesellschaft-Umwelt/Bevoelkerung/Sterbefaelle-Lebenserwartung/Tabellen/sonderauswertung-sterbefaelle.html?nn=209016 +Stand 22.11.21 + +Daten zu den Impfungen von +https://github.com/robert-koch-institut/COVID-19-Impfungen_in_Deutschland +erh�ltlich unter der Creative Commons Namensnennung 4.0 International Lizenz +Stand 30.11.21 + +Lizenz +====== +Die Scripte, sowie die Ergebnisse werden unter der +Creative Commons Attribution 4.0 International (CC BY 4.0) +https://creativecommons.org/licenses/by/4.0/ +ver�ffentlicht \ No newline at end of file