Applying Model Checking to Industrial-Sized PLC Programs

作者:Adiego Borja Fernandez*; Darvas Daniel; Vinuela Enrique Blanco; Tournier Jean Charles; Bliudze Simon; Blech Jan Olaf; Gonzalez Suarez Victor Manuel
来源:IEEE Transactions on Industrial Informatics, 2015, 11(6): 1400-1410.
DOI:10.1109/TII.2015.2489184

摘要

Programmable logic controllers (PLCs) are embedded computers widely used in industrial control systems. Ensuring that a PLC software complies with its specification is a challenging task. Formal verification has become a recommended practice to ensure the correctness of safety-critical software, but is still underused in industry due to the complexity of building and managing formal models of real applications. In this paper, we propose a general methodology to perform automated model checking of complex properties expressed in temporal logics [e.g., computation tree logic (CTL) and linear temporal logic (LTL)] on PLC programs. This methodology is based on an intermediate model (IM) meant to transform PLC programs written in various standard languages [structured text (ST), sequential function chart (SFC), etc.] to different modeling languages of verification tools. We present the syntax and semantics of the IM, and the transformation rules of the ST and SFC languages to the nuXmv model checker passing through the IM. Finally, two real cases studies of the European Organization for Nuclear Research (CERN) PLC programs, written mainly in the ST language, are presented to illustrate and validate the proposed approach.

  • 出版日期2015-12