Project for developing and demonstrating eXchange Calculus processes in FCPP.
All commands below are assumed to be issued from the cloned git repository folder. For any issues with reproducing the experiments, please contact Giorgio Audrito.
- FCPP main website: https://fcpp.github.io.
- FCPP documentation: http://fcpp-doc.surge.sh.
- FCPP presentation paper: http://giorgio.audrito.info/static/fcpp.pdf.
- FCPP sources: https://github.com/fcpp/fcpp.
The next sections contain the setup instructions for the various supported OSs. Jump to the section dedicated to your system of choice and ignore the others.
Pre-requisites:
At this point, run "MSYS2 MinGW x64" from the start menu; a terminal will appear. Run the following commands:
pacman -Syu
After updating packages, the terminal will close. Open it again, and then type:
pacman -Sy --noconfirm --needed base-devel mingw-w64-x86_64-toolchain mingw-w64-x86_64-cmake mingw-w64-x86_64-make git
The build system should now be available from the "MSYS2 MinGW x64" terminal.
Pre-requisites:
- Xorg-dev package (X11)
- G++ 9 (or higher)
- CMake 3.18 (or higher)
- Asymptote (for building the plots)
- Doxygen (for building the documentation)
To install these packages in Ubuntu, type the following command:
sudo apt-get install xorg-dev g++ cmake asymptote doxygen
In Fedora, the xorg-dev package is not available. Instead, install the packages:
libX11-devel libXinerama-devel.x86_6 libXcursor-devel.x86_64 libXi-devel.x86_64 libXrandr-devel.x86_64 mesa-libGL-devel.x86_64
Pre-requisites:
- Xcode Command Line Tools
- CMake 3.18 (or higher)
- Asymptote (for building the plots)
- Doxygen (for building the documentation)
To install them, assuming you have the brew package manager, type the following commands:
xcode-select --install
brew install cmake asymptote doxygen
If you use a VM with a graphical interface, refer to the section for the operating system installed on it.
Warning: the graphical simulations are based on OpenGL, and common Virtual Machine software (e.g., VirtualBox) has faulty support for OpenGL. If you rely on a virtual machine for graphical simulations, it might work provided that you select hardware virtualization (as opposed to software virtualization). However, it is recommended to use the native OS whenever possible.
Executing a graphical simulation will open a window displaying the simulation scenario, initially still: you can start running the simulation by pressing P (current simulated time is displayed in the bottom-left corner). While the simulation is running, network statistics may be periodically printed in the console, and be possibly aggregated in form of an Asymptote plot at simulation end. You can interact with the simulation through the following keys:
Escto end the simulationPto stop/resumeO/Ito speed-up/slow-down simulated timeLto show/hide connection links between nodesGto show/hide the grid on the reference plane and node pinsMenables/disables the marker for selecting nodesleft-clickon a selected node to open a window with node detailsCresets the camera to the starting positionQ,W,E,A,S,Dto move the simulation area along orthogonal axesright-click+mouse dragto rotate the cameramouse scrollfor zooming in and outleft-shiftadded to the camera commands above for precision control- any other key will show/hide a legenda displaying this list
Hovering on a node will also display its UID in the top-left corner.
./make.sh gui run -DNOTREE -O graphic
Runs a single test simulation with GUI for the spherical scenario, single message sent.
./make.sh gui run -DNOTREE -DMULTI_TEST -O graphic
Runs a single test simulation with GUI for the spherical scenario, multiple messages sent.
./make.sh gui run -DNOSPHERE -O graphic
Runs a single test simulation with GUI for the tree scenario, single message sent (comparing spawnXC and spawnFC).
For all three commands above, produced graphics can be found in plot/graphic.pdf.
- dens density of the network as avg number of neighbours
- hops network diameter
- speed maximum speed of devices as a percentage of the communication speed
- tvar variance of the round durations, as a percentage of the avg
dcount(delivery count): number of messages that arrived to destinationaproc(average processes): average number of process instances (i.e., for a single process, the average number of devices running it)adel(average delay)
See also the namespace tag in file lib/generals.hpp.
./make.sh run -DNOTREE -O batch
Runs 100 simulations for the spherical scenario, single message sent.
./make.sh run -DNOTREE -DMULTI_TEST -O batch
Runs 100 simulations for the spherical scenario, multiple messages sent.
./make.sh run -DNOSPHERE -O batch
Runs 100 simulations for the tree scenario, single message sent (comparing spawnXC and spawnFC).
For all three commands above, produced graphics can be found in plot/batch.pdf.
For parameters and metrics see the previous section.
./make.sh gui run -O repctl_graphic
Runs a single test simulation with GUI for the replicated PastCTL scenario.
Produced graphics can be found in plot/repctl_graphic.pdf.
erroraverage percentage of time with wrong values of criticsvaluevalue of critics along time
For parameters see the previous sections.
./make.sh run -O repctl_batch
Runs 2400 test simulations for the replicated PastCTL scenario.
Produced graphics can be found in plot/repctl_batch.pdf.
For parameters and metrics see the previous section.