Comparing formal tools for system design (original) (raw)

2020, Proceedings of the ACM/IEEE 42nd International Conference on Software Engineering

Formal methods and tools have a long history of successful applications in the design of safety-critical railway products. However, most of the experiences focused on the application of a single method at once, and little work has been performed to compare the applicability of the dierent available frameworks to the railway context. As a result, companies willing to introduce formal methods in their development process have little guidance on the selection of tools that could t their needs. To address this goal, this paper presents a comparison between 9 dierent formal tools, namely Atelier B, CADP, FDR4, NuSMV, ProB, Simulink, SPIN, UMC, and UPPAAL SMC. We performed a judgment study, involving 17 experts with experience in formal methods applied to railways. In the study, part of the experts were required to model a railway signaling problem (a moving-block train distancing system) with the dierent tools, and to provide feedback on their experience. The information produced was then synthesized, and the results were validated by the remaining experts. Based on the outcome of this process, we provide a synthesis that describes when to use a certain tool, and what are the problems that may be faced by modelers. Our experience shows that the dierent tools serve dierent purposes, and multiple formal methods are required to fully cover the needs of the railway system design process. CCS CONCEPTS • General and reference → Empirical studies; • Software and its engineering → Formal methods; System modeling languages.