2381/11932098.v1
Uraz Turker
Sertac Karahoda
Husnu Yenigun
Kamer Kaya
Osman Tufan Erenay
Multicore and many core parallelization of cheap synchronizing sequence heuristics
2020
University of Leicester
Software testing
Finite state automata
Synchronizing sequences
Parallel algorithms
graphics processing units
2020-03-26 08:42:41
article
https://leicester.figshare.com/articles/journal_contribution/Multicore_and_many_core_parallelization_of_cheap_synchronizing_sequence_heuristics/11932098
An important concept in finite state machine based testing is synchronization which is used to initialize an implementation to a particular state. Usually, synchronizing sequences are used for this purpose and the length of the sequence used is important since it determines the cost of the initialization process. Unfortunately, the shortest synchronization sequence problem is NP-Hard. Instead, heuristics are used to generate short sequences. However, the cubic complexity of even the fastest heuristic algorithms can be a problem in practice. In order to scale the performance of the heuristics for generating short synchronizing sequences, we propose algorithmic improvements together with a parallel implementation of the cheapest heuristics existing in the literature. To identify the bottlenecks of these heuristics, we experimented on random and slowly synchronizing automata. The identified bottlenecks in the algorithms are improved by using algorithmic modifications. We also implement the techniques on multicore CPUs and Graphics Processing Units (GPUs) to take benefit of the modern parallel computation architectures. The sequential implementation of the heuristic algorithms are compared to our parallel implementations by using a test suite consisting of 1200 automata. The speedup values obtained depend on the size and the nature of the automaton. In our experiments, we observe speedup values as high as 340x by using a 16-core CPU parallelization, and 496x by using a GPU. Furthermore, the proposed methods scale well and the speedup values increase as the size of the automata increases.