In the context of automotive applications, complex tasks such as automatic driving of electric vehicles are handled through the composition of several components, each offering a different service. Such component composition is not straightforward and is often subject to bugs that might stem mainly from the incompatibility of services. In other words, in this context, which includes critical services and in which people's life is at stake, detecting and eliminating bugs early at the design stage is crucial and even mandatory. To remedy this issue, we propose in this paper a formal approach for modeling and verifying the reliability of electric self-driving vehicles that are continuously communicating with off-road infrastructures. First, for the modeling phase, SysML language is used to model the system architecture and to specify the connections between its embedded components. Second, we present a formal verification approach based on the extended interface automata formalism to verify the compatibility between the interacting components, and to check whether this set of components achieve their required tasks. This formalism allows to specify component interfaces that exhibit component protocols and system non-functional constraints. The proposed approach permits an algorithmic verification to decide whether a set of components, when assembled together, fulfill compatibility conditions. Results in this paper show, on one hand, that SysML and extended interface automata formalism are relevant to model and capture component features in the context of automotive systems, on the other hand, that our methodology allows to develop autonomous electric vehicle systems correct-by-design, regarding to component compatibility.
Read full abstract