Немає перевірених версій цієї сторінки; ймовірно, її ще не перевіряли на відповідність правилам проекту.

Jupyter (укр. Юпітер; [ˈpɪtər][3]) — це проєкт і спільнота, метою якої є «розробка програмного забезпечення з відкритим кодом, відкритих стандартів та служб для інтерактивних обчислень[en] на десятках мов програмування».[4] Його виділили з IPython у 2014 році Фернандо Перес[en][5] та Браян Грейнджер.[6] Назва Project Jupyter є посиланням на три основні мови програмування, які підтримує Jupyter, а саме: Julia, Python і R. Це також данина пам'яті записникам Галілея, в яких записані відкриття супутників Юпітера. Проєкт Jupyter розробив і підтримує інтерактивні обчислювальні продукти Jupyter Notebook, JupyterHub і JupyterLab. Jupyter фінансується NumFOCUS.[7]

Jupyter
На честьJulia, Python і R
Типнеприбуткова організація
проєкт
ЗасновникFernando Pérezd
Засновано2014[1]
Правовий статуснеприбуткова організація
Країна США[1]
ЧленствоJoint Roadmap for Open Science Toolsd[2]
ПродукціяJupyter Notebook[d], JupyterLab[d]
Вебсайт: jupyter.org

CMNS: Jupyter у Вікісховищі
Рукопис Галілео Галілея 1610 року із спостереженнями Юпітера (⊛) і чотирьох його супутників (✱), зображення яких допомогло створити логотип для Jupyter

У 2014 році Фернандо Перес оголосив про допоміжний проєкт від IPython під назвою Project Jupyter.[8] IPython продовжує існувати як оболонка Python і ядро для Jupyter, тоді як Notebook[en] та інші незалежні від мови[en] частини IPython переміщено під іменем Jupyter.[9][10] Jupyter не залежить від мов і підтримує середовища виконання (ядра) на кількох десятках мов, серед яких Julia, R, Haskell, Ruby і, звичайно, Python (через ядро IPython).[11]

У 2015 році GitHub і Jupyter Project оголосили про вихід формату файлів Jupyter notebooks (файли .ipynb) на платформі GitHub.[12][13]

Філософія

ред.

Функціональна філософія Project Jupyter полягає в підтримці інтерактивної науки про дані та наукових обчислень[en] на всіх мовах програмування за допомогою розробки програмного забезпечення з відкритим кодом. Згідно з веб-сайтом Project Jupyter, «Jupyter завжди буде програмним забезпеченням з відкритим вихідним кодом, безкоштовним для всіх і випущеним на ліберальних умовах модифікованої ліцензії BSD».

Jupyter Notebook

ред.
 
Інтерфейс Jupyter Notebook

Jupyter Notebook (раніше IPython Notebooks) — це веб-інтерактивне обчислювальне середовище для створення Notebook документів.

Документ Jupyter Notebook — це REPL на основі браузера, що містить упорядкований список комірок введення/виводу, який може містити код, текст (за допомогою Markdown), математику, графіки та мультимедійні дані. Під інтерфейсом notebook — це документ JSON, який відповідає версійній схемі, він зазвичай закінчується розширенням «.ipynb».

Блокноти Jupyter створені на основі ряду популярних бібліотек з відкритим вихідним кодом:

Jupyter Notebook може підключатися до багатьох ядер, щоб дозволити програмування різними мовами. Ядро Jupyter — це програма, відповідальна за обробку різних типів запитів (виконання коду[en], автодоповнення коду, перевірка) та надання відповіді. Ядра спілкуються з іншими компонентами Jupyter за допомогою ZeroMQ і, таким чином, можуть бути на тих самих або віддалених машинах. На відміну від багатьох інших інтерфейсів, подібних до ноутбуків, у Jupyter ядра не знають, що вони прикріплені до певного документа, і можуть бути підключені до багатьох клієнтів одночасно. Зазвичай ядра дозволяють писати лише на одній мові, але є кілька винятків. За замовчуванням Jupyter Notebook постачається з ядром IPython. Станом на випуск 2.3[14][15] (жовтень 2014 р.) існує 49 ядер, сумісних з Jupyter, для багатьох мов програмування, включаючи Python, R, Julia та Haskell.[16]

Блокнот Jupyter можна конвертувати в ряд відкритих стандартних вихідних форматів (HTML, презентаційні слайди[en], LaTeX, PDF, ReStructuredText, Markdown, Python) за допомогою «Download as» у веб-інтерфейсі та бібліотеки nbconvert[17] або інтерфейсу командного рядка «jupyter» nbconvert. Щоб спростити візуалізацію документів блокнота Jupyter в Інтернеті, бібліотека nbconvert[18] надається як послуга через NbViewer[19], яка може отримати URL-адресу будь-якого загальнодоступного документа блокнота, одразу ж перетворюючи його в HTML, та відобразити на користувача.

Інтерфейс блокнота був доданий до IPython у випуску 0.12[20] (грудень 2011 р.), перейменований на блокнот Jupyter у 2015 р. (IPython 4.0 — це Jupyter 1.0). Jupyter Notebook схожий на notebook-інтерфейси інших програм, таких як Maple, Mathematica і SageMath, стиль обчислювального інтерфейсу, який виник з Mathematica у 1980-х роках.[21] Інтерес Jupyter наздогнав популярність інтерфейсу Mathematica notebook на початку 2018 року[21]

JupyterLab — це новіший інтерфейс користувача для Project Jupyter. Він пропонує будівельні блоки класичного блокнота Jupyter (ноутбук, термінал, текстовий редактор, браузер файлів, розширені вихідні дані тощо) у гнучкому інтерфейсі користувача. Перший стабільний випуск було оголошено 20 лютого 2018 року.[22]

Інші продукти

ред.
  • JupyterHub[23] — багатокористувацький сервер для ноутбуків Jupyter. Він розроблений для підтримки багатьох у користуванні, створенні, керуванні та проксуванні багатьох окремих серверів Jupyter Notebook. Хоча JupyterHub вимагає керування серверами, сторонні служби, такі як Jupyo[24], є альтернативою JupyterHub. Вони дозволяють розміщувати багатокористувацькі ноутбуки Jupyter і керувати ними в хмарі.
  • Jupyter Book — це проєкт з відкритим вихідним кодом для створення книг і документів із обчислювального матеріалу.[25] Він дозволяє користувачеві створювати вміст у суміші Markdown, розширеної версії Markdown під назвою MyST,[26] Maths & Equations з використанням MathJax[en], Jupyter Notebooks, reStructuredText, результату запуску Jupyter Notebooks під час складання. Можна створити кілька вихідних форматів (наразі окремі файли, багатосторінкові веб-сторінки HTML і файли PDF).
  • nbgrader — це інструмент для створення та оцінювання (позначення) завдань у блокнотах Jupyter.[27] Це дозволяє викладачу створювати завдання, які включають вправи з кодування на Python або будь-якому іншому підтримуваному ядрі, а також текстові відповіді. Надіслані завдання можна автоматично позначати, оцінювати вручну або все це разом.

Прийняття в індустрії

ред.

Jupyter Notebook став популярним інтерфейсом користувача для хмарних обчислень. Основні постачальники хмарних послуг прийняли Jupyter Notebook або похідні інструменти як фронтенд-інтерфейс для користувачів хмари. Приклади включають Amazon SageMaker[en] Notebooks,[28] Google Colaboratory[29] і Microsoft Azure Notebook.[30]

Google Colaboratory (також відомий як Colab) — це безкоштовне середовище блокнотів Jupyter, яке працює у хмарі та зберігає свої блокноти на Google Drive. Colab спочатку був внутрішнім проєктом Google; була зроблена спроба[31] відкрити вихідний код для всього коду та працювати більш безпосередньо вгору, що призвело до розробки розширення «Відкрити в Colab» для Google Chrome[32], але це врешті закінчилося, і розробка Colab продовжилася всередині. Станом на жовтень 2019 інтерфейс користувача Colaboratory дозволяє створювати блокноти лише з ядрами Python 2 і Python 3; проте наявний ноутбук, специфікація ядра якого є IR або Swift, також буде працювати, оскільки R і Swift встановлені в контейнері. Мова Julia також може працювати на Colab (напр. Python і графічні процесори; Блоки тензорної обробки Google також працюють з Julia на Colab[33]).[34][35]

ЗМІ

ред.
  • 11 лютого 2016 року колаборація LIGO оголосила про перше спостереження гравітаційних хвиль. Співпраця випустила необроблені наукові дані разом із записниками Jupyter, які містять код Python для обробки даних та відтворення цифр із документу цього відкриття.[36]
  • 5 квітня 2018 року The Atlantic опублікувала статтю під назвою The Scientific Paper Is Obsolete, в якій обговорювалася роль Notebook Jupyter і Mathematica в майбутньому наукового видання.[21] Ця стаття викликала відповіді від видатних учених і академіків, включаючи економіста Пола Ромера.[37]

Нагороди

ред.

Див. також

ред.

Посилання

ред.
  1. а б https://jupyter.org/about
  2. Open Science Projects Collaborate on Joint Roadmap — 2018.
  3. деякі користувачі вимовляють «py» як /pʌɪ/, відсилаючись на вимову мови програмування Python /ˈpʌɪθn/
  4. Project Jupyter. www.jupyter.org. Процитовано 13 листопада 2020.
  5. Berkeley Institute for Data Science.
  6. Speaker: Brian Granger: Jupyter Notebook conference & training: JupyterCon.
  7. NumFOCUS Sponsored Projects. NumFOCUS. Процитовано 25 жовтня 2021.
  8. Project Jupyter // Speaker Deck.
  9. The Notebook, Qt console and a number of other pieces are now parts of Jupyter. GitHub. 29 травня 2021.
  10. The Big Split™. 28 серпня 2017.
  11. Project Jupyter | Home.
  12. sshirokov (7 травня 2015). GitHub + Jupyter Notebooks = <3. The GitHub Blog (амер.). Процитовано 10 квітня 2018.
  13. Rendering Notebooks on GitHub. Jupyter Blog. 7 травня 2015. Процитовано 10 квітня 2018.
  14. What's new in IPython > Issues closed in the 2.x development cycle.
  15. What's new in IPython > 2.0 Series.
  16. Jupyter kernels > List of (some) IPython compatible kernels. GitHub.
  17. nbconvert: Convert Notebooks to other formats. nbconvert 6.0.8.dev0 documentation. Процитовано 13 листопада 2020.
  18. jupyter/nbconvert, Project Jupyter, 12 квітня 2021, процитовано 13 квітня 2021
  19. nbviewer. nbviewer.jupyter.org. Процитовано 13 листопада 2020.
  20. Notebook's announcement- 0.12 release note.
  21. а б в Somers, James. The Scientific Paper Is Obsolete. The Atlantic (амер.). Процитовано 10 квітня 2018.
  22. JupyterLab is Ready for Users. Jupyter Blog. 20 лютого 2018. Процитовано 4 травня 2018.
  23. Project Jupyter.
  24. Jupyo | Jupyter notebooks for Python, R, Julia in the cloud. jupyo.com. Архів оригіналу за 3 січня 2019. Процитовано 2 січня 2019.
  25. Books with Jupyter. jupyterbook.org (англ.). Процитовано 13 листопада 2020.
  26. The MyST Syntax Guide. myst-parser.readthedocs.io. Процитовано 13 листопада 2020.
  27. nbgrader 0.6.1 documentation. nbgrader.readthedocs.io. Процитовано 13 листопада 2020.
  28. Amazon SageMaker on AWS. Amazon Web Services, Inc. (амер.). Процитовано 9 травня 2018.
  29. Welcome to Colaboratory. research.google.com. Процитовано 9 травня 2018.
  30. Online Jupyter Notebooks. notebooks.azure.com. Процитовано 9 травня 2018.
  31. Nerds rejoice: Google just released its internal tool to collaborate on AI. Quartz (амер.). Процитовано 6 вересня 2018.
  32. Open in Colab GitHub repository. GitHub (англ.). Процитовано 6 вересня 2018.
  33. Julia on TPUs, JuliaTPU, 3 грудня 2019, процитовано 3 грудня 2019
  34. Google Colaboratory. colab.research.google.com (англ.). Процитовано 6 грудня 2019.
  35. gpu — Julia in Google Colab. Stack Overflow. Процитовано 6 грудня 2019.
  36. LIGO Open Science Center. losc.ligo.org (англ.). Процитовано 4 травня 2018.
  37. Romer, Paul. Jupyter, Mathematica, and the Future of the Research Paper. paulromer.net (амер.). Процитовано 15 квітня 2018.
  38. Sloan Foundation Grant. ipython.org. Процитовано 3 травня 2018.
  39. An Open Source Framework for Interactive, Collaborative and Reproducible Scientific Computing and EducationOpen Source Tools for Interactive, Collaborative and Reproducible Computing. ipython.org. Процитовано 3 травня 2018.
  40. Perez, Fernando (28 грудня 2015). IPython 2015 Final Report — Sloan Foundation (PDF). ipython.org. Архів оригіналу (PDF) за 7 жовтня 2020. Процитовано 3 травня 2018.
  41. UC Berkeley and Cal Poly to Expand and Enhance Open-Source Software for Scientific Computing and Data Science | Helmsley Charitable Trust. helmsleytrust.org (англ.). Архів оригіналу за 3 січня 2020. Процитовано 3 травня 2018.
  42. Software System Award. ACM Awards. Association for Computing Machinery. Архів оригіналу за 5 травня 2016. Процитовано квітня 28, 2016.

Посилання

ред.