Skip to content
David edited this page Jun 8, 2022 · 14 revisions

Nerlnet is a distributed machine learning platform developed for both research and deployment on real edge hardware devices.​
Nerlnet is highly configurable and very modular platform, it supports different kinds of communication protocols and has a simple python API for experiment management.​
The Erlang is the core of the distributed system of Nerlnet. The network of Nerlnet is based on Cowboy and it is based on common network modules: Servers, Routers and Clients. Clients can host sources that generate data in the network, and workers that execute neural networks implemented in C++, such as cppSANN, under IoT hardware constraints.

Nerlnet architecture:

The left side of the figure describes communication between API Python server and Nerlnet Main-Server.
The ApiServer loads configurations of experiment from a JSON file and sends them to Nerlnet MainServer which builds
the network before the experiment.

On the right side of the figure there are the MainServer and distributed network components as defined in JSON configuration file.
Red communication lines are dedicated for monitoring and statistics collection from the distributed network.
Blue arrows are communication lines of the distributed network.
Distributed network components such as router, edge compute unit and sensors (or data generators) can be deployed on any hardware and even multiple components per hardware.