IHMCRealtime is a simple support library that provides four feature sets:
- A JNI-backed threading library for attaching real-time POSIX threads to a running JVM process, allowing for deterministic computation of tasks
- A JNI-backed CPU Affinity library
- Pure Java data structures for lockless inter-thread communication
- Simple utility to retrieve Linux processes from /proc and set their scheduler and priority
- Setting CPU DMA Latency
Pre-compiled shared objects for the native portion are provided for Ubuntu 20.04+ (x86_64, arm64).
Javadoc of the code can be found at http://ihmcrobotics.bitbucket.org/ihmcrealtime/. In the coming weeks, we will be working on improving the documentation.
Frequently today, "real-time" is meant to refer to UI design that is extremely responsive in regards to changes in the underlying data model, especially in systems with latency such as web UI's bound to data models living on a server. In this situation, however, we are using real-time in the well-defined manner, meaning computation that has a time deadline and as such cannot afford to be interrupted by many things that would normally be allowed to take precedence over a thread of execution, such as the operating system or GUI. As such, this library is meant to be used on platforms that feature fully preemptible kernels.
Real-time computation in a multi-threaded environment is not a small problem. This library aims to provide the bare essentials in terms of real-time computation, and so pushes some of the challenge on to the developer instead of solving it in code. Specifically, IHMC Realtime does not account for:
- Garbage Collection
- Priority inversion
We work around these two restrictions by writing low-to-zero object allocation code in our real-time processes, and by using lockless concurrent data structures. Code paths that will run inside of a thread spawned using the IHMCRealtime library cannot use synchronize
, wait()/notify()
, or other such lock-based thread safety techniques. Because of this, we have made available the pure Java data structures that we use to avoid having to rely on these constructs.
IHMC Realtime can be downloaded from Maven Central using Maven or gradle. Add the following to your gradle build script
dependencies {
compile group: 'us.ihmc', name: 'ihmc-realtime', version: '1.5.0'
}
The Java portion of IHMCRealtime was developed and tested under Java 7.
IHMCRealtime is designed to be run on a Linux kernel backed OS with the RT_PREEMPT patch applied. Instructions for setting up such a system can be found here.
On Ubuntu, you will need a minimum of the cmake
, build-essential
, and libcap-dev
installed from your package manager. You will also need a JDK installation for the JNI headers. IHMCRealtime was developed against OpenJDK 17
from the Ubuntu package repositories.
$ sudo apt-get update && sudo apt-get install cmake build-essential libcap-dev openjdk-17-jdk
To compile, run cppbuild.bash
from the repository root directory. For building the libraries for a release, use the build-natives
GitHub workflow.