Industrial deployment of system engineering methods providing high dependability and productivity

 

Generation of certifiably correct programs from formal models

Iliasov, Alexei (2011) Generation of certifiably correct programs from formal models. In: 1st Int. Workshop on Software Certification. At the 22nd Int. Symposium on Software Reliability Engineering (ISSRE 2011). , November 30, 2011, Hiroshima, Japan.

[img]
Preview
PDF
207Kb

Abstract

Application of formal notations and verifications techniques helps to deliver systems that are free from engineering defects. A code generator is an essential tool for formal development of real-world systems; it transforms models into runnable software quickly, consistently and reproducibly. Commonly, a code generator is a program constructed informally and producing an output that is not formally traced to an input. Industrial standards to the development of safety-critical systems, such as IEC 61508, require a justification for any tool used in a development: extensive prior experience or a formal certification. An extensive experience is often not an option as there are very few sufficiently mature modelling toolsets. The certification of a code generator is a major effort increasing costs and development time. We propose an approach where a modeller places no trust whatsoever in the code generation stage but rather obtains software that is certifiable without any further effort. The essence of the approach is in the transformation of a formal model into runnable software that is demonstratively correct in respect to a given set of verification criteria, coming from a requirements document. A Hoare logic is used to embedded correctness criteria into the resultant program; the approach supports design-by-contract annotations to allow developer to mix formal and informal parts with a fair degree of rigour.

Item Type:Conference or Workshop Item (Paper)
Subjects:Tool developments > Code generation
Event-B
Tool developments > Provers
Methodology
ID Code:348
Deposited By: Prof A Romanovsky
Deposited On:05 Oct 2011 12:32
Last Modified:29 Oct 2011 18:22

Repository Staff Only: item control page

Deploy-Project - All right reserved