Skip to content

Latest commit

 

History

History
118 lines (77 loc) · 3.47 KB

0197-common-lisp-jupyter.org

File metadata and controls

118 lines (77 loc) · 3.47 KB

common-lisp-jupyter

This library provides a Common Lisp kernel for Jupyter.

Jupyter is a scientific environment for experiments. It is good when you want to play with data, to plot graphics and provides some comments in markdown.

Jupyter saves your programming session along with results in one file allowing to share your results with other programmers or analytics.

Maybe you didn’t know, but GitHub is able to render such notebooks. Here I found a large list of interesting notebooks. Take a look at this one, for example:

https://github.com/mqlaql/geospatial-data/blob/master/Geospatial-Data-with-Python.ipynb

Now, let’s return to the Common Lisp. Jupyter is using a protocol allowing to write backends in different programming languages. They are called “kernels”.

Here is how we can install Common Lisp Jupyter kernel on OSX. I’m using Homebrew and Roswell because they are making everything so easy!

[poftheday] brew install zeromq

[poftheday] brew install jupyterlab

[poftheday] ros install common-lisp-jupyter

Now we can start a notebook in console mode:

[poftheday] jupyter console --kernel=common-lisp
Jupyter console 6.2.0

common-lisp-jupyter: a Common Lisp Jupyter kernel
(C) 2019 Tarn Burton (MIT)
In [1]: (lisp-implementation-type)
Out[1]: "SBCL"

In [2]: (lisp-implementation-version)
Out[2]: "2.0.8"

In [3]: (values 1 2 3)
Out[3]: 1
Out[3]: 2
Out[3]: 3

In [4]: (jupyter:file "/Users/art/Desktop/Screenshot 2020-09-25 at 23.50.02.png")
Out[4]: /Users/art/Desktop/Screenshot 2020-09-25 at 23.50.02.png

And this command will start a webserver with full Jupyter Notebook:

# To start a web UI, run
[poftheday] jupyter notebook

When the browser will open Jupyter, choose this menu to start Common Lisp Jupyter kernel:

../../media/0197/01-choosing-cl-kernel.png

Now if you enter the same code as we did before in console, you’ll see, that web version is able to render our “screenshot” file below the “code cell”:

../../media/0197/02-basic-code.png

It is also very easy to render formulas and to request an input from the user:

../../media/0197/03-latex-formula.png

Also, you can render any HTML along with styles:

../../media/0197/04-rendering-any-html.png

Or you might define functions which will return HTML or files:

../../media/0197/05-returning-html-from-a-function.png

This way, libraries extending common-lisp-jupyter may be created. They can do plotting for example, or render graphs, etc.

Here how you can make you own classes renderable by Jupyter:

../../media/0197/06-custom-renderable.png

Though, it would be nice to make it possible to define render method for object not inherited from the jupyter:result.

The developer of this library did a very good job documenting it and providing examples. You will find all of them here.

This project is in active development phase. For example, right now support for Jupyter widgets is added.

Please, join this effort and make your pull requests to this repository, if you are interested in building CL environment for data science!