diff --git a/content/GA_2_3/Analysis.ipynb b/content/GA_2_3/Analysis.ipynb index 67cfdaa4b4056ed694d3d1ec2f7c52e35e7b68de..147f69abc0b46d92e204d006ad6381a59f6bab3d 100644 --- a/content/GA_2_3/Analysis.ipynb +++ b/content/GA_2_3/Analysis.ipynb @@ -86,7 +86,7 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 5, "metadata": {}, "outputs": [], "source": [ @@ -123,9 +123,20 @@ }, { "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], + "execution_count": 4, + "metadata": {}, + "outputs": [ + { + "data": { + "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmcAAAHLCAYAAACNhD8ZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACgg0lEQVR4nO2dd3hU1fb3vzOTSe89gRB67wFjEBAlJBBFscPl/ih64bVgw4pX6YK9o1ixUq7eizWUiCAgETAQkF6kpyekt0nmvH9szxQySaacOW3W53nyzGTmlH2+s886a6+99t4ajuM4EARBEARBELJAK3UBCIIgCIIgCDPknBEEQRAEQcgIcs4IgiAIgiBkBDlnBEEQBEEQMoKcM4IgCIIgCBlBzhlBEARBEISMIOeMIAiCIAhCRpBzRhAEQRAEISPIOSMIgiAIgpAR5JwRBEEQBEHICHLOCIIgCIIgZAQ5Z63w6aefQqPR4OzZs1IXxW7sLfPChQuh0Wjceg6xjyX3sjhyfP73KSkpcUtZPAGj0YilS5eiW7du0Ov16Natm9RF8gjstS2u3G+O7CvWeexBLfd1UlISbrnlFqmLoQg4jkNjY6NT+3qkc/bnn3/i9ttvR2JiInx9fdGhQweMGzcOb7/9ttRFIzyIXbt2YeHChSgvL3freY4ePQovLy9oNBqUlZUJcszq6mosWLAA48ePR3h4ODQaDT799FO79r3pppvg7++PqqqqVreZOnUqvL29UVpa6lT53n33XcyfPx+33norPvnkE7z//vtOHactXNEAMD/8//jjD5vfjxkzBv379xeotOpFrPuIYM7GsWPH0LdvX0GP29DQgKeeegrx8fHw8/NDcnIysrKyBN//5MmTmDx5Mjp27Ah/f3/07t0bixcvRm1trdV2M2bMgEajafXv0qVL7Zbpyy+/RGRkJIKCgjBz5kzHnTTOw/jtt984b29vrnv37tySJUu4Dz/8kJs/fz6XlpbGdevWzbRdU1MTV1dXxxmNRglL6xj2lnnBggWcsz/9qlWrOADcmTNnnNrfEjlpLOR12cLWtb788ss2z8n/PsXFxYKc++abb+Y6d+7MAeB+/fVXQY555swZDgDXqVMnbsyYMRwAbtWqVXbtu3btWg4A99lnn9n8vqamhgsICOAmTpzodPmGDh3KpaWlOb2/PbiiAceZ69zevXttfn/ttddy/fr1E6i04mCvbXHl3r9y39buI1fPI7RNEPq+loK//vqLA8B9+eWXgh538uTJnJeXF/f4449z77//PpeSksJ5eXlxO3bsEGz/8+fPc6GhoVxiYiK3fPly7v333+dmzJjBAeBuuukmq+Pt2rWL++KLL6z+Pv/8c87f35/r27dvu+U5c+YMFxgYyL3yyivc119/zfXv35978cUXHdLEyzFXTvk8//zzCAkJwd69exEaGmr1XVFRkem9TqeDTqcTuXSuobQyK628riDVte7atQs//fQTsrKycN111+HQoUMYPXq0y8eNi4tDfn4+YmNj8ccff2D48OF273vTTTchKCgIq1evxrRp01p8/91336GmpgZTp051qmz19fU4cOAAFi1a5NT+9uKKBp6OK/eDI/t6ko0RgyNHjgCAoJGzPXv2YO3atXj55Zfx+OOPAwCmTZuG/v3748knn8SuXbsE2f+LL75AeXk5du7ciX79+gEAZs+eDaPRiM8//xyXL19GWFgYACAlJQUpKSlW59m5cydqa2vtskt//PEHUlNT8dhjjwEA9Ho9PvroIzz55JN26+Jx3ZqnT59Gv379WjhmABAdHW16byvfgM8ZOHXqFGbMmIHQ0FCEhIRg5syZVmHRGTNmoHPnzi2Obysfo6qqCo888gg6d+4MHx8fREdHY9y4cdi3b59pm/3792PChAkIDg5GYGAgxo4di99//73F8W2VeefOnRg+fDh8fX3RrVu3Vrt3zp07h/vvvx+9evWCn58fIiIicMcddzidb2HPddkq77Zt2zBs2DCr8trSzd7fQsjrOnjwIDQaDb7//nvTZzk5OdBoNBg6dKjVthMmTEBycnKr17pw4UI88cQTAIAuXbqYwuWW5SovL2/z2uzhqaeewowZMzBmzBiEhITg0KFDDl61bXx8fBAbG+vUvn5+frj11luxZcsWqwYRz+rVqxEUFISbbrrJ4WPfc8898PPzQ3NzM5599lloNJoWRlYoXNHAUc6ePdtmN0tb2HsP2HtP8dhrW2xh636w99yW+7Z3H115HqHtnGXZjx07hjvvvBPBwcGIiIjAww8/jPr6+hbb23Nf21tOe+wsAFy6dAl33303YmJi4OPjg379+uGTTz6x+xrXr19vlWs2atQoTJ06FRUVFXYfozW++eYb6HQ6zJ492/SZr68v7rnnHmRnZ+PC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", + "text/plain": [ + "<Figure size 640x480 with 1 Axes>" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], "source": [ "T_meas = 5\n", "f_s = 100 #sampling rate [Hz]\n", @@ -138,8 +149,8 @@ "x = A * np.sin(2 * np.pi * f_c * t_vec + phi)\n", "\n", "plt.plot(t_vec, x, color='b', label='signal')\n", - "plt.xlabel('$t \\: [s]$')\n", - "plt.ylabel('$x(t) \\: [V]$')\n", + "plt.xlabel(r'$t \\: [s]$')\n", + "plt.ylabel(r'$x(t) \\: [V]$')\n", "plt.legend(loc='upper right')\n", "plt.title(fr'Sinusoidal signal with $A$={A} V, $f_c$={f_c} Hz and initial phase $\\phi$={phi:.3f} °')\n", "plt.grid()" @@ -863,7 +874,7 @@ ], "metadata": { "kernelspec": { - "display_name": "Python 3 (ipykernel)", + "display_name": "mude-base", "language": "python", "name": "python3" }, @@ -877,7 +888,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.9.13" + "version": "3.12.4" }, "widgets": { "application/vnd.jupyter.widget-state+json": { diff --git a/src/students/Week_2_3/WS_2_3_solution.html b/src/students/Week_2_3/WS_2_3_solution.html new file mode 100644 index 0000000000000000000000000000000000000000..3ea1323e8a9b75a3df2b5f4c1c06f288193c3965 --- /dev/null +++ b/src/students/Week_2_3/WS_2_3_solution.html @@ -0,0 +1,8087 @@ +<!DOCTYPE html> + +<html lang="en"> +<head><meta charset="utf-8"/> +<meta content="width=device-width, initial-scale=1.0" name="viewport"/> +<title>WS_2_3_solution</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script><script> +(function() { + function addWidgetsRenderer() { + var mimeElement = document.querySelector('script[type="application/vnd.jupyter.widget-view+json"]'); + var scriptElement = document.createElement('script'); + + var widgetRendererSrc = 'https://unpkg.com/@jupyter-widgets/html-manager@*/dist/embed-amd.js'; + + var widgetState; + + // Fallback for older version: + try { + widgetState = mimeElement && JSON.parse(mimeElement.innerHTML); + + if (widgetState && (widgetState.version_major < 2 || !widgetState.version_major)) { + + var widgetRendererSrc = 'https://unpkg.com/@jupyter-js-widgets@*/dist/embed.js'; + + } + } catch(e) {} + + scriptElement.src = widgetRendererSrc; + document.body.appendChild(scriptElement); + } + + document.addEventListener('DOMContentLoaded', addWidgetsRenderer); +}()); +</script> +<style type="text/css"> + pre { line-height: 125%; } +td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +.highlight .hll { background-color: var(--jp-cell-editor-active-background) } +.highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) } +.highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */ +.highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */ +.highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */ +.highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */ +.highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */ +.highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */ +.highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */ +.highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */ +.highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */ +.highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */ +.highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */ +.highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */ +.highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */ +.highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */ +.highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */ +.highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */ +.highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */ +.highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */ +.highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */ +.highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */ +.highlight .pm { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation.Marker */ +.highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */ +.highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */ +.highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */ +.highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */ +.highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */ +.highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */ +.highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */ +.highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */ +.highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */ +.highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */ +.highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */ +.highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */ +.highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */ +.highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */ +.highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */ +.highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */ +.highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */ +.highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */ +.highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */ +.highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */ + </style> +<style type="text/css"> +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/* + * Mozilla scrollbar styling + */ + +/* use standard opaque scrollbars for most nodes */ +[data-jp-theme-scrollbars='true'] { + scrollbar-color: rgb(var(--jp-scrollbar-thumb-color)) + var(--jp-scrollbar-background-color); +} + +/* for code nodes, use a transparent style of scrollbar. These selectors + * will match lower in the tree, and so will override the above */ +[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar, +[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar { + scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; +} + +/* tiny scrollbar */ + +.jp-scrollbar-tiny { + scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent; + scrollbar-width: thin; +} + +/* tiny scrollbar */ + +.jp-scrollbar-tiny::-webkit-scrollbar, +.jp-scrollbar-tiny::-webkit-scrollbar-corner { + background-color: transparent; + height: 4px; + width: 4px; +} + +.jp-scrollbar-tiny::-webkit-scrollbar-thumb { + background: rgba(var(--jp-scrollbar-thumb-color), 0.5); +} + +.jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal { + border-left: 0 solid transparent; + border-right: 0 solid transparent; +} + +.jp-scrollbar-tiny::-webkit-scrollbar-track:vertical { + border-top: 0 solid transparent; + border-bottom: 0 solid transparent; +} + +/* + * Lumino + */ + +.lm-ScrollBar[data-orientation='horizontal'] { + min-height: 16px; + max-height: 16px; + min-width: 45px; + border-top: 1px solid #a0a0a0; +} + +.lm-ScrollBar[data-orientation='vertical'] { + min-width: 16px; + max-width: 16px; + min-height: 45px; + border-left: 1px solid #a0a0a0; +} + +.lm-ScrollBar-button { + background-color: #f0f0f0; + background-position: center center; + min-height: 15px; + max-height: 15px; + min-width: 15px; + max-width: 15px; +} + +.lm-ScrollBar-button:hover { + background-color: #dadada; +} + +.lm-ScrollBar-button.lm-mod-active { + background-color: #cdcdcd; +} + +.lm-ScrollBar-track { + background: #f0f0f0; +} + +.lm-ScrollBar-thumb { + background: #cdcdcd; +} + +.lm-ScrollBar-thumb:hover { + background: #bababa; +} + +.lm-ScrollBar-thumb.lm-mod-active { + background: #a0a0a0; +} + +.lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb { + height: 100%; + min-width: 15px; + border-left: 1px solid #a0a0a0; + border-right: 1px solid #a0a0a0; +} + +.lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb { + width: 100%; + min-height: 15px; + border-top: 1px solid #a0a0a0; + border-bottom: 1px solid #a0a0a0; +} + +.lm-ScrollBar[data-orientation='horizontal'] + .lm-ScrollBar-button[data-action='decrement'] { + background-image: var(--jp-icon-caret-left); + background-size: 17px; +} + +.lm-ScrollBar[data-orientation='horizontal'] + .lm-ScrollBar-button[data-action='increment'] { + background-image: var(--jp-icon-caret-right); + background-size: 17px; +} + +.lm-ScrollBar[data-orientation='vertical'] + .lm-ScrollBar-button[data-action='decrement'] { + background-image: var(--jp-icon-caret-up); + background-size: 17px; +} + +.lm-ScrollBar[data-orientation='vertical'] + .lm-ScrollBar-button[data-action='increment'] { + background-image: var(--jp-icon-caret-down); + background-size: 17px; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-Widget { + box-sizing: border-box; + position: relative; + overflow: hidden; +} + +.lm-Widget.lm-mod-hidden { + display: none !important; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +.lm-AccordionPanel[data-orientation='horizontal'] > .lm-AccordionPanel-title { + /* Title is rotated for horizontal accordion panel using CSS */ + display: block; + transform-origin: top left; + transform: rotate(-90deg) translate(-100%); +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-CommandPalette { + display: flex; + flex-direction: column; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.lm-CommandPalette-search { + flex: 0 0 auto; +} + +.lm-CommandPalette-content { + flex: 1 1 auto; + margin: 0; + padding: 0; + min-height: 0; + overflow: auto; + list-style-type: none; +} + +.lm-CommandPalette-header { + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} + +.lm-CommandPalette-item { + display: flex; + flex-direction: row; +} + +.lm-CommandPalette-itemIcon { + flex: 0 0 auto; +} + +.lm-CommandPalette-itemContent { + flex: 1 1 auto; + overflow: hidden; +} + +.lm-CommandPalette-itemShortcut { + flex: 0 0 auto; +} + +.lm-CommandPalette-itemLabel { + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} + +.lm-close-icon { + border: 1px solid transparent; + background-color: transparent; + position: absolute; + z-index: 1; + right: 3%; + top: 0; + bottom: 0; + margin: auto; + padding: 7px 0; + display: none; + vertical-align: middle; + outline: 0; + cursor: pointer; +} +.lm-close-icon:after { + content: 'X'; + display: block; + width: 15px; + height: 15px; + text-align: center; + color: #000; + font-weight: normal; + font-size: 12px; + cursor: pointer; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-DockPanel { + z-index: 0; +} + +.lm-DockPanel-widget { + z-index: 0; +} + +.lm-DockPanel-tabBar { + z-index: 1; +} + +.lm-DockPanel-handle { + z-index: 2; +} + +.lm-DockPanel-handle.lm-mod-hidden { + display: none !important; +} + +.lm-DockPanel-handle:after { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + content: ''; +} + +.lm-DockPanel-handle[data-orientation='horizontal'] { + cursor: ew-resize; +} + +.lm-DockPanel-handle[data-orientation='vertical'] { + cursor: ns-resize; +} + +.lm-DockPanel-handle[data-orientation='horizontal']:after { + left: 50%; + min-width: 8px; + transform: translateX(-50%); +} + +.lm-DockPanel-handle[data-orientation='vertical']:after { + top: 50%; + min-height: 8px; + transform: translateY(-50%); +} + +.lm-DockPanel-overlay { + z-index: 3; + box-sizing: border-box; + pointer-events: none; +} + +.lm-DockPanel-overlay.lm-mod-hidden { + display: none !important; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-Menu { + z-index: 10000; + position: absolute; + white-space: nowrap; + overflow-x: hidden; + overflow-y: auto; + outline: none; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.lm-Menu-content { + margin: 0; + padding: 0; + display: table; + list-style-type: none; +} + +.lm-Menu-item { + display: table-row; +} + +.lm-Menu-item.lm-mod-hidden, +.lm-Menu-item.lm-mod-collapsed { + display: none !important; +} + +.lm-Menu-itemIcon, +.lm-Menu-itemSubmenuIcon { + display: table-cell; + text-align: center; +} + +.lm-Menu-itemLabel { + display: table-cell; + text-align: left; +} + +.lm-Menu-itemShortcut { + display: table-cell; + text-align: right; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-MenuBar { + outline: none; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.lm-MenuBar-content { + margin: 0; + padding: 0; + display: flex; + flex-direction: row; + list-style-type: none; +} + +.lm-MenuBar-item { + box-sizing: border-box; +} + +.lm-MenuBar-itemIcon, +.lm-MenuBar-itemLabel { + display: inline-block; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-ScrollBar { + display: flex; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.lm-ScrollBar[data-orientation='horizontal'] { + flex-direction: row; +} + +.lm-ScrollBar[data-orientation='vertical'] { + flex-direction: column; +} + +.lm-ScrollBar-button { + box-sizing: border-box; + flex: 0 0 auto; +} + +.lm-ScrollBar-track { + box-sizing: border-box; + position: relative; + overflow: hidden; + flex: 1 1 auto; +} + +.lm-ScrollBar-thumb { + box-sizing: border-box; + position: absolute; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-SplitPanel-child { + z-index: 0; +} + +.lm-SplitPanel-handle { + z-index: 1; +} + +.lm-SplitPanel-handle.lm-mod-hidden { + display: none !important; +} + +.lm-SplitPanel-handle:after { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + content: ''; +} + +.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle { + cursor: ew-resize; +} + +.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle { + cursor: ns-resize; +} + +.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after { + left: 50%; + min-width: 8px; + transform: translateX(-50%); +} + +.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after { + top: 50%; + min-height: 8px; + transform: translateY(-50%); +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-TabBar { + display: flex; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.lm-TabBar[data-orientation='horizontal'] { + flex-direction: row; + align-items: flex-end; +} + +.lm-TabBar[data-orientation='vertical'] { + flex-direction: column; + align-items: flex-end; +} + +.lm-TabBar-content { + margin: 0; + padding: 0; + display: flex; + flex: 1 1 auto; + list-style-type: none; +} + +.lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content { + flex-direction: row; +} + +.lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content { + flex-direction: column; +} + +.lm-TabBar-tab { + display: flex; + flex-direction: row; + box-sizing: border-box; + overflow: hidden; + touch-action: none; /* Disable native Drag/Drop */ +} + +.lm-TabBar-tabIcon, +.lm-TabBar-tabCloseIcon { + flex: 0 0 auto; +} + +.lm-TabBar-tabLabel { + flex: 1 1 auto; + overflow: hidden; + white-space: nowrap; +} + +.lm-TabBar-tabInput { + user-select: all; + width: 100%; + box-sizing: border-box; +} + +.lm-TabBar-tab.lm-mod-hidden { + display: none !important; +} + +.lm-TabBar-addButton.lm-mod-hidden { + display: none !important; +} + +.lm-TabBar.lm-mod-dragging .lm-TabBar-tab { + position: relative; +} + +.lm-TabBar.lm-mod-dragging[data-orientation='horizontal'] .lm-TabBar-tab { + left: 0; + transition: left 150ms ease; +} + +.lm-TabBar.lm-mod-dragging[data-orientation='vertical'] .lm-TabBar-tab { + top: 0; + transition: top 150ms ease; +} + +.lm-TabBar.lm-mod-dragging .lm-TabBar-tab.lm-mod-dragging { + transition: none; +} + +.lm-TabBar-tabLabel .lm-TabBar-tabInput { + user-select: all; + width: 100%; + box-sizing: border-box; + background: inherit; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-TabPanel-tabBar { + z-index: 1; +} + +.lm-TabPanel-stackedPanel { + z-index: 0; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-Collapse { + display: flex; + flex-direction: column; + align-items: stretch; +} + +.jp-Collapse-header { + padding: 1px 12px; + background-color: var(--jp-layout-color1); + border-bottom: solid var(--jp-border-width) var(--jp-border-color2); + color: var(--jp-ui-font-color1); + cursor: pointer; + display: flex; + align-items: center; + font-size: var(--jp-ui-font-size0); + font-weight: 600; + text-transform: uppercase; + user-select: none; +} + +.jp-Collapser-icon { + height: 16px; +} + +.jp-Collapse-header-collapsed .jp-Collapser-icon { + transform: rotate(-90deg); + margin: auto 0; +} + +.jp-Collapser-title { + line-height: 25px; +} + +.jp-Collapse-contents { + padding: 0 12px; + background-color: var(--jp-layout-color1); + color: var(--jp-ui-font-color1); + overflow: auto; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */ + +/** + * (DEPRECATED) Support for consuming icons as CSS background images + */ + +/* Icons urls */ + +:root { + --jp-icon-add-above: url(); + --jp-icon-add-below: url(); + --jp-icon-add: url(); + --jp-icon-bell: url(); + --jp-icon-bug-dot: url(); + --jp-icon-bug: url(); + --jp-icon-build: url(); + --jp-icon-caret-down-empty-thin: url(); + --jp-icon-caret-down-empty: url(); + --jp-icon-caret-down: url(); + --jp-icon-caret-left: url(); + --jp-icon-caret-right: url(); + --jp-icon-caret-up-empty-thin: url(); + --jp-icon-caret-up: url(); + --jp-icon-case-sensitive: url(); + --jp-icon-check: url(); + --jp-icon-circle-empty: url(); + --jp-icon-circle: url(); + --jp-icon-clear: url(); + --jp-icon-close: url(); + --jp-icon-code-check: url(); + --jp-icon-code: url(); + --jp-icon-collapse-all: url(); + --jp-icon-console: url(); + --jp-icon-copy: url(); + --jp-icon-copyright: url(); + --jp-icon-cut: url(); + --jp-icon-delete: url(); + --jp-icon-download: url(); + --jp-icon-duplicate: url(); + --jp-icon-edit: url(); + --jp-icon-ellipses: url(); + --jp-icon-error: url(); + --jp-icon-expand-all: url(); + --jp-icon-extension: url(); + --jp-icon-fast-forward: url(); + --jp-icon-file-upload: url(); + --jp-icon-file: url(); + --jp-icon-filter-dot: url(); + --jp-icon-filter-list: url(); + --jp-icon-filter: url(); + --jp-icon-folder-favorite: url(); + --jp-icon-folder: url(); + --jp-icon-home: url(); + --jp-icon-html5: url(); + --jp-icon-image: url(); + --jp-icon-info: url(); + --jp-icon-inspector: url(); + --jp-icon-json: url(); + --jp-icon-julia: url(); + --jp-icon-jupyter-favicon: url(); + --jp-icon-jupyter: url(); + --jp-icon-jupyterlab-wordmark: url(); + --jp-icon-kernel: url(); + --jp-icon-keyboard: url(); + --jp-icon-launch: url(); + --jp-icon-launcher: url(); + --jp-icon-line-form: url(); + --jp-icon-link: url(); + --jp-icon-list: url(); + --jp-icon-markdown: url(); + --jp-icon-move-down: url(); + --jp-icon-move-up: url(); + --jp-icon-new-folder: url(); + --jp-icon-not-trusted: url(); + --jp-icon-notebook: url(); + --jp-icon-numbering: url(); + --jp-icon-offline-bolt: url(); + --jp-icon-palette: url(); + --jp-icon-paste: url(); + --jp-icon-pdf: url(); + --jp-icon-python: url(); + --jp-icon-r-kernel: url(); + --jp-icon-react: url(); + --jp-icon-redo: url(); + --jp-icon-refresh: url(); + --jp-icon-regex: url(); + --jp-icon-run: url(); + --jp-icon-running: url(); + --jp-icon-save: url(); + --jp-icon-search: url(); + --jp-icon-settings: url(); + --jp-icon-share: url(); + --jp-icon-spreadsheet: url(); + --jp-icon-stop: url(); + --jp-icon-tab: url(); + --jp-icon-table-rows: url(); + --jp-icon-tag: url(); + --jp-icon-terminal: url(); + --jp-icon-text-editor: url(); + --jp-icon-toc: url(); + --jp-icon-tree-view: url(); + --jp-icon-trusted: url(); + --jp-icon-undo: url(); + --jp-icon-user: url(); + --jp-icon-users: url(); + --jp-icon-vega: url(); + --jp-icon-word: url(); + --jp-icon-yaml: url(); +} + +/* Icon CSS class declarations */ + +.jp-AddAboveIcon { + background-image: var(--jp-icon-add-above); +} + +.jp-AddBelowIcon { + background-image: var(--jp-icon-add-below); +} + +.jp-AddIcon { + background-image: var(--jp-icon-add); +} + +.jp-BellIcon { + background-image: var(--jp-icon-bell); +} + +.jp-BugDotIcon { + background-image: var(--jp-icon-bug-dot); +} + +.jp-BugIcon { + background-image: var(--jp-icon-bug); +} + +.jp-BuildIcon { + background-image: var(--jp-icon-build); +} + +.jp-CaretDownEmptyIcon { + background-image: var(--jp-icon-caret-down-empty); +} + +.jp-CaretDownEmptyThinIcon { + background-image: var(--jp-icon-caret-down-empty-thin); +} + +.jp-CaretDownIcon { + background-image: var(--jp-icon-caret-down); +} + +.jp-CaretLeftIcon { + background-image: var(--jp-icon-caret-left); +} + +.jp-CaretRightIcon { + background-image: var(--jp-icon-caret-right); +} + +.jp-CaretUpEmptyThinIcon { + background-image: var(--jp-icon-caret-up-empty-thin); +} + +.jp-CaretUpIcon { + background-image: var(--jp-icon-caret-up); +} + +.jp-CaseSensitiveIcon { + background-image: var(--jp-icon-case-sensitive); +} + +.jp-CheckIcon { + background-image: var(--jp-icon-check); +} + +.jp-CircleEmptyIcon { + background-image: var(--jp-icon-circle-empty); +} + +.jp-CircleIcon { + background-image: var(--jp-icon-circle); +} + +.jp-ClearIcon { + background-image: var(--jp-icon-clear); +} + +.jp-CloseIcon { + background-image: var(--jp-icon-close); +} + +.jp-CodeCheckIcon { + background-image: var(--jp-icon-code-check); +} + +.jp-CodeIcon { + background-image: var(--jp-icon-code); +} + +.jp-CollapseAllIcon { + background-image: var(--jp-icon-collapse-all); +} + +.jp-ConsoleIcon { + background-image: var(--jp-icon-console); +} + +.jp-CopyIcon { + background-image: var(--jp-icon-copy); +} + +.jp-CopyrightIcon { + background-image: var(--jp-icon-copyright); +} + +.jp-CutIcon { + background-image: var(--jp-icon-cut); +} + +.jp-DeleteIcon { + background-image: var(--jp-icon-delete); +} + +.jp-DownloadIcon { + background-image: var(--jp-icon-download); +} + +.jp-DuplicateIcon { + background-image: var(--jp-icon-duplicate); +} + +.jp-EditIcon { + background-image: var(--jp-icon-edit); +} + +.jp-EllipsesIcon { + background-image: var(--jp-icon-ellipses); +} + +.jp-ErrorIcon { + background-image: var(--jp-icon-error); +} + +.jp-ExpandAllIcon { + background-image: var(--jp-icon-expand-all); +} + +.jp-ExtensionIcon { + background-image: var(--jp-icon-extension); +} + +.jp-FastForwardIcon { + background-image: var(--jp-icon-fast-forward); +} + +.jp-FileIcon { + background-image: var(--jp-icon-file); +} + +.jp-FileUploadIcon { + background-image: var(--jp-icon-file-upload); +} + +.jp-FilterDotIcon { + background-image: var(--jp-icon-filter-dot); +} + +.jp-FilterIcon { + background-image: var(--jp-icon-filter); +} + +.jp-FilterListIcon { + background-image: var(--jp-icon-filter-list); +} + +.jp-FolderFavoriteIcon { + background-image: var(--jp-icon-folder-favorite); +} + +.jp-FolderIcon { + background-image: var(--jp-icon-folder); +} + +.jp-HomeIcon { + background-image: var(--jp-icon-home); +} + +.jp-Html5Icon { + background-image: var(--jp-icon-html5); +} + +.jp-ImageIcon { + background-image: var(--jp-icon-image); +} + +.jp-InfoIcon { + background-image: var(--jp-icon-info); +} + +.jp-InspectorIcon { + background-image: var(--jp-icon-inspector); +} + +.jp-JsonIcon { + background-image: var(--jp-icon-json); +} + +.jp-JuliaIcon { + background-image: var(--jp-icon-julia); +} + +.jp-JupyterFaviconIcon { + background-image: var(--jp-icon-jupyter-favicon); +} + +.jp-JupyterIcon { + background-image: var(--jp-icon-jupyter); +} + +.jp-JupyterlabWordmarkIcon { + background-image: var(--jp-icon-jupyterlab-wordmark); +} + +.jp-KernelIcon { + background-image: var(--jp-icon-kernel); +} + +.jp-KeyboardIcon { + background-image: var(--jp-icon-keyboard); +} + +.jp-LaunchIcon { + background-image: var(--jp-icon-launch); +} + +.jp-LauncherIcon { + background-image: var(--jp-icon-launcher); +} + +.jp-LineFormIcon { + background-image: var(--jp-icon-line-form); +} + +.jp-LinkIcon { + background-image: var(--jp-icon-link); +} + +.jp-ListIcon { + background-image: var(--jp-icon-list); +} + +.jp-MarkdownIcon { + background-image: var(--jp-icon-markdown); +} + +.jp-MoveDownIcon { + background-image: var(--jp-icon-move-down); +} + +.jp-MoveUpIcon { + background-image: var(--jp-icon-move-up); +} + +.jp-NewFolderIcon { + background-image: var(--jp-icon-new-folder); +} + +.jp-NotTrustedIcon { + background-image: var(--jp-icon-not-trusted); +} + +.jp-NotebookIcon { + background-image: var(--jp-icon-notebook); +} + +.jp-NumberingIcon { + background-image: var(--jp-icon-numbering); +} + +.jp-OfflineBoltIcon { + background-image: var(--jp-icon-offline-bolt); +} + +.jp-PaletteIcon { + background-image: var(--jp-icon-palette); +} + +.jp-PasteIcon { + background-image: var(--jp-icon-paste); +} + +.jp-PdfIcon { + background-image: var(--jp-icon-pdf); +} + +.jp-PythonIcon { + background-image: var(--jp-icon-python); +} + +.jp-RKernelIcon { + background-image: var(--jp-icon-r-kernel); +} + +.jp-ReactIcon { + background-image: var(--jp-icon-react); +} + +.jp-RedoIcon { + background-image: var(--jp-icon-redo); +} + +.jp-RefreshIcon { + background-image: var(--jp-icon-refresh); +} + +.jp-RegexIcon { + background-image: var(--jp-icon-regex); +} + +.jp-RunIcon { + background-image: var(--jp-icon-run); +} + +.jp-RunningIcon { + background-image: var(--jp-icon-running); +} + +.jp-SaveIcon { + background-image: var(--jp-icon-save); +} + +.jp-SearchIcon { + background-image: var(--jp-icon-search); +} + +.jp-SettingsIcon { + background-image: var(--jp-icon-settings); +} + +.jp-ShareIcon { + background-image: var(--jp-icon-share); +} + +.jp-SpreadsheetIcon { + background-image: var(--jp-icon-spreadsheet); +} + +.jp-StopIcon { + background-image: var(--jp-icon-stop); +} + +.jp-TabIcon { + background-image: var(--jp-icon-tab); +} + +.jp-TableRowsIcon { + background-image: var(--jp-icon-table-rows); +} + +.jp-TagIcon { + background-image: var(--jp-icon-tag); +} + +.jp-TerminalIcon { + background-image: var(--jp-icon-terminal); +} + +.jp-TextEditorIcon { + background-image: var(--jp-icon-text-editor); +} + +.jp-TocIcon { + background-image: var(--jp-icon-toc); +} + +.jp-TreeViewIcon { + background-image: var(--jp-icon-tree-view); +} + +.jp-TrustedIcon { + background-image: var(--jp-icon-trusted); +} + +.jp-UndoIcon { + background-image: var(--jp-icon-undo); +} + +.jp-UserIcon { + background-image: var(--jp-icon-user); +} + +.jp-UsersIcon { + background-image: var(--jp-icon-users); +} + +.jp-VegaIcon { + background-image: var(--jp-icon-vega); +} + +.jp-WordIcon { + background-image: var(--jp-icon-word); +} + +.jp-YamlIcon { + background-image: var(--jp-icon-yaml); +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/** + * (DEPRECATED) Support for consuming icons as CSS background images + */ + +.jp-Icon, +.jp-MaterialIcon { + background-position: center; + background-repeat: no-repeat; + background-size: 16px; + min-width: 16px; + min-height: 16px; +} + +.jp-Icon-cover { + background-position: center; + background-repeat: no-repeat; + background-size: cover; +} + +/** + * (DEPRECATED) Support for specific CSS icon sizes + */ + +.jp-Icon-16 { + background-size: 16px; + min-width: 16px; + min-height: 16px; +} + +.jp-Icon-18 { + background-size: 18px; + min-width: 18px; + min-height: 18px; +} + +.jp-Icon-20 { + background-size: 20px; + min-width: 20px; + min-height: 20px; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.lm-TabBar .lm-TabBar-addButton { + align-items: center; + display: flex; + padding: 4px; + padding-bottom: 5px; + margin-right: 1px; + background-color: var(--jp-layout-color2); +} + +.lm-TabBar .lm-TabBar-addButton:hover { + background-color: var(--jp-layout-color1); +} + +.lm-DockPanel-tabBar .lm-TabBar-tab { + width: var(--jp-private-horizontal-tab-width); +} + +.lm-DockPanel-tabBar .lm-TabBar-content { + flex: unset; +} + +.lm-DockPanel-tabBar[data-orientation='horizontal'] { + flex: 1 1 auto; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/** + * Support for icons as inline SVG HTMLElements + */ + +/* recolor the primary elements of an icon */ +.jp-icon0[fill] { + fill: var(--jp-inverse-layout-color0); +} + +.jp-icon1[fill] { + fill: var(--jp-inverse-layout-color1); +} + +.jp-icon2[fill] { + fill: var(--jp-inverse-layout-color2); +} + +.jp-icon3[fill] { + fill: var(--jp-inverse-layout-color3); +} + +.jp-icon4[fill] { + fill: var(--jp-inverse-layout-color4); +} + +.jp-icon0[stroke] { + stroke: var(--jp-inverse-layout-color0); +} + +.jp-icon1[stroke] { + stroke: var(--jp-inverse-layout-color1); +} + +.jp-icon2[stroke] { + stroke: var(--jp-inverse-layout-color2); +} + +.jp-icon3[stroke] { + stroke: var(--jp-inverse-layout-color3); +} + +.jp-icon4[stroke] { + stroke: var(--jp-inverse-layout-color4); +} + +/* recolor the accent elements of an icon */ +.jp-icon-accent0[fill] { + fill: var(--jp-layout-color0); +} + +.jp-icon-accent1[fill] { + fill: var(--jp-layout-color1); +} + +.jp-icon-accent2[fill] { + fill: var(--jp-layout-color2); +} + +.jp-icon-accent3[fill] { + fill: var(--jp-layout-color3); +} + +.jp-icon-accent4[fill] { + fill: var(--jp-layout-color4); +} + +.jp-icon-accent0[stroke] { + stroke: var(--jp-layout-color0); +} + +.jp-icon-accent1[stroke] { + stroke: var(--jp-layout-color1); +} + +.jp-icon-accent2[stroke] { + stroke: var(--jp-layout-color2); +} + +.jp-icon-accent3[stroke] { + stroke: var(--jp-layout-color3); +} + +.jp-icon-accent4[stroke] { + stroke: var(--jp-layout-color4); +} + +/* set the color of an icon to transparent */ +.jp-icon-none[fill] { + fill: none; +} + +.jp-icon-none[stroke] { + stroke: none; +} + +/* brand icon colors. Same for light and dark */ +.jp-icon-brand0[fill] { + fill: var(--jp-brand-color0); +} + +.jp-icon-brand1[fill] { + fill: var(--jp-brand-color1); +} + +.jp-icon-brand2[fill] { + fill: var(--jp-brand-color2); +} + +.jp-icon-brand3[fill] { + fill: var(--jp-brand-color3); +} + +.jp-icon-brand4[fill] { + fill: var(--jp-brand-color4); +} + +.jp-icon-brand0[stroke] { + stroke: var(--jp-brand-color0); +} + +.jp-icon-brand1[stroke] { + stroke: var(--jp-brand-color1); +} + +.jp-icon-brand2[stroke] { + stroke: var(--jp-brand-color2); +} + +.jp-icon-brand3[stroke] { + stroke: var(--jp-brand-color3); +} + +.jp-icon-brand4[stroke] { + stroke: var(--jp-brand-color4); +} + +/* warn icon colors. Same for light and dark */ +.jp-icon-warn0[fill] { + fill: var(--jp-warn-color0); +} + +.jp-icon-warn1[fill] { + fill: var(--jp-warn-color1); +} + +.jp-icon-warn2[fill] { + fill: var(--jp-warn-color2); +} + +.jp-icon-warn3[fill] { + fill: var(--jp-warn-color3); +} + +.jp-icon-warn0[stroke] { + stroke: var(--jp-warn-color0); +} + +.jp-icon-warn1[stroke] { + stroke: var(--jp-warn-color1); +} + +.jp-icon-warn2[stroke] { + stroke: var(--jp-warn-color2); +} + +.jp-icon-warn3[stroke] { + stroke: var(--jp-warn-color3); +} + +/* icon colors that contrast well with each other and most backgrounds */ +.jp-icon-contrast0[fill] { + fill: var(--jp-icon-contrast-color0); +} + +.jp-icon-contrast1[fill] { + fill: var(--jp-icon-contrast-color1); +} + +.jp-icon-contrast2[fill] { + fill: var(--jp-icon-contrast-color2); +} + +.jp-icon-contrast3[fill] { + fill: var(--jp-icon-contrast-color3); +} + +.jp-icon-contrast0[stroke] { + stroke: var(--jp-icon-contrast-color0); +} + +.jp-icon-contrast1[stroke] { + stroke: var(--jp-icon-contrast-color1); +} + +.jp-icon-contrast2[stroke] { + stroke: var(--jp-icon-contrast-color2); +} + +.jp-icon-contrast3[stroke] { + stroke: var(--jp-icon-contrast-color3); +} + +.jp-icon-dot[fill] { + fill: var(--jp-warn-color0); +} + +.jp-jupyter-icon-color[fill] { + fill: var(--jp-jupyter-icon-color, var(--jp-warn-color0)); +} + +.jp-notebook-icon-color[fill] { + fill: var(--jp-notebook-icon-color, var(--jp-warn-color0)); +} + +.jp-json-icon-color[fill] { + fill: var(--jp-json-icon-color, var(--jp-warn-color1)); +} + +.jp-console-icon-color[fill] { + fill: var(--jp-console-icon-color, white); +} + +.jp-console-icon-background-color[fill] { + fill: var(--jp-console-icon-background-color, var(--jp-brand-color1)); +} + +.jp-terminal-icon-color[fill] { + fill: var(--jp-terminal-icon-color, var(--jp-layout-color2)); +} + +.jp-terminal-icon-background-color[fill] { + fill: var( + --jp-terminal-icon-background-color, + var(--jp-inverse-layout-color2) + ); +} + +.jp-text-editor-icon-color[fill] { + fill: var(--jp-text-editor-icon-color, var(--jp-inverse-layout-color3)); +} + +.jp-inspector-icon-color[fill] { + fill: var(--jp-inspector-icon-color, var(--jp-inverse-layout-color3)); +} + +/* CSS for icons in selected filebrowser listing items */ +.jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] { + fill: #fff; +} + +.jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] { + fill: var(--jp-brand-color1); +} + +/* stylelint-disable selector-max-class, selector-max-compound-selectors */ + +/** +* TODO: come up with non css-hack solution for showing the busy icon on top +* of the close icon +* CSS for complex behavior of close icon of tabs in the main area tabbar +*/ +.lm-DockPanel-tabBar + .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty + > .lm-TabBar-tabCloseIcon + > :not(:hover) + > .jp-icon3[fill] { + fill: none; +} + +.lm-DockPanel-tabBar + .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty + > .lm-TabBar-tabCloseIcon + > :not(:hover) + > .jp-icon-busy[fill] { + fill: var(--jp-inverse-layout-color3); +} + +/* stylelint-enable selector-max-class, selector-max-compound-selectors */ + +/* CSS for icons in status bar */ +#jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] { + fill: #fff; +} + +#jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] { + fill: var(--jp-brand-color1); +} + +/* special handling for splash icon CSS. While the theme CSS reloads during + splash, the splash icon can loose theming. To prevent that, we set a + default for its color variable */ +:root { + --jp-warn-color0: var(--md-orange-700); +} + +/* not sure what to do with this one, used in filebrowser listing */ +.jp-DragIcon { + margin-right: 4px; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/** + * Support for alt colors for icons as inline SVG HTMLElements + */ + +/* alt recolor the primary elements of an icon */ +.jp-icon-alt .jp-icon0[fill] { + fill: var(--jp-layout-color0); +} + +.jp-icon-alt .jp-icon1[fill] { + fill: var(--jp-layout-color1); +} + +.jp-icon-alt .jp-icon2[fill] { + fill: var(--jp-layout-color2); +} + +.jp-icon-alt .jp-icon3[fill] { + fill: var(--jp-layout-color3); +} + +.jp-icon-alt .jp-icon4[fill] { + fill: var(--jp-layout-color4); +} + +.jp-icon-alt .jp-icon0[stroke] { + stroke: var(--jp-layout-color0); +} + +.jp-icon-alt .jp-icon1[stroke] { + stroke: var(--jp-layout-color1); +} + +.jp-icon-alt .jp-icon2[stroke] { + stroke: var(--jp-layout-color2); +} + +.jp-icon-alt .jp-icon3[stroke] { + stroke: var(--jp-layout-color3); +} + +.jp-icon-alt .jp-icon4[stroke] { + stroke: var(--jp-layout-color4); +} + +/* alt recolor the accent elements of an icon */ +.jp-icon-alt .jp-icon-accent0[fill] { + fill: var(--jp-inverse-layout-color0); +} + +.jp-icon-alt .jp-icon-accent1[fill] { + fill: var(--jp-inverse-layout-color1); +} + +.jp-icon-alt .jp-icon-accent2[fill] { + fill: var(--jp-inverse-layout-color2); +} + +.jp-icon-alt .jp-icon-accent3[fill] { + fill: var(--jp-inverse-layout-color3); +} + +.jp-icon-alt .jp-icon-accent4[fill] { + fill: var(--jp-inverse-layout-color4); +} + +.jp-icon-alt .jp-icon-accent0[stroke] { + stroke: var(--jp-inverse-layout-color0); +} + +.jp-icon-alt .jp-icon-accent1[stroke] { + stroke: var(--jp-inverse-layout-color1); +} + +.jp-icon-alt .jp-icon-accent2[stroke] { + stroke: var(--jp-inverse-layout-color2); +} + +.jp-icon-alt .jp-icon-accent3[stroke] { + stroke: var(--jp-inverse-layout-color3); +} + +.jp-icon-alt .jp-icon-accent4[stroke] { + stroke: var(--jp-inverse-layout-color4); +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-icon-hoverShow:not(:hover) .jp-icon-hoverShow-content { + display: none !important; +} + +/** + * Support for hover colors for icons as inline SVG HTMLElements + */ + +/** + * regular colors + */ + +/* recolor the primary elements of an icon */ +.jp-icon-hover :hover .jp-icon0-hover[fill] { + fill: var(--jp-inverse-layout-color0); +} + +.jp-icon-hover :hover .jp-icon1-hover[fill] { + fill: var(--jp-inverse-layout-color1); +} + +.jp-icon-hover :hover .jp-icon2-hover[fill] { + fill: var(--jp-inverse-layout-color2); +} + +.jp-icon-hover :hover .jp-icon3-hover[fill] { + fill: var(--jp-inverse-layout-color3); +} + +.jp-icon-hover :hover .jp-icon4-hover[fill] { + fill: var(--jp-inverse-layout-color4); +} + +.jp-icon-hover :hover .jp-icon0-hover[stroke] { + stroke: var(--jp-inverse-layout-color0); +} + +.jp-icon-hover :hover .jp-icon1-hover[stroke] { + stroke: var(--jp-inverse-layout-color1); +} + +.jp-icon-hover :hover .jp-icon2-hover[stroke] { + stroke: var(--jp-inverse-layout-color2); +} + +.jp-icon-hover :hover .jp-icon3-hover[stroke] { + stroke: var(--jp-inverse-layout-color3); +} + +.jp-icon-hover :hover .jp-icon4-hover[stroke] { + stroke: var(--jp-inverse-layout-color4); +} + +/* recolor the accent elements of an icon */ +.jp-icon-hover :hover .jp-icon-accent0-hover[fill] { + fill: var(--jp-layout-color0); +} + +.jp-icon-hover :hover .jp-icon-accent1-hover[fill] { + fill: var(--jp-layout-color1); +} + +.jp-icon-hover :hover .jp-icon-accent2-hover[fill] { + fill: var(--jp-layout-color2); +} + +.jp-icon-hover :hover .jp-icon-accent3-hover[fill] { + fill: var(--jp-layout-color3); +} + +.jp-icon-hover :hover .jp-icon-accent4-hover[fill] { + fill: var(--jp-layout-color4); +} + +.jp-icon-hover :hover .jp-icon-accent0-hover[stroke] { + stroke: var(--jp-layout-color0); +} + +.jp-icon-hover :hover .jp-icon-accent1-hover[stroke] { + stroke: var(--jp-layout-color1); +} + +.jp-icon-hover :hover .jp-icon-accent2-hover[stroke] { + stroke: var(--jp-layout-color2); +} + +.jp-icon-hover :hover .jp-icon-accent3-hover[stroke] { + stroke: var(--jp-layout-color3); +} + +.jp-icon-hover :hover .jp-icon-accent4-hover[stroke] { + stroke: var(--jp-layout-color4); +} + +/* set the color of an icon to transparent */ +.jp-icon-hover :hover .jp-icon-none-hover[fill] { + fill: none; +} + +.jp-icon-hover :hover .jp-icon-none-hover[stroke] { + stroke: none; +} + +/** + * inverse colors + */ + +/* inverse recolor the primary elements of an icon */ +.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] { + fill: var(--jp-layout-color0); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] { + fill: var(--jp-layout-color1); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] { + fill: var(--jp-layout-color2); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] { + fill: var(--jp-layout-color3); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] { + fill: var(--jp-layout-color4); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] { + stroke: var(--jp-layout-color0); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] { + stroke: var(--jp-layout-color1); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] { + stroke: var(--jp-layout-color2); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] { + stroke: var(--jp-layout-color3); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] { + stroke: var(--jp-layout-color4); +} + +/* inverse recolor the accent elements of an icon */ +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] { + fill: var(--jp-inverse-layout-color0); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] { + fill: var(--jp-inverse-layout-color1); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] { + fill: var(--jp-inverse-layout-color2); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] { + fill: var(--jp-inverse-layout-color3); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] { + fill: var(--jp-inverse-layout-color4); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] { + stroke: var(--jp-inverse-layout-color0); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] { + stroke: var(--jp-inverse-layout-color1); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] { + stroke: var(--jp-inverse-layout-color2); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] { + stroke: var(--jp-inverse-layout-color3); +} + +.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] { + stroke: var(--jp-inverse-layout-color4); +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-IFrame { + width: 100%; + height: 100%; +} + +.jp-IFrame > iframe { + border: none; +} + +/* +When drag events occur, `lm-mod-override-cursor` is added to the body. +Because iframes steal all cursor events, the following two rules are necessary +to suppress pointer events while resize drags are occurring. There may be a +better solution to this problem. +*/ +body.lm-mod-override-cursor .jp-IFrame { + position: relative; +} + +body.lm-mod-override-cursor .jp-IFrame::before { + content: ''; + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; + background: transparent; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2014-2016, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-HoverBox { + position: fixed; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-FormGroup-content fieldset { + border: none; + padding: 0; + min-width: 0; + width: 100%; +} + +/* stylelint-disable selector-max-type */ + +.jp-FormGroup-content fieldset .jp-inputFieldWrapper input, +.jp-FormGroup-content fieldset .jp-inputFieldWrapper select, +.jp-FormGroup-content fieldset .jp-inputFieldWrapper textarea { + font-size: var(--jp-content-font-size2); + border-color: var(--jp-input-border-color); + border-style: solid; + border-radius: var(--jp-border-radius); + border-width: 1px; + padding: 6px 8px; + background: none; + color: var(--jp-ui-font-color0); + height: inherit; +} + +.jp-FormGroup-content fieldset input[type='checkbox'] { + position: relative; + top: 2px; + margin-left: 0; +} + +.jp-FormGroup-content button.jp-mod-styled { + cursor: pointer; +} + +.jp-FormGroup-content .checkbox label { + cursor: pointer; + font-size: var(--jp-content-font-size1); +} + +.jp-FormGroup-content .jp-root > fieldset > legend { + display: none; +} + +.jp-FormGroup-content .jp-root > fieldset > p { + display: none; +} + +/** copy of `input.jp-mod-styled:focus` style */ +.jp-FormGroup-content fieldset input:focus, +.jp-FormGroup-content fieldset select:focus { + -moz-outline-radius: unset; + outline: var(--jp-border-width) solid var(--md-blue-500); + outline-offset: -1px; + box-shadow: inset 0 0 4px var(--md-blue-300); +} + +.jp-FormGroup-content fieldset input:hover:not(:focus), +.jp-FormGroup-content fieldset select:hover:not(:focus) { + background-color: var(--jp-border-color2); +} + +/* stylelint-enable selector-max-type */ + +.jp-FormGroup-content .checkbox .field-description { + /* Disable default description field for checkbox: + because other widgets do not have description fields, + we add descriptions to each widget on the field level. + */ + display: none; +} + +.jp-FormGroup-content #root__description { + display: none; +} + +.jp-FormGroup-content .jp-modifiedIndicator { + width: 5px; + background-color: var(--jp-brand-color2); + margin-top: 0; + margin-left: calc(var(--jp-private-settingeditor-modifier-indent) * -1); + flex-shrink: 0; +} + +.jp-FormGroup-content .jp-modifiedIndicator.jp-errorIndicator { + background-color: var(--jp-error-color0); + margin-right: 0.5em; +} + +/* RJSF ARRAY style */ + +.jp-arrayFieldWrapper legend { + font-size: var(--jp-content-font-size2); + color: var(--jp-ui-font-color0); + flex-basis: 100%; + padding: 4px 0; + font-weight: var(--jp-content-heading-font-weight); + border-bottom: 1px solid var(--jp-border-color2); +} + +.jp-arrayFieldWrapper .field-description { + padding: 4px 0; + white-space: pre-wrap; +} + +.jp-arrayFieldWrapper .array-item { + width: 100%; + border: 1px solid var(--jp-border-color2); + border-radius: 4px; + margin: 4px; +} + +.jp-ArrayOperations { + display: flex; + margin-left: 8px; +} + +.jp-ArrayOperationsButton { + margin: 2px; +} + +.jp-ArrayOperationsButton .jp-icon3[fill] { + fill: var(--jp-ui-font-color0); +} + +button.jp-ArrayOperationsButton.jp-mod-styled:disabled { + cursor: not-allowed; + opacity: 0.5; +} + +/* RJSF form validation error */ + +.jp-FormGroup-content .validationErrors { + color: var(--jp-error-color0); +} + +/* Hide panel level error as duplicated the field level error */ +.jp-FormGroup-content .panel.errors { + display: none; +} + +/* RJSF normal content (settings-editor) */ + +.jp-FormGroup-contentNormal { + display: flex; + align-items: center; + flex-wrap: wrap; +} + +.jp-FormGroup-contentNormal .jp-FormGroup-contentItem { + margin-left: 7px; + color: var(--jp-ui-font-color0); +} + +.jp-FormGroup-contentNormal .jp-FormGroup-description { + flex-basis: 100%; + padding: 4px 7px; +} + +.jp-FormGroup-contentNormal .jp-FormGroup-default { + flex-basis: 100%; + padding: 4px 7px; +} + +.jp-FormGroup-contentNormal .jp-FormGroup-fieldLabel { + font-size: var(--jp-content-font-size1); + font-weight: normal; + min-width: 120px; +} + +.jp-FormGroup-contentNormal fieldset:not(:first-child) { + margin-left: 7px; +} + +.jp-FormGroup-contentNormal .field-array-of-string .array-item { + /* Display `jp-ArrayOperations` buttons side-by-side with content except + for small screens where flex-wrap will place them one below the other. + */ + display: flex; + align-items: center; + flex-wrap: wrap; +} + +.jp-FormGroup-contentNormal .jp-objectFieldWrapper .form-group { + padding: 2px 8px 2px var(--jp-private-settingeditor-modifier-indent); + margin-top: 2px; +} + +/* RJSF compact content (metadata-form) */ + +.jp-FormGroup-content.jp-FormGroup-contentCompact { + width: 100%; +} + +.jp-FormGroup-contentCompact .form-group { + display: flex; + padding: 0.5em 0.2em 0.5em 0; +} + +.jp-FormGroup-contentCompact + .jp-FormGroup-compactTitle + .jp-FormGroup-description { + font-size: var(--jp-ui-font-size1); + color: var(--jp-ui-font-color2); +} + +.jp-FormGroup-contentCompact .jp-FormGroup-fieldLabel { + padding-bottom: 0.3em; +} + +.jp-FormGroup-contentCompact .jp-inputFieldWrapper .form-control { + width: 100%; + box-sizing: border-box; +} + +.jp-FormGroup-contentCompact .jp-arrayFieldWrapper .jp-FormGroup-compactTitle { + padding-bottom: 7px; +} + +.jp-FormGroup-contentCompact + .jp-objectFieldWrapper + .jp-objectFieldWrapper + .form-group { + padding: 2px 8px 2px var(--jp-private-settingeditor-modifier-indent); + margin-top: 2px; +} + +.jp-FormGroup-contentCompact ul.error-detail { + margin-block-start: 0.5em; + margin-block-end: 0.5em; + padding-inline-start: 1em; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +.jp-SidePanel { + display: flex; + flex-direction: column; + min-width: var(--jp-sidebar-min-width); + overflow-y: auto; + color: var(--jp-ui-font-color1); + background: var(--jp-layout-color1); + font-size: var(--jp-ui-font-size1); +} + +.jp-SidePanel-header { + flex: 0 0 auto; + display: flex; + border-bottom: var(--jp-border-width) solid var(--jp-border-color2); + font-size: var(--jp-ui-font-size0); + font-weight: 600; + letter-spacing: 1px; + margin: 0; + padding: 2px; + text-transform: uppercase; +} + +.jp-SidePanel-toolbar { + flex: 0 0 auto; +} + +.jp-SidePanel-content { + flex: 1 1 auto; +} + +.jp-SidePanel-toolbar, +.jp-AccordionPanel-toolbar { + height: var(--jp-private-toolbar-height); +} + +.jp-SidePanel-toolbar.jp-Toolbar-micro { + display: none; +} + +.lm-AccordionPanel .jp-AccordionPanel-title { + box-sizing: border-box; + line-height: 25px; + margin: 0; + display: flex; + align-items: center; + background: var(--jp-layout-color1); + color: var(--jp-ui-font-color1); + border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color); + box-shadow: var(--jp-toolbar-box-shadow); + font-size: var(--jp-ui-font-size0); +} + +.jp-AccordionPanel-title { + cursor: pointer; + user-select: none; + -moz-user-select: none; + -webkit-user-select: none; + text-transform: uppercase; +} + +.lm-AccordionPanel[data-orientation='horizontal'] > .jp-AccordionPanel-title { + /* Title is rotated for horizontal accordion panel using CSS */ + display: block; + transform-origin: top left; + transform: rotate(-90deg) translate(-100%); +} + +.jp-AccordionPanel-title .lm-AccordionPanel-titleLabel { + user-select: none; + text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; +} + +.jp-AccordionPanel-title .lm-AccordionPanel-titleCollapser { + transform: rotate(-90deg); + margin: auto 0; + height: 16px; +} + +.jp-AccordionPanel-title.lm-mod-expanded .lm-AccordionPanel-titleCollapser { + transform: rotate(0deg); +} + +.lm-AccordionPanel .jp-AccordionPanel-toolbar { + background: none; + box-shadow: none; + border: none; + margin-left: auto; +} + +.lm-AccordionPanel .lm-SplitPanel-handle:hover { + background: var(--jp-layout-color3); +} + +.jp-text-truncated { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2017, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-Spinner { + position: absolute; + display: flex; + justify-content: center; + align-items: center; + z-index: 10; + left: 0; + top: 0; + width: 100%; + height: 100%; + background: var(--jp-layout-color0); + outline: none; +} + +.jp-SpinnerContent { + font-size: 10px; + margin: 50px auto; + text-indent: -9999em; + width: 3em; + height: 3em; + border-radius: 50%; + background: var(--jp-brand-color3); + background: linear-gradient( + to right, + #f37626 10%, + rgba(255, 255, 255, 0) 42% + ); + position: relative; + animation: load3 1s infinite linear, fadeIn 1s; +} + +.jp-SpinnerContent::before { + width: 50%; + height: 50%; + background: #f37626; + border-radius: 100% 0 0; + position: absolute; + top: 0; + left: 0; + content: ''; +} + +.jp-SpinnerContent::after { + background: var(--jp-layout-color0); + width: 75%; + height: 75%; + border-radius: 50%; + content: ''; + margin: auto; + position: absolute; + top: 0; + left: 0; + bottom: 0; + right: 0; +} + +@keyframes fadeIn { + 0% { + opacity: 0; + } + + 100% { + opacity: 1; + } +} + +@keyframes load3 { + 0% { + transform: rotate(0deg); + } + + 100% { + transform: rotate(360deg); + } +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2014-2017, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +button.jp-mod-styled { + font-size: var(--jp-ui-font-size1); + color: var(--jp-ui-font-color0); + border: none; + box-sizing: border-box; + text-align: center; + line-height: 32px; + height: 32px; + padding: 0 12px; + letter-spacing: 0.8px; + outline: none; + appearance: none; + -webkit-appearance: none; + -moz-appearance: none; +} + +input.jp-mod-styled { + background: var(--jp-input-background); + height: 28px; + box-sizing: border-box; + border: var(--jp-border-width) solid var(--jp-border-color1); + padding-left: 7px; + padding-right: 7px; + font-size: var(--jp-ui-font-size2); + color: var(--jp-ui-font-color0); + outline: none; + appearance: none; + -webkit-appearance: none; + -moz-appearance: none; +} + +input[type='checkbox'].jp-mod-styled { + appearance: checkbox; + -webkit-appearance: checkbox; + -moz-appearance: checkbox; + height: auto; +} + +input.jp-mod-styled:focus { + border: var(--jp-border-width) solid var(--md-blue-500); + box-shadow: inset 0 0 4px var(--md-blue-300); +} + +.jp-select-wrapper { + display: flex; + position: relative; + flex-direction: column; + padding: 1px; + background-color: var(--jp-layout-color1); + box-sizing: border-box; + margin-bottom: 12px; +} + +.jp-select-wrapper:not(.multiple) { + height: 28px; +} + +.jp-select-wrapper.jp-mod-focused select.jp-mod-styled { + border: var(--jp-border-width) solid var(--jp-input-active-border-color); + box-shadow: var(--jp-input-box-shadow); + background-color: var(--jp-input-active-background); +} + +select.jp-mod-styled:hover { + cursor: pointer; + color: var(--jp-ui-font-color0); + background-color: var(--jp-input-hover-background); + box-shadow: inset 0 0 1px rgba(0, 0, 0, 0.5); +} + +select.jp-mod-styled { + flex: 1 1 auto; + width: 100%; + font-size: var(--jp-ui-font-size2); + background: var(--jp-input-background); + color: var(--jp-ui-font-color0); + padding: 0 25px 0 8px; + border: var(--jp-border-width) solid var(--jp-input-border-color); + border-radius: 0; + outline: none; + appearance: none; + -webkit-appearance: none; + -moz-appearance: none; +} + +select.jp-mod-styled:not([multiple]) { + height: 32px; +} + +select.jp-mod-styled[multiple] { + max-height: 200px; + overflow-y: auto; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-switch { + display: flex; + align-items: center; + padding-left: 4px; + padding-right: 4px; + font-size: var(--jp-ui-font-size1); + background-color: transparent; + color: var(--jp-ui-font-color1); + border: none; + height: 20px; +} + +.jp-switch:hover { + background-color: var(--jp-layout-color2); +} + +.jp-switch-label { + margin-right: 5px; + font-family: var(--jp-ui-font-family); +} + +.jp-switch-track { + cursor: pointer; + background-color: var(--jp-switch-color, var(--jp-border-color1)); + -webkit-transition: 0.4s; + transition: 0.4s; + border-radius: 34px; + height: 16px; + width: 35px; + position: relative; +} + +.jp-switch-track::before { + content: ''; + position: absolute; + height: 10px; + width: 10px; + margin: 3px; + left: 0; + background-color: var(--jp-ui-inverse-font-color1); + -webkit-transition: 0.4s; + transition: 0.4s; + border-radius: 50%; +} + +.jp-switch[aria-checked='true'] .jp-switch-track { + background-color: var(--jp-switch-true-position-color, var(--jp-warn-color0)); +} + +.jp-switch[aria-checked='true'] .jp-switch-track::before { + /* track width (35) - margins (3 + 3) - thumb width (10) */ + left: 19px; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2014-2016, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +:root { + --jp-private-toolbar-height: calc( + 28px + var(--jp-border-width) + ); /* leave 28px for content */ +} + +.jp-Toolbar { + color: var(--jp-ui-font-color1); + flex: 0 0 auto; + display: flex; + flex-direction: row; + border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color); + box-shadow: var(--jp-toolbar-box-shadow); + background: var(--jp-toolbar-background); + min-height: var(--jp-toolbar-micro-height); + padding: 2px; + z-index: 8; + overflow-x: hidden; +} + +/* Toolbar items */ + +.jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer { + flex-grow: 1; + flex-shrink: 1; +} + +.jp-Toolbar-item.jp-Toolbar-kernelStatus { + display: inline-block; + width: 32px; + background-repeat: no-repeat; + background-position: center; + background-size: 16px; +} + +.jp-Toolbar > .jp-Toolbar-item { + flex: 0 0 auto; + display: flex; + padding-left: 1px; + padding-right: 1px; + font-size: var(--jp-ui-font-size1); + line-height: var(--jp-private-toolbar-height); + height: 100%; +} + +/* Toolbar buttons */ + +/* This is the div we use to wrap the react component into a Widget */ +div.jp-ToolbarButton { + color: transparent; + border: none; + box-sizing: border-box; + outline: none; + appearance: none; + -webkit-appearance: none; + -moz-appearance: none; + padding: 0; + margin: 0; +} + +button.jp-ToolbarButtonComponent { + background: var(--jp-layout-color1); + border: none; + box-sizing: border-box; + outline: none; + appearance: none; + -webkit-appearance: none; + -moz-appearance: none; + padding: 0 6px; + margin: 0; + height: 24px; + border-radius: var(--jp-border-radius); + display: flex; + align-items: center; + text-align: center; + font-size: 14px; + min-width: unset; + min-height: unset; +} + +button.jp-ToolbarButtonComponent:disabled { + opacity: 0.4; +} + +button.jp-ToolbarButtonComponent > span { + padding: 0; + flex: 0 0 auto; +} + +button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label { + font-size: var(--jp-ui-font-size1); + line-height: 100%; + padding-left: 2px; + color: var(--jp-ui-font-color1); + font-family: var(--jp-ui-font-family); +} + +#jp-main-dock-panel[data-mode='single-document'] + .jp-MainAreaWidget + > .jp-Toolbar.jp-Toolbar-micro { + padding: 0; + min-height: 0; +} + +#jp-main-dock-panel[data-mode='single-document'] + .jp-MainAreaWidget + > .jp-Toolbar { + border: none; + box-shadow: none; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +.jp-WindowedPanel-outer { + position: relative; + overflow-y: auto; +} + +.jp-WindowedPanel-inner { + position: relative; +} + +.jp-WindowedPanel-window { + position: absolute; + left: 0; + right: 0; + overflow: visible; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/* Sibling imports */ + +body { + color: var(--jp-ui-font-color1); + font-size: var(--jp-ui-font-size1); +} + +/* Disable native link decoration styles everywhere outside of dialog boxes */ +a { + text-decoration: unset; + color: unset; +} + +a:hover { + text-decoration: unset; + color: unset; +} + +/* Accessibility for links inside dialog box text */ +.jp-Dialog-content a { + text-decoration: revert; + color: var(--jp-content-link-color); +} + +.jp-Dialog-content a:hover { + text-decoration: revert; +} + +/* Styles for ui-components */ +.jp-Button { + color: var(--jp-ui-font-color2); + border-radius: var(--jp-border-radius); + padding: 0 12px; + font-size: var(--jp-ui-font-size1); + + /* Copy from blueprint 3 */ + display: inline-flex; + flex-direction: row; + border: none; + cursor: pointer; + align-items: center; + justify-content: center; + text-align: left; + vertical-align: middle; + min-height: 30px; + min-width: 30px; +} + +.jp-Button:disabled { + cursor: not-allowed; +} + +.jp-Button:empty { + padding: 0 !important; +} + +.jp-Button.jp-mod-small { + min-height: 24px; + min-width: 24px; + font-size: 12px; + padding: 0 7px; +} + +/* Use our own theme for hover styles */ +.jp-Button.jp-mod-minimal:hover { + background-color: var(--jp-layout-color2); +} + +.jp-Button.jp-mod-minimal { + background: none; +} + +.jp-InputGroup { + display: block; + position: relative; +} + +.jp-InputGroup input { + box-sizing: border-box; + border: none; + border-radius: 0; + background-color: transparent; + color: var(--jp-ui-font-color0); + box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); + padding-bottom: 0; + padding-top: 0; + padding-left: 10px; + padding-right: 28px; + position: relative; + width: 100%; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + font-size: 14px; + font-weight: 400; + height: 30px; + line-height: 30px; + outline: none; + vertical-align: middle; +} + +.jp-InputGroup input:focus { + box-shadow: inset 0 0 0 var(--jp-border-width) + var(--jp-input-active-box-shadow-color), + inset 0 0 0 3px var(--jp-input-active-box-shadow-color); +} + +.jp-InputGroup input:disabled { + cursor: not-allowed; + resize: block; + background-color: var(--jp-layout-color2); + color: var(--jp-ui-font-color2); +} + +.jp-InputGroup input:disabled ~ span { + cursor: not-allowed; + color: var(--jp-ui-font-color2); +} + +.jp-InputGroup input::placeholder, +input::placeholder { + color: var(--jp-ui-font-color2); +} + +.jp-InputGroupAction { + position: absolute; + bottom: 1px; + right: 0; + padding: 6px; +} + +.jp-HTMLSelect.jp-DefaultStyle select { + background-color: initial; + border: none; + border-radius: 0; + box-shadow: none; + color: var(--jp-ui-font-color0); + display: block; + font-size: var(--jp-ui-font-size1); + font-family: var(--jp-ui-font-family); + height: 24px; + line-height: 14px; + padding: 0 25px 0 10px; + text-align: left; + -moz-appearance: none; + -webkit-appearance: none; +} + +.jp-HTMLSelect.jp-DefaultStyle select:disabled { + background-color: var(--jp-layout-color2); + color: var(--jp-ui-font-color2); + cursor: not-allowed; + resize: block; +} + +.jp-HTMLSelect.jp-DefaultStyle select:disabled ~ span { + cursor: not-allowed; +} + +/* Use our own theme for hover and option styles */ +/* stylelint-disable-next-line selector-max-type */ +.jp-HTMLSelect.jp-DefaultStyle select:hover, +.jp-HTMLSelect.jp-DefaultStyle select > option { + background-color: var(--jp-layout-color2); + color: var(--jp-ui-font-color0); +} + +select { + box-sizing: border-box; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Styles +|----------------------------------------------------------------------------*/ + +.jp-StatusBar-Widget { + display: flex; + align-items: center; + background: var(--jp-layout-color2); + min-height: var(--jp-statusbar-height); + justify-content: space-between; + padding: 0 10px; +} + +.jp-StatusBar-Left { + display: flex; + align-items: center; + flex-direction: row; +} + +.jp-StatusBar-Middle { + display: flex; + align-items: center; +} + +.jp-StatusBar-Right { + display: flex; + align-items: center; + flex-direction: row-reverse; +} + +.jp-StatusBar-Item { + max-height: var(--jp-statusbar-height); + margin: 0 2px; + height: var(--jp-statusbar-height); + white-space: nowrap; + text-overflow: ellipsis; + color: var(--jp-ui-font-color1); + padding: 0 6px; +} + +.jp-mod-highlighted:hover { + background-color: var(--jp-layout-color3); +} + +.jp-mod-clicked { + background-color: var(--jp-brand-color1); +} + +.jp-mod-clicked:hover { + background-color: var(--jp-brand-color0); +} + +.jp-mod-clicked .jp-StatusBar-TextItem { + color: var(--jp-ui-inverse-font-color1); +} + +.jp-StatusBar-HoverItem { + box-shadow: '0px 4px 4px rgba(0, 0, 0, 0.25)'; +} + +.jp-StatusBar-TextItem { + font-size: var(--jp-ui-font-size1); + font-family: var(--jp-ui-font-family); + line-height: 24px; + color: var(--jp-ui-font-color1); +} + +.jp-StatusBar-GroupItem { + display: flex; + align-items: center; + flex-direction: row; +} + +.jp-Statusbar-ProgressCircle svg { + display: block; + margin: 0 auto; + width: 16px; + height: 24px; + align-self: normal; +} + +.jp-Statusbar-ProgressCircle path { + fill: var(--jp-inverse-layout-color3); +} + +.jp-Statusbar-ProgressBar-progress-bar { + height: 10px; + width: 100px; + border: solid 0.25px var(--jp-brand-color2); + border-radius: 3px; + overflow: hidden; + align-self: center; +} + +.jp-Statusbar-ProgressBar-progress-bar > div { + background-color: var(--jp-brand-color2); + background-image: linear-gradient( + -45deg, + rgba(255, 255, 255, 0.2) 25%, + transparent 25%, + transparent 50%, + rgba(255, 255, 255, 0.2) 50%, + rgba(255, 255, 255, 0.2) 75%, + transparent 75%, + transparent + ); + background-size: 40px 40px; + float: left; + width: 0%; + height: 100%; + font-size: 12px; + line-height: 14px; + color: #fff; + text-align: center; + animation: jp-Statusbar-ExecutionTime-progress-bar 2s linear infinite; +} + +.jp-Statusbar-ProgressBar-progress-bar p { + color: var(--jp-ui-font-color1); + font-family: var(--jp-ui-font-family); + font-size: var(--jp-ui-font-size1); + line-height: 10px; + width: 100px; +} + +@keyframes jp-Statusbar-ExecutionTime-progress-bar { + 0% { + background-position: 0 0; + } + + 100% { + background-position: 40px 40px; + } +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Variables +|----------------------------------------------------------------------------*/ + +:root { + --jp-private-commandpalette-search-height: 28px; +} + +/*----------------------------------------------------------------------------- +| Overall styles +|----------------------------------------------------------------------------*/ + +.lm-CommandPalette { + padding-bottom: 0; + color: var(--jp-ui-font-color1); + background: var(--jp-layout-color1); + + /* This is needed so that all font sizing of children done in ems is + * relative to this base size */ + font-size: var(--jp-ui-font-size1); +} + +/*----------------------------------------------------------------------------- +| Modal variant +|----------------------------------------------------------------------------*/ + +.jp-ModalCommandPalette { + position: absolute; + z-index: 10000; + top: 38px; + left: 30%; + margin: 0; + padding: 4px; + width: 40%; + box-shadow: var(--jp-elevation-z4); + border-radius: 4px; + background: var(--jp-layout-color0); +} + +.jp-ModalCommandPalette .lm-CommandPalette { + max-height: 40vh; +} + +.jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after { + display: none; +} + +.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header { + display: none; +} + +.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item { + margin-left: 4px; + margin-right: 4px; +} + +.jp-ModalCommandPalette + .lm-CommandPalette + .lm-CommandPalette-item.lm-mod-disabled { + display: none; +} + +/*----------------------------------------------------------------------------- +| Search +|----------------------------------------------------------------------------*/ + +.lm-CommandPalette-search { + padding: 4px; + background-color: var(--jp-layout-color1); + z-index: 2; +} + +.lm-CommandPalette-wrapper { + overflow: overlay; + padding: 0 9px; + background-color: var(--jp-input-active-background); + height: 30px; + box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color); +} + +.lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper { + box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color), + inset 0 0 0 3px var(--jp-input-active-box-shadow-color); +} + +.jp-SearchIconGroup { + color: white; + background-color: var(--jp-brand-color1); + position: absolute; + top: 4px; + right: 4px; + padding: 5px 5px 1px; +} + +.jp-SearchIconGroup svg { + height: 20px; + width: 20px; +} + +.jp-SearchIconGroup .jp-icon3[fill] { + fill: var(--jp-layout-color0); +} + +.lm-CommandPalette-input { + background: transparent; + width: calc(100% - 18px); + float: left; + border: none; + outline: none; + font-size: var(--jp-ui-font-size1); + color: var(--jp-ui-font-color0); + line-height: var(--jp-private-commandpalette-search-height); +} + +.lm-CommandPalette-input::-webkit-input-placeholder, +.lm-CommandPalette-input::-moz-placeholder, +.lm-CommandPalette-input:-ms-input-placeholder { + color: var(--jp-ui-font-color2); + font-size: var(--jp-ui-font-size1); +} + +/*----------------------------------------------------------------------------- +| Results +|----------------------------------------------------------------------------*/ + +.lm-CommandPalette-header:first-child { + margin-top: 0; +} + +.lm-CommandPalette-header { + border-bottom: solid var(--jp-border-width) var(--jp-border-color2); + color: var(--jp-ui-font-color1); + cursor: pointer; + display: flex; + font-size: var(--jp-ui-font-size0); + font-weight: 600; + letter-spacing: 1px; + margin-top: 8px; + padding: 8px 0 8px 12px; + text-transform: uppercase; +} + +.lm-CommandPalette-header.lm-mod-active { + background: var(--jp-layout-color2); +} + +.lm-CommandPalette-header > mark { + background-color: transparent; + font-weight: bold; + color: var(--jp-ui-font-color1); +} + +.lm-CommandPalette-item { + padding: 4px 12px 4px 4px; + color: var(--jp-ui-font-color1); + font-size: var(--jp-ui-font-size1); + font-weight: 400; + display: flex; +} + +.lm-CommandPalette-item.lm-mod-disabled { + color: var(--jp-ui-font-color2); +} + +.lm-CommandPalette-item.lm-mod-active { + color: var(--jp-ui-inverse-font-color1); + background: var(--jp-brand-color1); +} + +.lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark { + color: var(--jp-ui-inverse-font-color0); +} + +.lm-CommandPalette-item.lm-mod-active .jp-icon-selectable[fill] { + fill: var(--jp-layout-color0); +} + +.lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) { + color: var(--jp-ui-inverse-font-color1); + background: var(--jp-brand-color1); +} + +.lm-CommandPalette-item:hover:not(.lm-mod-active):not(.lm-mod-disabled) { + background: var(--jp-layout-color2); +} + +.lm-CommandPalette-itemContent { + overflow: hidden; +} + +.lm-CommandPalette-itemLabel > mark { + color: var(--jp-ui-font-color0); + background-color: transparent; + font-weight: bold; +} + +.lm-CommandPalette-item.lm-mod-disabled mark { + color: var(--jp-ui-font-color2); +} + +.lm-CommandPalette-item .lm-CommandPalette-itemIcon { + margin: 0 4px 0 0; + position: relative; + width: 16px; + top: 2px; + flex: 0 0 auto; +} + +.lm-CommandPalette-item.lm-mod-disabled .lm-CommandPalette-itemIcon { + opacity: 0.6; +} + +.lm-CommandPalette-item .lm-CommandPalette-itemShortcut { + flex: 0 0 auto; +} + +.lm-CommandPalette-itemCaption { + display: none; +} + +.lm-CommandPalette-content { + background-color: var(--jp-layout-color1); +} + +.lm-CommandPalette-content:empty::after { + content: 'No results'; + margin: auto; + margin-top: 20px; + width: 100px; + display: block; + font-size: var(--jp-ui-font-size2); + font-family: var(--jp-ui-font-family); + font-weight: lighter; +} + +.lm-CommandPalette-emptyMessage { + text-align: center; + margin-top: 24px; + line-height: 1.32; + padding: 0 8px; + color: var(--jp-content-font-color3); +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2014-2017, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-Dialog { + position: absolute; + z-index: 10000; + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + top: 0; + left: 0; + margin: 0; + padding: 0; + width: 100%; + height: 100%; + background: var(--jp-dialog-background); +} + +.jp-Dialog-content { + display: flex; + flex-direction: column; + margin-left: auto; + margin-right: auto; + background: var(--jp-layout-color1); + padding: 24px 24px 12px; + min-width: 300px; + min-height: 150px; + max-width: 1000px; + max-height: 500px; + box-sizing: border-box; + box-shadow: var(--jp-elevation-z20); + word-wrap: break-word; + border-radius: var(--jp-border-radius); + + /* This is needed so that all font sizing of children done in ems is + * relative to this base size */ + font-size: var(--jp-ui-font-size1); + color: var(--jp-ui-font-color1); + resize: both; +} + +.jp-Dialog-content.jp-Dialog-content-small { + max-width: 500px; +} + +.jp-Dialog-button { + overflow: visible; +} + +button.jp-Dialog-button:focus { + outline: 1px solid var(--jp-brand-color1); + outline-offset: 4px; + -moz-outline-radius: 0; +} + +button.jp-Dialog-button:focus::-moz-focus-inner { + border: 0; +} + +button.jp-Dialog-button.jp-mod-styled.jp-mod-accept:focus, +button.jp-Dialog-button.jp-mod-styled.jp-mod-warn:focus, +button.jp-Dialog-button.jp-mod-styled.jp-mod-reject:focus { + outline-offset: 4px; + -moz-outline-radius: 0; +} + +button.jp-Dialog-button.jp-mod-styled.jp-mod-accept:focus { + outline: 1px solid var(--jp-accept-color-normal, var(--jp-brand-color1)); +} + +button.jp-Dialog-button.jp-mod-styled.jp-mod-warn:focus { + outline: 1px solid var(--jp-warn-color-normal, var(--jp-error-color1)); +} + +button.jp-Dialog-button.jp-mod-styled.jp-mod-reject:focus { + outline: 1px solid var(--jp-reject-color-normal, var(--md-grey-600)); +} + +button.jp-Dialog-close-button { + padding: 0; + height: 100%; + min-width: unset; + min-height: unset; +} + +.jp-Dialog-header { + display: flex; + justify-content: space-between; + flex: 0 0 auto; + padding-bottom: 12px; + font-size: var(--jp-ui-font-size3); + font-weight: 400; + color: var(--jp-ui-font-color1); +} + +.jp-Dialog-body { + display: flex; + flex-direction: column; + flex: 1 1 auto; + font-size: var(--jp-ui-font-size1); + background: var(--jp-layout-color1); + color: var(--jp-ui-font-color1); + overflow: auto; +} + +.jp-Dialog-footer { + display: flex; + flex-direction: row; + justify-content: flex-end; + align-items: center; + flex: 0 0 auto; + margin-left: -12px; + margin-right: -12px; + padding: 12px; +} + +.jp-Dialog-checkbox { + padding-right: 5px; +} + +.jp-Dialog-checkbox > input:focus-visible { + outline: 1px solid var(--jp-input-active-border-color); + outline-offset: 1px; +} + +.jp-Dialog-spacer { + flex: 1 1 auto; +} + +.jp-Dialog-title { + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; +} + +.jp-Dialog-body > .jp-select-wrapper { + width: 100%; +} + +.jp-Dialog-body > button { + padding: 0 16px; +} + +.jp-Dialog-body > label { + line-height: 1.4; + color: var(--jp-ui-font-color0); +} + +.jp-Dialog-button.jp-mod-styled:not(:last-child) { + margin-right: 12px; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +.jp-Input-Boolean-Dialog { + flex-direction: row-reverse; + align-items: end; + width: 100%; +} + +.jp-Input-Boolean-Dialog > label { + flex: 1 1 auto; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2014-2016, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-MainAreaWidget > :focus { + outline: none; +} + +.jp-MainAreaWidget .jp-MainAreaWidget-error { + padding: 6px; +} + +.jp-MainAreaWidget .jp-MainAreaWidget-error > pre { + width: auto; + padding: 10px; + background: var(--jp-error-color3); + border: var(--jp-border-width) solid var(--jp-error-color1); + border-radius: var(--jp-border-radius); + color: var(--jp-ui-font-color1); + font-size: var(--jp-ui-font-size1); + white-space: pre-wrap; + word-wrap: break-word; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/** + * google-material-color v1.2.6 + * https://github.com/danlevan/google-material-color + */ +:root { + --md-red-50: #ffebee; + --md-red-100: #ffcdd2; + --md-red-200: #ef9a9a; + --md-red-300: #e57373; + --md-red-400: #ef5350; + --md-red-500: #f44336; + --md-red-600: #e53935; + --md-red-700: #d32f2f; + --md-red-800: #c62828; + --md-red-900: #b71c1c; + --md-red-A100: #ff8a80; + --md-red-A200: #ff5252; + --md-red-A400: #ff1744; + --md-red-A700: #d50000; + --md-pink-50: #fce4ec; + --md-pink-100: #f8bbd0; + --md-pink-200: #f48fb1; + --md-pink-300: #f06292; + --md-pink-400: #ec407a; + --md-pink-500: #e91e63; + --md-pink-600: #d81b60; + --md-pink-700: #c2185b; + --md-pink-800: #ad1457; + --md-pink-900: #880e4f; + --md-pink-A100: #ff80ab; + --md-pink-A200: #ff4081; + --md-pink-A400: #f50057; + --md-pink-A700: #c51162; + --md-purple-50: #f3e5f5; + --md-purple-100: #e1bee7; + --md-purple-200: #ce93d8; + --md-purple-300: #ba68c8; + --md-purple-400: #ab47bc; + --md-purple-500: #9c27b0; + --md-purple-600: #8e24aa; + --md-purple-700: #7b1fa2; + --md-purple-800: #6a1b9a; + --md-purple-900: #4a148c; + --md-purple-A100: #ea80fc; + --md-purple-A200: #e040fb; + --md-purple-A400: #d500f9; + --md-purple-A700: #a0f; + --md-deep-purple-50: #ede7f6; + --md-deep-purple-100: #d1c4e9; + --md-deep-purple-200: #b39ddb; + --md-deep-purple-300: #9575cd; + --md-deep-purple-400: #7e57c2; + --md-deep-purple-500: #673ab7; + --md-deep-purple-600: #5e35b1; + --md-deep-purple-700: #512da8; + --md-deep-purple-800: #4527a0; + --md-deep-purple-900: #311b92; + --md-deep-purple-A100: #b388ff; + --md-deep-purple-A200: #7c4dff; + --md-deep-purple-A400: #651fff; + --md-deep-purple-A700: #6200ea; + --md-indigo-50: #e8eaf6; + --md-indigo-100: #c5cae9; + --md-indigo-200: #9fa8da; + --md-indigo-300: #7986cb; + --md-indigo-400: #5c6bc0; + --md-indigo-500: #3f51b5; + --md-indigo-600: #3949ab; + --md-indigo-700: #303f9f; + --md-indigo-800: #283593; + --md-indigo-900: #1a237e; + --md-indigo-A100: #8c9eff; + --md-indigo-A200: #536dfe; + --md-indigo-A400: #3d5afe; + --md-indigo-A700: #304ffe; + --md-blue-50: #e3f2fd; + --md-blue-100: #bbdefb; + --md-blue-200: #90caf9; + --md-blue-300: #64b5f6; + --md-blue-400: #42a5f5; + --md-blue-500: #2196f3; + --md-blue-600: #1e88e5; + --md-blue-700: #1976d2; + --md-blue-800: #1565c0; + --md-blue-900: #0d47a1; + --md-blue-A100: #82b1ff; + --md-blue-A200: #448aff; + --md-blue-A400: #2979ff; + --md-blue-A700: #2962ff; + --md-light-blue-50: #e1f5fe; + --md-light-blue-100: #b3e5fc; + --md-light-blue-200: #81d4fa; + --md-light-blue-300: #4fc3f7; + --md-light-blue-400: #29b6f6; + --md-light-blue-500: #03a9f4; + --md-light-blue-600: #039be5; + --md-light-blue-700: #0288d1; + --md-light-blue-800: #0277bd; + --md-light-blue-900: #01579b; + --md-light-blue-A100: #80d8ff; + --md-light-blue-A200: #40c4ff; + --md-light-blue-A400: #00b0ff; + --md-light-blue-A700: #0091ea; + --md-cyan-50: #e0f7fa; + --md-cyan-100: #b2ebf2; + --md-cyan-200: #80deea; + --md-cyan-300: #4dd0e1; + --md-cyan-400: #26c6da; + --md-cyan-500: #00bcd4; + --md-cyan-600: #00acc1; + --md-cyan-700: #0097a7; + --md-cyan-800: #00838f; + --md-cyan-900: #006064; + --md-cyan-A100: #84ffff; + --md-cyan-A200: #18ffff; + --md-cyan-A400: #00e5ff; + --md-cyan-A700: #00b8d4; + --md-teal-50: #e0f2f1; + --md-teal-100: #b2dfdb; + --md-teal-200: #80cbc4; + --md-teal-300: #4db6ac; + --md-teal-400: #26a69a; + --md-teal-500: #009688; + --md-teal-600: #00897b; + --md-teal-700: #00796b; + --md-teal-800: #00695c; + --md-teal-900: #004d40; + --md-teal-A100: #a7ffeb; + --md-teal-A200: #64ffda; + --md-teal-A400: #1de9b6; + --md-teal-A700: #00bfa5; + --md-green-50: #e8f5e9; + --md-green-100: #c8e6c9; + --md-green-200: #a5d6a7; + --md-green-300: #81c784; + --md-green-400: #66bb6a; + --md-green-500: #4caf50; + --md-green-600: #43a047; + --md-green-700: #388e3c; + --md-green-800: #2e7d32; + --md-green-900: #1b5e20; + --md-green-A100: #b9f6ca; + --md-green-A200: #69f0ae; + --md-green-A400: #00e676; + --md-green-A700: #00c853; + --md-light-green-50: #f1f8e9; + --md-light-green-100: #dcedc8; + --md-light-green-200: #c5e1a5; + --md-light-green-300: #aed581; + --md-light-green-400: #9ccc65; + --md-light-green-500: #8bc34a; + --md-light-green-600: #7cb342; + --md-light-green-700: #689f38; + --md-light-green-800: #558b2f; + --md-light-green-900: #33691e; + --md-light-green-A100: #ccff90; + --md-light-green-A200: #b2ff59; + --md-light-green-A400: #76ff03; + --md-light-green-A700: #64dd17; + --md-lime-50: #f9fbe7; + --md-lime-100: #f0f4c3; + --md-lime-200: #e6ee9c; + --md-lime-300: #dce775; + --md-lime-400: #d4e157; + --md-lime-500: #cddc39; + --md-lime-600: #c0ca33; + --md-lime-700: #afb42b; + --md-lime-800: #9e9d24; + --md-lime-900: #827717; + --md-lime-A100: #f4ff81; + --md-lime-A200: #eeff41; + --md-lime-A400: #c6ff00; + --md-lime-A700: #aeea00; + --md-yellow-50: #fffde7; + --md-yellow-100: #fff9c4; + --md-yellow-200: #fff59d; + --md-yellow-300: #fff176; + --md-yellow-400: #ffee58; + --md-yellow-500: #ffeb3b; + --md-yellow-600: #fdd835; + --md-yellow-700: #fbc02d; + --md-yellow-800: #f9a825; + --md-yellow-900: #f57f17; + --md-yellow-A100: #ffff8d; + --md-yellow-A200: #ff0; + --md-yellow-A400: #ffea00; + --md-yellow-A700: #ffd600; + --md-amber-50: #fff8e1; + --md-amber-100: #ffecb3; + --md-amber-200: #ffe082; + --md-amber-300: #ffd54f; + --md-amber-400: #ffca28; + --md-amber-500: #ffc107; + --md-amber-600: #ffb300; + --md-amber-700: #ffa000; + --md-amber-800: #ff8f00; + --md-amber-900: #ff6f00; + --md-amber-A100: #ffe57f; + --md-amber-A200: #ffd740; + --md-amber-A400: #ffc400; + --md-amber-A700: #ffab00; + --md-orange-50: #fff3e0; + --md-orange-100: #ffe0b2; + --md-orange-200: #ffcc80; + --md-orange-300: #ffb74d; + --md-orange-400: #ffa726; + --md-orange-500: #ff9800; + --md-orange-600: #fb8c00; + --md-orange-700: #f57c00; + --md-orange-800: #ef6c00; + --md-orange-900: #e65100; + --md-orange-A100: #ffd180; + --md-orange-A200: #ffab40; + --md-orange-A400: #ff9100; + --md-orange-A700: #ff6d00; + --md-deep-orange-50: #fbe9e7; + --md-deep-orange-100: #ffccbc; + --md-deep-orange-200: #ffab91; + --md-deep-orange-300: #ff8a65; + --md-deep-orange-400: #ff7043; + --md-deep-orange-500: #ff5722; + --md-deep-orange-600: #f4511e; + --md-deep-orange-700: #e64a19; + --md-deep-orange-800: #d84315; + --md-deep-orange-900: #bf360c; + --md-deep-orange-A100: #ff9e80; + --md-deep-orange-A200: #ff6e40; + --md-deep-orange-A400: #ff3d00; + --md-deep-orange-A700: #dd2c00; + --md-brown-50: #efebe9; + --md-brown-100: #d7ccc8; + --md-brown-200: #bcaaa4; + --md-brown-300: #a1887f; + --md-brown-400: #8d6e63; + --md-brown-500: #795548; + --md-brown-600: #6d4c41; + --md-brown-700: #5d4037; + --md-brown-800: #4e342e; + --md-brown-900: #3e2723; + --md-grey-50: #fafafa; + --md-grey-100: #f5f5f5; + --md-grey-200: #eee; + --md-grey-300: #e0e0e0; + --md-grey-400: #bdbdbd; + --md-grey-500: #9e9e9e; + --md-grey-600: #757575; + --md-grey-700: #616161; + --md-grey-800: #424242; + --md-grey-900: #212121; + --md-blue-grey-50: #eceff1; + --md-blue-grey-100: #cfd8dc; + --md-blue-grey-200: #b0bec5; + --md-blue-grey-300: #90a4ae; + --md-blue-grey-400: #78909c; + --md-blue-grey-500: #607d8b; + --md-blue-grey-600: #546e7a; + --md-blue-grey-700: #455a64; + --md-blue-grey-800: #37474f; + --md-blue-grey-900: #263238; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2014-2017, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| RenderedText +|----------------------------------------------------------------------------*/ + +:root { + /* This is the padding value to fill the gaps between lines containing spans with background color. */ + --jp-private-code-span-padding: calc( + (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2 + ); +} + +.jp-RenderedText { + text-align: left; + padding-left: var(--jp-code-padding); + line-height: var(--jp-code-line-height); + font-family: var(--jp-code-font-family); +} + +.jp-RenderedText pre, +.jp-RenderedJavaScript pre, +.jp-RenderedHTMLCommon pre { + color: var(--jp-content-font-color1); + font-size: var(--jp-code-font-size); + border: none; + margin: 0; + padding: 0; +} + +.jp-RenderedText pre a:link { + text-decoration: none; + color: var(--jp-content-link-color); +} + +.jp-RenderedText pre a:hover { + text-decoration: underline; + color: var(--jp-content-link-color); +} + +.jp-RenderedText pre a:visited { + text-decoration: none; + color: var(--jp-content-link-color); +} + +/* console foregrounds and backgrounds */ +.jp-RenderedText pre .ansi-black-fg { + color: #3e424d; +} + +.jp-RenderedText pre .ansi-red-fg { + color: #e75c58; +} + +.jp-RenderedText pre .ansi-green-fg { + color: #00a250; +} + +.jp-RenderedText pre .ansi-yellow-fg { + color: #ddb62b; +} + +.jp-RenderedText pre .ansi-blue-fg { + color: #208ffb; +} + +.jp-RenderedText pre .ansi-magenta-fg { + color: #d160c4; +} + +.jp-RenderedText pre .ansi-cyan-fg { + color: #60c6c8; +} + +.jp-RenderedText pre .ansi-white-fg { + color: #c5c1b4; +} + +.jp-RenderedText pre .ansi-black-bg { + background-color: #3e424d; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-red-bg { + background-color: #e75c58; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-green-bg { + background-color: #00a250; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-yellow-bg { + background-color: #ddb62b; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-blue-bg { + background-color: #208ffb; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-magenta-bg { + background-color: #d160c4; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-cyan-bg { + background-color: #60c6c8; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-white-bg { + background-color: #c5c1b4; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-black-intense-fg { + color: #282c36; +} + +.jp-RenderedText pre .ansi-red-intense-fg { + color: #b22b31; +} + +.jp-RenderedText pre .ansi-green-intense-fg { + color: #007427; +} + +.jp-RenderedText pre .ansi-yellow-intense-fg { + color: #b27d12; +} + +.jp-RenderedText pre .ansi-blue-intense-fg { + color: #0065ca; +} + +.jp-RenderedText pre .ansi-magenta-intense-fg { + color: #a03196; +} + +.jp-RenderedText pre .ansi-cyan-intense-fg { + color: #258f8f; +} + +.jp-RenderedText pre .ansi-white-intense-fg { + color: #a1a6b2; +} + +.jp-RenderedText pre .ansi-black-intense-bg { + background-color: #282c36; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-red-intense-bg { + background-color: #b22b31; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-green-intense-bg { + background-color: #007427; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-yellow-intense-bg { + background-color: #b27d12; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-blue-intense-bg { + background-color: #0065ca; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-magenta-intense-bg { + background-color: #a03196; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-cyan-intense-bg { + background-color: #258f8f; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-white-intense-bg { + background-color: #a1a6b2; + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-default-inverse-fg { + color: var(--jp-ui-inverse-font-color0); +} + +.jp-RenderedText pre .ansi-default-inverse-bg { + background-color: var(--jp-inverse-layout-color0); + padding: var(--jp-private-code-span-padding) 0; +} + +.jp-RenderedText pre .ansi-bold { + font-weight: bold; +} + +.jp-RenderedText pre .ansi-underline { + text-decoration: underline; +} + +.jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] { + background: var(--jp-rendermime-error-background); + padding-top: var(--jp-code-padding); +} + +/*----------------------------------------------------------------------------- +| RenderedLatex +|----------------------------------------------------------------------------*/ + +.jp-RenderedLatex { + color: var(--jp-content-font-color1); + font-size: var(--jp-content-font-size1); + line-height: var(--jp-content-line-height); +} + +/* Left-justify outputs.*/ +.jp-OutputArea-output.jp-RenderedLatex { + padding: var(--jp-code-padding); + text-align: left; +} + +/*----------------------------------------------------------------------------- +| RenderedHTML +|----------------------------------------------------------------------------*/ + +.jp-RenderedHTMLCommon { + color: var(--jp-content-font-color1); + font-family: var(--jp-content-font-family); + font-size: var(--jp-content-font-size1); + line-height: var(--jp-content-line-height); + + /* Give a bit more R padding on Markdown text to keep line lengths reasonable */ + padding-right: 20px; +} + +.jp-RenderedHTMLCommon em { + font-style: italic; +} + +.jp-RenderedHTMLCommon strong { + font-weight: bold; +} + +.jp-RenderedHTMLCommon u { + text-decoration: underline; +} + +.jp-RenderedHTMLCommon a:link { + text-decoration: none; + color: var(--jp-content-link-color); +} + +.jp-RenderedHTMLCommon a:hover { + text-decoration: underline; + color: var(--jp-content-link-color); +} + +.jp-RenderedHTMLCommon a:visited { + text-decoration: none; + color: var(--jp-content-link-color); +} + +/* Headings */ + +.jp-RenderedHTMLCommon h1, +.jp-RenderedHTMLCommon h2, +.jp-RenderedHTMLCommon h3, +.jp-RenderedHTMLCommon h4, +.jp-RenderedHTMLCommon h5, +.jp-RenderedHTMLCommon h6 { + line-height: var(--jp-content-heading-line-height); + font-weight: var(--jp-content-heading-font-weight); + font-style: normal; + margin: var(--jp-content-heading-margin-top) 0 + var(--jp-content-heading-margin-bottom) 0; +} + +.jp-RenderedHTMLCommon h1:first-child, +.jp-RenderedHTMLCommon h2:first-child, +.jp-RenderedHTMLCommon h3:first-child, +.jp-RenderedHTMLCommon h4:first-child, +.jp-RenderedHTMLCommon h5:first-child, +.jp-RenderedHTMLCommon h6:first-child { + margin-top: calc(0.5 * var(--jp-content-heading-margin-top)); +} + +.jp-RenderedHTMLCommon h1:last-child, +.jp-RenderedHTMLCommon h2:last-child, +.jp-RenderedHTMLCommon h3:last-child, +.jp-RenderedHTMLCommon h4:last-child, +.jp-RenderedHTMLCommon h5:last-child, +.jp-RenderedHTMLCommon h6:last-child { + margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom)); +} + +.jp-RenderedHTMLCommon h1 { + font-size: var(--jp-content-font-size5); +} + +.jp-RenderedHTMLCommon h2 { + font-size: var(--jp-content-font-size4); +} + +.jp-RenderedHTMLCommon h3 { + font-size: var(--jp-content-font-size3); +} + +.jp-RenderedHTMLCommon h4 { + font-size: var(--jp-content-font-size2); +} + +.jp-RenderedHTMLCommon h5 { + font-size: var(--jp-content-font-size1); +} + +.jp-RenderedHTMLCommon h6 { + font-size: var(--jp-content-font-size0); +} + +/* Lists */ + +/* stylelint-disable selector-max-type, selector-max-compound-selectors */ + +.jp-RenderedHTMLCommon ul:not(.list-inline), +.jp-RenderedHTMLCommon ol:not(.list-inline) { + padding-left: 2em; +} + +.jp-RenderedHTMLCommon ul { + list-style: disc; +} + +.jp-RenderedHTMLCommon ul ul { + list-style: square; +} + +.jp-RenderedHTMLCommon ul ul ul { + list-style: circle; +} + +.jp-RenderedHTMLCommon ol { + list-style: decimal; +} + +.jp-RenderedHTMLCommon ol ol { + list-style: upper-alpha; +} + +.jp-RenderedHTMLCommon ol ol ol { + list-style: lower-alpha; +} + +.jp-RenderedHTMLCommon ol ol ol ol { + list-style: lower-roman; +} + +.jp-RenderedHTMLCommon ol ol ol ol ol { + list-style: decimal; +} + +.jp-RenderedHTMLCommon ol, +.jp-RenderedHTMLCommon ul { + margin-bottom: 1em; +} + +.jp-RenderedHTMLCommon ul ul, +.jp-RenderedHTMLCommon ul ol, +.jp-RenderedHTMLCommon ol ul, +.jp-RenderedHTMLCommon ol ol { + margin-bottom: 0; +} + +/* stylelint-enable selector-max-type, selector-max-compound-selectors */ + +.jp-RenderedHTMLCommon hr { + color: var(--jp-border-color2); + background-color: var(--jp-border-color1); + margin-top: 1em; + margin-bottom: 1em; +} + +.jp-RenderedHTMLCommon > pre { + margin: 1.5em 2em; +} + +.jp-RenderedHTMLCommon pre, +.jp-RenderedHTMLCommon code { + border: 0; + background-color: var(--jp-layout-color0); + color: var(--jp-content-font-color1); + font-family: var(--jp-code-font-family); + font-size: inherit; + line-height: var(--jp-code-line-height); + padding: 0; + white-space: pre-wrap; +} + +.jp-RenderedHTMLCommon :not(pre) > code { + background-color: var(--jp-layout-color2); + padding: 1px 5px; +} + +/* Tables */ + +.jp-RenderedHTMLCommon table { + border-collapse: collapse; + border-spacing: 0; + border: none; + color: var(--jp-ui-font-color1); + font-size: var(--jp-ui-font-size1); + table-layout: fixed; + margin-left: auto; + margin-bottom: 1em; + margin-right: auto; +} + +.jp-RenderedHTMLCommon thead { + border-bottom: var(--jp-border-width) solid var(--jp-border-color1); + vertical-align: bottom; +} + +.jp-RenderedHTMLCommon td, +.jp-RenderedHTMLCommon th, +.jp-RenderedHTMLCommon tr { + vertical-align: middle; + padding: 0.5em; + line-height: normal; + white-space: normal; + max-width: none; + border: none; +} + +.jp-RenderedMarkdown.jp-RenderedHTMLCommon td, +.jp-RenderedMarkdown.jp-RenderedHTMLCommon th { + max-width: none; +} + +:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td, +:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th, +:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr { + text-align: right; +} + +.jp-RenderedHTMLCommon th { + font-weight: bold; +} + +.jp-RenderedHTMLCommon tbody tr:nth-child(odd) { + background: var(--jp-layout-color0); +} + +.jp-RenderedHTMLCommon tbody tr:nth-child(even) { + background: var(--jp-rendermime-table-row-background); +} + +.jp-RenderedHTMLCommon tbody tr:hover { + background: var(--jp-rendermime-table-row-hover-background); +} + +.jp-RenderedHTMLCommon p { + text-align: left; + margin: 0; + margin-bottom: 1em; +} + +.jp-RenderedHTMLCommon img { + -moz-force-broken-image-icon: 1; +} + +/* Restrict to direct children as other images could be nested in other content. */ +.jp-RenderedHTMLCommon > img { + display: block; + margin-left: 0; + margin-right: 0; + margin-bottom: 1em; +} + +/* Change color behind transparent images if they need it... */ +[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background { + background-color: var(--jp-inverse-layout-color1); +} + +[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background { + background-color: var(--jp-inverse-layout-color1); +} + +.jp-RenderedHTMLCommon img, +.jp-RenderedImage img, +.jp-RenderedHTMLCommon svg, +.jp-RenderedSVG svg { + max-width: 100%; + height: auto; +} + +.jp-RenderedHTMLCommon img.jp-mod-unconfined, +.jp-RenderedImage img.jp-mod-unconfined, +.jp-RenderedHTMLCommon svg.jp-mod-unconfined, +.jp-RenderedSVG svg.jp-mod-unconfined { + max-width: none; +} + +.jp-RenderedHTMLCommon .alert { + padding: var(--jp-notebook-padding); + border: var(--jp-border-width) solid transparent; + border-radius: var(--jp-border-radius); + margin-bottom: 1em; +} + +.jp-RenderedHTMLCommon .alert-info { + color: var(--jp-info-color0); + background-color: var(--jp-info-color3); + border-color: var(--jp-info-color2); +} + +.jp-RenderedHTMLCommon .alert-info hr { + border-color: var(--jp-info-color3); +} + +.jp-RenderedHTMLCommon .alert-info > p:last-child, +.jp-RenderedHTMLCommon .alert-info > ul:last-child { + margin-bottom: 0; +} + +.jp-RenderedHTMLCommon .alert-warning { + color: var(--jp-warn-color0); + background-color: var(--jp-warn-color3); + border-color: var(--jp-warn-color2); +} + +.jp-RenderedHTMLCommon .alert-warning hr { + border-color: var(--jp-warn-color3); +} + +.jp-RenderedHTMLCommon .alert-warning > p:last-child, +.jp-RenderedHTMLCommon .alert-warning > ul:last-child { + margin-bottom: 0; +} + +.jp-RenderedHTMLCommon .alert-success { + color: var(--jp-success-color0); + background-color: var(--jp-success-color3); + border-color: var(--jp-success-color2); +} + +.jp-RenderedHTMLCommon .alert-success hr { + border-color: var(--jp-success-color3); +} + +.jp-RenderedHTMLCommon .alert-success > p:last-child, +.jp-RenderedHTMLCommon .alert-success > ul:last-child { + margin-bottom: 0; +} + +.jp-RenderedHTMLCommon .alert-danger { + color: var(--jp-error-color0); + background-color: var(--jp-error-color3); + border-color: var(--jp-error-color2); +} + +.jp-RenderedHTMLCommon .alert-danger hr { + border-color: var(--jp-error-color3); +} + +.jp-RenderedHTMLCommon .alert-danger > p:last-child, +.jp-RenderedHTMLCommon .alert-danger > ul:last-child { + margin-bottom: 0; +} + +.jp-RenderedHTMLCommon blockquote { + margin: 1em 2em; + padding: 0 1em; + border-left: 5px solid var(--jp-border-color2); +} + +a.jp-InternalAnchorLink { + visibility: hidden; + margin-left: 8px; + color: var(--md-blue-800); +} + +h1:hover .jp-InternalAnchorLink, +h2:hover .jp-InternalAnchorLink, +h3:hover .jp-InternalAnchorLink, +h4:hover .jp-InternalAnchorLink, +h5:hover .jp-InternalAnchorLink, +h6:hover .jp-InternalAnchorLink { + visibility: visible; +} + +.jp-RenderedHTMLCommon kbd { + background-color: var(--jp-rendermime-table-row-background); + border: 1px solid var(--jp-border-color0); + border-bottom-color: var(--jp-border-color2); + border-radius: 3px; + box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25); + display: inline-block; + font-size: var(--jp-ui-font-size0); + line-height: 1em; + padding: 0.2em 0.5em; +} + +/* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0. + * At the bottom of cells this is a bit too much as there is also spacing + * between cells. Going all the way to 0 gets too tight between markdown and + * code cells. + */ +.jp-RenderedHTMLCommon > *:last-child { + margin-bottom: 0.5em; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Copyright (c) 2014-2017, PhosphorJS Contributors +| +| Distributed under the terms of the BSD 3-Clause License. +| +| The full license is in the file LICENSE, distributed with this software. +|----------------------------------------------------------------------------*/ + +.lm-cursor-backdrop { + position: fixed; + width: 200px; + height: 200px; + margin-top: -100px; + margin-left: -100px; + will-change: transform; + z-index: 100; +} + +.lm-mod-drag-image { + will-change: transform; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +.jp-lineFormSearch { + padding: 4px 12px; + background-color: var(--jp-layout-color2); + box-shadow: var(--jp-toolbar-box-shadow); + z-index: 2; + font-size: var(--jp-ui-font-size1); +} + +.jp-lineFormCaption { + font-size: var(--jp-ui-font-size0); + line-height: var(--jp-ui-font-size1); + margin-top: 4px; + color: var(--jp-ui-font-color0); +} + +.jp-baseLineForm { + border: none; + border-radius: 0; + position: absolute; + background-size: 16px; + background-repeat: no-repeat; + background-position: center; + outline: none; +} + +.jp-lineFormButtonContainer { + top: 4px; + right: 8px; + height: 24px; + padding: 0 12px; + width: 12px; +} + +.jp-lineFormButtonIcon { + top: 0; + right: 0; + background-color: var(--jp-brand-color1); + height: 100%; + width: 100%; + box-sizing: border-box; + padding: 4px 6px; +} + +.jp-lineFormButton { + top: 0; + right: 0; + background-color: transparent; + height: 100%; + width: 100%; + box-sizing: border-box; +} + +.jp-lineFormWrapper { + overflow: hidden; + padding: 0 8px; + border: 1px solid var(--jp-border-color0); + background-color: var(--jp-input-active-background); + height: 22px; +} + +.jp-lineFormWrapperFocusWithin { + border: var(--jp-border-width) solid var(--md-blue-500); + box-shadow: inset 0 0 4px var(--md-blue-300); +} + +.jp-lineFormInput { + background: transparent; + width: 200px; + height: 100%; + border: none; + outline: none; + color: var(--jp-ui-font-color0); + line-height: 28px; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) 2014-2016, Jupyter Development Team. +| +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-JSONEditor { + display: flex; + flex-direction: column; + width: 100%; +} + +.jp-JSONEditor-host { + flex: 1 1 auto; + border: var(--jp-border-width) solid var(--jp-input-border-color); + border-radius: 0; + background: var(--jp-layout-color0); + min-height: 50px; + padding: 1px; +} + +.jp-JSONEditor.jp-mod-error .jp-JSONEditor-host { + border-color: red; + outline-color: red; +} + +.jp-JSONEditor-header { + display: flex; + flex: 1 0 auto; + padding: 0 0 0 12px; +} + +.jp-JSONEditor-header label { + flex: 0 0 auto; +} + +.jp-JSONEditor-commitButton { + height: 16px; + width: 16px; + background-size: 18px; + background-repeat: no-repeat; + background-position: center; +} + +.jp-JSONEditor-host.jp-mod-focused { + background-color: var(--jp-input-active-background); + border: 1px solid var(--jp-input-active-border-color); + box-shadow: var(--jp-input-box-shadow); +} + +.jp-Editor.jp-mod-dropTarget { + border: var(--jp-border-width) solid var(--jp-input-active-border-color); + box-shadow: var(--jp-input-box-shadow); +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ +.jp-DocumentSearch-input { + border: none; + outline: none; + color: var(--jp-ui-font-color0); + font-size: var(--jp-ui-font-size1); + background-color: var(--jp-layout-color0); + font-family: var(--jp-ui-font-family); + padding: 2px 1px; + resize: none; +} + +.jp-DocumentSearch-overlay { + position: absolute; + background-color: var(--jp-toolbar-background); + border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color); + border-left: var(--jp-border-width) solid var(--jp-toolbar-border-color); + top: 0; + right: 0; + z-index: 7; + min-width: 405px; + padding: 2px; + font-size: var(--jp-ui-font-size1); + + --jp-private-document-search-button-height: 20px; +} + +.jp-DocumentSearch-overlay button { + background-color: var(--jp-toolbar-background); + outline: 0; +} + +.jp-DocumentSearch-overlay button:hover { + background-color: var(--jp-layout-color2); +} + +.jp-DocumentSearch-overlay button:active { + background-color: var(--jp-layout-color3); +} + +.jp-DocumentSearch-overlay-row { + display: flex; + align-items: center; + margin-bottom: 2px; +} + +.jp-DocumentSearch-button-content { + display: inline-block; + cursor: pointer; + box-sizing: border-box; + width: 100%; + height: 100%; +} + +.jp-DocumentSearch-button-content svg { + width: 100%; + height: 100%; +} + +.jp-DocumentSearch-input-wrapper { + border: var(--jp-border-width) solid var(--jp-border-color0); + display: flex; + background-color: var(--jp-layout-color0); + margin: 2px; +} + +.jp-DocumentSearch-input-wrapper:focus-within { + border-color: var(--jp-cell-editor-active-border-color); +} + +.jp-DocumentSearch-toggle-wrapper, +.jp-DocumentSearch-button-wrapper { + all: initial; + overflow: hidden; + display: inline-block; + border: none; + box-sizing: border-box; +} + +.jp-DocumentSearch-toggle-wrapper { + width: 14px; + height: 14px; +} + +.jp-DocumentSearch-button-wrapper { + width: var(--jp-private-document-search-button-height); + height: var(--jp-private-document-search-button-height); +} + +.jp-DocumentSearch-toggle-wrapper:focus, +.jp-DocumentSearch-button-wrapper:focus { + outline: var(--jp-border-width) solid + var(--jp-cell-editor-active-border-color); + outline-offset: -1px; +} + +.jp-DocumentSearch-toggle-wrapper, +.jp-DocumentSearch-button-wrapper, +.jp-DocumentSearch-button-content:focus { + outline: none; +} + +.jp-DocumentSearch-toggle-placeholder { + width: 5px; +} + +.jp-DocumentSearch-input-button::before { + display: block; + padding-top: 100%; +} + +.jp-DocumentSearch-input-button-off { + opacity: var(--jp-search-toggle-off-opacity); +} + +.jp-DocumentSearch-input-button-off:hover { + opacity: var(--jp-search-toggle-hover-opacity); +} + +.jp-DocumentSearch-input-button-on { + opacity: var(--jp-search-toggle-on-opacity); +} + +.jp-DocumentSearch-index-counter { + padding-left: 10px; + padding-right: 10px; + user-select: none; + min-width: 35px; + display: inline-block; +} + +.jp-DocumentSearch-up-down-wrapper { + display: inline-block; + padding-right: 2px; + margin-left: auto; + white-space: nowrap; +} + +.jp-DocumentSearch-spacer { + margin-left: auto; +} + +.jp-DocumentSearch-up-down-wrapper button { + outline: 0; + border: none; + width: var(--jp-private-document-search-button-height); + height: var(--jp-private-document-search-button-height); + vertical-align: middle; + margin: 1px 5px 2px; +} + +.jp-DocumentSearch-up-down-button:hover { + background-color: var(--jp-layout-color2); +} + +.jp-DocumentSearch-up-down-button:active { + background-color: var(--jp-layout-color3); +} + +.jp-DocumentSearch-filter-button { + border-radius: var(--jp-border-radius); +} + +.jp-DocumentSearch-filter-button:hover { + background-color: var(--jp-layout-color2); +} + +.jp-DocumentSearch-filter-button-enabled { + background-color: var(--jp-layout-color2); +} + +.jp-DocumentSearch-filter-button-enabled:hover { + background-color: var(--jp-layout-color3); +} + +.jp-DocumentSearch-search-options { + padding: 0 8px; + margin-left: 3px; + width: 100%; + display: grid; + justify-content: start; + grid-template-columns: 1fr 1fr; + align-items: center; + justify-items: stretch; +} + +.jp-DocumentSearch-search-filter-disabled { + color: var(--jp-ui-font-color2); +} + +.jp-DocumentSearch-search-filter { + display: flex; + align-items: center; + user-select: none; +} + +.jp-DocumentSearch-regex-error { + color: var(--jp-error-color0); +} + +.jp-DocumentSearch-replace-button-wrapper { + overflow: hidden; + display: inline-block; + box-sizing: border-box; + border: var(--jp-border-width) solid var(--jp-border-color0); + margin: auto 2px; + padding: 1px 4px; + height: calc(var(--jp-private-document-search-button-height) + 2px); +} + +.jp-DocumentSearch-replace-button-wrapper:focus { + border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color); +} + +.jp-DocumentSearch-replace-button { + display: inline-block; + text-align: center; + cursor: pointer; + box-sizing: border-box; + color: var(--jp-ui-font-color1); + + /* height - 2 * (padding of wrapper) */ + line-height: calc(var(--jp-private-document-search-button-height) - 2px); + width: 100%; + height: 100%; +} + +.jp-DocumentSearch-replace-button:focus { + outline: none; +} + +.jp-DocumentSearch-replace-wrapper-class { + margin-left: 14px; + display: flex; +} + +.jp-DocumentSearch-replace-toggle { + border: none; + background-color: var(--jp-toolbar-background); + border-radius: var(--jp-border-radius); +} + +.jp-DocumentSearch-replace-toggle:hover { + background-color: var(--jp-layout-color2); +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.cm-editor { + line-height: var(--jp-code-line-height); + font-size: var(--jp-code-font-size); + font-family: var(--jp-code-font-family); + border: 0; + border-radius: 0; + height: auto; + + /* Changed to auto to autogrow */ +} + +.cm-editor pre { + padding: 0 var(--jp-code-padding); +} + +.jp-CodeMirrorEditor[data-type='inline'] .cm-dialog { + background-color: var(--jp-layout-color0); + color: var(--jp-content-font-color1); +} + +.jp-CodeMirrorEditor { + cursor: text; +} + +/* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */ +@media screen and (min-width: 2138px) and (max-width: 4319px) { + .jp-CodeMirrorEditor[data-type='inline'] .cm-cursor { + border-left: var(--jp-code-cursor-width1) solid + var(--jp-editor-cursor-color); + } +} + +/* When zoomed out less than 33% */ +@media screen and (min-width: 4320px) { + .jp-CodeMirrorEditor[data-type='inline'] .cm-cursor { + border-left: var(--jp-code-cursor-width2) solid + var(--jp-editor-cursor-color); + } +} + +.cm-editor.jp-mod-readOnly .cm-cursor { + display: none; +} + +.jp-CollaboratorCursor { + border-left: 5px solid transparent; + border-right: 5px solid transparent; + border-top: none; + border-bottom: 3px solid; + background-clip: content-box; + margin-left: -5px; + margin-right: -5px; +} + +.cm-searching, +.cm-searching span { + /* `.cm-searching span`: we need to override syntax highlighting */ + background-color: var(--jp-search-unselected-match-background-color); + color: var(--jp-search-unselected-match-color); +} + +.cm-searching::selection, +.cm-searching span::selection { + background-color: var(--jp-search-unselected-match-background-color); + color: var(--jp-search-unselected-match-color); +} + +.jp-current-match > .cm-searching, +.jp-current-match > .cm-searching span, +.cm-searching > .jp-current-match, +.cm-searching > .jp-current-match span { + background-color: var(--jp-search-selected-match-background-color); + color: var(--jp-search-selected-match-color); +} + +.jp-current-match > .cm-searching::selection, +.cm-searching > .jp-current-match::selection, +.jp-current-match > .cm-searching span::selection { + background-color: var(--jp-search-selected-match-background-color); + color: var(--jp-search-selected-match-color); +} + +.cm-trailingspace { + background-image: url(); + background-position: center left; + background-repeat: repeat-x; +} + +.jp-CollaboratorCursor-hover { + position: absolute; + z-index: 1; + transform: translateX(-50%); + color: white; + border-radius: 3px; + padding-left: 4px; + padding-right: 4px; + padding-top: 1px; + padding-bottom: 1px; + text-align: center; + font-size: var(--jp-ui-font-size1); + white-space: nowrap; +} + +.jp-CodeMirror-ruler { + border-left: 1px dashed var(--jp-border-color2); +} + +/* Styles for shared cursors (remote cursor locations and selected ranges) */ +.jp-CodeMirrorEditor .cm-ySelectionCaret { + position: relative; + border-left: 1px solid black; + margin-left: -1px; + margin-right: -1px; + box-sizing: border-box; +} + +.jp-CodeMirrorEditor .cm-ySelectionCaret > .cm-ySelectionInfo { + white-space: nowrap; + position: absolute; + top: -1.15em; + padding-bottom: 0.05em; + left: -1px; + font-size: 0.95em; + font-family: var(--jp-ui-font-family); + font-weight: bold; + line-height: normal; + user-select: none; + color: white; + padding-left: 2px; + padding-right: 2px; + z-index: 101; + transition: opacity 0.3s ease-in-out; +} + +.jp-CodeMirrorEditor .cm-ySelectionInfo { + transition-delay: 0.7s; + opacity: 0; +} + +.jp-CodeMirrorEditor .cm-ySelectionCaret:hover > .cm-ySelectionInfo { + opacity: 1; + transition-delay: 0s; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-MimeDocument { + outline: none; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Variables +|----------------------------------------------------------------------------*/ + +:root { + --jp-private-filebrowser-button-height: 28px; + --jp-private-filebrowser-button-width: 48px; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-FileBrowser .jp-SidePanel-content { + display: flex; + flex-direction: column; +} + +.jp-FileBrowser-toolbar.jp-Toolbar { + flex-wrap: wrap; + row-gap: 12px; + border-bottom: none; + height: auto; + margin: 8px 12px 0; + box-shadow: none; + padding: 0; + justify-content: flex-start; +} + +.jp-FileBrowser-Panel { + flex: 1 1 auto; + display: flex; + flex-direction: column; +} + +.jp-BreadCrumbs { + flex: 0 0 auto; + margin: 8px 12px; +} + +.jp-BreadCrumbs-item { + margin: 0 2px; + padding: 0 2px; + border-radius: var(--jp-border-radius); + cursor: pointer; +} + +.jp-BreadCrumbs-item:hover { + background-color: var(--jp-layout-color2); +} + +.jp-BreadCrumbs-item:first-child { + margin-left: 0; +} + +.jp-BreadCrumbs-item.jp-mod-dropTarget { + background-color: var(--jp-brand-color2); + opacity: 0.7; +} + +/*----------------------------------------------------------------------------- +| Buttons +|----------------------------------------------------------------------------*/ + +.jp-FileBrowser-toolbar > .jp-Toolbar-item { + flex: 0 0 auto; + padding-left: 0; + padding-right: 2px; + align-items: center; + height: unset; +} + +.jp-FileBrowser-toolbar > .jp-Toolbar-item .jp-ToolbarButtonComponent { + width: 40px; +} + +/*----------------------------------------------------------------------------- +| Other styles +|----------------------------------------------------------------------------*/ + +.jp-FileDialog.jp-mod-conflict input { + color: var(--jp-error-color1); +} + +.jp-FileDialog .jp-new-name-title { + margin-top: 12px; +} + +.jp-LastModified-hidden { + display: none; +} + +.jp-FileSize-hidden { + display: none; +} + +.jp-FileBrowser .lm-AccordionPanel > h3:first-child { + display: none; +} + +/*----------------------------------------------------------------------------- +| DirListing +|----------------------------------------------------------------------------*/ + +.jp-DirListing { + flex: 1 1 auto; + display: flex; + flex-direction: column; + outline: 0; +} + +.jp-DirListing-header { + flex: 0 0 auto; + display: flex; + flex-direction: row; + align-items: center; + overflow: hidden; + border-top: var(--jp-border-width) solid var(--jp-border-color2); + border-bottom: var(--jp-border-width) solid var(--jp-border-color1); + box-shadow: var(--jp-toolbar-box-shadow); + z-index: 2; +} + +.jp-DirListing-headerItem { + padding: 4px 12px 2px; + font-weight: 500; +} + +.jp-DirListing-headerItem:hover { + background: var(--jp-layout-color2); +} + +.jp-DirListing-headerItem.jp-id-name { + flex: 1 0 84px; +} + +.jp-DirListing-headerItem.jp-id-modified { + flex: 0 0 112px; + border-left: var(--jp-border-width) solid var(--jp-border-color2); + text-align: right; +} + +.jp-DirListing-headerItem.jp-id-filesize { + flex: 0 0 75px; + border-left: var(--jp-border-width) solid var(--jp-border-color2); + text-align: right; +} + +.jp-id-narrow { + display: none; + flex: 0 0 5px; + padding: 4px; + border-left: var(--jp-border-width) solid var(--jp-border-color2); + text-align: right; + color: var(--jp-border-color2); +} + +.jp-DirListing-narrow .jp-id-narrow { + display: block; +} + +.jp-DirListing-narrow .jp-id-modified, +.jp-DirListing-narrow .jp-DirListing-itemModified { + display: none; +} + +.jp-DirListing-headerItem.jp-mod-selected { + font-weight: 600; +} + +/* increase specificity to override bundled default */ +.jp-DirListing-content { + flex: 1 1 auto; + margin: 0; + padding: 0; + list-style-type: none; + overflow: auto; + background-color: var(--jp-layout-color1); +} + +.jp-DirListing-content mark { + color: var(--jp-ui-font-color0); + background-color: transparent; + font-weight: bold; +} + +.jp-DirListing-content .jp-DirListing-item.jp-mod-selected mark { + color: var(--jp-ui-inverse-font-color0); +} + +/* Style the directory listing content when a user drops a file to upload */ +.jp-DirListing.jp-mod-native-drop .jp-DirListing-content { + outline: 5px dashed rgba(128, 128, 128, 0.5); + outline-offset: -10px; + cursor: copy; +} + +.jp-DirListing-item { + display: flex; + flex-direction: row; + align-items: center; + padding: 4px 12px; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.jp-DirListing-checkboxWrapper { + /* Increases hit area of checkbox. */ + padding: 4px; +} + +.jp-DirListing-header + .jp-DirListing-checkboxWrapper + + .jp-DirListing-headerItem { + padding-left: 4px; +} + +.jp-DirListing-content .jp-DirListing-checkboxWrapper { + position: relative; + left: -4px; + margin: -4px 0 -4px -8px; +} + +.jp-DirListing-checkboxWrapper.jp-mod-visible { + visibility: visible; +} + +/* For devices that support hovering, hide checkboxes until hovered, selected... +*/ +@media (hover: hover) { + .jp-DirListing-checkboxWrapper { + visibility: hidden; + } + + .jp-DirListing-item:hover .jp-DirListing-checkboxWrapper, + .jp-DirListing-item.jp-mod-selected .jp-DirListing-checkboxWrapper { + visibility: visible; + } +} + +.jp-DirListing-item[data-is-dot] { + opacity: 75%; +} + +.jp-DirListing-item.jp-mod-selected { + color: var(--jp-ui-inverse-font-color1); + background: var(--jp-brand-color1); +} + +.jp-DirListing-item.jp-mod-dropTarget { + background: var(--jp-brand-color3); +} + +.jp-DirListing-item:hover:not(.jp-mod-selected) { + background: var(--jp-layout-color2); +} + +.jp-DirListing-itemIcon { + flex: 0 0 20px; + margin-right: 4px; +} + +.jp-DirListing-itemText { + flex: 1 0 64px; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + user-select: none; +} + +.jp-DirListing-itemText:focus { + outline-width: 2px; + outline-color: var(--jp-inverse-layout-color1); + outline-style: solid; + outline-offset: 1px; +} + +.jp-DirListing-item.jp-mod-selected .jp-DirListing-itemText:focus { + outline-color: var(--jp-layout-color1); +} + +.jp-DirListing-itemModified { + flex: 0 0 125px; + text-align: right; +} + +.jp-DirListing-itemFileSize { + flex: 0 0 90px; + text-align: right; +} + +.jp-DirListing-editor { + flex: 1 0 64px; + outline: none; + border: none; + color: var(--jp-ui-font-color1); + background-color: var(--jp-layout-color1); +} + +.jp-DirListing-item.jp-mod-running .jp-DirListing-itemIcon::before { + color: var(--jp-success-color1); + content: '\25CF'; + font-size: 8px; + position: absolute; + left: -8px; +} + +.jp-DirListing-item.jp-mod-running.jp-mod-selected + .jp-DirListing-itemIcon::before { + color: var(--jp-ui-inverse-font-color1); +} + +.jp-DirListing-item.lm-mod-drag-image, +.jp-DirListing-item.jp-mod-selected.lm-mod-drag-image { + font-size: var(--jp-ui-font-size1); + padding-left: 4px; + margin-left: 4px; + width: 160px; + background-color: var(--jp-ui-inverse-font-color2); + box-shadow: var(--jp-elevation-z2); + border-radius: 0; + color: var(--jp-ui-font-color1); + transform: translateX(-40%) translateY(-58%); +} + +.jp-Document { + min-width: 120px; + min-height: 120px; + outline: none; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Main OutputArea +| OutputArea has a list of Outputs +|----------------------------------------------------------------------------*/ + +.jp-OutputArea { + overflow-y: auto; +} + +.jp-OutputArea-child { + display: table; + table-layout: fixed; + width: 100%; + overflow: hidden; +} + +.jp-OutputPrompt { + width: var(--jp-cell-prompt-width); + color: var(--jp-cell-outprompt-font-color); + font-family: var(--jp-cell-prompt-font-family); + padding: var(--jp-code-padding); + letter-spacing: var(--jp-cell-prompt-letter-spacing); + line-height: var(--jp-code-line-height); + font-size: var(--jp-code-font-size); + border: var(--jp-border-width) solid transparent; + opacity: var(--jp-cell-prompt-opacity); + + /* Right align prompt text, don't wrap to handle large prompt numbers */ + text-align: right; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + + /* Disable text selection */ + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.jp-OutputArea-prompt { + display: table-cell; + vertical-align: top; +} + +.jp-OutputArea-output { + display: table-cell; + width: 100%; + height: auto; + overflow: auto; + user-select: text; + -moz-user-select: text; + -webkit-user-select: text; + -ms-user-select: text; +} + +.jp-OutputArea .jp-RenderedText { + padding-left: 1ch; +} + +/** + * Prompt overlay. + */ + +.jp-OutputArea-promptOverlay { + position: absolute; + top: 0; + width: var(--jp-cell-prompt-width); + height: 100%; + opacity: 0.5; +} + +.jp-OutputArea-promptOverlay:hover { + background: var(--jp-layout-color2); + box-shadow: inset 0 0 1px var(--jp-inverse-layout-color0); + cursor: zoom-out; +} + +.jp-mod-outputsScrolled .jp-OutputArea-promptOverlay:hover { + cursor: zoom-in; +} + +/** + * Isolated output. + */ +.jp-OutputArea-output.jp-mod-isolated { + width: 100%; + display: block; +} + +/* +When drag events occur, `lm-mod-override-cursor` is added to the body. +Because iframes steal all cursor events, the following two rules are necessary +to suppress pointer events while resize drags are occurring. There may be a +better solution to this problem. +*/ +body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated { + position: relative; +} + +body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated::before { + content: ''; + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; + background: transparent; +} + +/* pre */ + +.jp-OutputArea-output pre { + border: none; + margin: 0; + padding: 0; + overflow-x: auto; + overflow-y: auto; + word-break: break-all; + word-wrap: break-word; + white-space: pre-wrap; +} + +/* tables */ + +.jp-OutputArea-output.jp-RenderedHTMLCommon table { + margin-left: 0; + margin-right: 0; +} + +/* description lists */ + +.jp-OutputArea-output dl, +.jp-OutputArea-output dt, +.jp-OutputArea-output dd { + display: block; +} + +.jp-OutputArea-output dl { + width: 100%; + overflow: hidden; + padding: 0; + margin: 0; +} + +.jp-OutputArea-output dt { + font-weight: bold; + float: left; + width: 20%; + padding: 0; + margin: 0; +} + +.jp-OutputArea-output dd { + float: left; + width: 80%; + padding: 0; + margin: 0; +} + +.jp-TrimmedOutputs pre { + background: var(--jp-layout-color3); + font-size: calc(var(--jp-code-font-size) * 1.4); + text-align: center; + text-transform: uppercase; +} + +/* Hide the gutter in case of + * - nested output areas (e.g. in the case of output widgets) + * - mirrored output areas + */ +.jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt { + display: none; +} + +/* Hide empty lines in the output area, for instance due to cleared widgets */ +.jp-OutputArea-prompt:empty { + padding: 0; + border: 0; +} + +/*----------------------------------------------------------------------------- +| executeResult is added to any Output-result for the display of the object +| returned by a cell +|----------------------------------------------------------------------------*/ + +.jp-OutputArea-output.jp-OutputArea-executeResult { + margin-left: 0; + width: 100%; +} + +/* Text output with the Out[] prompt needs a top padding to match the + * alignment of the Out[] prompt itself. + */ +.jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output { + padding-top: var(--jp-code-padding); + border-top: var(--jp-border-width) solid transparent; +} + +/*----------------------------------------------------------------------------- +| The Stdin output +|----------------------------------------------------------------------------*/ + +.jp-Stdin-prompt { + color: var(--jp-content-font-color0); + padding-right: var(--jp-code-padding); + vertical-align: baseline; + flex: 0 0 auto; +} + +.jp-Stdin-input { + font-family: var(--jp-code-font-family); + font-size: inherit; + color: inherit; + background-color: inherit; + width: 42%; + min-width: 200px; + + /* make sure input baseline aligns with prompt */ + vertical-align: baseline; + + /* padding + margin = 0.5em between prompt and cursor */ + padding: 0 0.25em; + margin: 0 0.25em; + flex: 0 0 70%; +} + +.jp-Stdin-input::placeholder { + opacity: 0; +} + +.jp-Stdin-input:focus { + box-shadow: none; +} + +.jp-Stdin-input:focus::placeholder { + opacity: 1; +} + +/*----------------------------------------------------------------------------- +| Output Area View +|----------------------------------------------------------------------------*/ + +.jp-LinkedOutputView .jp-OutputArea { + height: 100%; + display: block; +} + +.jp-LinkedOutputView .jp-OutputArea-output:only-child { + height: 100%; +} + +/*----------------------------------------------------------------------------- +| Printing +|----------------------------------------------------------------------------*/ + +@media print { + .jp-OutputArea-child { + break-inside: avoid-page; + } +} + +/*----------------------------------------------------------------------------- +| Mobile +|----------------------------------------------------------------------------*/ +@media only screen and (max-width: 760px) { + .jp-OutputPrompt { + display: table-row; + text-align: left; + } + + .jp-OutputArea-child .jp-OutputArea-output { + display: table-row; + margin-left: var(--jp-notebook-padding); + } +} + +/* Trimmed outputs warning */ +.jp-TrimmedOutputs > a { + margin: 10px; + text-decoration: none; + cursor: pointer; +} + +.jp-TrimmedOutputs > a:hover { + text-decoration: none; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Table of Contents +|----------------------------------------------------------------------------*/ + +:root { + --jp-private-toc-active-width: 4px; +} + +.jp-TableOfContents { + display: flex; + flex-direction: column; + background: var(--jp-layout-color1); + color: var(--jp-ui-font-color1); + font-size: var(--jp-ui-font-size1); + height: 100%; +} + +.jp-TableOfContents-placeholder { + text-align: center; +} + +.jp-TableOfContents-placeholderContent { + color: var(--jp-content-font-color2); + padding: 8px; +} + +.jp-TableOfContents-placeholderContent > h3 { + margin-bottom: var(--jp-content-heading-margin-bottom); +} + +.jp-TableOfContents .jp-SidePanel-content { + overflow-y: auto; +} + +.jp-TableOfContents-tree { + margin: 4px; +} + +.jp-TableOfContents ol { + list-style-type: none; +} + +/* stylelint-disable-next-line selector-max-type */ +.jp-TableOfContents li > ol { + /* Align left border with triangle icon center */ + padding-left: 11px; +} + +.jp-TableOfContents-content { + /* left margin for the active heading indicator */ + margin: 0 0 0 var(--jp-private-toc-active-width); + padding: 0; + background-color: var(--jp-layout-color1); +} + +.jp-tocItem { + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.jp-tocItem-heading { + display: flex; + cursor: pointer; +} + +.jp-tocItem-heading:hover { + background-color: var(--jp-layout-color2); +} + +.jp-tocItem-content { + display: block; + padding: 4px 0; + white-space: nowrap; + text-overflow: ellipsis; + overflow-x: hidden; +} + +.jp-tocItem-collapser { + height: 20px; + margin: 2px 2px 0; + padding: 0; + background: none; + border: none; + cursor: pointer; +} + +.jp-tocItem-collapser:hover { + background-color: var(--jp-layout-color3); +} + +/* Active heading indicator */ + +.jp-tocItem-heading::before { + content: ' '; + background: transparent; + width: var(--jp-private-toc-active-width); + height: 24px; + position: absolute; + left: 0; + border-radius: var(--jp-border-radius); +} + +.jp-tocItem-heading.jp-tocItem-active::before { + background-color: var(--jp-brand-color1); +} + +.jp-tocItem-heading:hover.jp-tocItem-active::before { + background: var(--jp-brand-color0); + opacity: 1; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +.jp-Collapser { + flex: 0 0 var(--jp-cell-collapser-width); + padding: 0; + margin: 0; + border: none; + outline: none; + background: transparent; + border-radius: var(--jp-border-radius); + opacity: 1; +} + +.jp-Collapser-child { + display: block; + width: 100%; + box-sizing: border-box; + + /* height: 100% doesn't work because the height of its parent is computed from content */ + position: absolute; + top: 0; + bottom: 0; +} + +/*----------------------------------------------------------------------------- +| Printing +|----------------------------------------------------------------------------*/ + +/* +Hiding collapsers in print mode. + +Note: input and output wrappers have "display: block" propery in print mode. +*/ + +@media print { + .jp-Collapser { + display: none; + } +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Header/Footer +|----------------------------------------------------------------------------*/ + +/* Hidden by zero height by default */ +.jp-CellHeader, +.jp-CellFooter { + height: 0; + width: 100%; + padding: 0; + margin: 0; + border: none; + outline: none; + background: transparent; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Input +|----------------------------------------------------------------------------*/ + +/* All input areas */ +.jp-InputArea { + display: table; + table-layout: fixed; + width: 100%; + overflow: hidden; +} + +.jp-InputArea-editor { + display: table-cell; + overflow: hidden; + vertical-align: top; + + /* This is the non-active, default styling */ + border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); + border-radius: 0; + background: var(--jp-cell-editor-background); +} + +.jp-InputPrompt { + display: table-cell; + vertical-align: top; + width: var(--jp-cell-prompt-width); + color: var(--jp-cell-inprompt-font-color); + font-family: var(--jp-cell-prompt-font-family); + padding: var(--jp-code-padding); + letter-spacing: var(--jp-cell-prompt-letter-spacing); + opacity: var(--jp-cell-prompt-opacity); + line-height: var(--jp-code-line-height); + font-size: var(--jp-code-font-size); + border: var(--jp-border-width) solid transparent; + + /* Right align prompt text, don't wrap to handle large prompt numbers */ + text-align: right; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + + /* Disable text selection */ + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +/*----------------------------------------------------------------------------- +| Mobile +|----------------------------------------------------------------------------*/ +@media only screen and (max-width: 760px) { + .jp-InputArea-editor { + display: table-row; + margin-left: var(--jp-notebook-padding); + } + + .jp-InputPrompt { + display: table-row; + text-align: left; + } +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Placeholder +|----------------------------------------------------------------------------*/ + +.jp-Placeholder { + display: table; + table-layout: fixed; + width: 100%; +} + +.jp-Placeholder-prompt { + display: table-cell; + box-sizing: border-box; +} + +.jp-Placeholder-content { + display: table-cell; + padding: 4px 6px; + border: 1px solid transparent; + border-radius: 0; + background: none; + box-sizing: border-box; + cursor: pointer; +} + +.jp-Placeholder-contentContainer { + display: flex; +} + +.jp-Placeholder-content:hover, +.jp-InputPlaceholder > .jp-Placeholder-content:hover { + border-color: var(--jp-layout-color3); +} + +.jp-Placeholder-content .jp-MoreHorizIcon { + width: 32px; + height: 16px; + border: 1px solid transparent; + border-radius: var(--jp-border-radius); +} + +.jp-Placeholder-content .jp-MoreHorizIcon:hover { + border: 1px solid var(--jp-border-color1); + box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.25); + background-color: var(--jp-layout-color0); +} + +.jp-PlaceholderText { + white-space: nowrap; + overflow-x: hidden; + color: var(--jp-inverse-layout-color3); + font-family: var(--jp-code-font-family); +} + +.jp-InputPlaceholder > .jp-Placeholder-content { + border-color: var(--jp-cell-editor-border-color); + background: var(--jp-cell-editor-background); +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Private CSS variables +|----------------------------------------------------------------------------*/ + +:root { + --jp-private-cell-scrolling-output-offset: 5px; +} + +/*----------------------------------------------------------------------------- +| Cell +|----------------------------------------------------------------------------*/ + +.jp-Cell { + padding: var(--jp-cell-padding); + margin: 0; + border: none; + outline: none; + background: transparent; +} + +/*----------------------------------------------------------------------------- +| Common input/output +|----------------------------------------------------------------------------*/ + +.jp-Cell-inputWrapper, +.jp-Cell-outputWrapper { + display: flex; + flex-direction: row; + padding: 0; + margin: 0; + + /* Added to reveal the box-shadow on the input and output collapsers. */ + overflow: visible; +} + +/* Only input/output areas inside cells */ +.jp-Cell-inputArea, +.jp-Cell-outputArea { + flex: 1 1 auto; +} + +/*----------------------------------------------------------------------------- +| Collapser +|----------------------------------------------------------------------------*/ + +/* Make the output collapser disappear when there is not output, but do so + * in a manner that leaves it in the layout and preserves its width. + */ +.jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser { + border: none !important; + background: transparent !important; +} + +.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser { + min-height: var(--jp-cell-collapser-min-height); +} + +/*----------------------------------------------------------------------------- +| Output +|----------------------------------------------------------------------------*/ + +/* Put a space between input and output when there IS output */ +.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper { + margin-top: 5px; +} + +.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea { + overflow-y: auto; + max-height: 24em; + margin-left: var(--jp-private-cell-scrolling-output-offset); + resize: vertical; +} + +.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea[style*='height'] { + max-height: unset; +} + +.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea::after { + content: ' '; + box-shadow: inset 0 0 6px 2px rgb(0 0 0 / 30%); + width: 100%; + height: 100%; + position: sticky; + bottom: 0; + top: 0; + margin-top: -50%; + float: left; + display: block; + pointer-events: none; +} + +.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-child { + padding-top: 6px; +} + +.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt { + width: calc( + var(--jp-cell-prompt-width) - var(--jp-private-cell-scrolling-output-offset) + ); +} + +.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-promptOverlay { + left: calc(-1 * var(--jp-private-cell-scrolling-output-offset)); +} + +/*----------------------------------------------------------------------------- +| CodeCell +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| MarkdownCell +|----------------------------------------------------------------------------*/ + +.jp-MarkdownOutput { + display: table-cell; + width: 100%; + margin-top: 0; + margin-bottom: 0; + padding-left: var(--jp-code-padding); +} + +.jp-MarkdownOutput.jp-RenderedHTMLCommon { + overflow: auto; +} + +/* collapseHeadingButton (show always if hiddenCellsButton is _not_ shown) */ +.jp-collapseHeadingButton { + display: flex; + min-height: var(--jp-cell-collapser-min-height); + font-size: var(--jp-code-font-size); + position: absolute; + background-color: transparent; + background-size: 25px; + background-repeat: no-repeat; + background-position-x: center; + background-position-y: top; + background-image: var(--jp-icon-caret-down); + right: 0; + top: 0; + bottom: 0; +} + +.jp-collapseHeadingButton.jp-mod-collapsed { + background-image: var(--jp-icon-caret-right); +} + +/* + set the container font size to match that of content + so that the nested collapse buttons have the right size +*/ +.jp-MarkdownCell .jp-InputPrompt { + font-size: var(--jp-content-font-size1); +} + +/* + Align collapseHeadingButton with cell top header + The font sizes are identical to the ones in packages/rendermime/style/base.css +*/ +.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='1'] { + font-size: var(--jp-content-font-size5); + background-position-y: calc(0.3 * var(--jp-content-font-size5)); +} + +.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='2'] { + font-size: var(--jp-content-font-size4); + background-position-y: calc(0.3 * var(--jp-content-font-size4)); +} + +.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='3'] { + font-size: var(--jp-content-font-size3); + background-position-y: calc(0.3 * var(--jp-content-font-size3)); +} + +.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='4'] { + font-size: var(--jp-content-font-size2); + background-position-y: calc(0.3 * var(--jp-content-font-size2)); +} + +.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='5'] { + font-size: var(--jp-content-font-size1); + background-position-y: top; +} + +.jp-mod-rendered .jp-collapseHeadingButton[data-heading-level='6'] { + font-size: var(--jp-content-font-size0); + background-position-y: top; +} + +/* collapseHeadingButton (show only on (hover,active) if hiddenCellsButton is shown) */ +.jp-Notebook.jp-mod-showHiddenCellsButton .jp-collapseHeadingButton { + display: none; +} + +.jp-Notebook.jp-mod-showHiddenCellsButton + :is(.jp-MarkdownCell:hover, .jp-mod-active) + .jp-collapseHeadingButton { + display: flex; +} + +/* showHiddenCellsButton (only show if jp-mod-showHiddenCellsButton is set, which +is a consequence of the showHiddenCellsButton option in Notebook Settings)*/ +.jp-Notebook.jp-mod-showHiddenCellsButton .jp-showHiddenCellsButton { + margin-left: calc(var(--jp-cell-prompt-width) + 2 * var(--jp-code-padding)); + margin-top: var(--jp-code-padding); + border: 1px solid var(--jp-border-color2); + background-color: var(--jp-border-color3) !important; + color: var(--jp-content-font-color0) !important; + display: flex; +} + +.jp-Notebook.jp-mod-showHiddenCellsButton .jp-showHiddenCellsButton:hover { + background-color: var(--jp-border-color2) !important; +} + +.jp-showHiddenCellsButton { + display: none; +} + +/*----------------------------------------------------------------------------- +| Printing +|----------------------------------------------------------------------------*/ + +/* +Using block instead of flex to allow the use of the break-inside CSS property for +cell outputs. +*/ + +@media print { + .jp-Cell-inputWrapper, + .jp-Cell-outputWrapper { + display: block; + } +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Variables +|----------------------------------------------------------------------------*/ + +:root { + --jp-notebook-toolbar-padding: 2px 5px 2px 2px; +} + +/*----------------------------------------------------------------------------- + +/*----------------------------------------------------------------------------- +| Styles +|----------------------------------------------------------------------------*/ + +.jp-NotebookPanel-toolbar { + padding: var(--jp-notebook-toolbar-padding); + + /* disable paint containment from lumino 2.0 default strict CSS containment */ + contain: style size !important; +} + +.jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused { + border: none; + box-shadow: none; +} + +.jp-Notebook-toolbarCellTypeDropdown select { + height: 24px; + font-size: var(--jp-ui-font-size1); + line-height: 14px; + border-radius: 0; + display: block; +} + +.jp-Notebook-toolbarCellTypeDropdown span { + top: 5px !important; +} + +.jp-Toolbar-responsive-popup { + position: absolute; + height: fit-content; + display: flex; + flex-direction: row; + flex-wrap: wrap; + justify-content: flex-end; + border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color); + box-shadow: var(--jp-toolbar-box-shadow); + background: var(--jp-toolbar-background); + min-height: var(--jp-toolbar-micro-height); + padding: var(--jp-notebook-toolbar-padding); + z-index: 1; + right: 0; + top: 0; +} + +.jp-Toolbar > .jp-Toolbar-responsive-opener { + margin-left: auto; +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Variables +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- + +/*----------------------------------------------------------------------------- +| Styles +|----------------------------------------------------------------------------*/ + +.jp-Notebook-ExecutionIndicator { + position: relative; + display: inline-block; + height: 100%; + z-index: 9997; +} + +.jp-Notebook-ExecutionIndicator-tooltip { + visibility: hidden; + height: auto; + width: max-content; + width: -moz-max-content; + background-color: var(--jp-layout-color2); + color: var(--jp-ui-font-color1); + text-align: justify; + border-radius: 6px; + padding: 0 5px; + position: fixed; + display: table; +} + +.jp-Notebook-ExecutionIndicator-tooltip.up { + transform: translateX(-50%) translateY(-100%) translateY(-32px); +} + +.jp-Notebook-ExecutionIndicator-tooltip.down { + transform: translateX(calc(-100% + 16px)) translateY(5px); +} + +.jp-Notebook-ExecutionIndicator-tooltip.hidden { + display: none; +} + +.jp-Notebook-ExecutionIndicator:hover .jp-Notebook-ExecutionIndicator-tooltip { + visibility: visible; +} + +.jp-Notebook-ExecutionIndicator span { + font-size: var(--jp-ui-font-size1); + font-family: var(--jp-ui-font-family); + color: var(--jp-ui-font-color1); + line-height: 24px; + display: block; +} + +.jp-Notebook-ExecutionIndicator-progress-bar { + display: flex; + justify-content: center; + height: 100%; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +/* + * Execution indicator + */ +.jp-tocItem-content::after { + content: ''; + + /* Must be identical to form a circle */ + width: 12px; + height: 12px; + background: none; + border: none; + position: absolute; + right: 0; +} + +.jp-tocItem-content[data-running='0']::after { + border-radius: 50%; + border: var(--jp-border-width) solid var(--jp-inverse-layout-color3); + background: none; +} + +.jp-tocItem-content[data-running='1']::after { + border-radius: 50%; + border: var(--jp-border-width) solid var(--jp-inverse-layout-color3); + background-color: var(--jp-inverse-layout-color3); +} + +.jp-tocItem-content[data-running='0'], +.jp-tocItem-content[data-running='1'] { + margin-right: 12px; +} + +/* + * Copyright (c) Jupyter Development Team. + * Distributed under the terms of the Modified BSD License. + */ + +.jp-Notebook-footer { + height: 27px; + margin-left: calc( + var(--jp-cell-prompt-width) + var(--jp-cell-collapser-width) + + var(--jp-cell-padding) + ); + width: calc( + 100% - + ( + var(--jp-cell-prompt-width) + var(--jp-cell-collapser-width) + + var(--jp-cell-padding) + var(--jp-cell-padding) + ) + ); + border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); + color: var(--jp-ui-font-color3); + margin-top: 6px; + background: none; + cursor: pointer; +} + +.jp-Notebook-footer:focus { + border-color: var(--jp-cell-editor-active-border-color); +} + +/* For devices that support hovering, hide footer until hover */ +@media (hover: hover) { + .jp-Notebook-footer { + opacity: 0; + } + + .jp-Notebook-footer:focus, + .jp-Notebook-footer:hover { + opacity: 1; + } +} + +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| Imports +|----------------------------------------------------------------------------*/ + +/*----------------------------------------------------------------------------- +| CSS variables +|----------------------------------------------------------------------------*/ + +:root { + --jp-side-by-side-output-size: 1fr; + --jp-side-by-side-resized-cell: var(--jp-side-by-side-output-size); + --jp-private-notebook-dragImage-width: 304px; + --jp-private-notebook-dragImage-height: 36px; + --jp-private-notebook-selected-color: var(--md-blue-400); + --jp-private-notebook-active-color: var(--md-green-400); +} + +/*----------------------------------------------------------------------------- +| Notebook +|----------------------------------------------------------------------------*/ + +/* stylelint-disable selector-max-class */ + +.jp-NotebookPanel { + display: block; + height: 100%; +} + +.jp-NotebookPanel.jp-Document { + min-width: 240px; + min-height: 120px; +} + +.jp-Notebook { + padding: var(--jp-notebook-padding); + outline: none; + overflow: auto; + background: var(--jp-layout-color0); +} + +.jp-Notebook.jp-mod-scrollPastEnd::after { + display: block; + content: ''; + min-height: var(--jp-notebook-scroll-padding); +} + +.jp-MainAreaWidget-ContainStrict .jp-Notebook * { + contain: strict; +} + +.jp-Notebook .jp-Cell { + overflow: visible; +} + +.jp-Notebook .jp-Cell .jp-InputPrompt { + cursor: move; +} + +/*----------------------------------------------------------------------------- +| Notebook state related styling +| +| The notebook and cells each have states, here are the possibilities: +| +| - Notebook +| - Command +| - Edit +| - Cell +| - None +| - Active (only one can be active) +| - Selected (the cells actions are applied to) +| - Multiselected (when multiple selected, the cursor) +| - No outputs +|----------------------------------------------------------------------------*/ + +/* Command or edit modes */ + +.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-InputPrompt { + opacity: var(--jp-cell-prompt-not-active-opacity); + color: var(--jp-cell-prompt-not-active-font-color); +} + +.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-OutputPrompt { + opacity: var(--jp-cell-prompt-not-active-opacity); + color: var(--jp-cell-prompt-not-active-font-color); +} + +/* cell is active */ +.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser { + background: var(--jp-brand-color1); +} + +/* cell is dirty */ +.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt { + color: var(--jp-warn-color1); +} + +.jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt::before { + color: var(--jp-warn-color1); + content: '•'; +} + +.jp-Notebook .jp-Cell.jp-mod-active.jp-mod-dirty .jp-Collapser { + background: var(--jp-warn-color1); +} + +/* collapser is hovered */ +.jp-Notebook .jp-Cell .jp-Collapser:hover { + box-shadow: var(--jp-elevation-z2); + background: var(--jp-brand-color1); + opacity: var(--jp-cell-collapser-not-active-hover-opacity); +} + +/* cell is active and collapser is hovered */ +.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser:hover { + background: var(--jp-brand-color0); + opacity: 1; +} + +/* Command mode */ + +.jp-Notebook.jp-mod-commandMode .jp-Cell.jp-mod-selected { + background: var(--jp-notebook-multiselected-color); +} + +.jp-Notebook.jp-mod-commandMode + .jp-Cell.jp-mod-active.jp-mod-selected:not(.jp-mod-multiSelected) { + background: transparent; +} + +/* Edit mode */ + +.jp-Notebook.jp-mod-editMode .jp-Cell.jp-mod-active .jp-InputArea-editor { + border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color); + box-shadow: var(--jp-input-box-shadow); + background-color: var(--jp-cell-editor-active-background); +} + +/*----------------------------------------------------------------------------- +| Notebook drag and drop +|----------------------------------------------------------------------------*/ + +.jp-Notebook-cell.jp-mod-dropSource { + opacity: 0.5; +} + +.jp-Notebook-cell.jp-mod-dropTarget, +.jp-Notebook.jp-mod-commandMode + .jp-Notebook-cell.jp-mod-active.jp-mod-selected.jp-mod-dropTarget { + border-top-color: var(--jp-private-notebook-selected-color); + border-top-style: solid; + border-top-width: 2px; +} + +.jp-dragImage { + display: block; + flex-direction: row; + width: var(--jp-private-notebook-dragImage-width); + height: var(--jp-private-notebook-dragImage-height); + border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); + background: var(--jp-cell-editor-background); + overflow: visible; +} + +.jp-dragImage-singlePrompt { + box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.12); +} + +.jp-dragImage .jp-dragImage-content { + flex: 1 1 auto; + z-index: 2; + font-size: var(--jp-code-font-size); + font-family: var(--jp-code-font-family); + line-height: var(--jp-code-line-height); + padding: var(--jp-code-padding); + border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); + background: var(--jp-cell-editor-background-color); + color: var(--jp-content-font-color3); + text-align: left; + margin: 4px 4px 4px 0; +} + +.jp-dragImage .jp-dragImage-prompt { + flex: 0 0 auto; + min-width: 36px; + color: var(--jp-cell-inprompt-font-color); + padding: var(--jp-code-padding); + padding-left: 12px; + font-family: var(--jp-cell-prompt-font-family); + letter-spacing: var(--jp-cell-prompt-letter-spacing); + line-height: 1.9; + font-size: var(--jp-code-font-size); + border: var(--jp-border-width) solid transparent; +} + +.jp-dragImage-multipleBack { + z-index: -1; + position: absolute; + height: 32px; + width: 300px; + top: 8px; + left: 8px; + background: var(--jp-layout-color2); + border: var(--jp-border-width) solid var(--jp-input-border-color); + box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.12); +} + +/*----------------------------------------------------------------------------- +| Cell toolbar +|----------------------------------------------------------------------------*/ + +.jp-NotebookTools { + display: block; + min-width: var(--jp-sidebar-min-width); + color: var(--jp-ui-font-color1); + background: var(--jp-layout-color1); + + /* This is needed so that all font sizing of children done in ems is + * relative to this base size */ + font-size: var(--jp-ui-font-size1); + overflow: auto; +} + +.jp-ActiveCellTool { + padding: 12px 0; + display: flex; +} + +.jp-ActiveCellTool-Content { + flex: 1 1 auto; +} + +.jp-ActiveCellTool .jp-ActiveCellTool-CellContent { + background: var(--jp-cell-editor-background); + border: var(--jp-border-width) solid var(--jp-cell-editor-border-color); + border-radius: 0; + min-height: 29px; +} + +.jp-ActiveCellTool .jp-InputPrompt { + min-width: calc(var(--jp-cell-prompt-width) * 0.75); +} + +.jp-ActiveCellTool-CellContent > pre { + padding: 5px 4px; + margin: 0; + white-space: normal; +} + +.jp-MetadataEditorTool { + flex-direction: column; + padding: 12px 0; +} + +.jp-RankedPanel > :not(:first-child) { + margin-top: 12px; +} + +.jp-KeySelector select.jp-mod-styled { + font-size: var(--jp-ui-font-size1); + color: var(--jp-ui-font-color0); + border: var(--jp-border-width) solid var(--jp-border-color1); +} + +.jp-KeySelector label, +.jp-MetadataEditorTool label, +.jp-NumberSetter label { + line-height: 1.4; +} + +.jp-NotebookTools .jp-select-wrapper { + margin-top: 4px; + margin-bottom: 0; +} + +.jp-NumberSetter input { + width: 100%; + margin-top: 4px; +} + +.jp-NotebookTools .jp-Collapse { + margin-top: 16px; +} + +/*----------------------------------------------------------------------------- +| Presentation Mode (.jp-mod-presentationMode) +|----------------------------------------------------------------------------*/ + +.jp-mod-presentationMode .jp-Notebook { + --jp-content-font-size1: var(--jp-content-presentation-font-size1); + --jp-code-font-size: var(--jp-code-presentation-font-size); +} + +.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt, +.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt { + flex: 0 0 110px; +} + +/*----------------------------------------------------------------------------- +| Side-by-side Mode (.jp-mod-sideBySide) +|----------------------------------------------------------------------------*/ +.jp-mod-sideBySide.jp-Notebook .jp-Notebook-cell { + margin-top: 3em; + margin-bottom: 3em; + margin-left: 5%; + margin-right: 5%; +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell { + display: grid; + grid-template-columns: minmax(0, 1fr) min-content minmax( + 0, + var(--jp-side-by-side-output-size) + ); + grid-template-rows: auto minmax(0, 1fr) auto; + grid-template-areas: + 'header header header' + 'input handle output' + 'footer footer footer'; +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell.jp-mod-resizedCell { + grid-template-columns: minmax(0, 1fr) min-content minmax( + 0, + var(--jp-side-by-side-resized-cell) + ); +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellHeader { + grid-area: header; +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-Cell-inputWrapper { + grid-area: input; +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-Cell-outputWrapper { + /* overwrite the default margin (no vertical separation needed in side by side move */ + margin-top: 0; + grid-area: output; +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellFooter { + grid-area: footer; +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellResizeHandle { + grid-area: handle; + user-select: none; + display: block; + height: 100%; + cursor: ew-resize; + padding: 0 var(--jp-cell-padding); +} + +.jp-mod-sideBySide.jp-Notebook .jp-CodeCell .jp-CellResizeHandle::after { + content: ''; + display: block; + background: var(--jp-border-color2); + height: 100%; + width: 5px; +} + +.jp-mod-sideBySide.jp-Notebook + .jp-CodeCell.jp-mod-resizedCell + .jp-CellResizeHandle::after { + background: var(--jp-border-color0); +} + +.jp-CellResizeHandle { + display: none; +} + +/*----------------------------------------------------------------------------- +| Placeholder +|----------------------------------------------------------------------------*/ + +.jp-Cell-Placeholder { + padding-left: 55px; +} + +.jp-Cell-Placeholder-wrapper { + background: #fff; + border: 1px solid; + border-color: #e5e6e9 #dfe0e4 #d0d1d5; + border-radius: 4px; + -webkit-border-radius: 4px; + margin: 10px 15px; +} + +.jp-Cell-Placeholder-wrapper-inner { + padding: 15px; + position: relative; +} + +.jp-Cell-Placeholder-wrapper-body { + background-repeat: repeat; + background-size: 50% auto; +} + +.jp-Cell-Placeholder-wrapper-body div { + background: #f6f7f8; + background-image: -webkit-linear-gradient( + left, + #f6f7f8 0%, + #edeef1 20%, + #f6f7f8 40%, + #f6f7f8 100% + ); + background-repeat: no-repeat; + background-size: 800px 104px; + height: 104px; + position: absolute; + right: 15px; + left: 15px; + top: 15px; +} + +div.jp-Cell-Placeholder-h1 { + top: 20px; + height: 20px; + left: 15px; + width: 150px; +} + +div.jp-Cell-Placeholder-h2 { + left: 15px; + top: 50px; + height: 10px; + width: 100px; +} + +div.jp-Cell-Placeholder-content-1, +div.jp-Cell-Placeholder-content-2, +div.jp-Cell-Placeholder-content-3 { + left: 15px; + right: 15px; + height: 10px; +} + +div.jp-Cell-Placeholder-content-1 { + top: 100px; +} + +div.jp-Cell-Placeholder-content-2 { + top: 120px; +} + +div.jp-Cell-Placeholder-content-3 { + top: 140px; +} + +</style> +<style type="text/css"> +/*----------------------------------------------------------------------------- +| Copyright (c) Jupyter Development Team. +| Distributed under the terms of the Modified BSD License. +|----------------------------------------------------------------------------*/ + +/* +The following CSS variables define the main, public API for styling JupyterLab. +These variables should be used by all plugins wherever possible. In other +words, plugins should not define custom colors, sizes, etc unless absolutely +necessary. This enables users to change the visual theme of JupyterLab +by changing these variables. + +Many variables appear in an ordered sequence (0,1,2,3). These sequences +are designed to work well together, so for example, `--jp-border-color1` should +be used with `--jp-layout-color1`. The numbers have the following meanings: + +* 0: super-primary, reserved for special emphasis +* 1: primary, most important under normal situations +* 2: secondary, next most important under normal situations +* 3: tertiary, next most important under normal situations + +Throughout JupyterLab, we are mostly following principles from Google's +Material Design when selecting colors. We are not, however, following +all of MD as it is not optimized for dense, information rich UIs. +*/ + +:root { + /* Elevation + * + * We style box-shadows using Material Design's idea of elevation. These particular numbers are taken from here: + * + * https://github.com/material-components/material-components-web + * https://material-components-web.appspot.com/elevation.html + */ + + --jp-shadow-base-lightness: 0; + --jp-shadow-umbra-color: rgba( + var(--jp-shadow-base-lightness), + var(--jp-shadow-base-lightness), + var(--jp-shadow-base-lightness), + 0.2 + ); + --jp-shadow-penumbra-color: rgba( + var(--jp-shadow-base-lightness), + var(--jp-shadow-base-lightness), + var(--jp-shadow-base-lightness), + 0.14 + ); + --jp-shadow-ambient-color: rgba( + var(--jp-shadow-base-lightness), + var(--jp-shadow-base-lightness), + var(--jp-shadow-base-lightness), + 0.12 + ); + --jp-elevation-z0: none; + --jp-elevation-z1: 0 2px 1px -1px var(--jp-shadow-umbra-color), + 0 1px 1px 0 var(--jp-shadow-penumbra-color), + 0 1px 3px 0 var(--jp-shadow-ambient-color); + --jp-elevation-z2: 0 3px 1px -2px var(--jp-shadow-umbra-color), + 0 2px 2px 0 var(--jp-shadow-penumbra-color), + 0 1px 5px 0 var(--jp-shadow-ambient-color); + --jp-elevation-z4: 0 2px 4px -1px var(--jp-shadow-umbra-color), + 0 4px 5px 0 var(--jp-shadow-penumbra-color), + 0 1px 10px 0 var(--jp-shadow-ambient-color); + --jp-elevation-z6: 0 3px 5px -1px var(--jp-shadow-umbra-color), + 0 6px 10px 0 var(--jp-shadow-penumbra-color), + 0 1px 18px 0 var(--jp-shadow-ambient-color); + --jp-elevation-z8: 0 5px 5px -3px var(--jp-shadow-umbra-color), + 0 8px 10px 1px var(--jp-shadow-penumbra-color), + 0 3px 14px 2px var(--jp-shadow-ambient-color); + --jp-elevation-z12: 0 7px 8px -4px var(--jp-shadow-umbra-color), + 0 12px 17px 2px var(--jp-shadow-penumbra-color), + 0 5px 22px 4px var(--jp-shadow-ambient-color); + --jp-elevation-z16: 0 8px 10px -5px var(--jp-shadow-umbra-color), + 0 16px 24px 2px var(--jp-shadow-penumbra-color), + 0 6px 30px 5px var(--jp-shadow-ambient-color); + --jp-elevation-z20: 0 10px 13px -6px var(--jp-shadow-umbra-color), + 0 20px 31px 3px var(--jp-shadow-penumbra-color), + 0 8px 38px 7px var(--jp-shadow-ambient-color); + --jp-elevation-z24: 0 11px 15px -7px var(--jp-shadow-umbra-color), + 0 24px 38px 3px var(--jp-shadow-penumbra-color), + 0 9px 46px 8px var(--jp-shadow-ambient-color); + + /* Borders + * + * The following variables, specify the visual styling of borders in JupyterLab. + */ + + --jp-border-width: 1px; + --jp-border-color0: var(--md-grey-400); + --jp-border-color1: var(--md-grey-400); + --jp-border-color2: var(--md-grey-300); + --jp-border-color3: var(--md-grey-200); + --jp-inverse-border-color: var(--md-grey-600); + --jp-border-radius: 2px; + + /* UI Fonts + * + * The UI font CSS variables are used for the typography all of the JupyterLab + * user interface elements that are not directly user generated content. + * + * The font sizing here is done assuming that the body font size of --jp-ui-font-size1 + * is applied to a parent element. When children elements, such as headings, are sized + * in em all things will be computed relative to that body size. + */ + + --jp-ui-font-scale-factor: 1.2; + --jp-ui-font-size0: 0.83333em; + --jp-ui-font-size1: 13px; /* Base font size */ + --jp-ui-font-size2: 1.2em; + --jp-ui-font-size3: 1.44em; + --jp-ui-font-family: system-ui, -apple-system, blinkmacsystemfont, 'Segoe UI', + helvetica, arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', + 'Segoe UI Symbol'; + + /* + * Use these font colors against the corresponding main layout colors. + * In a light theme, these go from dark to light. + */ + + /* Defaults use Material Design specification */ + --jp-ui-font-color0: rgba(0, 0, 0, 1); + --jp-ui-font-color1: rgba(0, 0, 0, 0.87); + --jp-ui-font-color2: rgba(0, 0, 0, 0.54); + --jp-ui-font-color3: rgba(0, 0, 0, 0.38); + + /* + * Use these against the brand/accent/warn/error colors. + * These will typically go from light to darker, in both a dark and light theme. + */ + + --jp-ui-inverse-font-color0: rgba(255, 255, 255, 1); + --jp-ui-inverse-font-color1: rgba(255, 255, 255, 1); + --jp-ui-inverse-font-color2: rgba(255, 255, 255, 0.7); + --jp-ui-inverse-font-color3: rgba(255, 255, 255, 0.5); + + /* Content Fonts + * + * Content font variables are used for typography of user generated content. + * + * The font sizing here is done assuming that the body font size of --jp-content-font-size1 + * is applied to a parent element. When children elements, such as headings, are sized + * in em all things will be computed relative to that body size. + */ + + --jp-content-line-height: 1.6; + --jp-content-font-scale-factor: 1.2; + --jp-content-font-size0: 0.83333em; + --jp-content-font-size1: 14px; /* Base font size */ + --jp-content-font-size2: 1.2em; + --jp-content-font-size3: 1.44em; + --jp-content-font-size4: 1.728em; + --jp-content-font-size5: 2.0736em; + + /* This gives a magnification of about 125% in presentation mode over normal. */ + --jp-content-presentation-font-size1: 17px; + --jp-content-heading-line-height: 1; + --jp-content-heading-margin-top: 1.2em; + --jp-content-heading-margin-bottom: 0.8em; + --jp-content-heading-font-weight: 500; + + /* Defaults use Material Design specification */ + --jp-content-font-color0: rgba(0, 0, 0, 1); + --jp-content-font-color1: rgba(0, 0, 0, 0.87); + --jp-content-font-color2: rgba(0, 0, 0, 0.54); + --jp-content-font-color3: rgba(0, 0, 0, 0.38); + --jp-content-link-color: var(--md-blue-900); + --jp-content-font-family: system-ui, -apple-system, blinkmacsystemfont, + 'Segoe UI', helvetica, arial, sans-serif, 'Apple Color Emoji', + 'Segoe UI Emoji', 'Segoe UI Symbol'; + + /* + * Code Fonts + * + * Code font variables are used for typography of code and other monospaces content. + */ + + --jp-code-font-size: 13px; + --jp-code-line-height: 1.3077; /* 17px for 13px base */ + --jp-code-padding: 5px; /* 5px for 13px base, codemirror highlighting needs integer px value */ + --jp-code-font-family-default: menlo, consolas, 'DejaVu Sans Mono', monospace; + --jp-code-font-family: var(--jp-code-font-family-default); + + /* This gives a magnification of about 125% in presentation mode over normal. */ + --jp-code-presentation-font-size: 16px; + + /* may need to tweak cursor width if you change font size */ + --jp-code-cursor-width0: 1.4px; + --jp-code-cursor-width1: 2px; + --jp-code-cursor-width2: 4px; + + /* Layout + * + * The following are the main layout colors use in JupyterLab. In a light + * theme these would go from light to dark. + */ + + --jp-layout-color0: white; + --jp-layout-color1: white; + --jp-layout-color2: var(--md-grey-200); + --jp-layout-color3: var(--md-grey-400); + --jp-layout-color4: var(--md-grey-600); + + /* Inverse Layout + * + * The following are the inverse layout colors use in JupyterLab. In a light + * theme these would go from dark to light. + */ + + --jp-inverse-layout-color0: #111; + --jp-inverse-layout-color1: var(--md-grey-900); + --jp-inverse-layout-color2: var(--md-grey-800); + --jp-inverse-layout-color3: var(--md-grey-700); + --jp-inverse-layout-color4: var(--md-grey-600); + + /* Brand/accent */ + + --jp-brand-color0: var(--md-blue-900); + --jp-brand-color1: var(--md-blue-700); + --jp-brand-color2: var(--md-blue-300); + --jp-brand-color3: var(--md-blue-100); + --jp-brand-color4: var(--md-blue-50); + --jp-accent-color0: var(--md-green-900); + --jp-accent-color1: var(--md-green-700); + --jp-accent-color2: var(--md-green-300); + --jp-accent-color3: var(--md-green-100); + + /* State colors (warn, error, success, info) */ + + --jp-warn-color0: var(--md-orange-900); + --jp-warn-color1: var(--md-orange-700); + --jp-warn-color2: var(--md-orange-300); + --jp-warn-color3: var(--md-orange-100); + --jp-error-color0: var(--md-red-900); + --jp-error-color1: var(--md-red-700); + --jp-error-color2: var(--md-red-300); + --jp-error-color3: var(--md-red-100); + --jp-success-color0: var(--md-green-900); + --jp-success-color1: var(--md-green-700); + --jp-success-color2: var(--md-green-300); + --jp-success-color3: var(--md-green-100); + --jp-info-color0: var(--md-cyan-900); + --jp-info-color1: var(--md-cyan-700); + --jp-info-color2: var(--md-cyan-300); + --jp-info-color3: var(--md-cyan-100); + + /* Cell specific styles */ + + --jp-cell-padding: 5px; + --jp-cell-collapser-width: 8px; + --jp-cell-collapser-min-height: 20px; + --jp-cell-collapser-not-active-hover-opacity: 0.6; + --jp-cell-editor-background: var(--md-grey-100); + --jp-cell-editor-border-color: var(--md-grey-300); + --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300); + --jp-cell-editor-active-background: var(--jp-layout-color0); + --jp-cell-editor-active-border-color: var(--jp-brand-color1); + --jp-cell-prompt-width: 64px; + --jp-cell-prompt-font-family: var(--jp-code-font-family-default); + --jp-cell-prompt-letter-spacing: 0; + --jp-cell-prompt-opacity: 1; + --jp-cell-prompt-not-active-opacity: 0.5; + --jp-cell-prompt-not-active-font-color: var(--md-grey-700); + + /* A custom blend of MD grey and blue 600 + * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */ + --jp-cell-inprompt-font-color: #307fc1; + + /* A custom blend of MD grey and orange 600 + * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */ + --jp-cell-outprompt-font-color: #bf5b3d; + + /* Notebook specific styles */ + + --jp-notebook-padding: 10px; + --jp-notebook-select-background: var(--jp-layout-color1); + --jp-notebook-multiselected-color: var(--md-blue-50); + + /* The scroll padding is calculated to fill enough space at the bottom of the + notebook to show one single-line cell (with appropriate padding) at the top + when the notebook is scrolled all the way to the bottom. We also subtract one + pixel so that no scrollbar appears if we have just one single-line cell in the + notebook. This padding is to enable a 'scroll past end' feature in a notebook. + */ + --jp-notebook-scroll-padding: calc( + 100% - var(--jp-code-font-size) * var(--jp-code-line-height) - + var(--jp-code-padding) - var(--jp-cell-padding) - 1px + ); + + /* Rendermime styles */ + + --jp-rendermime-error-background: #fdd; + --jp-rendermime-table-row-background: var(--md-grey-100); + --jp-rendermime-table-row-hover-background: var(--md-light-blue-50); + + /* Dialog specific styles */ + + --jp-dialog-background: rgba(0, 0, 0, 0.25); + + /* Console specific styles */ + + --jp-console-padding: 10px; + + /* Toolbar specific styles */ + + --jp-toolbar-border-color: var(--jp-border-color1); + --jp-toolbar-micro-height: 8px; + --jp-toolbar-background: var(--jp-layout-color1); + --jp-toolbar-box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.24); + --jp-toolbar-header-margin: 4px 4px 0 4px; + --jp-toolbar-active-background: var(--md-grey-300); + + /* Statusbar specific styles */ + + --jp-statusbar-height: 24px; + + /* Input field styles */ + + --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300); + --jp-input-active-background: var(--jp-layout-color1); + --jp-input-hover-background: var(--jp-layout-color1); + --jp-input-background: var(--md-grey-100); + --jp-input-border-color: var(--jp-inverse-border-color); + --jp-input-active-border-color: var(--jp-brand-color1); + --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3); + + /* General editor styles */ + + --jp-editor-selected-background: #d9d9d9; + --jp-editor-selected-focused-background: #d7d4f0; + --jp-editor-cursor-color: var(--jp-ui-font-color0); + + /* Code mirror specific styles */ + + --jp-mirror-editor-keyword-color: #008000; + --jp-mirror-editor-atom-color: #88f; + --jp-mirror-editor-number-color: #080; + --jp-mirror-editor-def-color: #00f; + --jp-mirror-editor-variable-color: var(--md-grey-900); + --jp-mirror-editor-variable-2-color: rgb(0, 54, 109); + --jp-mirror-editor-variable-3-color: #085; + --jp-mirror-editor-punctuation-color: #05a; + --jp-mirror-editor-property-color: #05a; + --jp-mirror-editor-operator-color: #a2f; + --jp-mirror-editor-comment-color: #408080; + --jp-mirror-editor-string-color: #ba2121; + --jp-mirror-editor-string-2-color: #708; + --jp-mirror-editor-meta-color: #a2f; + --jp-mirror-editor-qualifier-color: #555; + --jp-mirror-editor-builtin-color: #008000; + --jp-mirror-editor-bracket-color: #997; + --jp-mirror-editor-tag-color: #170; + --jp-mirror-editor-attribute-color: #00c; + --jp-mirror-editor-header-color: blue; + --jp-mirror-editor-quote-color: #090; + --jp-mirror-editor-link-color: #00c; + --jp-mirror-editor-error-color: #f00; + --jp-mirror-editor-hr-color: #999; + + /* + RTC user specific colors. + These colors are used for the cursor, username in the editor, + and the icon of the user. + */ + + --jp-collaborator-color1: #ffad8e; + --jp-collaborator-color2: #dac83d; + --jp-collaborator-color3: #72dd76; + --jp-collaborator-color4: #00e4d0; + --jp-collaborator-color5: #45d4ff; + --jp-collaborator-color6: #e2b1ff; + --jp-collaborator-color7: #ff9de6; + + /* Vega extension styles */ + + --jp-vega-background: white; + + /* Sidebar-related styles */ + + --jp-sidebar-min-width: 250px; + + /* Search-related styles */ + + --jp-search-toggle-off-opacity: 0.5; + --jp-search-toggle-hover-opacity: 0.8; + --jp-search-toggle-on-opacity: 1; + --jp-search-selected-match-background-color: rgb(245, 200, 0); + --jp-search-selected-match-color: black; + --jp-search-unselected-match-background-color: var( + --jp-inverse-layout-color0 + ); + --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0); + + /* Icon colors that work well with light or dark backgrounds */ + --jp-icon-contrast-color0: var(--md-purple-600); + --jp-icon-contrast-color1: var(--md-green-600); + --jp-icon-contrast-color2: var(--md-pink-600); + --jp-icon-contrast-color3: var(--md-blue-600); + + /* Button colors */ + --jp-accept-color-normal: var(--md-blue-700); + --jp-accept-color-hover: var(--md-blue-800); + --jp-accept-color-active: var(--md-blue-900); + --jp-warn-color-normal: var(--md-red-700); + --jp-warn-color-hover: var(--md-red-800); + --jp-warn-color-active: var(--md-red-900); + --jp-reject-color-normal: var(--md-grey-600); + --jp-reject-color-hover: var(--md-grey-700); + --jp-reject-color-active: var(--md-grey-800); + + /* File or activity icons and switch semantic variables */ + --jp-jupyter-icon-color: #f37626; + --jp-notebook-icon-color: #f37626; + --jp-json-icon-color: var(--md-orange-700); + --jp-console-icon-background-color: var(--md-blue-700); + --jp-console-icon-color: white; + --jp-terminal-icon-background-color: var(--md-grey-800); + --jp-terminal-icon-color: var(--md-grey-200); + --jp-text-editor-icon-color: var(--md-grey-700); + --jp-inspector-icon-color: var(--md-grey-700); + --jp-switch-color: var(--md-grey-400); + --jp-switch-true-position-color: var(--md-orange-900); +} +</style> +<style type="text/css"> +/* Force rendering true colors when outputing to pdf */ +* { + -webkit-print-color-adjust: exact; +} + +/* Misc */ +a.anchor-link { + display: none; +} + +/* Input area styling */ +.jp-InputArea { + overflow: hidden; +} + +.jp-InputArea-editor { + overflow: hidden; +} + +.cm-editor.cm-s-jupyter .highlight pre { +/* weird, but --jp-code-padding defined to be 5px but 4px horizontal padding is hardcoded for pre.cm-line */ + padding: var(--jp-code-padding) 4px; + margin: 0; + + font-family: inherit; + font-size: inherit; + line-height: inherit; + color: inherit; + +} + +.jp-OutputArea-output pre { + line-height: inherit; + font-family: inherit; +} + +.jp-RenderedText pre { + color: var(--jp-content-font-color1); + font-size: var(--jp-code-font-size); +} + +/* Hiding the collapser by default */ +.jp-Collapser { + display: none; +} + +@page { + margin: 0.5in; /* Margin for each printed piece of paper */ +} + +@media print { + .jp-Cell-inputWrapper, + .jp-Cell-outputWrapper { + display: block; + } +} +</style> +<!-- Load mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_CHTML-full,Safe"> </script> +<!-- MathJax configuration --> +<script type="text/x-mathjax-config"> + init_mathjax = function() { + if (window.MathJax) { + // MathJax loaded + MathJax.Hub.Config({ + TeX: { + equationNumbers: { + autoNumber: "AMS", + useLabelIds: true + } + }, + tex2jax: { + inlineMath: [ ['$','$'], ["\\(","\\)"] ], + displayMath: [ ['$$','$$'], ["\\[","\\]"] ], + processEscapes: true, + processEnvironments: true + }, + displayAlign: 'center', + CommonHTML: { + linebreaks: { + automatic: true + } + } + }); + + MathJax.Hub.Queue(["Typeset", MathJax.Hub]); + } + } + init_mathjax(); + </script> +<!-- End of mathjax configuration --><script type="module"> + document.addEventListener("DOMContentLoaded", async () => { + const diagrams = document.querySelectorAll(".jp-Mermaid > pre.mermaid"); + // do not load mermaidjs if not needed + if (!diagrams.length) { + return; + } + const mermaid = (await import("https://cdnjs.cloudflare.com/ajax/libs/mermaid/10.6.0/mermaid.esm.min.mjs")).default; + const parser = new DOMParser(); + + mermaid.initialize({ + maxTextSize: 100000, + startOnLoad: false, + fontFamily: window + .getComputedStyle(document.body) + .getPropertyValue("--jp-ui-font-family"), + theme: document.querySelector("body[data-jp-theme-light='true']") + ? "default" + : "dark", + }); + + let _nextMermaidId = 0; + + function makeMermaidImage(svg) { + const img = document.createElement("img"); + const doc = parser.parseFromString(svg, "image/svg+xml"); + const svgEl = doc.querySelector("svg"); + const { maxWidth } = svgEl?.style || {}; + const firstTitle = doc.querySelector("title"); + const firstDesc = doc.querySelector("desc"); + + img.setAttribute("src", `data:image/svg+xml,${encodeURIComponent(svg)}`); + if (maxWidth) { + img.width = parseInt(maxWidth); + } + if (firstTitle) { + img.setAttribute("alt", firstTitle.textContent); + } + if (firstDesc) { + const caption = document.createElement("figcaption"); + caption.className = "sr-only"; + caption.textContent = firstDesc.textContent; + return [img, caption]; + } + return [img]; + } + + async function makeMermaidError(text) { + let errorMessage = ""; + try { + await mermaid.parse(text); + } catch (err) { + errorMessage = `${err}`; + } + + const result = document.createElement("details"); + result.className = 'jp-RenderedMermaid-Details'; + const summary = document.createElement("summary"); + summary.className = 'jp-RenderedMermaid-Summary'; + const pre = document.createElement("pre"); + const code = document.createElement("code"); + code.innerText = text; + pre.appendChild(code); + summary.appendChild(pre); + result.appendChild(summary); + + const warning = document.createElement("pre"); + warning.innerText = errorMessage; + result.appendChild(warning); + return [result]; + } + + async function renderOneMarmaid(src) { + const id = `jp-mermaid-${_nextMermaidId++}`; + const parent = src.parentNode; + let raw = src.textContent.trim(); + const el = document.createElement("div"); + el.style.visibility = "hidden"; + document.body.appendChild(el); + let results = null; + let output = null; + try { + const { svg } = await mermaid.render(id, raw, el); + results = makeMermaidImage(svg); + output = document.createElement("figure"); + results.map(output.appendChild, output); + } catch (err) { + parent.classList.add("jp-mod-warning"); + results = await makeMermaidError(raw); + output = results[0]; + } finally { + el.remove(); + } + parent.classList.add("jp-RenderedMermaid"); + parent.appendChild(output); + } + + void Promise.all([...diagrams].map(renderOneMarmaid)); + }); +</script> +<style> + .jp-Mermaid:not(.jp-RenderedMermaid) { + display: none; + } + + .jp-RenderedMermaid { + overflow: auto; + display: flex; + } + + .jp-RenderedMermaid.jp-mod-warning { + width: auto; + padding: 0.5em; + margin-top: 0.5em; + border: var(--jp-border-width) solid var(--jp-warn-color2); + border-radius: var(--jp-border-radius); + color: var(--jp-ui-font-color1); + font-size: var(--jp-ui-font-size1); + white-space: pre-wrap; + word-wrap: break-word; + } + + .jp-RenderedMermaid figure { + margin: 0; + overflow: auto; + max-width: 100%; + } + + .jp-RenderedMermaid img { + max-width: 100%; + } + + .jp-RenderedMermaid-Details > pre { + margin-top: 1em; + } + + .jp-RenderedMermaid-Summary { + color: var(--jp-warn-color2); + } + + .jp-RenderedMermaid:not(.jp-mod-warning) pre { + display: none; + } + + .jp-RenderedMermaid-Summary > pre { + display: inline-block; + white-space: normal; + } +</style> +<!-- End of mermaid configuration --></head> +<body class="jp-Notebook" data-jp-theme-light="true" data-jp-theme-name="JupyterLab Light"> +<main> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=4af6b45f-f7aa-46a8-9d79-c1579ae0a799"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<h1 id="WS-2.3:-Discrete-Fourier-Transform-(DFT):-You-Try-Meow-(Miauw)">WS 2.3: Discrete Fourier Transform (DFT): You Try Meow (Miauw)<a class="anchor-link" href="#WS-2.3:-Discrete-Fourier-Transform-(DFT):-You-Try-Meow-(Miauw)">¶</a></h1><h1 style="position: absolute; display: flex; flex-grow: 0; flex-shrink: 0; flex-direction: row-reverse; top: 60px;right: 30px; margin: 0; border: 0"> +<style> + .markdown {width:100%; position: relative} + article { position: relative } + </style> +<img alt="No description has been provided for this image" src="https://gitlab.tudelft.nl/mude/public/-/raw/main/tu-logo/TU_P1_full-color.png" style="width:100px"/> +<img alt="No description has been provided for this image" src="https://gitlab.tudelft.nl/mude/public/-/raw/main/mude-logo/MUDE_Logo-small.png" style="width:100px"/> +</h1> +<h2 style="height: 10px"> +</h2> +<p><em><a href="http://mude.citg.tudelft.nl/">CEGM1000 MUDE</a>: Week 2.3, Signal Processing. For: November 27, 2024</em></p> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=eff9791a"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<p>The goal of this workshop to work with the <em>Discrete Fourier Transform</em> (DFT), implemented in Python as the <em>Fast Fourier Transform</em> (FFT) through <code>np.fft.fft</code>, and to understand and interpret its output.</p> +<p>The notebook consists of two parts:</p> +<ul> +<li>The first part (Task 0) is a demonstration of the use of the DFT (<em>you read and execute the code cells</em>),</li> +<li>The second part is a simple exercise with the DFT (<em>you write the code</em>).</li> +</ul> +<p>To start off, let's do a quick quiz question: <em>what is the primary purpose of the DFT?</em></p> +<p><em>Find the answer <a href="https://tudelft.h5p.com/content/1292126914399042257/embed">here</a>.</em></p> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=03f3b3c6-d3f6-4121-9f39-c30c8bf70ea5"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<p>That's right! We convert our signal into the frequency domain. And if you would like an additional explanation of the key frequencies, you can find it <a href="https://medium.com/@kovalenko.alx/fun-with-fourier-591662576a77">here</a>.</p> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=bfca25a5-75ce-4837-9387-01f95be10bd0"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<div style="background-color:#facb8e; color: black; vertical-align: middle; padding:15px; margin: 10px; border-radius: 10px; width: 95%"> <p>Note the use of <code>zip</code>, <code>stem</code>, <code>annotate</code> and the modulo operator +<code>%</code>. Refer to PA11 if you do not understand these tools. Furthermore, note that the term _modulus_ is also used here (and in the textbook), which is another term for _absolute value._</p></div> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs" id="cell-id=da13fbf3"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [1]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span> +<span class="kn">from</span> <span class="nn">matplotlib</span> <span class="kn">import</span> <span class="n">pyplot</span> <span class="k">as</span> <span class="n">plt</span> +</pre></div> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=13234855"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<h2 id="Task-0:-Demonstration-of-DFT-using-pulse-function">Task 0: Demonstration of DFT using pulse function<a class="anchor-link" href="#Task-0:-Demonstration-of-DFT-using-pulse-function">¶</a></h2><p>In the first part of this notebook, we use $x(t)=\Pi(\frac{t}{4})$, and its Fourier transform $X(f)=4 \,\textrm{sinc}(4f)$, as an example (see the first worked example in Chapter 3 on the Fourier transform). The pulse lasts for 4 seconds in the time domain; for convenience, below it is not centered at $t$ = 0, but shifted (delayed) to the right.</p> +<p>The signal $x(t)$ clearly is non-periodic and is an energy signal; apart from a short time span of 'activity' it is zero elsewhere.</p> +<p>We create a pulse function $x(t)$ in discrete time $x_n$ by numpy. The total signal duration is $T$ = 20 seconds (observation or record length). The sampling interval is $\Delta t$ = 1 second. There are $N$ = 20 samples, and each sample represents 1 second, hence $N \Delta t = T$.</p> +<p>Note that the time array starts at $t$ = 0 s, and hence, the last sample is at $t$ = 19 s (and not at $t$ = 20 s, as then we would have 21 samples).</p> +<h3 id="Task-0.1:-Visualize-the-Signal">Task 0.1: Visualize the Signal<a class="anchor-link" href="#Task-0.1:-Visualize-the-Signal">¶</a></h3> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=b33e1be2"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [2]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="n">t</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">20</span><span class="p">,</span><span class="mi">1</span><span class="p">)</span> +<span class="n">xt</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">concatenate</span><span class="p">((</span><span class="n">np</span><span class="o">.</span><span class="n">zeros</span><span class="p">(</span><span class="mi">8</span><span class="p">),</span> <span class="n">np</span><span class="o">.</span><span class="n">ones</span><span class="p">(</span><span class="mi">4</span><span class="p">),</span> <span class="n">np</span><span class="o">.</span><span class="n">zeros</span><span class="p">(</span><span class="mi">8</span><span class="p">)))</span> + +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">t</span><span class="p">,</span> <span class="n">xt</span><span class="p">,</span><span class="s1">'o'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">stem</span><span class="p">(</span><span class="n">t</span><span class="p">[</span><span class="mi">8</span><span class="p">:</span><span class="mi">12</span><span class="p">],</span> <span class="n">xt</span><span class="p">[</span><span class="mi">8</span><span class="p">:</span><span class="mi">12</span><span class="p">])</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xticks</span><span class="p">(</span><span class="n">ticks</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">21</span><span class="p">,</span><span class="mi">5</span><span class="p">),</span> <span class="n">labels</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">21</span><span class="p">,</span><span class="mi">5</span><span class="p">))</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'time [s]'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'xn'</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=a338eede"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<h3 id="Task-0.2:-Evaluate-(and-visualize)-the-DFT">Task 0.2: Evaluate (and visualize) the DFT<a class="anchor-link" href="#Task-0.2:-Evaluate-(and-visualize)-the-DFT">¶</a></h3><p>We use <code>numpy.fft.fft</code> to compute the one-dimensional Discrete Fourier Transform (DFT) of $x_n$, which takes a signal as argument and returns an array of coefficients (refer to the <a href="https://numpy.org/doc/stable/reference/generated/numpy.fft.fft.html">documentation</a> as needed).</p> +<p>The DFT converts $N$ samples of the time domain signal $x_n$, into $N$ samples of the frequency domain. In this case, it produces $X_k$ with $k = 0, 1, 2, \ldots, N-1$, with $N$ = 20, which are complex numbers.</p> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=26d0f558-caa7-41f2-9477-60d74940fc10"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<div style="background-color:#AABAB2; color: black; vertical-align: middle; padding:15px; margin: 10px; border-radius: 10px; width: 95%"> +<p> +<b>Task 0.2:</b> +Read the code cell below before executing it and identify the following: +<ol> +<li>Where is the DFT computed, and what is the output?</li> +<li>Why is the modulus (absolute value) used on the DFT output?</li> +<li>What are the values are used for the x and y axes of the plot?</li> +<li>How is frequency information found and added to the plot (mathematically)?</li> +</ol> +Once you understand the figure, continue reading to understand <em>what do these 20 complex numbers mean, and how should we interpret them?</em> +</p> +</div> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=3acb465b"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [3]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="n">abs_fft</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">fft</span><span class="o">.</span><span class="n">fft</span><span class="p">(</span><span class="n">xt</span><span class="p">))</span> +<span class="n">index_fft</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">20</span><span class="p">,</span><span class="mi">1</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">index_fft</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">,</span> <span class="s1">'o'</span><span class="p">)</span> + +<span class="n">freq</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">,</span> <span class="mf">0.05</span><span class="p">)</span> +<span class="k">for</span> <span class="n">x</span><span class="p">,</span><span class="n">y</span> <span class="ow">in</span> <span class="nb">zip</span><span class="p">(</span><span class="n">index_fft</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">):</span> + <span class="k">if</span> <span class="n">x</span><span class="o">%</span><span class="k">5</span> == 0 or x==19: + <span class="n">label</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"f=</span><span class="si">{</span><span class="n">freq</span><span class="p">[</span><span class="n">x</span><span class="p">]</span><span class="si">:</span><span class="s2">.2f</span><span class="si">}</span><span class="s2"> Hz"</span> + <span class="n">plt</span><span class="o">.</span><span class="n">annotate</span><span class="p">(</span><span class="n">label</span><span class="p">,</span> + <span class="p">(</span><span class="n">x</span><span class="p">,</span><span class="n">y</span><span class="p">),</span> + <span class="n">textcoords</span><span class="o">=</span><span class="s2">"offset points"</span><span class="p">,</span> + <span class="n">xytext</span><span class="o">=</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">10</span><span class="p">),</span> + <span class="n">fontsize</span><span class="o">=</span><span class="mi">10</span><span class="p">,</span> + <span class="n">ha</span><span class="o">=</span><span class="s1">'center'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylim</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">5</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlim</span><span class="p">(</span><span class="o">-</span><span class="mi">2</span><span class="p">,</span><span class="mi">21</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'fft-index'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'$|X_k|$'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">stem</span><span class="p">(</span><span class="n">index_fft</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=09c72cdd"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<p>The frequency resolution $\Delta f$ equals one-over-the-measurement-duration, hence $\Delta f = 1/T$. With that knowledge, we can reconstruct the frequencies expressed in Hertz.</p> +<p>The spectrum of the sampled signal is periodic in the sampling frequency $f_s$ which equals 1 Hz ($\Delta t$ = 1 s). Therefore, it is computed just for one period $[0,f_s)$. The last value, with index 19, represents the component with frequency $f$ = 0.95 Hz. A spectrum is commonly presented and interpreted as double-sided, so in the above graph we can interpret the spectral components with indices 10 to 19 corresponding to negative frequencies.</p> +<h3 id="Task-0.3:-Identify-negative-frequencies">Task 0.3: Identify negative frequencies<a class="anchor-link" href="#Task-0.3:-Identify-negative-frequencies">¶</a></h3> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=df1f483b"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [4]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="n">abs_fft</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">fft</span><span class="o">.</span><span class="n">fft</span><span class="p">(</span><span class="n">xt</span><span class="p">))</span> +<span class="n">plt</span><span class="o">.</span><span class="n">stem</span><span class="p">(</span><span class="n">index_fft</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">index_fft</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">,</span> <span class="s1">'o'</span><span class="p">)</span> + +<span class="n">freq</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">concatenate</span><span class="p">((</span><span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">,</span> <span class="mf">0.05</span><span class="p">),</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="o">-</span><span class="mf">0.5</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="mf">0.05</span><span class="p">)))</span> +<span class="k">for</span> <span class="n">x</span><span class="p">,</span><span class="n">y</span> <span class="ow">in</span> <span class="nb">zip</span><span class="p">(</span><span class="n">index_fft</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">):</span> + <span class="k">if</span> <span class="n">x</span><span class="o">%</span><span class="k">5</span> == 0 or x==19: + <span class="n">label</span> <span class="o">=</span> <span class="sa">f</span><span class="s2">"f=</span><span class="si">{</span><span class="n">freq</span><span class="p">[</span><span class="n">x</span><span class="p">]</span><span class="si">:</span><span class="s2">.2f</span><span class="si">}</span><span class="s2"> Hz"</span> + <span class="n">plt</span><span class="o">.</span><span class="n">annotate</span><span class="p">(</span><span class="n">label</span><span class="p">,</span> + <span class="p">(</span><span class="n">x</span><span class="p">,</span><span class="n">y</span><span class="p">),</span> + <span class="n">textcoords</span><span class="o">=</span><span class="s2">"offset points"</span><span class="p">,</span> + <span class="n">xytext</span><span class="o">=</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">10</span><span class="p">),</span> + <span class="n">fontsize</span><span class="o">=</span><span class="mi">10</span><span class="p">,</span> + <span class="n">ha</span><span class="o">=</span><span class="s1">'center'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylim</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="mi">5</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlim</span><span class="p">(</span><span class="o">-</span><span class="mi">2</span><span class="p">,</span><span class="mi">21</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'fft-index'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'$|X_k|$'</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=2d87a9a6"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<p>Now we can interpret the DFT of the $x(t)=\Pi(\frac{t}{4})$. The sampling interval is $\Delta t$ = 1 second, and the obsesrvation length is T=20 seconds, and we have N=20 samples.</p> +<ul> +<li>We can recognize a bit of a sinc function.</li> +<li>The DFT is computed from 0 Hz, for positive frequencies up to $\frac{fs}{2} = 0.5$ Hz, after which the negative frequencies follow from -0.5 to -0.05 Hz.</li> +<li>$X(f)=4 \textrm{sinc}(4f)$ has its first null at $f=0.25$Hz.</li> +</ul> +<h3 id="Task-0.4:-Create-symmetric-plot">Task 0.4: Create symmetric plot<a class="anchor-link" href="#Task-0.4:-Create-symmetric-plot">¶</a></h3><p>For convenient visualization, we may want to explicitly shift the negative frequencies to the left-hand side to create a symmetric plot. We can use <code>numpy.fft.fftshift</code> to do that. In other words, the zero-frequency component appears in the center of the spectrum. Now, it nicely shows a symmetric sprectrum. It well resembles the sinc-function (taking into account that we plot the modulus/absolute value). The output of the DFT still consists of $N$ = 20 elements. To enable this, we set up a new frequency array (in Hz) on the interval $[-fs/2,fs/2)$.</p> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=e1eef6b6-1e90-43db-b059-6521b2a840d3"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<div style="background-color:#AABAB2; color: black; vertical-align: middle; padding:15px; margin: 10px; border-radius: 10px; width: 95%"> +<p> +<b>Task 0.4:</b> +Read the code cell below before executing it and identify how the plot is modified based on the (new) specification of frequency. Note that it is more than just the <code>freq</code> variable! +</p> +</div> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=a8aac894"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [5]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="n">abs_fft_shift</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">fft</span><span class="o">.</span><span class="n">fftshift</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">fft</span><span class="o">.</span><span class="n">fft</span><span class="p">(</span><span class="n">xt</span><span class="p">)))</span> +<span class="n">freq</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="o">-</span><span class="mf">0.5</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">,</span> <span class="mf">0.05</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">stem</span><span class="p">(</span><span class="n">freq</span><span class="p">,</span> <span class="n">abs_fft_shift</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">freq</span><span class="p">,</span> <span class="n">abs_fft_shift</span><span class="p">,</span> <span class="s1">'o'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'|Xk|'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'frequency [Hz]'</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=569ca2d3"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<h3 id="Task-0.5:-Showing-spectrum-only-for-positive-frequencies">Task 0.5: Showing spectrum only for positive frequencies<a class="anchor-link" href="#Task-0.5:-Showing-spectrum-only-for-positive-frequencies">¶</a></h3><p>In practice, because of the symmetry, one typically plots only the right-hand side of the (double-sided) spectrum, hence only the part for positive frequencies $f \geq 0$. This is simply a matter of preference, and a way to save some space.</p> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=a26e361d-c5fa-47a2-b32c-416cc3d10659"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<div style="background-color:#AABAB2; color: black; vertical-align: middle; padding:15px; margin: 10px; border-radius: 10px; width: 95%"> +<p> +<b>Task 0.5:</b> +Can you identify what has changed (in the code and visually), compared to the previous plot? +</p> +</div> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=b9608638"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [6]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="n">N</span><span class="o">=</span><span class="nb">len</span><span class="p">(</span><span class="n">xt</span><span class="p">)</span> +<span class="n">abs_fft</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">fft</span><span class="o">.</span><span class="n">fft</span><span class="p">(</span><span class="n">xt</span><span class="p">))</span> +<span class="n">freq</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mf">0.0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">,</span> <span class="mf">0.05</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">freq</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)],</span> <span class="n">abs_fft</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)],</span> <span class="s1">'o'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">stem</span><span class="p">(</span><span class="n">freq</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)],</span> <span class="n">abs_fft</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)])</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'$|X_k|$'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'frequency [Hz]'</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=83c4ca67-9234-4741-a56f-294a12bcd98a"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<div style="background-color:#AABAB2; color: black; vertical-align: middle; padding:15px; margin: 10px; border-radius: 10px; width: 95%"> +<p> +<b>Task 0.6:</b> +Confirm that you understand how we have arrived at the plot above, which illustrates the magnitude (amplitude) spectrum for frequencies $f \in [0,f_s/2)$, rather than $[0,f_s)$. +</p> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=9f5558b4"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<h2 id="Task-1:-Application-of-DFT-using-simple-cosine">Task 1: Application of DFT using simple cosine<a class="anchor-link" href="#Task-1:-Application-of-DFT-using-simple-cosine">¶</a></h2> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=46dd5c0c"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<p>It is always a good idea, in spectral analysis, to run a test with a very simple, basic signal. In this way you can test and verify your coding and interpretation of the results.</p> +<p>Our basic signal is just a plain cosine. We take the amplitude equal to one, and zero initial phase, so the signal reads $x(t) = \cos(2 \pi f_c t)$, with $f_c$ = 3 Hz in this exercise. With such a simple signal, we know in advance how the spectrum should look like. Namely just a spike at $f$ = 3 Hz, and also one at $f$ = -3 Hz, as we're, for mathematical convenience, working with double sided spectra. The spectrum should be zero at all other frequencies.</p> +<p>As a side note: the cosine is strictly a periodic function, not a-periodic (as above); still, the Fourier transform of the cosine is defined as two Dirac delta pulses or peaks (at 3 Hz and -3 Hz). You may want to check out the second worked example in Chapter 3 on the Fourier transform: Fourier transform in the limit.</p> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=87de3cc5"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<div style="background-color:#AABAB2; color: black; vertical-align: middle; padding:15px; margin: 10px; border-radius: 10px; width: 95%"> +<p> +<b>Task 1:</b> +<p>Create a sampled (discrete time) cosine signal by sampling at $f_s$ = 10 Hz, for a duration of $T$ = 2 seconds (make sure you use exactly $N$ = 20 samples). Plot the sampled signal, compute its DFT and plot its magnitude spectrum $|X_k|$ with proper labeling of the axes (just like we did in the first part of this notebook). Include a plot of the spectrum of the sampled cosine signal using only the positive frequencies (up to $f_s/2$, as in the last plot of the previous task).</p> +<p><em>Note: you are expected to produce three separate plots.</em></p> +</p> +</div> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=28ad034e"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [13]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="c1">### SOLUTION</span> + +<span class="n">fc</span><span class="o">=</span><span class="mi">3</span> +<span class="n">fs</span><span class="o">=</span><span class="mi">10</span> +<span class="n">dt</span><span class="o">=</span><span class="mi">1</span><span class="o">/</span><span class="n">fs</span> +<span class="n">T</span><span class="o">=</span><span class="mi">2</span> +<span class="n">N</span><span class="o">=</span><span class="n">T</span><span class="o">*</span><span class="n">fs</span> +<span class="n">t</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="n">T</span><span class="p">,</span><span class="n">dt</span><span class="p">)</span> +<span class="n">xt</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">cos</span><span class="p">(</span><span class="mi">2</span><span class="o">*</span><span class="n">np</span><span class="o">.</span><span class="n">pi</span><span class="o">*</span><span class="n">fc</span><span class="o">*</span><span class="n">t</span><span class="p">)</span> + +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">t</span><span class="p">,</span><span class="n">xt</span><span class="p">,</span> <span class="n">marker</span> <span class="o">=</span> <span class="s1">'o'</span><span class="p">)</span> + +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'time [s]'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'xn'</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=af87d120"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [15]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="c1">### SOLUTION</span> + +<span class="n">abs_fft</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">fft</span><span class="o">.</span><span class="n">fft</span><span class="p">(</span><span class="n">xt</span><span class="p">))</span> +<span class="n">freq</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="n">fs</span><span class="p">,</span><span class="mi">1</span><span class="o">/</span><span class="n">T</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">stem</span><span class="p">(</span><span class="n">freq</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">freq</span><span class="p">,</span> <span class="n">abs_fft</span><span class="p">,</span> <span class="s1">'o'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'|Xk|'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'frequency [Hz]'</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell" id="cell-id=6fd9014c"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"> +<div class="jp-InputPrompt jp-InputArea-prompt">In [9]:</div> +<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline"> +<div class="cm-editor cm-s-jupyter"> +<div class="highlight hl-ipython3"><pre><span></span><span class="c1">### SOLUTION</span> + +<span class="n">abs_fft</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">fft</span><span class="o">.</span><span class="n">fft</span><span class="p">(</span><span class="n">xt</span><span class="p">))</span> +<span class="n">freq</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span><span class="n">fs</span><span class="p">,</span><span class="mi">1</span><span class="o">/</span><span class="n">T</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">stem</span><span class="p">(</span><span class="n">freq</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)],</span> <span class="n">abs_fft</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)])</span> +<span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">freq</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)],</span> <span class="n">abs_fft</span><span class="p">[:</span><span class="nb">int</span><span class="p">(</span><span class="n">N</span><span class="o">/</span><span class="mi">2</span><span class="p">)],</span> <span class="s1">'o'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">'|Xk|'</span><span class="p">)</span> +<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">'frequency [Hz]'</span><span class="p">);</span> +</pre></div> +</div> +</div> +</div> +</div> +<div class="jp-Cell-outputWrapper"> +<div class="jp-Collapser jp-OutputCollapser jp-Cell-outputCollapser"> +</div> +<div class="jp-OutputArea jp-Cell-outputArea"> +<div class="jp-OutputArea-child"> +<div class="jp-OutputPrompt jp-OutputArea-prompt"></div> +<div class="jp-RenderedImage jp-OutputArea-output" tabindex="0"> +<img alt="No description has been provided for this image" class="" src=""/> +</div> +</div> +</div> +</div> +</div> +<div class="jp-Cell jp-MarkdownCell jp-Notebook-cell" id="cell-id=35961e4d"> +<div class="jp-Cell-inputWrapper" tabindex="0"> +<div class="jp-Collapser jp-InputCollapser jp-Cell-inputCollapser"> +</div> +<div class="jp-InputArea jp-Cell-inputArea"><div class="jp-InputPrompt jp-InputArea-prompt"> +</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput" data-mime-type="text/markdown"> +<p><strong>End of notebook.</strong></p> +<h2 style="height: 60px"> +</h2> +<h3 style="position: absolute; display: flex; flex-grow: 0; flex-shrink: 0; flex-direction: row-reverse; bottom: 60px; right: 50px; margin: 0; border: 0"> +<style> + .markdown {width:100%; position: relative} + article { position: relative } + </style> +<a href="http://creativecommons.org/licenses/by/4.0/" rel="license"> +<img alt="Creative Commons License" src="https://i.creativecommons.org/l/by/4.0/88x31.png" style="border-width:; width:88px; height:auto; padding-top:10px"> +</img></a> +<a href="https://www.tudelft.nl/en/ceg" rel="TU Delft"> +<img alt="TU Delft" src="https://gitlab.tudelft.nl/mude/public/-/raw/main/tu-logo/TU_P1_full-color.png" style="border-width:0; width:100px; height:auto; padding-bottom:0px"> +</img></a> +<a href="http://mude.citg.tudelft.nl/" rel="MUDE"> +<img alt="MUDE" src="https://gitlab.tudelft.nl/mude/public/-/raw/main/mude-logo/MUDE_Logo-small.png" style="border-width:0; width:100px; height:auto; padding-bottom:0px"> +</img></a> +</h3> +<span style="font-size: 75%"> +© Copyright 2024 <a href="http://mude.citg.tudelft.nl/" rel="MUDE">MUDE</a> TU Delft. This work is licensed under a <a href="http://creativecommons.org/licenses/by/4.0/" rel="license">CC BY 4.0 License</a>. + +</span></div> +</div> +</div> +</div> +</main> +</body> +<script type="application/vnd.jupyter.widget-state+json"> +{"state": {}, "version_major": 2, "version_minor": 0} +</script> +</html>