This article relies too much on references to primary sources. Please improve this by adding secondary or tertiary sources. (August 2021) (Learn how and when to remove this template message)
Project Jupyter
Jupyter logo.svg
AbbreviationJupyter
FormationFebruary 2015; 7 years ago (2015-02)
Typenonprofit organization
PurposeTo support interactive data science and scientific computing across all programming languages.[1]
Region served
Worldwide
Official language
English
Websitejupyter.org

Project Jupyter (/ˈpɪtər/ (listen) like the planet; some users pronounce "py" as /pʌɪ/ suggesting the pronunciation of Python /ˈpʌɪθn/) is a project and community whose goal is to "develop open-source software, open-standards, and services for interactive computing across dozens of programming languages".[2] It was spun off from IPython in 2014 by Fernando Pérez[3] and Brian Granger.[4] Project Jupyter's name is a reference to the three core programming languages supported by Jupyter, which are Julia, Python and R, and also a homage to Galileo's notebooks recording the discovery of the moons of Jupiter. Project Jupyter has developed and supported the interactive computing products Jupyter Notebook, JupyterHub, and JupyterLab. Jupyter is financially sponsored by NumFOCUS.[5]

History

Galileo Galilei's manuscript from 1610 with observations of Jupiter (⊛) and four of its moons (✱), whose depiction helped inspire the Jupyter logo
Galileo Galilei's manuscript from 1610 with observations of Jupiter (⊛) and four of its moons (✱), whose depiction helped inspire the Jupyter logo

In 2014, Fernando Pérez announced a spin-off project from IPython called Project Jupyter.[6] IPython continues to exist as a Python shell and a kernel for Jupyter, while the notebook and other language-agnostic parts of IPython moved under the Jupyter name.[7][8] Jupyter is language agnostic and it supports execution environments (aka kernels) in several dozen languages among which are Julia, R, Haskell, Ruby, and of course Python (via the IPython kernel).[9]

In 2015, GitHub and the Jupyter Project announced native rendering of Jupyter notebooks file format (.ipynb files) on the GitHub platform.[10][11]

Philosophy

Project Jupyter's operating philosophy is to support interactive data science and scientific computing across all programming languages via the development of open-source software. According to the Project Jupyter website, "Jupyter will always be 100% open-source software, free for all to use and released under the liberal terms of the modified BSD license".[1]

Jupyter Notebook

Jupyter Notebook interface
Jupyter Notebook interface

Jupyter Notebook (formerly IPython Notebooks) is a web-based interactive computational environment for creating notebook documents.

A Jupyter Notebook document is a browser-based REPL containing an ordered list of input/output cells which can contain code, text (using Markdown), mathematics, plots and rich media. Underneath the interface, a notebook is a JSON document, following a versioned schema, usually ending with the ".ipynb" extension.

Jupyter notebooks are built upon a number of popular open-source libraries:

Jupyter Notebook can connect to many kernels to allow programming in different languages. A Jupyter kernel is a program responsible for handling various types of requests (code execution, code completions, inspection), and providing a reply. Kernels talk to the other components of Jupyter using ZeroMQ, and thus can be on the same or remote machines. Unlike many other Notebook-like interfaces, in Jupyter, kernels are not aware that they are attached to a specific document, and can be connected to many clients at once. Usually kernels allow execution of only a single language, but there are a couple of exceptions.[citation needed] By default Jupyter Notebook ships with the IPython kernel. As of the 2.3 release[12][13] (October 2014), there are 49 Jupyter-compatible kernels for many programming languages, including Python, R, Julia and Haskell.[14]

A Jupyter Notebook can be converted to a number of open standard output formats (HTML, presentation slides, LaTeX, PDF, ReStructuredText, Markdown, Python) through "Download As" in the web interface, via the nbconvert library[15] or "jupyter nbconvert" command line interface in a shell. To simplify visualisation of Jupyter notebook documents on the web, the nbconvert library[16] is provided as a service through NbViewer[17] which can take a URL to any publicly available notebook document, convert it to HTML on the fly and display it to the user.

The notebook interface was added to IPython in the 0.12 release[18] (December 2011), renamed to Jupyter notebook in 2015 (IPython 4.0 is Jupyter 1.0). Jupyter Notebook is similar to the notebook interface of other programs such as Maple, Mathematica, and SageMath, a computational interface style that originated with Mathematica in the 1980s.[19] Jupyter interest overtook the popularity of the Mathematica notebook interface in early 2018.[19]

JupyterLab is a newer user interface for Project Jupyter. It offers the building blocks of the classic Jupyter Notebook (notebook, terminal, text editor, file browser, rich outputs, etc.) in a flexible user interface. The first stable release was announced on February 20, 2018.[20]

Other products

Industry adoption

"Colaboratory" redirects here. Not to be confused with Collaboratory.

The Jupyter Notebook has become a popular user interface for cloud computing, and major cloud providers have adopted the Jupyter Notebook or derivative tools as a frontend interface for cloud users. Examples include Amazon's SageMaker Notebooks,[26] Google's Colaboratory[27] and Microsoft's Azure Notebook.[28]

Google Colaboratory (also known as Colab) is a free Jupyter notebook environment that runs in the cloud and stores its notebooks on Google Drive. Colab was originally an internal Google project; an attempt[29] was made to open source all the code and work more directly upstream, leading to the development of the "Open in Colab" Google Chrome extension,[30] but this eventually ended, and Colab development continued internally. As of October 2019, the Colaboratory UI only allows for the creation of notebooks with Python 2 and Python 3 kernels; however, an existing notebook whose kernelspec is IR or Swift will also work, since both R and Swift are installed in the container. Julia language can also work on Colab (with e.g. Python and GPUs; Google's tensor processing units also work with Julia on Colab[31]).[32][33]

Media coverage

Grants and awards

See also

References

  1. ^ a b "About Us". Project Jupyter. 2018-04-20. Retrieved 2018-05-03.
  2. ^ "Project Jupyter". www.jupyter.org. Retrieved 2020-11-13.
  3. ^ "Berkeley Institute for Data Science".
  4. ^ "Speaker: Brian Granger: Jupyter Notebook conference & training: JupyterCon".
  5. ^ "NumFOCUS Sponsored Projects". NumFOCUS. Retrieved 2021-10-25.
  6. ^ "Project Jupyter // Speaker Deck".
  7. ^ "The Notebook, Qt console and a number of other pieces are now parts of Jupyter". GitHub. 29 May 2021.
  8. ^ "The Big Split™". 28 August 2017.
  9. ^ "Project Jupyter | Home".
  10. ^ sshirokov (2015-05-07). "GitHub + Jupyter Notebooks = <3". The GitHub Blog. Retrieved 2018-04-10.
  11. ^ "Rendering Notebooks on GitHub". Jupyter Blog. 2015-05-07. Retrieved 2018-04-10.
  12. ^ "What's new in IPython > Issues closed in the 2.x development cycle".
  13. ^ "What's new in IPython > 2.0 Series".
  14. ^ "Jupyter kernels > List of (some) IPython compatible kernels". GitHub.
  15. ^ "nbconvert: Convert Notebooks to other formats". nbconvert 6.0.8.dev0 documentation. Retrieved 2020-11-13.
  16. ^ jupyter/nbconvert, Project Jupyter, 2021-04-12, retrieved 2021-04-13
  17. ^ "nbviewer". nbviewer.jupyter.org. Retrieved 2020-11-13.
  18. ^ "Notebook's announcement- 0.12 release note".
  19. ^ a b c Somers, James. "The Scientific Paper Is Obsolete". The Atlantic. Retrieved 2018-04-10.
  20. ^ "JupyterLab is Ready for Users". Jupyter Blog. 2018-02-20. Retrieved 2018-05-04.
  21. ^ "Project Jupyter".
  22. ^ "Jupyo | Jupyter notebooks for Python, R, Julia in the cloud". jupyo.com. Archived from the original on 2019-01-03. Retrieved 2019-01-02.
  23. ^ "Books with Jupyter". jupyterbook.org. Retrieved 2020-11-13.
  24. ^ "The MyST Syntax Guide". myst-parser.readthedocs.io. Retrieved 2020-11-13.
  25. ^ "nbgrader 0.6.1 documentation". nbgrader.readthedocs.io. Retrieved 2020-11-13.
  26. ^ "Amazon SageMaker on AWS". Amazon Web Services, Inc. Retrieved 2018-05-09.
  27. ^ "Welcome to Colaboratory". research.google.com. Retrieved 2018-05-09.
  28. ^ "Online Jupyter Notebooks". notebooks.azure.com. Retrieved 2018-05-09.
  29. ^ "Nerds rejoice: Google just released its internal tool to collaborate on AI". Quartz. Retrieved 2018-09-06.
  30. ^ "Open in Colab GitHub repository". GitHub. Retrieved 2018-09-06.
  31. ^ Julia on TPUs, JuliaTPU, 2019-12-03, retrieved 2019-12-03
  32. ^ "Google Colaboratory". colab.research.google.com. Retrieved 2019-12-06.
  33. ^ "gpu — Julia in Google Colab". Stack Overflow. Retrieved 2019-12-06.
  34. ^ "LIGO Open Science Center". losc.ligo.org. Retrieved 2018-05-04.
  35. ^ Romer, Paul. "Jupyter, Mathematica, and the Future of the Research Paper". paulromer.net. Retrieved 2018-04-15.
  36. ^ "Sloan Foundation Grant". ipython.org. Retrieved 2018-05-03.
  37. ^ "An Open Source Framework for Interactive, Collaborative and Reproducible Scientific Computing and EducationOpen Source Tools for Interactive, Collaborative and Reproducible Computing". ipython.org. Retrieved 2018-05-03.
  38. ^ Perez, Fernando (December 28, 2015). "IPython 2015 Final Report — Sloan Foundation" (PDF). ipython.org. Retrieved May 3, 2018.
  39. ^ "UC Berkeley and Cal Poly to Expand and Enhance Open-Source Software for Scientific Computing and Data Science | Helmsley Charitable Trust". helmsleytrust.org. Archived from the original on 2020-01-03. Retrieved 2018-05-03.
  40. ^ "Software System Award". ACM Awards. Association for Computing Machinery. Retrieved April 28, 2016.