This repository contains source and documentation code for the AESA radar use case developped in collaboration with Saab AB, as part of the Swedish Governmental Agency for Innovation Systems, NFFP7 project: Correct by construction design methodology #2017-04892. The software projects in this repository support and have been used to generate the technical report of Ungureanu et al. (2019).
TBA
This project is structured accross multiple modules as different software "sandboxes", with their own environments and own dependencies. Please read the README.md
files associated with each subfolder for more details about installation and additional documentation. For convenience, make sure that the executable binaries compiled with Stack can be accessed from the default $PATH
. Also, most of the default settings assume that, for convenience, the (compiled or interpreted) tools are run from this root location, meaning that after you build a sub-project you come back to this location to run the different tools.
The indata generator is a Python script which generates the input data for the different AESA application. Usage example:
python3 scripts/generate-input.py -h
Use it according to the printed help message. Needless to say, this is the first tool that needs to be used prior to testing the AESA implementations. It currently has limited command-line customization options. If you want to generate different scenarios, you need to modify the source code under the Add Objects and Noise to the Data
section.
Dependencies: python3
, numpy
We wrote a couple of data plotter scripts written in Python script for user convenience. Different data files are plotted in a pop-up window and in PDF format. Usage example:
python3 scripts/plot-input.py -h
python3 scripts/plot-input-cube.py -h
python3 scripts/plot-output.py -h
Dependencies: python3
, numpy
, matplotlib
The technical report goes through several stages in designing and refining the AESA signal processing system model. Each intermediate step has associated an executable binary putting together a running testbench.
The following projects produce binaries. Check their README.md
file for more information.
We recommend to place the compiled binaries in the shell path, e.g.
export PATH=$(stack path --local-bin):$PATH
At the moment these are the generated binaries (and their usage):
aesa-cube --help
aesa-shallow --help
aesa-stream --help
aesa-deep --help
These binaries have their default settings as to be run from this folder, otherwise the paths need to be provided as command line arguments.
Dependencies: Haskell, Stack. The rest is taken care of by Stack.
Some models are also equipped with test suites. Compiling the test suites is also done through Stack. Running a suite is done from each project folder (e.g. ./aesa-atom/
) by typing in the command
stack test :<suite-name>
Check each project's README
, as well as the technical report to see which tests are relevant and you need to run.
Dependencies: Haskell, Stack. The rest is taken care of by Stack.