Interactive GIS in Jupyter with ipyleaflet
As Jupyter grew in popularity, a broad ecosystem of visualization packages based on Jupyter widgets has been developed, bringing even more interactivity to the Jupyter world.
In this article, we dive into Jupyter Interactive Widgets and the ipyleaflet package, an interactive maps visualization system for Jupyter.
data:image/s3,"s3://crabby-images/59ba1/59ba1c85f5cd966114862e2d8152d9094f4d80eb" alt=""
Jupyter Widgets
Jupyter Interactive Widgets are “special objects” that can be instantiated by the user in their code and result in a counterpart component being created in the front-end.
The core ipywidgets
package provides a collection of controls that Jupyter users can use to build simple UIs as part of their notebooks (sliders, buttons, dropdowns, layout components).
data:image/s3,"s3://crabby-images/4baf1/4baf1873a648210df8ebf8fb01adfe084bf0b2a9" alt=""
More than a collection of controls, it provides a framework upon which a large ecosystem of components has been built, allowing notebook authors to capture user inputs in very diverse ways.
Popular libraries built upon interactive widgets include
- bqplot, a 2-D plotting system for Jupyter,
- ipyvolume, a 3-D plotting package based on WebGL and ThreeJS,
- PythreeJS, a 3-D scene description package exposing a large part of the ThreeJS API to Jupyter,
- ipyvuetify, a large collection of VuetifyJS components exposed to Jupyter,
- ipywebrtc, a library exposing the features of the WebRTC protocol to Jupyter kernels,
- beakerx, a collection of widgets, extensions, and kernels for Jupyter,
and many more… This list is not comprehensive and dozens of other widget packages have been developed.
Key aspects of Jupyter widgets include:
- Bidirectionality
Widgets are not just meant for display but can also be used to capture user inputs, which can then trigger new computation. Notebook authors can compose sophisticated applications including a variety of components from different packages. - Language Agnosticism
Built upon the Jupyter ecosystem, the interactive widget protocol used for the synchronization between the kernel and the front-end is well-specified and can be implemented for any kernel.
Back-ends for other languages than Python already exist, such as for C++ (with the xeus-cling Jupyter kernel), and languages of the JVM such as Clojure or Groovy (with the beakerx kernels). - Extensibility
Jupyter widgets are not meant as a monolithic system with one and only one way to achieve a specific task. We strive to provide a foundational layer allowing third-party widget authors to be as inventive as possible.
A common pattern for Jupyter widget packages has been to bring the capabilities of popular JavaScript visualization frameworks to Jupyter with a bridge based on ipywidgets. This is the case for the ipyleaflet package, as well as pythreejs and ipyvuetify.
Another use case is the development of ad hoc controls that are not necessarily relevant for a mainstream visualization package, but may be specific to a scientific field. An example is the ipymesh project by Chris Kees which can be used to draw PSLG (planar straight-line graphs) in the Jupyter notebook.
ipyleaflet
ipyleaflet is a Jupyter - LeafletJS bridge, bringing mapping capabilities to the notebook and JupyterLab.
Built as a bridge between the LeafletJS package and Jupyter, the ipyleaflet API maps to that of LeafletJS, bringing most of the core features of the package to Jupyter, and enabling a few popular LeafletJS extensions. A small difference is that following the Python coding style, ipyleaflet makes use of snake_case instead of CamelCase for attribute names.
ipyleaflet features
The main components to the library are layers and controls, respectively items to be displayed on the map, and interactive widgets overlayed on the map area for greater interactivity.
The first thing for which you may want to change the default value are the zoom level, the position, or the base layer for the map.
data:image/s3,"s3://crabby-images/1c37c/1c37c467281689e9afccea57d5032fbba7197cb1" alt=""
Maps can be interactively edited in the Jupyter notebook, by dynamically changing or adding layers. In this screenshot, we add a custom layer including a GeoJSON dataset.
Note: An alternative layer to GeoJSON is GeoData, which lets the user load the data in the form of a GeoPandas dataframe instead of raw GeoJSON.
data:image/s3,"s3://crabby-images/ac61b/ac61baaed6165fb5a46459e5b4103b8bfcb38f21" alt=""
A number of simple primitives are available such as markers and heatmaps. In the following screencast, we show how primitive properties can be linked with other widgets, and used as means to take user input on a map:
data:image/s3,"s3://crabby-images/7ddc3/7ddc312fe39fa084a8222c05bcb135fdd69e2ee8" alt=""
The splitmap control can be used to compare to different set of ipyleaflet layers at the same location.
data:image/s3,"s3://crabby-images/39f42/39f427954b8789258f84ce3654466e989159ff7a" alt=""
Another interesting layer is the velocity layer which can be used to display wind velocity data. This control can take data in the form of an xarray dataset.
data:image/s3,"s3://crabby-images/c11d5/c11d5cc9a450a57e6a3d81aaae685c167edaec3c" alt=""
More classical visualization tools are also available, such as choropleths.
data:image/s3,"s3://crabby-images/e3c35/e3c35c20e39c4e9de0553af479c81cd8375d43e5" alt=""
JupyterLab Integration with the Sidecar and Theming Support
ipyleaflet is well integrated with JupyterLab
- ipyleaflet controls make use of the JupyterLab themes for coloring so that they don't stand out when using e.g. a dark theme.
data:image/s3,"s3://crabby-images/21ff0/21ff0fe0a61344bc05f29f576d48dfd4073b49af" alt=""
- ipyleaflet can be used in combination with the JupyterLab sidecar widget.
data:image/s3,"s3://crabby-images/64c3d/64c3d6fe9a8ec3cb948227110449e1abcc8f6881" alt=""
Together with the sidecar, a map can be programmatically added to the right-side toolbar of the JupyterLab application, and interactively edited in the notebook. This prevents the back-and-forth scrolling often required to see how changes are reflected visually.
The workflow enabled by ipyleaflet in combination with the sidecar is similar to that of the geonotebook project by Christopher Kotfila, Jonathan Beezley, and Dan LaManna from Kitware).
data:image/s3,"s3://crabby-images/2ba83/2ba833d388015a35cc38aeeaac4bc3d6809686db" alt=""
A more advanced example
Combined with other widget libraries such as bqplot or the core ipywidget package, ipyleaflet users can easily compose more complex applications and dashboards. In the following screencast, we explore the wealth-of-nations dataset with a leafletmap, a bqplot line chart and a dropdown widget:
data:image/s3,"s3://crabby-images/f09ef/f09ef387b12ed99e57318688735cc20a9b4ec6a7" alt=""
Trying ipyleaflet online with mybinder
If you would like to try out ipyleaflet now, it is possible thanks to the binder project. Just click on the image below!
data:image/s3,"s3://crabby-images/d7c03/d7c033f08e3f93113e30a2f00f0c3afef06e3fbe" alt=""
Interactive GIS in C++: xleaflet
As mentioned earlier, interactive widgets back-ends for other programming languages have be implemented. There is a C++ back-end for ipywidgets: xwidgets which is the building block for creating other C++ widgets back-ends.
data:image/s3,"s3://crabby-images/ae9af/ae9af0c82b9e3e39f9567b3da0d705bd90fb7e3d" alt=""
xleaflet is the C++ - LeafletJS bridge that exposes almost the same API as ipyleaflet, only that you use it from a C++ interpreter! It is based upon xwidgets which brings the bidirectional communication with the front-end.
You can learn more about the xeus-cling Jupyter kernel, xwidgets and xleaflet by reading the following blogpost.
data:image/s3,"s3://crabby-images/8d213/8d213c30f9ce74c743a34cb4a34b1f8929ff4916" alt=""
Deploying ipyleaflet-based dashboards with Voilà
data:image/s3,"s3://crabby-images/49ec2/49ec2083259668d4b427843140cc14d44268d074" alt=""
Voilà is a tool that turns Jupyter notebooks into standalone dashboards. Built upon the Jupyter stack, it inherits the language agnosticism of the ecosystem, and can be used to produce standalone applications based on ipyleaflet.
A companion project to Voilà is the Voilà gallery project, a public facing set up of JupyterHub serving Voilà dashboard. It is kindly hosted by OVH. You can check out the Voilà gallery at URL https://voila-gallery.org.
For more resources about voilà, check out
- the original announcement of the project: And Voilà!
- and for the gallery: A Gallery of Voilà Examples.
If you check out the Voilà gallery, don't miss Jeremy Tuloup's GPX loader demo!
Jupyter for Geo Sciences
Jupyter's adoption is exploding in the GeoScience space. Notable projects building upon Jupyter include
- JEODPP (JRC Earth Observation Data and Processing Platform) is a EU project providing petabyte scale storage and high-throughput computing capacities to facilitate large scale analysis of Earth Observation data. The main front-end to the platform is base on Jupyter. The mapping capability is based on ipyleaflet. End users can request custom visualization that are returned to them in the form of lazily computed tile layers.
- Pangeo is a community platform providing open, reproducible, and scalable sciences. The Pangeo software ecosystem involves open source tools such as xarray, Iris, Dask, Jupyter, and many other packages.
- It was recently announced that the NSF would be funding the UC Berkeley + NCAR "EarthCube" proposal "Jupyter meets the Earth: Enabling discovery in geoscience through interactive computing at scale". The plan involves the development of interactive dashboards with Voilà and contributions to the Voilà codebase.
Related Projects
Jupyter-gmaps
We should mention the jupyter-gmaps project by Pascal Bugnion. Jupyter-gmaps is a bridge between Google maps and Jupyter. Just like ipyleaflet, jupyter-gmaps is built upon the jupyter interactive widgets framework but relies on Google maps for the display instead of LeafletJS library.
This is a high-quality widget by another core developer of ipywidgets. Pascal is also one of the people behind Voilà and the Voilà gallery.
Folium
The Folium project enables maps visualization in the Jupyter notebook. Just like ipyleaflet, it is based on LeafletJS. Folium was created by Rob Story and is now maintained by Frank Conengmo and Filipe Fernandes.
A key difference between Folium and ipyleaflet is that ipyleaflet is built upon ipywidgets and allows bidirectional communication between the front-end and the backend enabling the use of the map to capture user input, while Folium is meant for displaying static data only. Folium enables many LeafletJS extensions, some of which may not be available in ipyleaflet at the moment.
Acknowledgements
The ipyleaflet project was started in 2015 by Brian Granger, and funded by the ERDC. The further development by Sylvain Corlay and Martin Renou was supported by QuantStack.
We are grateful to OVH for kindly hosting the Voilà gallery.
Other key contributors to Voilà and ipyleaflet that should be thanked here are Maarten Breddels, Pascal Bugnion, and Yuvi Panda. We should also mention the recent contributions by Vasavan Thirusittampalam who worked on the full-screen control and better interoperability with geopandas.
About the Authors
Sylvain Corlay, and Martin Renou are Scientific Software Developers at QuantStack.
Sylvain Corlay
data:image/s3,"s3://crabby-images/406fe/406fe2a35ead2060472a24e27f41832442c9867c" alt=""
Sylvain Corlay is the founder and CEO of QuantStack.
As an Open Source Developer, Sylvain contributes to Project Jupyter in the areas of interactive widgets and language kernels and is a steering committee member of the Project. Beyond QuantStack, Sylvain serves as a member of the board of directors of the NumFOCUS foundation. He also co-organizes the PyData Paris Meetup.
Martin Renou
data:image/s3,"s3://crabby-images/9af15/9af154b622c96deed6a074546804ed70ce37f184" alt=""
Martin Renou is a Scientific Software Developer at QuantStack. Prior to joining QuantStack, Martin also worked as a Software developer at Enthought. He studied at the French Aerospace Engineering School ISAE-Supaero, with major in autonomous systems and programming.
As an open source developer, Martin has worked on a variety of projects, such as SciviJS (a JavaScript 3-D mesh visualization library), Xtensor, and Xeus.