This a gnetic algorithm based road topology generator. The road generation is based on the SWAT tool, introduced by our team last year.
Our team: Dmytro Humeniuk, Foutse Khomh, Giuliano Antoniol. Polytechnique Montreal, Canada.
For information contact: dmytro.humeniuk@polymtl.ca
We have added some additional requirements to requirements.txt.
Most importantly, Pymoo pymoo==0.4.2.2 should be installed.
Here is an example of the command to launch the algorithm:
competition.py --visualize-tests --time-budget 7200 --executor beamng --map-size 200 --module-name ambiegen.ambiegen_generator --class-name AmbieGenTestGenerator --beamng-home C:\Users\gumen\Downloads\BeamNG.tech.v0.24.0.2\BeamNG.drive-0.24.0.2.13392 --beamng-user C:\Users\gumen\Documents\BeamNG.tech
The SBST Workshop offers a challenge for software testers who want to work with self-driving cars in the context of the usual tool competition.
The deadline to submit your tool is: January 21st 2022
The results of the evaluation will be communicated to participants on: February 25th 2022
The camera-ready paper describing your tool is due to: Sunday March 18th 2020
The competitors should generate virtual roads to test a lane keeping assist system using the provided code_pipeline.
The generated roads are evaluated in the BeamNG.tech driving simulator. This simulator is ideal for researchers due to its state-of-the-art soft-body physics simulation, ease of access to sensory data, and a Python API to control the simulation.
Note: BeamNG GmbH, the company developing the simulator, kindly offers it for free for researcher purposes upon registration (see Installation).
Deciding which test generator is the best is far from trivial and, currently, remains an open challenge. In this competition, we rank test generators by considering various metrics of effectiveness and efficiency that characterize the generated tests but also the process of generating them, i.e., test generation. We believe that our approach to compare test generators is objective and fair, and it can provide a compact metric to rank them.
The formula to rank test generators is the following weighted sum:
rank = a * OOB_Coverage + b * test_generation_efficiency + c * test_generation_effectiveness
where:
-
OOB_Coverage
captures the effectiveness of the generated tests that must expose as many failures as possible (i.e., Out Of Bound episodes) but also as many different failures as possible. We compute this metric by extending the approach adopted in the previous edition of the competition with our recent work on Illumination Search. As an example, our novel approach has been already adopted for the generation of relevant test cases from existing maps (see SALVO). Therefore, we identify tests' portion relevant to the OOBs, extract their structural and behavioral features, and populate feature maps of a predefined size (i.e., 25x25 cells). Finally, we defineOOB_Coverage
by counting the cells in the map covered by the exposed OOBs. Larger values ofOOB_Coverage
identify better test generators. -
test_generation_efficiency
captures the efficiency in generating, but not executing, the tests. We measure it as the inverse of the average time it takes for the generators to create the tests normalized using the following (standard) formula:norm(x) = (x - min) / (max - min)
Where
min
andmax
are values empirically found during the benchmarking as the minimum and maximum average times for generating test across all the competitors. -
test_generation_effectiveness
captures the ability of the test generator to create valid tests; therefore, we compute it as the ratio of valid tests over all the generated tests.
We set the values of the in the ranking formula's weights (i.e., a
, b
, and c
) to rank higher the test generators that trigger many and different failures; test generation efficiency and effectiveness are given equal but secondary importance. The motivation behind this choice is that test generators' main goal is to trigger failures, while being efficient and effective in generating the tests is of second order importance.
The following table summarizes the proposed weight assignment:
a | b | c |
---|---|---|
0.6 | 0.2 | 0.2 |
We make available a code pipeline that will integrate your test generator with the simulator by validating, executing and evaluating your test cases. Moreover, we offer some sample test generators to show how to use our code pipeline.
More information can be found on the SBST tool competition website: https://sbst22.github.io/tools/
Code pipeline: code that integrates your test generator with the simulator
Self driving car testing library: library that helps the integration of the test input generators, our code pipeline, and the BeamNG simulator
Scenario template: basic scenario used in this competition
Documentation: contains the installation guide, detailed rules of the competition, and the frequently asked questions
Sample test generators: sample test generators already integrated with the code pipeline for illustrative purposes
Requirements: contains the list of the required packages.
The software we developed is distributed under GNU GPL license. See the LICENSE.md file.
Dr. Alessio Gambi - Passau University, Germany - alessio.gambi@uni-passau.de
Dr. Vincenzo Riccio - Universita' della Svizzera Italiana, Lugano, Switzerland - vincenzo.riccio@usi.ch