Notebooks to Document Workflow

Total Page:16

File Type:pdf, Size:1020Kb

Notebooks to Document Workflow X XXX XX Notebooks to document workflow: X XX XX XX XXX XX XX XX XXX XX XX XX XXX a possible XX useful component in Virtual Research Environments X Oceanography Data analysis Reproducibility SeaDataCloud ODIP Virtual Research Environments Python Julia Jupyter 0 What do we want to do? Figure 5: Jupyter ( http://jupyter.org/) 6 Anatomy of a notebook Web application for the creation and sharing of notebook-type documents. Notebooks contain: To use jupyter notebooks both as a user guide and Evolved from IPython ,a command shell for interactive computing (2001). 1. Text cell to document the code as a user interface to describes the different steps to Reproducibility ! More than 40 language kernels available 2. Cell codes that can be exectuted piece by piece generate research products. ! Can be used as a multi-user server ( jupyterhub ) 3. Results from the code execution ! avoid installation steps on several users’ machine ”Interactive notebooks: Sharing the code”, Nature (2014) http://www.nature.com/ 4. Figures or animations news/interactive-notebooks-sharing-the-code-1.16261 3 Why do we use Jupyter? 1 A few definitions & acronyms… Text cell for documenting ( ) 1. Open source… as the others Application Programming Interface (API): rules and specifications that software Code cell to be executed 2. Many programming languages… as the others programs can follow to communicate with each other. 3. Easy installation… as some of the others Result of the cell execution DIVAnd: a software tool designed for the interpolation of in situ measurements in n 4. A nice solution to deploy on a cloud: JupyterHub dimensions. Notebook: web application for the creation and share of documents that include: Tool name R-Markdown Jupyter Beaker Cocalc Zeppelin I code .../rstudio/rmarkdown .../jupyter/notebook .../twosigma/beakerx .../sagemathinc/cocalc .../apache/zeppelin https://github.com/... I Julia, Python, R, figures and animations Julia, Python, R, Scala, R ,Python, Octave , R, Python, SQL, Bash, Javascript, C++, Torch, Scala, Python, SparkSQL, Languages Bash, Octave, Rubi, Cython, Julia,Java, I Rcpp, Stan, JavaScript Scala, Bash, Octave, Rubi, Hive, Markdown text, including equations Fortran, PHP, … C/C++, Perl, Ruby Fortran, … HTML, PDF, MS Word, PDF, LaTeX, HMTL, Virtual research environment (VRE): online infrastructure which aims to help researchers Export formats Beaker format JSON Order of execution ComparisonBeamer, HTML5 slides, … Markdown, reST to work collaboratively by managing Cloud deployment – JupyterHub Beaker Lab (discontinued) – Yes I the software tools, services and technologies, Figure obtained from the cell execution I the access to data resources, public or private, 4 A few more words about I the publication of the results obtained. 8 9 < spawns = Code cell to generate the plot Multi-user Hub which : manages ; multiple instances of the single-user Jupyter notebook 2 Notebooks: what exists today? proxies server ( https://github.com/jupyterhub/jupyterhub). Figure 1: Beaker ( http://beakernotebook.com/ ) Running Notebook-style development environment for working interactively with large and complex datasets. notebooks ! Usage of different languages in different cells, and terminals within the same notebook New notebooks ! Language manager with available language kernels Figure 2: ”Collaborative Calculation in the Cloud” ( https://cocalc.com/ ) Web-based cloud computing platform, formerly called formerly called SageMathCloud. ! Support of many languages ! Users to upload their file on the platform Available files to be later read or processed and directories Figure 6: Test instance of jupyterhub deployed for the SeaDataCloud VRE. Figure 3: R-Markdown ( http://rmarkdown.rstudio.com/ ) Spawner: responsible for the start of the computer environment for the user, either directly Dynamic, self-contained documents with embedded on the server or on a cluster. Several spawners are available, among them DockerSpawner, Figure 7: Examples of notebook cells. chunks of code. ! Possible to export in journal which enables JupyterHub to spawn single user notebook servers in Docker containers ( https://github.com/rstudio/rticles ) or ( https://github.com/jupyterhub/dockerspawner). presentation formats 7 Next steps ! A LTEXtemplates to ensure journal standards 5 How will we use notebooks in the VRE? ! Use the files produced by webODV as an input for DIVAnd ! Build a RESTful API to make easier the integration into the VRE 3 steps into 1 Figure 4: Apache Zeppelin ! Publish the notebooks along with the data and the products ( https://zeppelin.apache.org/ ) Web-based notebook for data-driven, interactive and 8With DIVA 9 with DIVAnd collaborative documents. < Read the doc = Acknowledgements Intended for big data and large scale projects. Compile and run the code ! Run the notebook! ! : ; The work presented in this poster has been developed in the frame of Languages can be mixed in the same notebook Document the execution: parameters, configuration, … ! Users can write their own interpreter (language SeaDataCloud–Further developing the pan-European infrastructure for marine and ocean backend) data management, Project ID 730960 and ODIP 2–Extending the Ocean Data Interoperability Platform, Project ID: 654310. Authors: Charles Troupin, Alexander Barth, Sylvain Watelet and Jean-Marie Beckers GHER_ULiege https://github.com/gher-ulg/ http://labos.ulg.ac.be/gher/.
Recommended publications
  • Teaching an ODE Course with Cocalc, Sage, Jupyter Notebooks, and LATEX
    An ODE Course with Jupyter Notebooks Teaching an ODE Course with CoCalc, Sage, Jupyter Notebooks, and LATEX Thomas W. Judson Stephen F. Austin State University [email protected] MAA Contributed Paper Session on The Teaching and Learning of Undergraduate Ordinary Differential Equations 2019 Joint Mathematics Meetings January 18, 2019 An ODE Course with Jupyter Notebooks UTMOST 1.0 The first UTMOST (Undergraduate Teaching in Mathematics with Open Software and Textbooks) project was a National Science Foundation CCLI Type 2 grant (2010{2014) that promoted open-source software and open-source curriculum in the undergraduate mathematics classroom. I American Institute of Mathematics (DUE{1022574) I Drake University (DUE{1022036) I Stephen F. Austin State University (DUE{1020957) I University of Colorado Boulder (DUE{1020687) I University of Washington (DUE{1020378) I University of California, San Diego An ODE Course with Jupyter Notebooks Highlights of UTMOST 1.0 The products of the first UTMOST grant included: I CoCalc (formerly SageMathCloud)|A comprehensive cloud computing environment for education and scientific computing. I Sage Cell Server|A mechanism to embed live computations into any webpage. I PreTeXt (formerly MathBook XML)|A framework for writing mathematics that can be published in a variety of formats. I Sage Education Workshops|Workshops for learning how to use Sage for the teaching and learning of mathematics. I AIM Open Textbook Initiative|An editorial board to identify and support quality open-source textbooks. An ODE Course with Jupyter Notebooks UTMOST 2.0 The second phase of UTMOST was launched in Fall 2016 and supported by the National Science Foundation as a two-year IUSE grant.
    [Show full text]
  • A Short Introduction to Sagemath
    A short introduction to SageMath Éric Gourgoulhon Laboratoire Univers et Théories (LUTH) CNRS / Observatoire de Paris / Université Paris Diderot Université Paris Sciences et Lettres 92190 Meudon, France http://luth.obspm.fr/~luthier/gourgoulhon/leshouches18/ École de Physique des Houches 11 July 2018 Éric Gourgoulhon SageMath Les Houches, 11 July 2018 1 / 13 Pynac, Maxima, SymPy: symbolic calculations GAP: group theory PARI/GP: number theory Singular: polynomial computations matplotlib: high quality figures Jupyter: graphical interface (notebook) and provides a uniform interface to them William Stein (Univ. of Washington) created SageMath in 2005; since then, ∼100 developers (mostly mathematicians) have joined the SageMath team SageMath is now supported by European Union via the open-math project OpenDreamKit (2015-2019, within the Horizon 2020 program) it is based on the Python programming language it makes use of many pre-existing open-sources packages, among which The mission Create a viable free open source alternative to Magma, Maple, Mathematica and Matlab. SageMath in a few words SageMath( nickname: Sage) is a free open-source mathematics software system Éric Gourgoulhon SageMath Les Houches, 11 July 2018 2 / 13 Pynac, Maxima, SymPy: symbolic calculations GAP: group theory PARI/GP: number theory Singular: polynomial computations matplotlib: high quality figures Jupyter: graphical interface (notebook) and provides a uniform interface to them William Stein (Univ. of Washington) created SageMath in 2005; since then, ∼100 developers (mostly mathematicians) have joined the SageMath team SageMath is now supported by European Union via the open-math project OpenDreamKit (2015-2019, within the Horizon 2020 program) it makes use of many pre-existing open-sources packages, among which The mission Create a viable free open source alternative to Magma, Maple, Mathematica and Matlab.
    [Show full text]
  • Scientific Programming in Python
    PHYS4038/MLiS and AS1/MPAGS Scientific Programming in mpags-python.github.io Steven Bamford An introduction to scientific programming with Session 1: Introduction to Python An introduction to scientific programming with Session 1.1: Choosing and using Python Why use a high-level language? • Modern high-level languages: • Python, R, JS, Julia, Ruby, IDL, Perl, … • Interactive interpreter • Ease of use • Speed of development • Readability • Writing code (‘scripting’) better than a one-off analysis • Permanent record • Repeatability Why not? • If you want fastest possible performance • at the expense of everything else • You need highly parallel code • Need low-level control • Unless you are working on a supercomputer or developing operating systems components, these probably don't apply to you • Even then, high-level language could be useful in places (glue, tests, etc.) Why Python is awesome • Designed to be easy to learn and use – clear syntax • Well documented • Powerful, flexible, fully-featured programming language • Multi-paradigm • Comprehensive scientific and data analysis tools • Fast, efficient • Interpreter, introspection • Runs everywhere, completely free • Large community Why learn Python? • Get more science done with less stress • Widely used throughout academia and industry • NASA, AstraZeneca, Google, Industrial Light & Magic, Philips,… • data science, machine learning, web services, engineering, science, finance, games, education, data management, … • Python programmers in demand • Easy introduction to general programming
    [Show full text]
  • Sage Installation Guide Release 9.4
    Sage Installation Guide Release 9.4 The Sage Development Team Aug 24, 2021 CONTENTS 1 Linux package managers 3 2 Install from Pre-built Binaries5 2.1 Download Guide.............................................5 2.2 Linux...................................................5 2.3 macOS..................................................6 2.4 Microsoft Windows (Cygwin)......................................6 3 Install from conda-forge 7 4 Install from Source Code 9 4.1 Supported platforms...........................................9 4.2 Prerequisites............................................... 10 4.3 Additional software........................................... 18 4.4 Step-by-step installation procedure.................................... 20 4.5 Make targets............................................... 25 4.6 Environment variables.......................................... 25 4.7 Installation in a Multiuser Environment................................. 30 5 Launching SageMath 33 5.1 Using a Jupyter Notebook remotely................................... 33 5.2 WSL Post-installation steps....................................... 34 5.3 Setting up SageMath as a Jupyter kernel in an existing Jupyter notebook or JupyterLab installation.. 35 6 Troubleshooting 37 Index 39 i ii Sage Installation Guide, Release 9.4 You can install SageMath either from a package manager, a pre-built binary tarball or from its sources. Installing SageMath from your distribution package manager is the preferred and fastest solution (dependencies will be automatically taken care of and SageMath will be using your system Python). It is the case at least for the following GNU/Linux distributions: Debian version >= 9, Ubuntu version >= 18.04, Arch Linux, and NixOS. If you are in this situation, see Linux package managers. If your operating system does not provide SageMath, you can also use a pre-built binary. See the section Install from Pre-built Binaries. Or you could install the sage package from the conda-forge project.
    [Show full text]
  • Project Jupyter: from Computational Notebooks to Large Scale Data Science with Sensitive Data
    @ellisonbg Project Jupyter: From Computational Notebooks to Large Scale Data Science with Sensitive Data Brian Granger Cal Poly, Physics/Data Science Project Jupyter, Co-Founder ACM Learning Seminar September 2018 Cal Poly Outline • Jupyter + Computational Notebooks • Data Science in Large, Complex Organizations • JupyterLab • JupyterHub Project Jupyter exists to develop open-source software, open- standards and services for interactive and reproducible computing. The Jupyter Notebook • Project Jupyter (https://jupyter.org) started in 2014 as a spinoff of IPython • Flagship application is the Jupyter Notebook • Interactive, exploratory, browser-based Visualization computing environment for data science, scientific computing, ML/AI • Notebook document format (.ipynb): • Live code, narrative text, equations (LaTeX), images, visualizations, audio • Reproducible Computational Narrative Narrative Text • ~100 programming languages supported • Over 500 contributors across 100s of GitHub repositories. Live Code • 2017 ACM Software System Award. Example notebook from the LIGO Collaboration Before Moving On: Attribution? Who Builds Jupyter? • Jupyter Steering Council: • Fernando Perez, Brian Granger, Min Ragan-Kelley, Paul Ivanov, Thomas Kluyver, Jason Grout, Matthias Bussonnier, Damian Avila, Steven Silvester, Jonathan Frederic, Kyle Kelley, Jessica Hamrick, Carol Willing, Sylvain Corlay, Peter Parente, Ana Ruvalcaba, Afshin Darian, M Pacer. • Other Core Jupyter Contributors: • Chris Holdgraf, Yuvi Panda, M Pacer, Ian Rose, Tim Head, Jessica Forde, Jamie Whitacre, Grant Nestor, Chris Colbert, Cameron Oelsen, Tim George, Maarten Breddels, 100s others. • Dozens of interns at Cal Poly • Funding • Alfred P. Sloan Foundation, Moore Foundation, Helmsley Trust, Schmidt Foundation • NumFOCUS: Parent 501(c)3 for Project Jupyter and other open-source projects How to think about the contributions of different people? What is the right narrative? Attribution Narrative: Not This! Jupyter is not the heroic work of one person, or even a small number of people.
    [Show full text]
  • Jupyter Documentation Release 4.1.1 Alpha
    Jupyter Documentation Release 4.1.1 alpha https://jupyter.org Sep 08, 2021 CONTENTS 1 Start Here 3 2 Sub-project documentation 5 3 Table of Contents 7 3.1 Get Started................................................7 3.2 Using Jupyter Tools........................................... 16 3.3 Jupyter Projects.............................................. 29 3.4 Community................................................ 42 3.5 Contributing............................................... 79 3.6 Reference................................................. 148 4 Resources 151 5 Indices and tables 153 Index 155 i ii Jupyter Documentation, Release 4.1.1 alpha Welcome to the Jupyter Project documentation. This website acts as “meta” documentation for the Jupyter ecosys- tem. It has a collection of resources to navigate the tools and communities in this ecosystem, and to help you get started. CONTENTS 1 Jupyter Documentation, Release 4.1.1 alpha 2 CONTENTS CHAPTER ONE START HERE Get started with Jupyter Notebook Community Try the notebook Sustainability and growth Architecture Contributor Guides What is Jupyter? How to contribute to the projects Narratives and Use Cases Release Notes Narratives of common deployment scenarios New features, upgrades, deprecation notes, and bug fixes IPython Reference An interactive Python kernel and REPL APIs Installation, Configuration, and Usage Advanced Documentation for users Documentation for advanced use-cases 3 Jupyter Documentation, Release 4.1.1 alpha 4 Chapter 1. Start Here CHAPTER TWO SUB-PROJECT DOCUMENTATION
    [Show full text]
  • User & Developer Survey 2021
    User & Developer Survey 2021 Andrew Claster & Viral Shah Methodology We conducted 2,660 interviews online among Julia users and developers June 2 – July 7, 2021 Margin of error is +/- 1.9 percentage points We recruited respondents online using Slack, Discourse, Twitter, LinkedIn, Facebook, email, JuliaLang.org and JuliaComputing.com The survey was administered in 4 languages: English, Chinese, Japanese and Spanish 2 62% Use Julia ‘A Great Deal’, Up from 56% in 2019; Python Is #2 for Julia Users & Developers How frequently do you use each of the following languages? Julia Python Great deal Some Great deal Some 94% 95% 94% 81% 81% 81% 32% 38% 37% 36% 42% 37% 62% 56% 58% 45% 39% 44% 2019 2020 2021 2019 2020 2021 Other languages not shown include Bash/Shell/PowerShell (67% great deal + some), C++ (38% great deal + some), C (37% great deal + some), MATLAB (37% great deal + some), R (33% great deal + some) and SQL (31% great deal + some) 3 78% Say Julia Is ‘One of My Favorite Languages’, Up from 73% in 2019; PytHon Has Been Declining Among Julia Users Since 2019 How much do you like each of the following languages? Julia PytHon One of my favorite languages Like One of my favorite languages Like 93% 93% 93% 20% 18% 15% 61% 57% 55% 35% 30% 73% 75% 78% 32% 26% 27% 23% 2019 2020 2021 2019 2020 2021 OtHer languages not shown include C (26% ‘one of my favorite languages’ + ‘like’), Bash/SHell/PowerSHell (19% ‘one of my favorite languages’ + ‘like’), R (19% ‘one of my favorite languages’ + ‘like’, C++ (18% ‘one of my favorite languages’ + ‘like’),
    [Show full text]
  • Jupyter Notebooks
    Universidad Complutense de Madrid GUIDE TO JUPYTER NOTEBOOKS FOR EDUCATIONAL PURPOSES Authors: Eduardo Cabrera Granado Elena D´ıazGarc´ıa Translation by: Alvaro´ D´ıazFern´andez Contents Introduction 1 Jupyter Notebook 3 Python 11 Course management with Jupyter Notebook 21 Educational Proposals 27 Conclusions 31 References 33 Introduction Jupyter is an open source project that aims to allow the usage of different program- ming languages in one computational platform. In fact, its name originates from three of the most popular programming languages for scientific computing: Julia, Python and R. It is built upon the Jupyter Notebook web interface, which brings to- gether the possibilities of executing code, including text along with LaTeX equations (via MathJax), video, and everything that can be visualized within a browser. On the other hand, its features can be extended by means of external tools, an example of which is nbconvert, which can handle conversion to LaTeX and PDF formats. Also available is the possibility to include web presentations based on Reveal.js, or interactive widgets within the document via ipywidgets. Jupyter's development has been supported by companies such as Microsoft or Google, as well as boosted by OpenDreamKit, a Horizon 2020 European Research Infrastructure project. The popularity of Jupyter for educational purposes has grown exponentially due to its flexibility, ease of access through a browser, and the added value brought by the possibility to isolate the document itself from the computational core. This architecture allows to forget about local installation. The lecturer can use an external server (or even their laptop) to supply students with lectures, slides, or interactive assignments.
    [Show full text]
  • Accessible Software and Tools for Pro Bono OR Volunteers
    Accessible software and tools for Pro Bono OR Volunteers Tool Link Category Further Details Apache OFBiz http://ofbiz.apache.org/ Supply chain management Provides a suite of enterprise applications that integrate and automate many of the business processes of an enterprise Apache https://www.zeppelin.apac Data visualisation Notebook for visualisation Zeppelin he.org/ ArangoDB https://www.arangodb.co Graph Database ArangoDB is designed as a native multi-model database from the first line of code. This enables you to model m/why-arangodb/ your data in a very flexible way and use ArangoDB for large number of use cases. ArcGIS https://arcgis.com/features Geospatial / Mapping Geographic information system (GIS) for working with maps and geographic information, creating maps, /index.html software compiling geographic data and analysing mapped information Awesome R https://www.awesome- Various: Data manipulation; A curated list of awesome R packages and tools r.com/ Database management; Graphical displays; Machine learning; Bayesian Bizagi http://www.bizagi.com/en Simulation A process modelling tool to design, document and evolve process model Blender https://www.blender.org/ 3D Modeling and animation An Open source 3D modelling and animation. Cassandra http://cassandra.apache.or Database A free and open-source, distributed, wide column store, NoSQL database management system designed to g/ handle large amounts of data across many commodity servers, providing high availability with no single point of failure ChartsBin http://www.chartsbin.com/ Geospatial / Mapping A web-based data visualization tool. No installation required. No coding needed. about/apply software CMPL https://projects.coin- Optimisation A mathematical programming language and a system for mathematical programming and optimisation of linear or.org/Cmpl optimisation problems.
    [Show full text]
  • Computational Linguistics (Syllabus)
    Computational Linguistics (Syllabus) Course Info Course# LIN 220 Time MF 1:00-2:20pm Location tbd Website on CoCalc Instructor Aniello De Santo Email [email protected] Office hours tbd Office SBS N-232 1 Bulletin description An introduction to computational linguistics for students with previous programming experi- ence. This course explores the models, algorithms, and techniques that dominate modern-day language technology, and it evaluates them from a linguistically informed perspective. Topics include corpus-based methods, finite-state approaches, machine learning, and model evaluation techniques. Great emphasis is put on discussing the limitations of existing techniques and how they might benefit from linguistic insights. Students will also hone their programming skills and develop familiarity with state-of-the-art software packages for computational linguistics. 2 Teaching goals • expand existing programming skills • master essential concepts and techniques in computational linguistics • critically evaluate computational models from a linguistically informed perspective • translate abstract computational models into fully functional source code • develop learning autonomy and the ability to deepen your programming knowledge through self-study 1 • Students must use the skills expected from their Versatility courses to study and practice them in greater depth, with further study applied to the area in which they are certified. 3 Prerequisites 3.1 Formal prerequisites C or better in at least one of the following courses: • LIN 120 • CSE 110 • CSE 114 • ISE 108 Students who do not meet this requirement may be allowed to enroll with permission of the instructor. 3.2 What’s required? This course assumes that you have already mastered essential programming concepts, including • variables • basic data types (strings, integers, arrays/lists) • control flow (if-else) • loops (while, for) • custom functions Even though the course uses Python 3 as its programming language, you do not need to have prior experience with that specific language.
    [Show full text]
  • Sagemathcloud Scientific Workplace
    History Website: https://cloud.sagemath.com Open Source: https://github.com/sagemath/cloud/ SageMathCloud 2006 Contact: William Stein <[email protected]> We create the Sage Notebook, a web-based graphical user Scientific Workplace interface for Sage, inspired by Google docs. It provides web- Credits MAA Project NExT, 2015 based access to Sage, but lacks reliability, scalability and other critical features needed to support millions of users. SageMathCloud makes available, is built upon, and powered https://cloud.sagemath.com by: GNU/Linux, Node.js, Coffeescript, Python, IPython, Sage, 2012 LATEX, Octave, R, Julia, GCC, Fortran, Lisp, Haskel, Codemir- SageMathCloud is the scientific workplace of the 21st cen- We start design of SageMathCloud as a successor to the ror, Bootstrap, term.js, diff-patch-merge, Markdown, pandoc, tury. It offers interactive documents for computational math- Sage Notebook. This involves exploring concrete ideas for rst2html, ImageMagic, rsync, ssh, Nginx, Cassandra, ZFS, ematics, data storage and document processing through a building the system, based on essential design constraints, Bup, Java, stunnel, tinc, HAproxy, and much, much more. modern web-interface. including high-availability, horizontal scalability and continu- Financial support ous snapshotting of data. • Collaborative online web-service NSF, Google, University of Washington 2013 • Real-time synchronization of worksheets and files Intense work starts full steam in March 2013, and the site is • Easy publishing and downloading of files launched publicly. Several classrooms start to use SageMath- • Snapshots with continuous backup of all data Cloud, including a 350-student Calculus course at UCLA. • Enhanced Sage installation & full scientific Python stack 2014 This flyer was created entirely inside SageMathCloud.
    [Show full text]
  • The Design Space of Computational Notebooks: an Analysis of 60 Systems in Academia and Industry
    The Design Space of Computational Notebooks: An Analysis of 60 Systems in Academia and Industry Sam Lau, Ian Drosos, Julia M. Markel, Philip J. Guo UC San Diego La Jolla, CA, USA Abstract—Computational notebooks such as Jupyter are now Despite this recent proliferation of notebook systems and used by millions of data scientists, machine learning engineers, the gradual maturing of this field, we still lack a systematic and computational researchers to do exploratory and end-user understanding of how these dozens of individual designs relate programming. In recent years, dozens of different notebook systems have been developed across academia and industry. to one another and what their tradeoffs are. To provide this However, we still lack an understanding of how their individual holistic overview, we developed the first comprehensive design designs relate to one another and what their tradeoffs are. To space of computational notebooks by analyzing dozens of provide a holistic view of this rapidly-emerging landscape, we notebook systems across academia and industry. performed, to our knowledge, the first comprehensive design In HCI research, a design space succinctly captures multiple analysis of dozens of notebook systems. We analyzed 60 notebooks (16 academic papers, 29 industry products, and 15 experimen- dimensions of variation in possible system features within a tal/R&D projects) and formulated a design space that succinctly given domain; each individual system covers a specific range captures variations in system features. Our design space covers 10 in its design space. Researchers have mapped out design dimensions that include diverse ways of importing data, editing spaces for systems in domains such as end-user program- code and prose, running code, and publishing notebook outputs.
    [Show full text]