Publication | Open Access
Applying Model Checking to Industrial-Sized PLC Programs
75
Citations
24
References
2015
Year
EngineeringVerificationComputer-aided VerificationModel CheckingModel VerificationSoftware AnalysisFormal VerificationSystems EngineeringTemporal LogicFormal ModelingPlc ProgramsAutomated Model CheckingComputer EngineeringComputer ScienceIndustrial-sized Plc ProgramsSoftware DesignSoftware VerificationProgram AnalysisAutomated ReasoningSoftware TestingFormal MethodsProcess ControlProgrammable Logic ControllersIndustrial Informatics
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.
| Year | Citations | |
|---|---|---|
Page 1
Page 1