data:image/s3,"s3://crabby-images/dadcd/dadcd039eb597722e35b1ea1e43f0f97a17bc57d" alt=""
From Jupyter to the Moon
A new Jupyter kernel for Lua based on Xeus
data:image/s3,"s3://crabby-images/1aac5/1aac5e9f8c7071835f4291e49968803eaa05c6ec" alt=""
A key principle in Jupyter’s design is language agnosticism, and one of the main extension points of the Jupyter ecosystem is the kernel, the part of the architecture responsible for executing the user’s code.
In the end, a Jupyter kernel is merely an executable implementing a well-defined inter-process communication protocol.
A reference implementation of the kernel is ipykernel, which provides the default Python kernel, and utilities to build other language kernels. Another reference implementation of the protocol is Xeus.
Xeus
Xeus is C++ library for writing Jupyter kernels. It is not a kernel but a library that simplifies the process of writing kernels. Xeus implements the Jupyter messaging protocol, so that kernel authors only need to implement a handful of methods related to the actual interpreter, like executing pieces of code and auto-completing. There is a long list of scripting languages which can be embedded in C/C++. With the help of Xeus, it is very easy to write kernels for such languages. In fact, Xeus has already been used for making several language kernels:
- xeus-cling is a Xeus-based C++ kernel.
- xeus-python is a Xeus-based Python kernel.
- xeus-sql / xeus-sqlite are Xeus-based kernel for SQL / SQLite databases.
- xeus-robot is a Jupyter kernel for the Robot Framework .
- LFortran is a modern interactive Fortran compiler with a Xeus-based Jupyter kernel.
xwidgets
The xwidget library is a C++ implementation of the Jupyter Interactive Widget protocol. Xwidgets were initially developed for xeus-cling, the Xeus C++ kernel, but any Xeus-based kernel can reuse these components.
A xeus-based Lua kernel
Today, I am pleased to announce the release of xeus-lua, a new Jupyter kernel for Lua based on Xeus.
data:image/s3,"s3://crabby-images/4d443/4d443cb81a237df0b1cdc655001c27e22dc5c7cd" alt=""
Lua
Lua, which means “Moon” in Portuguese, is a lightweight embeddable scripting language written in C. While Python is one of the leading scripting languages for scientific application, Lua is the leading scripting language used in games / game engines. The list of video games using Lua is long and includes triple-a games like Crisys and Farcry. Not only games rely on Lua, but also applications like Adobe Photoshop Lightroom.
Sol2
data:image/s3,"s3://crabby-images/c79de/c79dee7c255b9aafc85c5de2981db28b9ff952d1" alt=""
While Lua itself can be embedded in a C++ application quite easy, it is even easier when using Sol2. Sol2 is a C++ library that simplifies the usage of Lua from C++. Furthermore Sol2 can be used to expose C++ classes to Lua, in a similar fashion as pybind11 can be used to expose C++ classes to Python.
Xeus-lua
data:image/s3,"s3://crabby-images/d6e6c/d6e6c04265a205d3ef95f54d4d78da8105df43c7" alt=""
I am pleased to announce xeus-lua, a new Jupyter kernel for the Lua language based on Xeus. Using Sol2 and Xeus, it was very easy to implement a feature rich kernel using modern C++. With the help of Sol2, it was trivial to expose the xwidgets classes to Lua such that we can use the widgets within xeus-lua notebooks.
But why a Lua kernel?
While Lua might not be the hippest language in 2021, there are multiple reasons while I choose to implement such a Lua kernel, and why such a kernel can be useful:
- Writing a Xeus-based kernel is the best way to learn and familiarize oneself with the xeus ecosystem. And since Lua is so easy to build and embed, Lua and Xeus are perfect match. Implementing this kernel gave me great insights into Xeus and Jupyter itself.
- Learning Lua with xeus-lua is fun! Before writing xeus-lua, I had zero Lua experience. While implementing xeus-lua I learned Lua from within Jupyter by playing around with xwidgets from within Lua — this was a very joyful experience.
- The xeus-lua implementation might serve as reference for future kernel authors. In particular the integration of xwidgets in xeus-lua might be useful for future implementations.
- Since Lua is so easy to build, xeus-lua can be built for WebAssembly and will be integrated in JupyterLite — stay tuned!
Features
Obviously xeus-lua supports the execution of code.
data:image/s3,"s3://crabby-images/3517b/3517bf2e2a2b9922e56517598ebc936fc8a4b371" alt=""
Streams are redirected to the notebooks output
data:image/s3,"s3://crabby-images/0a88f/0a88f02ba652fd3ba1a84b686136be4ad4633933" alt=""
Errors messages are shown in the notebooks output
data:image/s3,"s3://crabby-images/d49a6/d49a6123c5a3d2090877feff8bf5c38f57f3182b" alt=""
Input streams are redirected to the notebooks input system
data:image/s3,"s3://crabby-images/8aa75/8aa752b137c40e2c387bf21c28736fc358664e0e" alt=""
Statements can be auto-completed with a press of tab
data:image/s3,"s3://crabby-images/dc221/dc2214673a8548344c688d749bdf8139b77f45cd" alt=""
Data of different sources as Latex, JSON and html can be displayed.
data:image/s3,"s3://crabby-images/08f37/08f37ba599a3c5a7ce4aa59509ae4445cacaba40" alt=""
Interactive widgets can be added to the notebook!
data:image/s3,"s3://crabby-images/61ec7/61ec7d3f9b1ac22e262603e55591c342dfe1e211" alt=""
We can feed the widgets with data!
data:image/s3,"s3://crabby-images/ed62a/ed62a64cf37265f741b50084a2ec5a95667af1ed" alt=""
Try It Out
You can try it right now with binder, without the need of installing anything on your computer, just by clicking on this link.
data:image/s3,"s3://crabby-images/5836b/5836b446c9735b1811d9baa1fcaeab2bc7d2a3d5" alt=""
Other Lua kernels
There are several Lua kernels available:
- lupyter: A Python based implementation of a Lua Jupyter kernel. The heavy lifting is done in a C-extension.
- ILua: A feature rich implementation. Ilua is implemented in Python and does the communication with Lua via IPC.
- IPyLua: IPyLua is a pure Lua implementation.
While these implementations are feature rich and work well, none of the above supports interactive widgets. Since xeus-lua is based on Xeus, we can reuse components from the Xeus ecosystem like xwidgets with minimal effort.
Acknowledgments
We are grateful to Juliette Taka for the illustration.
About the Author
Thorsten Beier is a Scientific Software Engineer at QuantStack. Before joining QuantStack, he graduated in computer science at the University of Heidelberg and worked at the EMBL. As an open source developer, Thorsten worked on a variety of projects, from nifty, and vigra in C++ to inferno, kipoi and ilastik in Python.