Read more
Computers are gaining more and more control over systems that we use or rely on in our daily lives, privately as well as professionally. In safety-critical applications, as well as in others, it is of paramount importance that systems controled by a computer or computing systems themselves reliably behave in accordance with the specification and requirements, in other words: here correctness of the system, of its software and hardware is crucial. In order to cope with this callenge, software engineers and computer scientists need to understand the foundations of programming, how different formal theories are linked together, how compilers correctly translate high-level programs into machine code, and why transformations performed are justifiable. This book presents 17 mutually reviewed invited papers organized in sections on methodology, programming, automation, compilation, and application.
List of contents
Methodology.- Theories of programming: Top-Down and Bottomup and Neeting in the Middle.- A Triptych Software Development Paradigm: Domain, Requirements and Software Towards a Nodel Development of a Decision Support System for Sustainable Development.- A Triptych Software Development Paradigm: Domain, Requirements and Software Towards a Nodel Development of a Decision Support System for Sustainable Development.- Real-Time Constraints Through the ProCoS Layers.- Real-Time Constraints Through the ProCoS Layers.- Monotonicity in Calculational Proofs.- Monotonicity in Calculational Proofs.- Programming.- The Alma Project, or How First-Order Logic Can Help us in Imperative Programming.- Type and Effect Systems.- Automation.- Proving Theorems About Java-Like Byte Code.- Multiple State and Single State Tableaux for Combining Local and Global Nodel Checking.- On the Existence of Network Invariants for Verifying Parameterized Systems.- Compilation.- Verification of Compilers.- Translation Validation: From SIGNAL to C.- Compilation and Synthesis for Real-Time Embedded Controllers.- Optimization Under the Perspective of Soundness, Completeness, and Reusability.- Application.- Verification of Automotive Control Units.- Correct Real-Time Software for Programmable Logic Controllers.- Formal Methods for the International Space Station ISS.- METAFrame in Practice: Design of Intelligent Network Services.
About the author
Bernhard Steffen studierte Mathematik an der Christian-Albrechts Universität zu Kiel, wo er anschließend auch in der Informatik promovierte. Nach Forschungsaufenthalten am Laboratory for Foundations in Computer Science in Edinburgh und an der Universität Aarhus, wurde er 1990 an die RWTH Aachen berufen, von wo er 1993 an die Universität Passau auf den Lehrstuhl für Programmiersysteme wechselte. Seit 1997 leitet er den Lehrstuhl für Programmiersysteme und Compilerbau an der TU-Dortmund. Bernhard Steffen ist Gründer der internationalen Konferenz über Tools and Algorithm for the Conbstruction and Analysis of Systems (TACAS) und des internationalen Journals über Software Tools for Technology Transfer (STTT). §