Skip to main content

Linux Comodular Realtime Interactive Compute Environment

Project description

LiCoRICE is an open-source computational platform implementing model-based design for realtime processing of streaming data.

It facilitates the execution of numerical operations in python with empirical realtime guarantees, supports storage of streaming data to an SQLite Database, and supports USB peripherals and output to a display via pygame, all while maintaining at least 1ms ticks.

LiCoRICE was developed in the Stanford Brain Interfacing Laboratory, where it is currently used to control and conduct closed-loop neuroscience experiments.

Motivation

Why Realtime?

While offline data analysis collects data and processes it in batches, realtime processing is the analysis of data as it is collected, allowing for predictable response time (latency) and minimal timing variation (jitter). Systems in which delays are consequential, such as conducting closed-loop experiments or high-frequency trading, can benefit from implementing realtime practices.

Why Licorice?

Although realtime computational platforms do exist, many of them are inaccessible due to programming language, hardware, cost, or being proprietary. The high-level, POSIX-compliant, and open-source nature of LiCoRICE forgoes these problems and allows users to easily install LiCoRICE and adapt it to their use case.

System Requirements

  • x86_64 system

  • Modern UNIX environment (Linux, MacOS)

  • Python 3.6+

  • GCC toolchain, libevent, SQLite3, and MessagePack

NOTE: Soft realtime timing guarantees are only currently tested for Ubuntu 20.04 LTS (Focal Fossa) and Ubuntu 18.04 LTS (Bionic Beaver).

We recommend starting with a stock install of Ubuntu Server 20.04 LTS. Use of other UNIX platforms besides MacOS requires manual installation of packages.

Installation

LiCoRICE can be installed with pip, but requires some dependencies and permissions detailed in the documentation.

To achieve minimal jitter, it is recommended to install the stock linux-lowlatency kernel or a custom kernel. We provide a one-click setup script to install a suitable realtime kernel.

User Guide

LiCoRICE has a growing user guide which walks through creating some basic models from the ground up.

Examples

LiCoRICE also ships with a number of examples that highlight its capabilities.

Some examples require external hardware to run.

Usage

In general, only one command needs to be issued to parse, compile, and run a model:

licorice go <model_name>

For a more detailed description, take a look at the API reference.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

licorice-0.0.7.tar.gz (94.5 kB view details)

Uploaded Source

File details

Details for the file licorice-0.0.7.tar.gz.

File metadata

  • Download URL: licorice-0.0.7.tar.gz
  • Upload date:
  • Size: 94.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.16

File hashes

Hashes for licorice-0.0.7.tar.gz
Algorithm Hash digest
SHA256 454ae2b5c309dfaa0670d4d270470d6f6871f0d5d2ee2dda1fae5524578fa8be
MD5 e87140e096cd716c9f507ee158151a66
BLAKE2b-256 ecd52dbb3b140fdde531a145e0c8e96da24d79278244242c10bf89110c424cda

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page