Model Checking
暫譯: 模型檢查

Edmund M. Clarke Jr., Orna Grumberg, Doron A. Peled

  • 出版商: MIT
  • 出版日期: 1999-12-20
  • 售價: $3,070
  • 貴賓價: 9.5$2,917
  • 語言: 英文
  • 頁數: 314
  • 裝訂: Hardcover
  • ISBN: 0262032708
  • ISBN-13: 9780262032704
  • 海外代購書籍(需單獨結帳)

買這商品的人也買了...

相關主題

商品描述

Description

Model checking is a technique for verifying finite state concurrent systems such as sequential circuit designs and communication protocols. It has a number of advantages over traditional approaches that are based on simulation, testing, and deductive reasoning. In particular, model checking is automatic and usually quite fast. Also, if the design contains an error, model checking will produce a counterexample that can be used to pinpoint the source of the error. The method, which was awarded the 1999 ACM Paris Kanellakis Award for Theory and Practice, has been used successfully in practice to verify real industrial designs, and companies are beginning to market commercial model checkers. The main challenge in model checking is dealing with the state space explosion problem. This problem occurs in systems with many components that can interact with each other or systems with data structures that can assume many different values. In such cases the number of global states can be enormous. Researchers have made considerable progress on this problem over the last ten years. This is the first comprehensive presentation of the theory and practice of model checking. The book, which includes basic as well as state-of-the-art techniques, algorithms, and tools, can be used both as an introduction to the subject and as a reference for researchers.

Table of Contents

Foreword  xi 
 Amir Pnueli
   
Preface  xiii 
 Introduction
  1 (12)
 The Need for Formal Methods
  1 (1)
 Hardware and Software Verification
  2 (2)
 The Process of Model Checking
  4 (1)
 Temporal Logic and Model Checking
  4 (2)
 Symbolic Algorithms
  6 (2)
 Partial Order Reduction
  8 (2)
 Other Approaches to the State Explosion Problem
  10 (3)
 Modeling Systems
  13 (14)
 Modeling Concurrent Systems
  14 (3)
 Concurrent Systems
  17 (7)
 Example of Program Translation
  24 (3)
 Temporal Logics
  27 (8)
 The Computation Tree Logic CTL*
  27 (3)
 CTL and LTL
  30 (2)
 Fairness
  32 (3)
 Model Checking
  35 (16)
 CTL Model Checking
  35 (6)
 LTL Model Checking
  41 (5)
 Tableau
   
 CTL* Model Checking
  46 (5)
 Binary Decision Diagram
  51 (10)
 Representing Boolean Formulas
  51 (6)
 Representing Kripke Structures
  57 (4)
 Symbolic Model Checking
  61 (36)
 Fixpoint Representations
  61 (5)
 Symbolic Model Checking for CTL
  66 (2)
 Fairness in Symbolic Model Checking
  68 (3)
 Counterexamples and Witnesses
  71 (4)
 An ALU Example
  75 (2)
 Relational Product Computations
  77 (10)
 Symbolic LTL Model Checking
  87 (10)
 Model Checking for the μ-Calculus
  97 (12)
 Introduction
  97 (1)
 The Propositional μ-Calculus
  98 (3)
 Evaluating Fixpoint Formulas
  101 (3)
 Representing μ-Calculus Formulas Using OBDDs
  104 (3)
 Translating CTL into the μ-Calculus
  107 (1)
 Complexity Considerations
  108 (1)
 Model Checking in Practice
  109 (12)
 The SMV Model Checker
  109 (3)
 A Realistic Example
  112 (9)
 Model Checking and Automata Theory
  121 (20)
 Automata on Finite and Infinite Words
  121 (2)
 Model Checking Using Automata
  123 (6)
 Checking Emptiness
  129 (3)
 Translating LTL into Automata
  132 (6)
 On-the-Fly Model Checking
  138 (1)
 Checking Language Containment Symbolically
  139 (2)
 Partial Order Reduction
  141 (30)
 Concurrency in Asynchronous Systems
  142 (2)
 Independence and Invisibility
  144 (3)
 Partial Order Reduction for LTL_x
  147 (4)
 An Example
  151 (3)
 Calculating Ample Sets
  154 (6)
 Correctness of the Algorithm
  160 (4)
 Partial Order Reduction in SPIN
  164 (7)
 Equivalences and Preorders between Structures
  171 (14)
 Equivalence and Preorder Algorithms
  178 (2)
 Tableau Construction
  180 (5)
 Compositional Reasoning
  185 (8)
 Composition of Structures
  187 (2)
 Justifying Assume-Guarantee Proofs
  189 (1)
 Verifying a CPU Controller
  190 (3)
 Abstraction
  193 (22)
 Cone of Influence Reduction
  193 (2)
 Data Abstraction
  195 (20)
 Symmetry
  215 (16)
 Groups and Symmetry
  215 (3)
 Quotient Models
  218 (3)
 Model Checking with Symmetry
  221 (3)
 Complexity Issues
  224 (4)
 Empirical Results
  228 (3)
 Infinite Families of Finite-State Systems
  231 (22)
 Temporal Logic for Infinite Families
  231 (1)
 Invariants
  232 (3)
 Futurebus+ Example Reconsidered
  235 (3)
 Graph and Network Grammars
  238 (10)
 Undecidability Result for a Family of Token Rings
  248 (5)
 Discrete Real-Time and Quantitative Temporal Analysis
  253 (12)
 Real-Time Systems and Rate-Monotonic Scheduling
  253 (1)
 Model Checking Real-Time Systems
  254 (1)
 RTCTL Model Checking
  255 (1)
 Quantitative Temporal Analysis: Minimum/Maximum Delay
  256 (3)
 Example: An Aircraft Controller
  259 (6)
 Continuous Real Time
  265 (28)
 Timed Automata
  265 (3)
 Parallel Composition
  268 (1)
 Modeling with Timed Automata
  269 (5)
 Clock Regions
  274 (6)
 Clock Zones
  280 (7)
 Difference Bound Matrices
  287 (4)
 Complexity Considerations
  291 (2)
 Conclusion
  293 (4)
References  297 (12)
Index  309

商品描述(中文翻譯)

**描述**

模型檢查是一種用於驗證有限狀態並發系統的技術,例如序列電路設計和通信協議。與基於模擬、測試和推理的傳統方法相比,它具有多項優勢。特別是,模型檢查是自動化的,通常相當快速。此外,如果設計中存在錯誤,模型檢查將生成一個反例,可以用來確定錯誤的來源。這種方法於1999年獲得ACM巴黎卡內拉基斯理論與實踐獎,並已成功應用於實際中以驗證真實的工業設計,許多公司也開始推廣商業模型檢查工具。模型檢查的主要挑戰在於處理狀態空間爆炸問題。這個問題出現在具有許多可以相互作用的組件的系統中,或是具有可以取多種不同值的數據結構的系統中。在這種情況下,全球狀態的數量可能會非常龐大。研究人員在過去十年中在這個問題上取得了相當大的進展。這是模型檢查理論與實踐的首次全面介紹。本書包括基本技術以及最先進的技術、算法和工具,既可作為該主題的入門書籍,也可作為研究人員的參考資料。

**目錄**

前言 xi
Amir Pnueli

序言 xiii
引言 1 (12)
正式方法的需求 1 (1)
硬體和軟體驗證 2 (2)
模型檢查的過程 4 (1)
時間邏輯與模型檢查 4 (2)
符號算法 6 (2)
部分順序簡化 8 (2)
解決狀態爆炸問題的其他方法 10 (3)
建模系統 13 (14)
建模並發系統 14 (3)
並發系統 17 (7)
程式翻譯範例 24 (3)
時間邏輯 27 (8)
計算樹邏輯 CTL* 27 (3)
CTL 和 LTL 30 (2)
公平性 32 (3)
模型檢查 35 (16)
CTL 模型檢查 35 (6)
LTL 模型檢查 41 (5)
表格 46 (5)
CTL* 模型檢查 46 (5)
二元決策圖 51 (10)
表示布林公式 51 (6)
表示 Kripke 結構 57 (4)
符號模型檢查 61 (36)
不動點表示 61 (5)
CTL 的符號模型檢查 66 (2)
符號模型檢查中的公平性 68 (3)
反例與見證 71 (4)
ALU 範例 75 (2)
關聯產品計算 77 (10)
符號 LTL 模型檢查 87 (10)
μ-演算的模型檢查 97 (12)
引言 97 (1)
命題 μ-演算 98 (3)
評估不動點公式 101 (3)
使用 OBDDs 表示 μ-演算公式 104 (3)
將 CTL 轉換為 μ-演算 107 (1)
複雜性考量 108 (1)
實踐中的模型檢查 109 (12)
SMV 模型檢查器 109 (3)
一個現實的範例 112 (9)
模型檢查與自動機理論 121 (20)
有限與無限字的自動機 121 (2)
使用自動機的模型檢查 123 (6)
檢查空性 129 (3)
將 LTL 轉換為自動機 132 (6)
即時模型檢查 138 (1)
符號檢查語言包含性 139 (2)
部分順序簡化 141 (30)
非同步系統中的並發性 142 (2)
獨立性與不可見性 144 (3)
LTL_x 的部分順序簡化 147 (4)
一個範例 151 (3)
計算充足集 154 (6)
算法的正確性 160 (4)
SPIN 中的部分順序簡化 164 (7)
結構之間的等價性與預序 171 (14)
等價性與預序算法 178 (2)
表格構造 180 (5)
組合推理 185 (8)
結構的組合 187 (2)
證明假設-保證的合理性 189 (1)
驗證 CPU 控制器 190 (3)
抽象 193 (22)
影響圈的簡化 193 (2)
數據抽象 195 (20)
對稱性 215 (16)
群組與對稱性 215 (3)
商模 218 (3)
使用對稱性的模型檢查 221 (3)
複雜性問題 224 (4)
實證結果 228 (3)
無限有限狀態系統的家族 231 (22)
無限家族的時間邏輯 231 (1)
不變式 232 (3)
重新考慮 Futurebus+ 範例 235 (3)
圖與網絡文法 238 (10)
一類令牌環的不可判定性結果 248 (5)
離散實時與定量時間分析 253 (12)
實時系統與速率單調調度 253 (1)
實時系統的模型檢查 254 (1)
RTCTL 模型檢查 255 (1)
定量時間分析:最小/最大延遲 256 (3)
範例:一個飛機控制器 259 (6)
連續實時 265 (28)
定時自動機 265 (3)
平行組合 268 (1)
使用定時自動機建模 269 (5)
時鐘區域 274 (6)
時鐘區域 280 (7)
差異界限矩陣 287 (4)
複雜性考量 291 (2)
結論 293 (4)
參考文獻 297 (12)
索引 309