A Case for Integrating Experimental Containers with Notebooks

Total Page:16

File Type:pdf, Size:1020Kb

A Case for Integrating Experimental Containers with Notebooks A Case for Integrating Experimental Containers with Notebooks Jason Anderson∗y and Kate Keaheyy∗ ∗Consortium for Advanced Science and Engineering University of Chicago, Chicago, IL 60637 Email: [email protected] yArgonne National Laboratory Lemont, IL 60439 Email: [email protected] Abstract—Computational notebooks have gained much pop- greatly facilitated by the advent of computational notebooks, ularity as a way of documenting research processes; they which have already proven themselves instrumental in com- allow users to express research narrative by integrating ideas municating scientific discoveries [2]. Their success lies in expressed as text, process expressed as code, and results in one the ability to provide a link between ideas (explained in executable document. However, the environments in which the text), process (captured as code), and results in the form code can run are currently limited, often containing only a of graphs, pictures, or other artifacts. They have however a fraction of the resources of one node, posing a barrier to many significant limitation in that the execution environment of a computations. In this paper, we make the case that integrating notebook is constrained to a small set of possibilities, such complex experimental environments, such as virtual clusters as preconfigured virtual machines or software containers, or complex networking environments that can be provisioned and often only granted a small fraction of a system’s full via infrastructure clouds, into computational notebooks will resources. While sufficient for many generic computations, significantly broaden their reach and at the same time help it falls short of being able to support large-scale scientific realize the potential of clouds as a platform for repeatable experiments that increasingly require complex experimen- research. To support our argument, we describe the integration tal containers composed of diverse and powerful resources of Jupyter notebooks into the Chameleon cloud testbed, which distributed over complex topologies. allows the user to define complex experimental environments The challenge of supporting such environments has been addressed by infrastructure clouds, from commercial and then assign processes to elements of this environment resources such as Amazon Web Services (AWS) [3] to similarly to the way a laptop user may switch between different open testbeds such as Chameleon [4]: they allow users to desktops. We evaluate our approach on an actual experiment create experimental containers implemented using isolation from both the development and replication perspective. vehicles from virtual machines to bare metal and from nodes to networks. Furthermore, the digital artifacts that 1. Introduction represent such containers—such as images and orchestra- tion templates [5] that marshal those images into complex Scientific computations, whether large-scale simulations, environments such as virtual clusters—can be shared and just-in-time analytics, or performance studies, each represent used by others to reestablish the experimental environment a computational experiment, which may have to be repeated within a given platform. This makes the task of replicating or replicated [1] for purposes of validation, variation, or computational experiments significantly easier; but the pro- other forms of evaluating and leveraging scientific con- cess that creates those digital artifacts is still complex and tribution. These computational experiments take place in thus poses a barrier to publishing them in the first place. experimental containers that define the environment of the In this paper, we propose a way to integrate notebooks– computation in terms of its configuration and makeup (i.e., a highly effective tool for the description of experimental compute nodes, networks, or storage resources as well as process–and experimental containers, capable of providing software configuration required by the computation). Such complex experimental environments, to mutual benefit. On experimental containers may be complex, and thus difficult one hand, dynamically and accurately deployed experimen- to create. Changes in their configuration may introduce tal containers based on shared artifacts developed for clouds inconsistencies, lead to wrong results, or even make re- or testbeds can address a deficiency of notebooks in terms of peating a computation impossible. Repeating or replicating documenting the experimental process. On the other hand, computational experiments thus relies on ensuring that its notebooks can provide a convenient and intuitive tool for experimental container is configured correctly every time. utilizing such containers in a way that more closely resem- The task of documenting an experimental process in bles the creative process and provides a way to introduce such a way that it can be shared and repeated has been variation in both the container makeup and the steps of experimentation. To support our argument, we describe the notebooks on hardware they control. This appraoch requires integration of Jupyter [6] notebooks with the Chameleon additional operational knowledge and reduces the likelihood testbed and a design pattern that leverages this integration of replicating the experiment results by requiring that future to allow the user to define arbitrarily complex experimental researchers possess similar hardware. containers and then assign processes to elements of this A different approach is implemented by systems such as container similarly to the way a laptop user may switch Popper [26] and Sumatra [27] which express an experimen- between different desktops. We evaluate our approach on an tal workflow that can be implemented across platforms in actual experiment from both the development and replication a declarative form. However, the “process” of experimenta- perspective to illustrate how it can help more investigators tion, when defined declaratively, requires understanding the structure more complex experiments interactively, and allow syntax and rules of different platforms and also creates chal- for their replication and controlled variation. lenges for an iterative workflow: declarative systems usually This paper is organized as follows. In Section 3 we do not have a mechanism for storing intermediate state, define experimental containers, describe their properties, and so are biased towards re-running the entire workflow and discuss their implementation across a range of testbeds. from start to finish. Besides this limitation, researchers find In Sections 4 and 5 we explain how we integrated this complex scenarios hard to represent unless care and time concept of a container into notebooks and discuss our im- is taken to follow the declarative model from the beginning plementation of integration of Jupyter notebooks with the [28], [29]. If a researcher makes the investment into such a Chameleon testbed. In Section 6, we validate our proposal workflow, their exact process does indeed become reliable, in the context of a demanding distributed experiment and streamlined, and easy to repeat. However, it is still hard to explain its benefits and limitations. interact with and produce variation easily which is necessary for exploring different inputs, configurations, and hypothe- 2. Related Work ses on the fly; in this context an imperative approach usually works better. The value of interweaving ideas (text) and process (code) in one document was first explored in an approach called 3. Experimental Containers literate programming [7]. Interactive notebooks follow the same pattern, but additionally allow the user to pause, Most computation takes place in the context of rewind, replay and resume a computation at any point, a complex configuration of resources including not supporting a more organic workflow. Additionally, the user only compute nodes, but potentially also accelerators, can work with rich, potentially interactive visualizations. networks, and storage. Recording and then replicating this The two predominant implementations of these interactive configuration is often not only complex and thus hard to do, notebooks are Wolfram Mathematica [8] and IPython (later but also needs to be done accurately to ensure consistency named Project Jupyter) [9]. Despite Mathematica’s longer of results. The latter is particularly true of Computer existence, Jupyter has better penetration within the aca- Science experiments in fields such power management or demic community, due to leveraging a large open-source performance variability, but can also affect other types development community and providing a web-based in- of computations. While virtualization techniques, such terface requiring no specialized client tools. The web in- as virtual machines or networks, addressed this problem terface spawned several managed “Notebook-as-a-Service” partially, we often need a generalized “container” that platforms to aid in reproducibility, such as CodeOcean [10], extends the abstraction over a combination of multiple WholeTale [11], Nextjournal [12], Binder [13], Wolfram resources working in concert. We describe below the Cloud [14], Azure Notebooks [15], Amazon EMR [16], properties of such experimental containers and discuss and Google Colab [17]. Pangeo [18] is recent development several implementations that satisfy them to various that applies this pattern to science problems across various degrees. domains. Many researchers have experimented with using Jupyter notebooks specifically to improve reproducibility Isolation: The ability
Recommended publications
  • Jupyter Notebooks—A Publishing Format for Reproducible Computational Workflows
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by Elpub digital library Jupyter Notebooks—a publishing format for reproducible computational workflows Thomas KLUYVERa,1, Benjamin RAGAN-KELLEYb,1, Fernando PÉREZc, Brian GRANGERd, Matthias BUSSONNIERc, Jonathan FREDERICd, Kyle KELLEYe, Jessica HAMRICKc, Jason GROUTf, Sylvain CORLAYf, Paul IVANOVg, Damián h i d j AVILA , Safia ABDALLA , Carol WILLING and Jupyter Development Team a University of Southampton, UK b Simula Research Lab, Norway c University of California, Berkeley, USA d California Polytechnic State University, San Luis Obispo, USA e Rackspace f Bloomberg LP g Disqus h Continuum Analytics i Project Jupyter j Worldwide Abstract. It is increasingly necessary for researchers in all fields to write computer code, and in order to reproduce research results, it is important that this code is published. We present Jupyter notebooks, a document format for publishing code, results and explanations in a form that is both readable and executable. We discuss various tools and use cases for notebook documents. Keywords. Notebook, reproducibility, research code 1. Introduction Researchers today across all academic disciplines often need to write computer code in order to collect and process data, carry out statistical tests, run simulations or draw figures. The widely applicable libraries and tools for this are often developed as open source projects (such as NumPy, Julia, or FEniCS), but the specific code researchers write for a particular piece of work is often left unpublished, hindering reproducibility. Some authors may describe computational methods in prose, as part of a general description of research methods.
    [Show full text]
  • Deep Dive on Project Jupyter
    A I M 4 1 3 Deep dive on Project Jupyter Dr. Brian E. Granger Principal Technical Program Manager Co-Founder and Leader Amazon Web Services Project Jupyter © 2019, Amazon Web Services, Inc. or its affiliates. All rights reserved. © 2019, Amazon Web Services, Inc. or its affiliates. All rights reserved. Project Jupyter exists to develop open-source software, open standards and services for interactive and reproducible computing. https://jupyter.org/ Overview • Project Jupyter is a multi-stakeholder, open source project. • Jupyter’s flagship application is the Text Math Jupyter Notebook. • Notebook document format: • Live code, narrative text, equations, images, visualizations, audio. • ~100 programming languages supported. Live code • Over 500 contributors across >100 GitHub repositories. • Part of the NumFOCUS Foundation: • Along with NumPy, Pandas, Julia, Matplotlib,… Charts Who uses Jupyter and how? Students/Teachers Data science Data Engineers Machine learning Data Scientists Scientific computing Researchers Data cleaning and transformation Scientists Exploratory data analysis ML Engineers Analytics ML Researchers Simulation Analysts Algorithm development Reporting Data visualization Jupyter has a large and diverse user community • Many millions of Jupyter users worldwide • Thousands of AWS customers • Highly international • Over 5M public notebooks on GitHub alone Example: Dive into Deep Learning • Dive into Deep Learning is a free, open-source book about deep learning. • Zhang, Lipton, Li, Smola from AWS • All content is Jupyter Notebooks on GitHub. • 890 page PDF, hundreds of notebooks • https://d2l.ai/ © 2019, Amazon Web Services, Inc. or its affiliates. All rights reserved. Common threads • Jupyter serves an extremely broad range of personas, usage cases, industries, and applications • What do these have in common? Ideas of Jupyter • Computational narrative • “Real-time thinking” with a computer • Direct manipulation user interfaces that augment the writing of code “Computers are good at consuming, producing, and processing data.
    [Show full text]
  • SENTINEL-2 DATA PROCESSING USING R Case Study: Imperial Valley, USA
    TRAINING KIT – R01 DFSDFGAGRIAGRA SENTINEL-2 DATA PROCESSING USING R Case Study: Imperial Valley, USA Research and User Support for Sentinel Core Products The RUS Service is funded by the European Commission, managed by the European Space Agency and operated by CSSI and its partners. Authors would be glad to receive your feedback or suggestions and to know how this material was used. Please, contact us on [email protected] Cover image credits: ESA The following training material has been prepared by Serco Italia S.p.A. within the RUS Copernicus project. Date of publication: November 2020 Version: 1.1 Suggested citation: Serco Italia SPA (2020). Sentinel-2 data processing using R (version 1.1). Retrieved from RUS Lectures at https://rus-copernicus.eu/portal/the-rus-library/learn-by-yourself/ This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License. DISCLAIMER While every effort has been made to ensure the accuracy of the information contained in this publication, RUS Copernicus does not warrant its accuracy or will, regardless of its or their negligence, assume liability for any foreseeable or unforeseeable use made of this publication. Consequently, such use is at the recipient’s own risk on the basis that any use by the recipient constitutes agreement to the terms of this disclaimer. The information contained in this publication does not purport to constitute professional advice. 2 Table of Contents 1 Introduction to RUS ........................................................................................................................
    [Show full text]
  • Final Report for the Redus Project
    FINAL REPORT FOR THE REDUS PROJECT Reduced Uncertainty in Stock Assessment Erik Olsen (HI), Sondre Aanes Norwegian Computing Center, Magne Aldrin Norwegian Computing Center, Olav Nikolai Breivik Norwegian Computing Center, Edvin Fuglebakk, Daisuke Goto, Nils Olav Handegard, Cecilie Hansen, Arne Johannes Holmin, Daniel Howell, Espen Johnsen, Natoya Jourdain, Knut Korsbrekke, Ono Kotaro, Håkon Otterå, Holly Ann Perryman, Samuel Subbey, Guldborg Søvik, Ibrahim Umar, Sindre Vatnehol og Jon Helge Vølstad (HI) RAPPORT FRA HAVFORSKNINGEN NR. 2021-16 Tittel (norsk og engelsk): Final report for the REDUS project Sluttrapport for REDUS-prosjektet Undertittel (norsk og engelsk): Reduced Uncertainty in Stock Assessment Rapportserie: År - Nr.: Dato: Distribusjon: Rapport fra havforskningen 2021-16 17.03.2021 Åpen ISSN:1893-4536 Prosjektnr: Forfatter(e): 14809 Erik Olsen (HI), Sondre Aanes Norwegian Computing Center, Magne Aldrin Norwegian Computing Center, Olav Nikolai Breivik Norwegian Program: Computing Center, Edvin Fuglebakk, Daisuke Goto, Nils Olav Handegard, Cecilie Hansen, Arne Johannes Holmin, Daniel Howell, Marine prosesser og menneskelig Espen Johnsen, Natoya Jourdain, Knut Korsbrekke, Ono Kotaro, påvirkning Håkon Otterå, Holly Ann Perryman, Samuel Subbey, Guldborg Søvik, Ibrahim Umar, Sindre Vatnehol og Jon Helge Vølstad (HI) Forskningsgruppe(r): Godkjent av: Forskningsdirektør(er): Geir Huse Programleder(e): Bentiske ressurser og prosesser Frode Vikebø Bunnfisk Fiskeridynamikk Pelagisk fisk Sjøpattedyr Økosystemakustikk Økosystemprosesser
    [Show full text]
  • Exploratory Data Science Using a Literate Programming Tool Mary Beth Kery1 Marissa Radensky2 Mahima Arya1 Bonnie E
    The Story in the Notebook: Exploratory Data Science using a Literate Programming Tool Mary Beth Kery1 Marissa Radensky2 Mahima Arya1 Bonnie E. John3 Brad A. Myers1 1Human-Computer Interaction Institute 2Amherst College 3Bloomberg L. P. Carnegie Mellon University Amherst, MA New York City, NY Pittsburgh, PA [email protected] [email protected] mkery, mahimaa, bam @cs.cmu.edu ABSTRACT engineers, many of whom never receive formal training in Literate programming tools are used by millions of software engineering [30]. programmers today, and are intended to facilitate presenting data analyses in the form of a narrative. We interviewed 21 As even more technical novices engage with code and data data scientists to study coding behaviors in a literate manipulations, it is key to have end-user programming programming environment and how data scientists kept track tools that address barriers to doing effective data science. For of variants they explored. For participants who tried to keep instance, programming with data often requires heavy a detailed history of their experimentation, both informal and exploration with different ways to manipulate the data formal versioning attempts led to problems, such as reduced [14,23]. Currently even experts struggle to keep track of the notebook readability. During iteration, participants actively experimentation they do, leading to lost work, confusion curated their notebooks into narratives, although primarily over how a result was achieved, and difficulties effectively through cell structure rather than markdown explanations. ideating [11]. Literate programming has recently arisen as a Next, we surveyed 45 data scientists and asked them to promising direction to address some of these problems [17].
    [Show full text]
  • 2019 Annual Report
    ANNUAL REPORT 2019 TABLE OF CONTENTS LETTER FROM THE BOARD CO-CHAIRPERSON ..............................................03 PROJECTS ....................................................................................................................... 04 New Sponsored Projects Project Highlights from 2019 Project Events Case Studies Affiliated Projects NumFOCUS Services to Projects PROGRAMS ..................................................................................................................... 16 PyData PyData Meetups PyData Conferences PyData Videos Small Development Grants to NumFOCUS Projects Inaugural Visiting Fellow Diversity and Inclusion in Scientific Computing (DISC) Google Season of Docs Google Summer of Code Sustainability Program GRANTS ........................................................................................................................... 25 Major Grants to Sponsored Projects through NumFOCUS SUPPORT ........................................................................................................................ 28 2019 NumFOCUS Corporate Sponsors Donor List FINANCIALS ................................................................................................................... 34 Revenue & Expenses Project Income Detail Project EOY Balance Detail PEOPLE ............................................................................................................................ 38 Staff Board of Directors Advisory Council LETTER FROM THE BOARD CO-CHAIRPERSON NumFOCUS was founded in
    [Show full text]
  • 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]
  • [Getting Started Guide]
    [Getting Started Guide] Contents What is Jupyter Notebook? .......................................................................................................................... 3 How To Use Jupyter Notebook? ................................................................................................................... 4 Log in to the UofT JupyterHub .................................................................................................................. 4 Jupyter file explorer .................................................................................................................................. 5 Create a new Jupyter notebook for python .............................................................................................. 6 Markdown cell .......................................................................................................................................... 7 Installing packages .................................................................................................................................... 8 Docstring (Package, class, and function descriptions) .............................................................................. 9 Magic commands .................................................................................................................................... 10 How to share/distribute files? .................................................................................................................... 11 One-click download (nbgitpuller) ..........................................................................................................
    [Show full text]
  • Project Jupyter: Computational Narratives As the Engine of Collaborative Data Science
    Project Jupyter: Computational Narratives as the Engine of Collaborative Data Science Note: this is the full text of the grant proposal that was funded by the Helmsley Trust, the Gordon and Betty Moore Foundation and the Alfred P. Sloan Foundation on April 2015, as described on these two announcements from UC Berkeley and Cal Poly , and press releases from the Helmsley Trust and the Moore Foundation . A PDF version of this document can be found here . Fernando Perez Brian E. Granger Lawrence Berkeley National Lab & Cal Poly San Luis Obispo UC Berkeley Statement of the problem and audience Computers are good at consuming, producing and processing data. Humans, on the other hand, process the world through narratives. Thus, in order for data, and the computations that process and visualize that data, to be useful for humans, they must be embedded into a narrative - a computational narrative - that tells a story for a particular audience and context. There are three fundamental aspects of these computational narratives that frame the problem we seek to address. First, a single computational narrative needs to span a wide range of contexts and audiences. For example, a biomedical researcher might originally perform statistical analyses and visualizations for a highly technical paper to be published in an academic journal. Over time, however, that same individual will give talks to other researchers, or even non-technical audiences. Eventually, it may even be important to enable non-coding lab scientists to perform that same statistical analyses and visualizations on data from new samples using a simplified graphical user interface.
    [Show full text]
  • Jupyter Notebooks for Ops
    Jupyter Notebooks for Ops LISA 2019 Derek Arnold Objectives An introduction/history of Jupyter Notebooks (aka "How Did We Get Here?") How they can be used in ways pertinent to ops folks (aka "What Do We Do Here?") How they can be maintained to facilitate use for non-ops folks (aka "How Can We Help These Folks Here?") What's next? (aka "What's Next?") Introduction Who are you? What do you do? Current employer: N/A A tech professional for ~20 years in various sectors (consulting, telecommunications, public sector, manufacturing) System administration (Linux mostly, some other UNIX, some Windows) many technical hats Enjoy trying to use tools to provide solutions in novel ways My fth LISA (FIF!) How did we get here? What are Jupyter Notebooks? Formal denition from Project Jupyter (https://jupyter.org): “The Jupyter Notebook is an open-source web application that allows you to create and share documents that contain live code, equations, visualizations and explanatory text. Uses include: data cleaning and transformation, numerical simulation, statistical modeling, machine learning and much more.” How did we get here? What specically is a Jupyter Notebook? Jupyter Notebooks are a mix of three distinct components (all maintained by Project Jupyter: The entire project is 100% open source under the 3-clause BSD license. The notebook document format, (based on JSON) The interactive computing protocol, (based on ZeroMQ and Websockets The kernel, (the default is iPython's Python kernel)* * more on this later How did we get here? What is iPython? iPython runs the Python in the notebook Reference for any other kernel for Jupyter Notebooks interesting way to run Python in its own right What Do We Do Here? Installing Jupyter Notebooks pip install jupyter conda install jupyter PSA: Please use virtual environments or, put another way..
    [Show full text]
  • Utilities for Authoring Sagemath Packages Release 0.0.7
    Utilities for authoring SageMath packages Release 0.0.7 Nicolas M. Thiéry et al. Feb 10, 2019 Contents 1 setuptools utilities for SageMath packages1 2 A Sphinx extension for writing SageMath-style documentation3 3 Sphinx extension demo 5 4 Live SageMath examples in static HTML pages with Thebe and binder7 4.1 In a nutshell...............................................7 4.2 Components...............................................7 4.3 For authors................................................8 4.4 Thebe versus SageMath Cell.......................................9 5 Indices and tables 11 Python Module Index 13 i ii CHAPTER 1 setuptools utilities for SageMath packages setuptools utilities for SageMath packages class sage_package.setuptools.SageTest(dist, **kw) Bases: setuptools.command.test.test A TestCommand for running doctests with sage -t run_tests() 1 Utilities for authoring SageMath packages, Release 0.0.7 2 Chapter 1. setuptools utilities for SageMath packages CHAPTER 2 A Sphinx extension for writing SageMath-style documentation A Sphinx extension for writing SageMath-style documentation This extension sets up: - the styling theme - intersphinx: enables crosslinks to the Python and SageMath documentation - extlinks: short hand roles for wikipedia, trac, arxiv, . sage_package.sphinx.setup(app) Initialize this Sphinx extension sage_package.sphinx.themes_path() Retrieve the location of the themes directory from the location of this package This is taken from Sphinx’s theme documentation 3 Utilities for authoring SageMath packages,
    [Show full text]
  • Towards Left Duff S Mdbg Holt Winters Gai Incl Tax Drupal Fapi Icici
    jimportneoneo_clienterrorentitynotfoundrelatedtonoeneo_j_sdn neo_j_traversalcyperneo_jclientpy_neo_neo_jneo_jphpgraphesrelsjshelltraverserwritebatchtransactioneventhandlerbatchinsertereverymangraphenedbgraphdatabaseserviceneo_j_communityjconfigurationjserverstartnodenotintransactionexceptionrest_graphdbneographytransactionfailureexceptionrelationshipentityneo_j_ogmsdnwrappingneoserverbootstrappergraphrepositoryneo_j_graphdbnodeentityembeddedgraphdatabaseneo_jtemplate neo_j_spatialcypher_neo_jneo_j_cyphercypher_querynoe_jcypherneo_jrestclientpy_neoallshortestpathscypher_querieslinkuriousneoclipseexecutionresultbatch_importerwebadmingraphdatabasetimetreegraphawarerelatedtoviacypherqueryrecorelationshiptypespringrestgraphdatabaseflockdbneomodelneo_j_rbshortpathpersistable withindistancegraphdbneo_jneo_j_webadminmiddle_ground_betweenanormcypher materialised handaling hinted finds_nothingbulbsbulbflowrexprorexster cayleygremlintitandborient_dbaurelius tinkerpoptitan_cassandratitan_graph_dbtitan_graphorientdbtitan rexter enough_ram arangotinkerpop_gremlinpyorientlinkset arangodb_graphfoxxodocumentarangodborientjssails_orientdborientgraphexectedbaasbox spark_javarddrddsunpersist asigned aql fetchplanoriento bsonobjectpyspark_rddrddmatrixfactorizationmodelresultiterablemlibpushdownlineage transforamtionspark_rddpairrddreducebykeymappartitionstakeorderedrowmatrixpair_rddblockmanagerlinearregressionwithsgddstreamsencouter fieldtypes spark_dataframejavarddgroupbykeyorg_apache_spark_rddlabeledpointdatabricksaggregatebykeyjavasparkcontextsaveastextfilejavapairdstreamcombinebykeysparkcontext_textfilejavadstreammappartitionswithindexupdatestatebykeyreducebykeyandwindowrepartitioning
    [Show full text]