Kilosim
0.4.1
Kilobot Simulator
|
This is maintained on GitHub in the kilosim repository. You can submit any issues or questions here.
Kilosim is a fast, lightweight, pseudo-physical* C++ simulator for Kilobot robots. Notable benefits include:
Logger
to easily to save experiment parameters in log continuous state dataViewer
for debugging and recording simulationsNote that this project is currently in a pre-release state and may still contain bugs, incomplete documentation, and missing features. If you have issues using the code, contact the developers or open an issue.
NOTE: We have tested Kilosim primarily on Ubuntu. Although CMake makes it possible to use across operating systems, we have not thoroughly tested this beyond Linux. Installation of dependencies will differ depending on your system.
You can either clone the repository from GitHub or download the latest release.
HDF5, SFML, and OpenMP. Install on Ubuntu-like systems with:
sudo apt install libsfml-dev libhdf5-dev libomp-dev
This is the primary way of using kilosim.
If your project uses cmake
, then incorporating kilosim is easy!
Just add the following lines to your CMakeLists.txt
file:
add_subdirectory(path/to/kilosim EXCLUDE_FROM_ALL) target_link_libraries(your_executable_target PRIVATE kilosim)
And everything will just work.
For a more detailed example, see the Kilosim Demo repository.
Compiling the library explicitly as follows is only necessary to run its tests and generate its documentation.
To compile, copy and paste the following:
mkdir build # Create a build directory cd build # Move into build directory cmake -DCMAKE_BUILD_TYPE=RelWithDebInfo -DCMAKE_INSTALL_PREFIX=../ .. #Configure for your system make # Build the library (equivalent to `make kilosim`) make install # Install the library to that indicated by `CMAKE_INSTALL_PREFIX` above cd .. # Move back to source directory
If you want to generate more than the library, you can alternatively run:
make kilosim # Build library make docs # Build documentation (optional) make install # Install all the components generated by the above commands
To clean up the build enter the source directory and run:
rm -rf build bin lib
Flags:
-DSANITIZE_ADDRESS=On
: Use address sanitizer to check memory safetyUse flags like so:
cmake -DSANITIZE_ADDRESS=ON ..
Compatibility:
In addition to the static library, we provide an executable example to test your installation.
Run the examples generated by make
and make install
:
./bin/kilosim_example examples/exampleConfig.json
Configuration files are defined as JSON files and can be loaded with a ConfigParser. The contents of flat JSON files can be automatically saved with your data using the Logger. (Support for saving JSON objects and arrays to HDF5 may be added in the future if someone needs/wants it.)
There are no fixed requirements for the contents of the configuration files; it's an un-opinionated convenience tool for importing and using whatever (atomic) parameters you want.
If you are having issues installing or using the simulator, open an issue or email Julia.
If you use this software, please cite it as follows:
DOI (all/latest version): 10.5281/zenodo.3406864
BibTeX:
We welcome contributions to the repository. To find things we're currently looking for help with, check out the open issues.
If you discover a bug or have an idea, for an improvement, open an issue.
If you add something you think would be useful to others, submit a pull request. All code should be fully documented. You can check your documentation by building the documentation locally Code reviews will be required for all pull requests, but we currently do not perform unit testing.
See a full list of the contributors and their contributions here.
Build the HTML documentation: (Requires Doxygen to be installed.)
make docs
This will automatically build the documentation and save the results to docs/
. The latest full documentation is automatically generated and published here.
This software is released under the MIT License.
If you use this software for a publication, please cite it.