An Extensible Simulator For Distributed Systems and Cyber-Physical Systems.
Find a file
2022-09-13 13:22:39 +02:00
esds Update tests 2022-09-13 13:22:39 +02:00
example Update platform parser 2022-09-11 16:14:17 +02:00
manual Update manual 2022-09-12 13:22:46 +02:00
tests Update tests 2022-09-13 13:22:39 +02:00
.gitignore Improve package architecture 2022-09-09 19:59:42 +02:00
.gitlab-ci.yml Update tests 2022-09-13 13:22:39 +02:00
icon.svg Update icon 2022-06-13 12:30:52 +02:00
LICENSE Add LICENSE 2022-06-10 07:00:18 +00:00
pyproject.toml Create entry point 2022-09-11 16:51:53 +02:00
README.md Cleaning 2022-09-02 10:01:16 +02:00
setup.cfg Create entry point 2022-09-11 16:51:53 +02:00

ESDS: An Extensible Simulator For Distributed Systems and Cyber-Physical Systems

Dependency Pipeline

What is ESDS ?

It is a short learning curve and coarse-grain network simulator. It contains the essential building blocks for the simulation of Distributed Systems, Cyber-Physical Systems (CPS), Wireless Sensors Networks (WSN) scenarios. It was originally designed to improve the flexibility/faithfulness of nodes implementations and mitigate the learning curve compare to existing network simulators.

ESDS is part of a research project. Studies and validation experiments are available online. For more details please visit http://todo.com.

Installation

> pip install esds

To ensure that esds is properly working and installed on your system, you can run the simulation tests with one of the following scripts:

  • tests/run.sh
  • tests/run.py

Features

  • Easy to use
  • Small API
  • Agent-based: node implementations are located in independant python files
  • Wireless interferences detection (i.e no modelization)
  • Custom node mobility (by updating the network matrix)
  • Nodes plugins (e.g energy consumption)

What ESDS does not implements ?

  • Network protocols (e.g IP/TCP/UDP)
  • Wireless physical layer models (e.g Friis and Log-Distance models, modulation, RSSI)
  • Routing algorithms (e.g Shortest path)
  • And much more!

Simulation API

  • api.args
  • api.send(<int>,<data>,<size>,<dst>)
  • api.sendt(<int>,<data>,<size>,<dst>,<t>)
  • api.receive(<int>)
  • api.receivet(<int>,<t>)
  • api.wait(<t>)
  • api.wait_end()
  • api.log(<message>)
  • api.read(<register>)
  • api.turn_on()
  • api.turn_off()
  • More details on the API in example/sender.py

Documentation

See manual/manual.pdf and the source code in example/ andtests/.