From 938e9ba72f26fef4d06e7609f7855078b25f1743 Mon Sep 17 00:00:00 2001 From: Ian Hunt-Isaak Date: Thu, 24 Feb 2022 23:53:21 -0500 Subject: [PATCH 1/4] create docs page --- .gitignore | 3 + dev-environment.yml | 9 ++ docs/Makefile | 23 +++++ docs/_static/basic.apng | Bin 0 -> 172641 bytes docs/_static/custom.css | 12 +++ docs/conf.py | 185 ++++++++++++++++++++++++++++++++++++++++ docs/contributing.md | 92 ++++++++++++++++++++ docs/index.ipynb | 118 +++++++++++++++++++++++++ docs/installing.md | 66 ++++++++++++++ docs/make.bat | 35 ++++++++ setup.py | 11 +++ 11 files changed, 554 insertions(+) create mode 100644 docs/Makefile create mode 100644 docs/_static/basic.apng create mode 100644 docs/_static/custom.css create mode 100644 docs/conf.py create mode 100644 docs/contributing.md create mode 100644 docs/index.ipynb create mode 100644 docs/installing.md create mode 100644 docs/make.bat diff --git a/.gitignore b/.gitignore index 7e9a87e9..70907701 100644 --- a/.gitignore +++ b/.gitignore @@ -32,3 +32,6 @@ ipympl/labextension # OS specific items .DS_Store + +# sphinx build dir +docs/_build diff --git a/dev-environment.yml b/dev-environment.yml index df8e89e6..92b5725a 100644 --- a/dev-environment.yml +++ b/dev-environment.yml @@ -13,5 +13,14 @@ dependencies: - flake8 - pytest - nbval + - pre-commit - pip: - build + - myst-nb + - Sphinx >= 1.5 + - sphinx-copybutton + - sphinx-panels + - sphinx-thebe + - sphinx-togglebutton + - sphinx-book-theme + - sphinx-autobuild diff --git a/docs/Makefile b/docs/Makefile new file mode 100644 index 00000000..6ff62d75 --- /dev/null +++ b/docs/Makefile @@ -0,0 +1,23 @@ +# Minimal makefile for Sphinx documentation +# + +# You can set these variables from the command line, and also +# from the environment for the first two. +SPHINXOPTS ?= -T --color +SPHINXBUILD ?= sphinx-build +SOURCEDIR = . +BUILDDIR = _build + +# Put it first so that "make" without argument is like "make help". +help: + @$(SPHINXBUILD) -M help "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) + +.PHONY: help Makefile + +# Catch-all target: route all unknown targets to Sphinx using the new +# "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS). +%: Makefile + @$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) + +watch: + sphinx-autobuild . _build/html --open-browser --watch examples diff --git a/docs/_static/basic.apng b/docs/_static/basic.apng new file mode 100644 index 0000000000000000000000000000000000000000..cab7d75dc4b2cea83d69140c49178049f1f2f117 GIT binary patch literal 172641 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�n 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 z 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 |\.\.\. " # doctest + +# Settings for linkcheck +linkcheck_anchors = False +linkcheck_ignore = [] # type: ignore + +execution_timeout = -1 +jupyter_execute_notebooks = "off" +if "EXECUTE_NB" in os.environ: + print("\033[93;1mWill run Jupyter notebooks!\033[0m") + jupyter_execute_notebooks = "force" + +# Settings for myst-parser +myst_enable_extensions = [ + "amsmath", + "colon_fence", + "dollarmath", + "smartquotes", + "substitution", +] +suppress_warnings = [ + "myst.header", +] + +# Add any paths that contain templates here, relative to this directory. +templates_path = ["_templates"] + +# List of patterns, relative to source directory, that match files and +# directories to ignore when looking for source files. +# This pattern also affects html_static_path and html_extra_path. +exclude_patterns = [ + "**ipynb_checkpoints", + ".DS_Store", + "Thumbs.db", + "_build", +] + + +# -- Options for HTML output ------------------------------------------------- + +# The theme to use for HTML and HTML Help pages. See the documentation for +# a list of builtin themes. +# +html_copy_source = True # needed for download notebook button +html_css_files = [ + "custom.css", +] +html_sourcelink_suffix = "" +html_static_path = ["_static"] +html_theme = "sphinx_book_theme" +html_theme_options = { + "launch_buttons": { + "binderhub_url": "https://mybinder.org", + "colab_url": "https://colab.research.google.com", + "notebook_interface": "jupyterlab", + "thebe": True, + "thebelab": True, + }, + "path_to_docs": "docs", + "repository_branch": "main", + "repository_url": "https://github.com/matplotlib/ipympl", + "use_download_button": True, + "use_edit_page_button": True, + "use_issues_button": True, + "use_repository_button": True, +} +html_title = "ipympl" + +master_doc = "index" +thebe_config = { + "repository_url": html_theme_options["repository_url"], + "repository_branch": html_theme_options["repository_branch"], +} + + +# based on pandas/doc/source/conf.py +def linkcode_resolve(domain, info): + """ + Determine the URL corresponding to Python object + """ + if domain != "py": + return None + + modname = info["module"] + fullname = info["fullname"] + + submod = sys.modules.get(modname) + if submod is None: + return None + + obj = submod + for part in fullname.split("."): + try: + obj = getattr(obj, part) + except AttributeError: + return None + + try: + fn = inspect.getsourcefile(inspect.unwrap(obj)) + except TypeError: + fn = None + if not fn: + return None + + try: + source, lineno = inspect.getsourcelines(obj) + except OSError: + lineno = None + + if lineno: + linespec = f"#L{lineno}-L{lineno + len(source) - 1}" + else: + linespec = "" + + fn = os.path.relpath(fn, start=os.path.dirname("../ipympl")) + + return ( + f"https://github.com/matplotlib/ipympl/blob/main/ipympl/{fn}{linespec}" # noqa + ) diff --git a/docs/contributing.md b/docs/contributing.md new file mode 100644 index 00000000..c8be4e35 --- /dev/null +++ b/docs/contributing.md @@ -0,0 +1,92 @@ +# Contributing + +Thanks for thinking of a way to help improve this library! Remember that contributions come in all shapes and sizes beyond writing bug fixes. Contributing to [documentation](#documentation), opening new [issues](https://github.com/matplotlib/ipympl/issues) for bugs, asking for clarification on things you find unclear, and requesting new features, are all super valuable contributions. + +## Code Improvements + +All development for this library happens on GitHub [here](https://github.com/matplotlib/ipympl). We recommend you work with a [Conda](https://www.anaconda.com/products/individual) environment (or an alternative virtual environment like [`venv`](https://docs.python.org/3/library/venv.html)). + +The below instructions use [Mamba](https://github.com/mamba-org/mamba#the-fast-cross-platform-package-manager) which is a very fast implementation of `conda`. + +```bash +git clone +cd ipympl +mamba env create --file dev-environment.yml +conda activate ipympl-dev +pre-commit install +``` + +Install the Python Packge +```bash +pip install -e . +``` + +When developing your extensions, you need to manually enable your extensions with the +notebook / lab frontend. For lab, this is done by the command: + +```bash +jupyter labextension develop --overwrite . +yarn run build +``` + +For classic notebook, you need to run: +```bash +jupyter nbextension install --py --symlink --sys-prefix --overwrite ipympl +jupyter nbextension enable --py --sys-prefix ipympl +``` + + + +### How to see your changes + +**Typescript**: + +If you use JupyterLab to develop then you can watch the source directory and run JupyterLab at the same time in different terminals to watch for changes in the extension's source and automatically rebuild the widget. + +```bash +# Watch the source directory in one terminal, automatically rebuilding when needed +yarn run watch +# Run JupyterLab in another terminal +jupyter lab +``` + +After a change wait for the build to finish and then refresh your browser and the changes should take effect. + +**Python:** + +If you make a change to the python code then you will need to restart the notebook kernel to have it take effect. + + +## Documentation + +Our documentation is built with [Sphinx](https://www.sphinx-doc.org) from the notebooks in the `docs` folder. It contains both Markdown files and Jupyter notebooks. + +Examples are best written as Jupyter notebooks. To write a new example, create in a notebook in the `docs/examples` directory and list its path under one of the [`toctree`s](https://www.sphinx-doc.org/en/master/usage/restructuredtext/directives.html#directive-toctree) in the `index.ipynb` file. When the docs are generated, they will be rendered as static html pages by [myst-nb](https://myst-nb.readthedocs.io). + +If you have installed all developer dependencies (see [above](#contributing)), you can rebuild the docs with the following `make` command run from inside the `docs` folder: + +``` +make html +``` + +Then you can open the `_build/index.html` file in your browser you should now be able to see the rendered documentation. + +Alternatively, you can use [sphinx-autobuild](https://github.com/executablebooks/sphinx-autobuild) to continuously watch source files for changes and rebuild the documentation for you. Sphinx-autobuild will be installed automatically in the dev environment you created earlier so all you need to do is run + +```bash +make watch +``` +from inside the `docs` folder + +In a few seconds your web browser should open up the documentation. Now whenever you save a file the documentation will automatically regenerate and the webpage will refresh for you! + +## Working with Git + +Using Git/GitHub can confusing (), so if you're new to Git, you may find it helpful to use a program like [GitHub Desktop](https://desktop.github.com) and to follow a [guide](https://github.com/firstcontributions/first-contributions#first-contributions). + +Also feel free to ask for help/advice on the relevant GitHub [issue](https://github.com/matplotlib/ipympl/issues). + + +## Getting Help contributing + +Feel free to ask questions about how to contribute on any Github Issue. You can also ask shorter questions on the [gitter chatroom](https://gitter.im/jupyter-widgets/Lobby). diff --git a/docs/index.ipynb b/docs/index.ipynb new file mode 100644 index 00000000..242e5546 --- /dev/null +++ b/docs/index.ipynb @@ -0,0 +1,118 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "id": "0bd21c1d-fda2-455d-b70d-e8b7ad0611f4", + "metadata": {}, + "source": [ + "# ipympl\n", + "\n", + "`ipympl` enables using the interactive features of matplotlib in Jupyter Notebooks, Jupyter Lab, Google Colab, VSCode notebooks, Google Colab\n", + "\n", + "Matplotlib requires a live Python kernel to have interactive plots so by default the outputs on this page will not be interactive. To try things out yourself you can either use [![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/matplotlib/ipympl/stable?urlpath=retro/notebooks/examples/ipympl.ipynb) or make these docs interactive by clicking on the rocket icon in the top right of the page.\n", + "\n", + "\n", + "## Installation\n", + "The quickest way to install is either:\n", + "\n", + "```bash\n", + "pip install ipympl\n", + "```\n", + "or `conda install -c conda-forge ipympl`\n", + "\n", + "\n", + "For more detailed instructions see [Installing](installing.md).\n", + "\n", + "\n", + "## Basic Example\n", + "To activate the `ipympl` backend all you need to do is include the `%matplotlib ipympl` magic in the notebook. Alternatively you can use `%matplotlib widget` which will have have the same effect." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "id": "2d7b9433-94df-4742-970e-7d9dbb1f6785", + "metadata": { + "tags": [] + }, + "outputs": [], + "source": [ + "%matplotlib ipympl\n", + "import matplotlib.pyplot as plt\n", + "import numpy as np\n", + "\n", + "fig, ax = plt.subplots()\n", + "\n", + "\n", + "x = np.linspace(0, 2*np.pi, 100)\n", + "y = np.sin(3*x)\n", + "ax.plot(x, y)\n" + ] + }, + { + "cell_type": "markdown", + "id": "52696782-2ecb-4fac-9d90-d5c8f81dac10", + "metadata": {}, + "source": [ + "With a working Kernel that simple example will give a plot with interactivity enabled in the notebook!\n", + "![A plot of sine wave, the user pans and zooms with the mouse](_static/basic.apng)" + ] + }, + { + "cell_type": "markdown", + "id": "eb0bcca2-f967-46a3-a0aa-9503312acd85", + "metadata": {}, + "source": [ + "## Install\n", + "\n", + "```bash\n", + "pip install ipympl\n", + "```\n", + "\n", + "\n", + "\n", + "```{toctree}\n", + ":maxdepth: 2\n", + "\n", + "installing.md\n", + "contributing.md\n", + "```\n", + "\n", + "```{toctree}\n", + ":caption: Examples\n", + ":maxdepth: 1\n", + "\n", + "examples/basic-example.ipynb\n", + "```\n" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.8.6" + }, + "widgets": { + "application/vnd.jupyter.widget-state+json": { + "state": {}, + "version_major": 2, + "version_minor": 0 + } + } + }, + "nbformat": 4, + "nbformat_minor": 5 +} diff --git a/docs/installing.md b/docs/installing.md new file mode 100644 index 00000000..c02b5b45 --- /dev/null +++ b/docs/installing.md @@ -0,0 +1,66 @@ +# Installing + +In most cases all you need to do is +```bash +pip install ipympl +``` +or alternatively with `mamba`/`conda` + +```bash +mamba install -c conda-forge ipympl +``` + +and then restart Jupyter. + + +### Jupyterlab < 3 +If you use JupyterLab 2, you still need to install the labextension manually: + +```bash +conda install -c conda-forge nodejs +jupyter labextension install @jupyter-widgets/jupyterlab-manager jupyter-matplotlib +``` + + + + +### Google Colab + +To use `ipympl` in colab run these lines: + +```python +from google.colab import output +output.enable_custom_widget_manager() +``` + +## Mixing Frontend and Backend Versions + +`ipympl` provides both a Frontend (in javascript) which handles displaying the plots and handling interaction events, as well as a backend (in Python) that renders the plots and interfaces with user code. These two parts need to be able to communicate with each other for everything to work. In the most common situation that your frontend and backend are from the same Python environment then installing `ipympl` should have given you compatible versions. + +However, there are situations when you may have different versions of ipympl in the frontend and the backend. In this case you need to ensure that you have compatible versions of the frontend and backend. For details and an initial compatibility table see the discussion on this [Github issue](https://github.com/matplotlib/ipympl/issues/416). + + +## Compatibility Table + +Not all versions of `ipympl` are compatible with different version of Jupyterlab or all versions of Matplotlib. The below table provides a reference for which versions are compatible. + +| `ipympl` | `jupyter-matplotlib` | `JupyterLab` | `Matplotlib` | +|----------|----------------------|--------------|--------------| +| 0.8.8 | 0.10.x | 3 or 2 | 3.3.1>= | +| 0.8.0-7 | 0.10.x | 3 or 2 | 3.3.1>=, <3.6| +| 0.7.0 | 0.9.0 | 3 or 2 | 3.3.1>= | +| 0.6.x | 0.8.x | 3 or 2 | 3.3.1>=, <3.4| +| 0.5.8 | 0.7.4 | 1 or 2 | 3.3.1>=, <3.4| +| 0.5.7 | 0.7.3 | 1 or 2 | 3.2.* | +| ... | ... | ... | | +| 0.5.3 | 0.7.2 | 1 or 2 | | +| 0.5.2 | 0.7.1 | 1 | | +| 0.5.1 | 0.7.0 | 1 | | +| 0.5.0 | 0.6.0 | 1 | | +| 0.4.0 | 0.5.0 | 1 | | +| 0.3.3 | 0.4.2 | 1 | | +| 0.3.2 | 0.4.1 | 1 | | +| 0.3.1 | 0.4.0 | 0 or 1 | | diff --git a/docs/make.bat b/docs/make.bat new file mode 100644 index 00000000..922152e9 --- /dev/null +++ b/docs/make.bat @@ -0,0 +1,35 @@ +@ECHO OFF + +pushd %~dp0 + +REM Command file for Sphinx documentation + +if "%SPHINXBUILD%" == "" ( + set SPHINXBUILD=sphinx-build +) +set SOURCEDIR=. +set BUILDDIR=_build + +if "%1" == "" goto help + +%SPHINXBUILD% >NUL 2>NUL +if errorlevel 9009 ( + echo. + echo.The 'sphinx-build' command was not found. Make sure you have Sphinx + echo.installed, then set the SPHINXBUILD environment variable to point + echo.to the full path of the 'sphinx-build' executable. Alternatively you + echo.may add the Sphinx directory to PATH. + echo. + echo.If you don't have Sphinx installed, grab it from + echo.http://sphinx-doc.org/ + exit /b 1 +) + +%SPHINXBUILD% -M %1 %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% +goto end + +:help +%SPHINXBUILD% -M help %SOURCEDIR% %BUILDDIR% %SPHINXOPTS% %O% + +:end +popd diff --git a/setup.py b/setup.py index 5360058a..76f6257b 100644 --- a/setup.py +++ b/setup.py @@ -66,6 +66,17 @@ 'ipywidgets>=7.6.0,<8', 'matplotlib>=2.0.0,<4', ], + extra_requires={ + "docs": [ + "myst-nb", + "Sphinx >= 1.5", + "sphinx-copybutton", + "sphinx-panels", + "sphinx-thebe", + "sphinx-togglebutton", + "sphinx-book-theme", + ] + }, packages=find_packages(), zip_safe=False, cmdclass=cmdclass, From 8158df049bce6c19773393e5a4ea3209d766f8e3 Mon Sep 17 00:00:00 2001 From: Ian Hunt-Isaak Date: Thu, 24 Feb 2022 23:57:00 -0500 Subject: [PATCH 2/4] move examples under docs --- README.md | 4 +- docs/examples/full-example.ipynb | 477 +++++++++++++++ docs/index.ipynb | 2 +- examples/ipympl.ipynb | 980 ------------------------------- pyproject.toml | 2 +- 5 files changed, 481 insertions(+), 984 deletions(-) create mode 100644 docs/examples/full-example.ipynb delete mode 100644 examples/ipympl.ipynb diff --git a/README.md b/README.md index cd5ddf92..a20f3dff 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ [![Latest PyPI version](https://img.shields.io/pypi/v/ipympl?logo=pypi)](https://pypi.python.org/pypi/ipympl) [![Latest conda-forge version](https://img.shields.io/conda/vn/conda-forge/ipympl?logo=conda-forge)](https://anaconda.org/conda-forge/ipympl) [![Latest npm version](https://img.shields.io/npm/v/jupyter-matplotlib?logo=npm)](https://www.npmjs.com/package/jupyter-matplotlib) -[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/matplotlib/ipympl/stable?urlpath=retro/notebooks/examples/ipympl.ipynb) +[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/matplotlib/ipympl/stable?urlpath=retro/notebooks/docs/examples/full-example.ipynb) [![Gitter](https://img.shields.io/badge/gitter-Join_chat-blue?logo=gitter)](https://gitter.im/jupyter-widgets/Lobby) Leveraging the Jupyter interactive widgets framework, `ipympl` enables the interactive features of matplotlib in the Jupyter notebook and in JupyterLab. @@ -21,7 +21,7 @@ magic: ``` ## Example -See the [example notebook](https://github.com/matplotlib/ipympl/blob/master/examples/ipympl.ipynb) for more! +See the [example notebook](https://github.com/matplotlib/ipympl/blob/master/docs/examples/ipympl.ipynb) for more! ![matplotlib screencast](matplotlib.gif) diff --git a/docs/examples/full-example.ipynb b/docs/examples/full-example.ipynb new file mode 100644 index 00000000..d036785c --- /dev/null +++ b/docs/examples/full-example.ipynb @@ -0,0 +1,477 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Comprehensive Example" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Enabling the `widget` backend.\n", + "# This requires jupyter-matplotlib a.k.a. ipympl.\n", + "# ipympl can be install via pip or conda.\n", + "%matplotlib widget\n", + "\n", + "import matplotlib.pyplot as plt\n", + "import numpy as np" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Testing matplotlib interactions with a simple plot\n", + "fig = plt.figure()\n", + "plt.plot(np.sin(np.linspace(0, 20, 100)));" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Always hide the toolbar\n", + "fig.canvas.toolbar_visible = False" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Put it back to its default\n", + "fig.canvas.toolbar_visible = 'fade-in-fade-out'" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Change the toolbar position\n", + "fig.canvas.toolbar_position = 'top'" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Hide the Figure name at the top of the figure\n", + "fig.canvas.header_visible = False" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Hide the footer\n", + "fig.canvas.footer_visible = False" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Disable the resizing feature\n", + "fig.canvas.resizable = False" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# If true then scrolling while the mouse is over the canvas will not move the entire notebook\n", + "fig.canvas.capture_scroll = True" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "You can also call `display` on `fig.canvas` to display the interactive plot anywhere in the notebooke" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "fig.canvas.toolbar_visible = True\n", + "display(fig.canvas)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Or you can `display(fig)` to embed the current plot as a png" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "display(fig)" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# 3D plotting" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "from mpl_toolkits.mplot3d import axes3d\n", + "\n", + "fig = plt.figure()\n", + "ax = fig.add_subplot(111, projection='3d')\n", + "\n", + "# Grab some test data.\n", + "X, Y, Z = axes3d.get_test_data(0.05)\n", + "\n", + "# Plot a basic wireframe.\n", + "ax.plot_wireframe(X, Y, Z, rstride=10, cstride=10)\n", + "\n", + "plt.show()" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Subplots" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# A more complex example from the matplotlib gallery\n", + "np.random.seed(0)\n", + "\n", + "n_bins = 10\n", + "x = np.random.randn(1000, 3)\n", + "\n", + "fig, axes = plt.subplots(nrows=2, ncols=2)\n", + "ax0, ax1, ax2, ax3 = axes.flatten()\n", + "\n", + "colors = ['red', 'tan', 'lime']\n", + "ax0.hist(x, n_bins, density=1, histtype='bar', color=colors, label=colors)\n", + "ax0.legend(prop={'size': 10})\n", + "ax0.set_title('bars with legend')\n", + "\n", + "ax1.hist(x, n_bins, density=1, histtype='bar', stacked=True)\n", + "ax1.set_title('stacked bar')\n", + "\n", + "ax2.hist(x, n_bins, histtype='step', stacked=True, fill=False)\n", + "ax2.set_title('stack step (unfilled)')\n", + "\n", + "# Make a multiple-histogram of data-sets with different length.\n", + "x_multi = [np.random.randn(n) for n in [10000, 5000, 2000]]\n", + "ax3.hist(x_multi, n_bins, histtype='bar')\n", + "ax3.set_title('different sample sizes')\n", + "\n", + "fig.tight_layout()\n", + "plt.show()" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "fig.canvas.toolbar_position = 'right'" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "fig.canvas.toolbar_visible = False" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Interactions with other widgets and layouting\n", + "\n", + "When you want to embed the figure into a layout of other widgets you should call `plt.ioff()` before creating the figure otherwise `plt.figure()` will trigger a display of the canvas automatically and outside of your layout. " + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### Without using `ioff`\n", + "\n", + "Here we will end up with the figure being displayed twice. The button won't do anything it just placed as an example of layouting." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "import ipywidgets as widgets\n", + "\n", + "# ensure we are interactive mode \n", + "# this is default but if this notebook is executed out of order it may have been turned off\n", + "plt.ion()\n", + "\n", + "fig = plt.figure()\n", + "ax = fig.gca()\n", + "ax.imshow(Z)\n", + "\n", + "widgets.AppLayout(\n", + " center=fig.canvas,\n", + " footer=widgets.Button(icon='check'),\n", + " pane_heights=[0, 6, 1]\n", + ")" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### Fixing the double display with `ioff`\n", + "\n", + "If we make sure interactive mode is off when we create the figure then the figure will only display where we want it to.\n", + "\n", + "There is ongoing work to allow usage of `ioff` as a context manager, see the [ipympl issue](https://github.com/matplotlib/ipympl/issues/220) and the [matplotlib issue](https://github.com/matplotlib/matplotlib/issues/17013)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "plt.ioff()\n", + "fig = plt.figure()\n", + "plt.ion()\n", + "\n", + "ax = fig.gca()\n", + "ax.imshow(Z)\n", + "\n", + "widgets.AppLayout(\n", + " center=fig.canvas,\n", + " footer=widgets.Button(icon='check'),\n", + " pane_heights=[0, 6, 1]\n", + ")" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# Interacting with other widgets\n", + "\n", + "## Changing a line plot with a slide" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# When using the `widget` backend from ipympl,\n", + "# fig.canvas is a proper Jupyter interactive widget, which can be embedded in\n", + "# an ipywidgets layout. See https://ipywidgets.readthedocs.io/en/stable/examples/Layout%20Templates.html\n", + "\n", + "# One can bound figure attributes to other widget values.\n", + "from ipywidgets import AppLayout, FloatSlider\n", + "\n", + "plt.ioff()\n", + "\n", + "slider = FloatSlider(\n", + " orientation='horizontal',\n", + " description='Factor:',\n", + " value=1.0,\n", + " min=0.02,\n", + " max=2.0\n", + ")\n", + "\n", + "slider.layout.margin = '0px 30% 0px 30%'\n", + "slider.layout.width = '40%'\n", + "\n", + "fig = plt.figure()\n", + "fig.canvas.header_visible = False\n", + "fig.canvas.layout.min_height = '400px'\n", + "plt.title('Plotting: y=sin({} * x)'.format(slider.value))\n", + "\n", + "x = np.linspace(0, 20, 500)\n", + "\n", + "lines = plt.plot(x, np.sin(slider.value * x))\n", + "\n", + "def update_lines(change):\n", + " plt.title('Plotting: y=sin({} * x)'.format(change.new))\n", + " lines[0].set_data(x, np.sin(change.new * x))\n", + " fig.canvas.draw()\n", + " fig.canvas.flush_events()\n", + "\n", + "slider.observe(update_lines, names='value')\n", + "\n", + "AppLayout(\n", + " center=fig.canvas,\n", + " footer=slider,\n", + " pane_heights=[0, 6, 1]\n", + ")" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## Update image data in a performant manner\n", + "\n", + "Two useful tricks to improve performance when updating an image displayed with matplolib are to:\n", + "1. Use the `set_data` method instead of calling imshow\n", + "2. Precompute and then index the array" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# precomputing all images\n", + "x = np.linspace(0,np.pi,200)\n", + "y = np.linspace(0,10,200)\n", + "X,Y = np.meshgrid(x,y)\n", + "parameter = np.linspace(-5,5)\n", + "example_image_stack = np.sin(X)[None,:,:]+np.exp(np.cos(Y[None,:,:]*parameter[:,None,None]))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "plt.ioff()\n", + "fig = plt.figure()\n", + "plt.ion()\n", + "im = plt.imshow(example_image_stack[0])\n", + "\n", + "def update(change):\n", + " im.set_data(example_image_stack[change['new']])\n", + " fig.canvas.draw_idle()\n", + " \n", + " \n", + "slider = widgets.IntSlider(value=0, min=0, max=len(parameter)-1)\n", + "slider.observe(update, names='value')\n", + "widgets.VBox([slider, fig.canvas])" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### Debugging widget updates and matplotlib callbacks\n", + "\n", + "If an error is raised in the `update` function then will not always display in the notebook which can make debugging difficult. This same issue is also true for matplotlib callbacks on user events such as mousemovement, for example see [issue](https://github.com/matplotlib/ipympl/issues/116). There are two ways to see the output:\n", + "1. In jupyterlab the output will show up in the Log Console (View > Show Log Console)\n", + "2. using `ipywidgets.Output`\n", + "\n", + "Here is an example of using an `Output` to capture errors in the update function from the previous example. To induce errors we changed the slider limits so that out of bounds errors will occur:\n", + "\n", + "From: `slider = widgets.IntSlider(value=0, min=0, max=len(parameter)-1)`\n", + "\n", + "To: `slider = widgets.IntSlider(value=0, min=0, max=len(parameter)+10)`\n", + "\n", + "If you move the slider all the way to the right you should see errors from the Output widget" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "plt.ioff()\n", + "fig = plt.figure()\n", + "plt.ion()\n", + "im = plt.imshow(example_image_stack[0])\n", + "\n", + "out = widgets.Output()\n", + "@out.capture()\n", + "def update(change):\n", + " with out:\n", + " if change['name'] == 'value':\n", + " im.set_data(example_image_stack[change['new']])\n", + " fig.canvas.draw_idle\n", + " \n", + " \n", + "slider = widgets.IntSlider(value=0, min=0, max=len(parameter)+10)\n", + "slider.observe(update)\n", + "display(widgets.VBox([slider, fig.canvas]))\n", + "display(out)" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.8.6" + }, + "widgets": { + "application/vnd.jupyter.widget-state+json": { + "state": {}, + "version_major": 2, + "version_minor": 0 + } + } + }, + "nbformat": 4, + "nbformat_minor": 4 +} diff --git a/docs/index.ipynb b/docs/index.ipynb index 242e5546..31e273e5 100644 --- a/docs/index.ipynb +++ b/docs/index.ipynb @@ -82,7 +82,7 @@ ":caption: Examples\n", ":maxdepth: 1\n", "\n", - "examples/basic-example.ipynb\n", + "examples/full-example.ipynb\n", "```\n" ] } diff --git a/examples/ipympl.ipynb b/examples/ipympl.ipynb deleted file mode 100644 index 7fb5fcea..00000000 --- a/examples/ipympl.ipynb +++ /dev/null @@ -1,980 +0,0 @@ -{ - "cells": [ - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "# The Matplotlib Jupyter Widget Backend\n", - "\n", - "Enabling interaction with matplotlib charts in the Jupyter notebook and JupyterLab\n", - "\n", - "https://github.com/matplotlib/ipympl" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Enabling the `widget` backend.\n", - "# This requires jupyter-matplotlib a.k.a. ipympl.\n", - "# ipympl can be install via pip or conda.\n", - "%matplotlib widget\n", - "\n", - "import matplotlib.pyplot as plt\n", - "import numpy as np" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Testing matplotlib interactions with a simple plot\n", - "fig = plt.figure()\n", - "plt.plot(np.sin(np.linspace(0, 20, 100)));" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Always hide the toolbar\n", - "fig.canvas.toolbar_visible = False" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Put it back to its default\n", - "fig.canvas.toolbar_visible = 'fade-in-fade-out'" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Change the toolbar position\n", - "fig.canvas.toolbar_position = 'top'" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Hide the Figure name at the top of the figure\n", - "fig.canvas.header_visible = False" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Hide the footer\n", - "fig.canvas.footer_visible = False" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# Disable the resizing feature\n", - "fig.canvas.resizable = False" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# If true then scrolling while the mouse is over the canvas will not move the entire notebook\n", - "fig.canvas.capture_scroll = True" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "You can also call `display` on `fig.canvas` to display the interactive plot anywhere in the notebooke" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "fig.canvas.toolbar_visible = True\n", - "display(fig.canvas)" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "Or you can `display(fig)` to embed the current plot as a png" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "display(fig)" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "# 3D plotting" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "from mpl_toolkits.mplot3d import axes3d\n", - "\n", - "fig = plt.figure()\n", - "ax = fig.add_subplot(111, projection='3d')\n", - "\n", - "# Grab some test data.\n", - "X, Y, Z = axes3d.get_test_data(0.05)\n", - "\n", - "# Plot a basic wireframe.\n", - "ax.plot_wireframe(X, Y, Z, rstride=10, cstride=10)\n", - "\n", - "plt.show()" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "# Subplots" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# A more complex example from the matplotlib gallery\n", - "np.random.seed(0)\n", - "\n", - "n_bins = 10\n", - "x = np.random.randn(1000, 3)\n", - "\n", - "fig, axes = plt.subplots(nrows=2, ncols=2)\n", - "ax0, ax1, ax2, ax3 = axes.flatten()\n", - "\n", - "colors = ['red', 'tan', 'lime']\n", - "ax0.hist(x, n_bins, density=1, histtype='bar', color=colors, label=colors)\n", - "ax0.legend(prop={'size': 10})\n", - "ax0.set_title('bars with legend')\n", - "\n", - "ax1.hist(x, n_bins, density=1, histtype='bar', stacked=True)\n", - "ax1.set_title('stacked bar')\n", - "\n", - "ax2.hist(x, n_bins, histtype='step', stacked=True, fill=False)\n", - "ax2.set_title('stack step (unfilled)')\n", - "\n", - "# Make a multiple-histogram of data-sets with different length.\n", - "x_multi = [np.random.randn(n) for n in [10000, 5000, 2000]]\n", - "ax3.hist(x_multi, n_bins, histtype='bar')\n", - "ax3.set_title('different sample sizes')\n", - "\n", - "fig.tight_layout()\n", - "plt.show()" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "fig.canvas.toolbar_position = 'right'" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "fig.canvas.toolbar_visible = False" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "# Interactions with other widgets and layouting\n", - "\n", - "When you want to embed the figure into a layout of other widgets you should call `plt.ioff()` before creating the figure otherwise `plt.figure()` will trigger a display of the canvas automatically and outside of your layout. " - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "### Without using `ioff`\n", - "\n", - "Here we will end up with the figure being displayed twice. The button won't do anything it just placed as an example of layouting." - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "import ipywidgets as widgets\n", - "\n", - "# ensure we are interactive mode \n", - "# this is default but if this notebook is executed out of order it may have been turned off\n", - "plt.ion()\n", - "\n", - "fig = plt.figure()\n", - "ax = fig.gca()\n", - "ax.imshow(Z)\n", - "\n", - "widgets.AppLayout(\n", - " center=fig.canvas,\n", - " footer=widgets.Button(icon='check'),\n", - " pane_heights=[0, 6, 1]\n", - ")" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "### Fixing the double display with `ioff`\n", - "\n", - "If we make sure interactive mode is off when we create the figure then the figure will only display where we want it to.\n", - "\n", - "There is ongoing work to allow usage of `ioff` as a context manager, see the [ipympl issue](https://github.com/matplotlib/ipympl/issues/220) and the [matplotlib issue](https://github.com/matplotlib/matplotlib/issues/17013)" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "plt.ioff()\n", - "fig = plt.figure()\n", - "plt.ion()\n", - "\n", - "ax = fig.gca()\n", - "ax.imshow(Z)\n", - "\n", - "widgets.AppLayout(\n", - " center=fig.canvas,\n", - " footer=widgets.Button(icon='check'),\n", - " pane_heights=[0, 6, 1]\n", - ")" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "# Interacting with other widgets\n", - "\n", - "## Changing a line plot with a slide" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# When using the `widget` backend from ipympl,\n", - "# fig.canvas is a proper Jupyter interactive widget, which can be embedded in\n", - "# an ipywidgets layout. See https://ipywidgets.readthedocs.io/en/stable/examples/Layout%20Templates.html\n", - "\n", - "# One can bound figure attributes to other widget values.\n", - "from ipywidgets import AppLayout, FloatSlider\n", - "\n", - "plt.ioff()\n", - "\n", - "slider = FloatSlider(\n", - " orientation='horizontal',\n", - " description='Factor:',\n", - " value=1.0,\n", - " min=0.02,\n", - " max=2.0\n", - ")\n", - "\n", - "slider.layout.margin = '0px 30% 0px 30%'\n", - "slider.layout.width = '40%'\n", - "\n", - "fig = plt.figure()\n", - "fig.canvas.header_visible = False\n", - "fig.canvas.layout.min_height = '400px'\n", - "plt.title('Plotting: y=sin({} * x)'.format(slider.value))\n", - "\n", - "x = np.linspace(0, 20, 500)\n", - "\n", - "lines = plt.plot(x, np.sin(slider.value * x))\n", - "\n", - "def update_lines(change):\n", - " plt.title('Plotting: y=sin({} * x)'.format(change.new))\n", - " lines[0].set_data(x, np.sin(change.new * x))\n", - " fig.canvas.draw()\n", - " fig.canvas.flush_events()\n", - "\n", - "slider.observe(update_lines, names='value')\n", - "\n", - "AppLayout(\n", - " center=fig.canvas,\n", - " footer=slider,\n", - " pane_heights=[0, 6, 1]\n", - ")" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "## Update image data in a performant manner\n", - "\n", - "Two useful tricks to improve performance when updating an image displayed with matplolib are to:\n", - "1. Use the `set_data` method instead of calling imshow\n", - "2. Precompute and then index the array" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "# precomputing all images\n", - "x = np.linspace(0,np.pi,200)\n", - "y = np.linspace(0,10,200)\n", - "X,Y = np.meshgrid(x,y)\n", - "parameter = np.linspace(-5,5)\n", - "example_image_stack = np.sin(X)[None,:,:]+np.exp(np.cos(Y[None,:,:]*parameter[:,None,None]))" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "plt.ioff()\n", - "fig = plt.figure()\n", - "plt.ion()\n", - "im = plt.imshow(example_image_stack[0])\n", - "\n", - "def update(change):\n", - " im.set_data(example_image_stack[change['new']])\n", - " fig.canvas.draw_idle()\n", - " \n", - " \n", - "slider = widgets.IntSlider(value=0, min=0, max=len(parameter)-1)\n", - "slider.observe(update, names='value')\n", - "widgets.VBox([slider, fig.canvas])" - ] - }, - { - "cell_type": "markdown", - "metadata": {}, - "source": [ - "### Debugging widget updates and matplotlib callbacks\n", - "\n", - "If an error is raised in the `update` function then will not always display in the notebook which can make debugging difficult. This same issue is also true for matplotlib callbacks on user events such as mousemovement, for example see [issue](https://github.com/matplotlib/ipympl/issues/116). There are two ways to see the output:\n", - "1. In jupyterlab the output will show up in the Log Console (View > Show Log Console)\n", - "2. using `ipywidgets.Output`\n", - "\n", - "Here is an example of using an `Output` to capture errors in the update function from the previous example. To induce errors we changed the slider limits so that out of bounds errors will occur:\n", - "\n", - "From: `slider = widgets.IntSlider(value=0, min=0, max=len(parameter)-1)`\n", - "\n", - "To: `slider = widgets.IntSlider(value=0, min=0, max=len(parameter)+10)`\n", - "\n", - "If you move the slider all the way to the right you should see errors from the Output widget" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "plt.ioff()\n", - "fig = plt.figure()\n", - "plt.ion()\n", - "im = plt.imshow(example_image_stack[0])\n", - "\n", - "out = widgets.Output()\n", - "@out.capture()\n", - "def update(change):\n", - " with out:\n", - " if change['name'] == 'value':\n", - " im.set_data(example_image_stack[change['new']])\n", - " fig.canvas.draw_idle\n", - " \n", - " \n", - "slider = widgets.IntSlider(value=0, min=0, max=len(parameter)+10)\n", - "slider.observe(update)\n", - "display(widgets.VBox([slider, fig.canvas]))\n", - "display(out)" - ] - } - ], - "metadata": { - "kernelspec": { - "display_name": "Python 3 (ipykernel)", - "language": "python", - "name": "python3" - }, - "language_info": { - "codemirror_mode": { - "name": "ipython", - "version": 3 - }, - "file_extension": ".py", - "mimetype": "text/x-python", - "name": "python", - "nbconvert_exporter": "python", - "pygments_lexer": "ipython3", - "version": "3.10.0" - }, - "widgets": { - "application/vnd.jupyter.widget-state+json": { - "state": { - "0f81ff97e38a42bc817642be40a5b088": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "1d8e39aba26f489797103338f306e335": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "1efdc4bda5354ce6bcbc85ca819d73b8": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "24e2ab8df2aa4054a422b6eb7d7859e9": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_c4d45a8399c743b7add76e74f0adb826", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "279f0e40c16545c5bcb022a49094102e": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "MPLCanvasModel", - "state": { - "_cursor": "default", - "_data_url": "", - "_figure_label": "Figure 2", - "_size": [ - 849, - 404 - ], - "layout": "IPY_MODEL_552f3b6b01fd4b5a895043ef5cfaacab", - "toolbar": "IPY_MODEL_94887f7e218d4b04a2040405c07a7b9c", - "toolbar_position": "left" - } - }, - "2d24739c972445bab6f70b2faf60468e": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_d6ca011c6b4848fca4f54792db6e1810", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "322845d53bbf41e48fff2d7e910aa7d9": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_1d8e39aba26f489797103338f306e335", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "39cbc3da16394333823008a783e060fb": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "3b60471eb1f8480fa0db1c7145d1c494": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "457678d86f794e3b9a39e9a2bfa11201": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "4941d1b8f23b49f7813b632ce98ac519": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "552f3b6b01fd4b5a895043ef5cfaacab": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "5da46e39b572491aa1e6500e6d05caa5": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "648ad64458ab4dc584554cbc380d1275": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "666fb982887b40cb9f1a64df448b19cc": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_39cbc3da16394333823008a783e060fb", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "7617b334eb8a4b56873315ec91fd5c0f": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "7feed35324274f078384bd8b165dc7da": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_1efdc4bda5354ce6bcbc85ca819d73b8", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "843c2da8ec7a4705a73d6bd933ce34cc": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "89d3126f60b24c718efe76975c7c79e0": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_3b60471eb1f8480fa0db1c7145d1c494", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "8f46a27a21324c5baac56bd42b7bda15": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "94887f7e218d4b04a2040405c07a7b9c": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_0f81ff97e38a42bc817642be40a5b088", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "9ff732c97a084d2c80f06df8d8605102": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "ToolbarModel", - "state": { - "layout": "IPY_MODEL_5da46e39b572491aa1e6500e6d05caa5", - "toolitems": [ - [ - "Home", - "Reset original view", - "home", - "home" - ], - [ - "Back", - "Back to previous view", - "arrow-left", - "back" - ], - [ - "Forward", - "Forward to next view", - "arrow-right", - "forward" - ], - [ - "Pan", - "Left button pans, Right button zooms\nx/y fixes axis, CTRL fixes aspect", - "arrows", - "pan" - ], - [ - "Zoom", - "Zoom to rectangle\nx/y fixes axis", - "square-o", - "zoom" - ], - [ - "Download", - "Download plot", - "floppy-o", - "save_figure" - ] - ] - } - }, - "b58647fae52d456c9c18a2eb9881afe9": { - "model_module": "jupyter-matplotlib", - "model_module_version": "^0.10.2", - "model_name": "MPLCanvasModel", - "state": { - "_cursor": "default", - "_data_url": "", - "_figure_label": "Figure 1", - "_size": [ - 932, - 409 - ], - "layout": "IPY_MODEL_8f46a27a21324c5baac56bd42b7bda15", - "toolbar": "IPY_MODEL_7feed35324274f078384bd8b165dc7da", - "toolbar_position": "left" - } - }, - "c4d45a8399c743b7add76e74f0adb826": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "cc665d7c08fd495fa15fd9c6b72149db": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - }, - "d6ca011c6b4848fca4f54792db6e1810": { - "model_module": "@jupyter-widgets/base", - "model_module_version": "1.2.0", - "model_name": "LayoutModel", - "state": {} - } - }, - "version_major": 2, - "version_minor": 0 - } - } - }, - "nbformat": 4, - "nbformat_minor": 4 -} diff --git a/pyproject.toml b/pyproject.toml index 02ab5bca..234fd2ab 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -5,7 +5,7 @@ build-backend = "setuptools.build_meta" [tool.pytest.ini_options] testpaths = [ - "examples", + "docs/examples", ] norecursedirs = [ "node_modules", From 49d1c1eb311642aec10a19194feae0cfc93377bd Mon Sep 17 00:00:00 2001 From: Ian Hunt-Isaak Date: Tue, 15 Mar 2022 12:08:04 -0400 Subject: [PATCH 3/4] add workflow to build docs --- .github/workflows/docs.yml | 33 +++++++++++++++++++++++++++++++++ docs/conf.py | 4 ---- setup.py | 3 +-- 3 files changed, 34 insertions(+), 6 deletions(-) create mode 100644 .github/workflows/docs.yml diff --git a/.github/workflows/docs.yml b/.github/workflows/docs.yml new file mode 100644 index 00000000..7128f32c --- /dev/null +++ b/.github/workflows/docs.yml @@ -0,0 +1,33 @@ +name: Docs + +on: [push, pull_request] + + +defaults: + run: + shell: bash -l {0} +jobs: + build: + runs-on: ubuntu-20.04 + steps: + - uses: actions/checkout@v2 + - name: Setup conda + uses: conda-incubator/setup-miniconda@v2 + with: + activate-environment: ipympl-dev + environment-file: dev-environment.yml + python-version: ${{ matrix.python-version }} + mamba-version: "*" + auto-activate-base: false + channels: conda-forge + - name: Install + run: python -m pip install -v .[docs] + - name: Build + run: make -C docs html + - name: Publish + if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }} + uses: peaceiris/actions-gh-pages@v3 + with: + github_token: ${{ secrets.GITHUB_TOKEN }} + publish_dir: ./docs/_build/html + force_orphan: true diff --git a/docs/conf.py b/docs/conf.py index babdb420..b7766a70 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -34,13 +34,11 @@ # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom # ones. extensions = [ - "jupyter_sphinx", "myst_nb", "sphinx.ext.intersphinx", "sphinx.ext.linkcode", "sphinx.ext.mathjax", "sphinx_copybutton", - "sphinx_panels", "sphinx_thebe", "sphinx_togglebutton", ] @@ -59,8 +57,6 @@ "python": ("https://docs.python.org/3", None), } -# remove panels css to get wider main content -panels_add_bootstrap_css = False # Settings for copybutton copybutton_prompt_is_regexp = True diff --git a/setup.py b/setup.py index 76f6257b..43481296 100644 --- a/setup.py +++ b/setup.py @@ -66,12 +66,11 @@ 'ipywidgets>=7.6.0,<8', 'matplotlib>=2.0.0,<4', ], - extra_requires={ + extras_require={ "docs": [ "myst-nb", "Sphinx >= 1.5", "sphinx-copybutton", - "sphinx-panels", "sphinx-thebe", "sphinx-togglebutton", "sphinx-book-theme", From c3b777ba929ebb94e5dbb84a87719258e7bd1999 Mon Sep 17 00:00:00 2001 From: Ian Hunt-Isaak Date: Tue, 15 Mar 2022 12:18:30 -0400 Subject: [PATCH 4/4] update for main branch --- .github/workflows/docs.yml | 2 +- .github/workflows/main.yml | 4 ++-- .github/workflows/mpl-latest.yml | 4 ++-- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/.github/workflows/docs.yml b/.github/workflows/docs.yml index 7128f32c..7ace4355 100644 --- a/.github/workflows/docs.yml +++ b/.github/workflows/docs.yml @@ -25,7 +25,7 @@ jobs: - name: Build run: make -C docs html - name: Publish - if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }} + if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/main' }} uses: peaceiris/actions-gh-pages@v3 with: github_token: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index a03391bd..b75187c1 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -3,10 +3,10 @@ name: Tests on: push: branches: - - master + - main pull_request: branches: - - master + - main defaults: run: diff --git a/.github/workflows/mpl-latest.yml b/.github/workflows/mpl-latest.yml index 68f1355d..bb12725d 100644 --- a/.github/workflows/mpl-latest.yml +++ b/.github/workflows/mpl-latest.yml @@ -5,10 +5,10 @@ on: - cron: "0 12 * * 1" # monday at noon UTC push: branches: - - master + - main pull_request: branches: - - master + - main jobs: run: