IElixir
Jupyter's kernel for Elixir
Hex: https://hex.pm/packages/ielixir.
Please see generated documentation for implementation details: http://hexdocs.pm/ielixir/.
Getting Started
Table of contents
- Configure Jupyter
- Configure IElixir
- Install Kernel
- Use IElixir
- Package management with Boyle
- Developement mode
- Generate documentation
- Docker
- Some issues
- Contribution
- References
- License
Configure Jupyter
I recommend you to use virtualenv
and virtualenvwrapper
for this project to isolate dependencies between this and other projects however you may also work without this if you don't like this.
$ pip install virtualenv virtualenvwrapper
Now you need to load virtualenvwrapper.sh
script into your current environment. I recommend you to add this like as well to the ~/.bash_profile.sh
script to have this script loaded every time you open fresh bash.
$ source /usr/local/bin/virtualenvwrapper.sh
Now using our new tools we can easily create isolated virtual environment for jupyter installation.
$ mkvirtualenv jupyter-env
$ workon jupyter-env
(jupyter-env) $ pip install jupyter
Configure IElixir
Clone IElixir repository and prepare the project
$ git clone https://github.com/pprzetacznik/IElixir.git
$ cd IElixir
$ mix deps.get
$ mix test
$ MIX_ENV=prod mix compile
Running all tests, including longer ones that requires more time for evaluation:
$ mix test --include skip
There may be also need to install rebar before IElixir installation, you can do this with command:
mix local.rebar --force
After this you may need to add ~/.mix/
to your $PATH
variable if you don't have rebar
visible yet outside ~/.mix/
directory.
Install Kernel
Simply run installation script to create file kernel.json
file in ./resouces
directory and bind it to the jupyter:
$ ./install_script.sh
Use IElixir
Run Jupyter console with following line:
(jupyter-env) $ jupyter console --kernel ielixir
To quit IElixir type Ctrl-D
.
Run Jupyter Notebook with following line:
(jupyter-env) $ jupyter notebook resources/example.ipynb
Go to http://localhost:8888/ site (by default) in your browser and pick IElixir kernel:
Evaluate some commands in your new notebook:
Magic commands
You can also use ans
variable to access output of previous cell. Moreover, if you want to access any cell which you can do it using it's number by calling out
map, eg. out[1]
.
Package management with Boyle
You can manage your packages in runtime with Boyle. Name of the package honours remarkable chemist, Robert Boyle. This package allows you to manage your Elixir virtual enviromnent without need of restarting erlang virtual machine. Boyle installs environment into ./envs/you_new_environment
directory and creates new mix project there with requested dependencies. It keeps takes care of fetching, compiling and loading/unloading modules from dependencies list of that environment.
You can also use this environment as a separate mix project and run it interactively with iex -S mix
from the environment directory.
Creating new Elixir virtual environment
iex> Boyle.mk("my_new_environment")
{:ok, ["my_new_environment"]}
List available virtual environments
iex> Boyle.list()
{:ok, ["my_new_environment"]}
Activate virtual environment
iex> Boyle.activate("my_new_environment")
:ok
Install new package in virtual environment and use new package
iex> Boyle.install({:number, "~> 0.5.7"})
:ok
iex> Number.Currency.number_to_currency(2034.46)
"$2,034.46"
Deactivate virtual environment and unload packages installed within that virtual environment
iex> Boyle.deactivate()
:ok
iex> Number.Currency.number_to_currency(2034.46)
** %UndefinedFunctionError{arity: 1, exports: nil, function: :number_to_currency, module: Number.Currency, reason: nil}
Additional resources:
- Notebook with Boyle examples
- Notebook with Boyle examples with usage of Matrex library
- Notebook with inline image examples with usage of Gnuplot library
Developement mode
If you want to see requests passing logs please use dev
environment to see what is happening in the background.
(jupyter-env) $ MIX_ENV=dev jupyter console --kernel ielixir
Generate documentation
Run following command and see doc
directory for generated documentation in HTML:
$ MIX_ENV=docs mix docs
Docker
You can find docker image at pprzetacznik/ielixir.
Running jupyter notebook:
$ docker run -p 8888:8888 --hostname localhost -v /my/workspace:/home/jovyan/work pprzetacznik/ielixir
Docker image is based on following images:
- jupyter/base-notebook image - this is image use as a base for ielixir image,
- elixir image - some installation parts were taken from dockerfile used for this image,
- pprzetacznik/ielixir-requirements image - this image resolves all dependencies for jupyter and elixir so only IElixir installation is left.
If you would like to make some changes to the images you can find dockerfiles in:
- docker/ielixir - for dockerfile source of pprzetacznik/ielixir image,
- docker/ielixir-requirements - for dockerfile source of pprzetacznik/ielixir-requirements image.
Other docker images worth seeing
Some issues
Problem with rebar
If you see following error after running install_script.sh
script then you should check if you have properly installed and visible rebar in mix
and in your local environment.
make: rebar: Command not found
make: *** [compile] Error 127
** (Mix) Could not compile dependency :erlzmq, "make" command failed. You can recompile this dependency with "mix deps.compile erlzmq", update it with "mix deps.update erlzmq" or clean it with "mix deps.clean erlzmq"
Erlang configuration
There may be need to run IElixir kernel with specific erlang attribute which can be turned on by setting variable:
ELIXIR_ERL_OPTIONS="-smp enable"
This option has been included inside install_script.sh
and start_script.sh
scripts.
Contribution
- Try to write some description of the feature or bug fix you're working in pull request's description and concise description of new modules or functions in moduledoc annotations,
- Please follow Elixir style guides to keep style clear, consider Elixir and Phoenix source code as the style ground truth,
- Keep as little comments as you can, comments tend to expire so try to use doctests instead to show how your code works,
- Write some unit tests for your code but don't try to test private functions, class tests are bad and units tests are good - https://blog.arkency.com/2014/09/unit-tests-vs-class-tests/
References
Some useful articles:
- IElixir Notebook in Docker
- Hydrogen plugin for Atom
- Installation guide
- Jupyter Notebooks with Elixir and RDF
I was inspired by following codes and articles:
- https://github.com/pminten/ielixir
- https://github.com/robbielynch/ierlang
- https://github.com/dsblank/simple_kernel
- http://andrew.gibiansky.com/blog/ipython/ipython-kernels/
- https://ipython.org/ipython-doc/dev/development/messaging.html
License
Copyright 2015 Piotr Przetacznik. IElixir source code is released under Apache 2 License. Check NOTICE and LICENSE files for more information.