منطق درخت محاسباتی
این مقاله نیازمند ویکیسازی است. لطفاً با توجه به راهنمای ویرایش و شیوهنامه، محتوای آن را بهبود بخشید. (دسامبر ۲۰۱۷) |
منطق درخت محاسباتی (به انگلیسی: Computation Tree Logic) یک منطق زمانی است؛ که در آن حالتهای مختلف سامانه، به صورت راسهای یک ماشین حالت وجود دارند. این ماشین حالت، به صورت یک درخت زمانی است؛ که هر مجموعه حالتهای سامانه در طول زمان (تاریخچه آن سامانه) متناظر یک مسیر با شروع از ریشهٔ درخت است. مزیت این منطق بر منطقهای مشابه؛ مثل منطق خطی زمانی، این است که میتوان یک مسیر خاص را مشخص کرد. برای مثال این جملات در این منطق(منطق درخت محاسباتی) قابل بیان هستند:
- حتماً به حالتی خواهیم رسید که در آن شرط برقرار است.
- اگر در حالتی باشیم که درست باشد، ممکن نیست در آینده برقرار شود.
- اگر حالتی باشد که درست نباشد، از آن به بعد همواره درست است.
منطق کلی این منطق، این است که در هر لحظه، ممکن است آیندههای متفاوتی داشته باشیم؛ لذا این درخت نامتناهی، تمامی حالتهای ممکن برای سامانه را در طول زمان نشان میدهد. ابداع اولیهٔ آن توسط Clarke و Emerson در سال ۱۹۸۱ بوده و پس از آن، Queille و Sifakis با کمی تفاوت، از آن در وارسی مدلها استفاده کردند. به علت سادگی، کارایی و گستردگی کاربرد این منطق، امروزه در بسیاری از روشهای درستییابی سیستمها از آن استفاده میشود.[۱]
قواعد لغوی
[ویرایش]اگر مجموعهٔ متغیرهای منطقی باشد، فرمولهای حالت منطق درخت محاسباتی به این صورت تعریف میشوند:
که در آن، ، یک فرمول حالت و یک فرمول مسیر است.
فرمولهای مسیر هم اینگونه تعریف میشوند:
که در آن، فرمولهای حالت هستند. البته در اینجا، ما یک تعریف مینیمال ارائه دادیم و تعاریف معادلی با استفاده از دیگر عملگرهای زمانی وجود دارد. برای مثال، جملات زیر در منطق درخت محاسباتی هستند:
قواعد معنایی
[ویرایش]فرض کنید یک مدل برای منطق درخت محاسباتی باشد. یعنی یک سیستم جابجایی است که مجموعهٔ حالتهای آن ، جابجاییها (که همان قواعد جابجایی از یک حالت به حالت دیگر است) و نیز مجموعهای است که نشان میدهد در هر حالت کدامیک از متغیرهای منطقی عضو درست هستند.[۲] حال معنای یک عبارت در منطق روی این مدل و با حالت شروع ، برای فرمولهای حالت به صورت استقرایی با قواعد زیر مشخص میشود:
و اما برای فرمولهای مسیر، برای مسیر در این سیستم جابجایی، به صورت زیر:
مثالها
[ویرایش]فرض کنید سامانهای داشته باشیم که بتواند حالتهای ready یا started را داشته باشد. حال میتوانیم بیان کنیم «ممکن است زمانی برسد که started درست باشد اما ready غلط». این عبارت به صورت است. یا برای مثال، اگر بخواهیم بیان کنیم ready هیچگاه درست نمیشود، به صورت است.
ارتباط با دیگران منطقها
[ویرایش]همانطور که منطق درخت محاسباتی یک منطق زمانی است، منطق خطی زمانی نیز شباهتهای بسیاری با آن دارد. تفاوت در اینجاست که در منطق خطی زمانی، امکان مشخص کردن یک مسیر بهطور خاص وجود ندارد و احکام بیانشده در مورد همه یا هیچیک از مسیرهای ممکن است. هرچند عباراتی وجود دارند که فقط در منطق درخت محاسباتی یا فقط در منطق خطی زمانی قابل بیان هستند، هر دوی این منطقها زیرمجموعهٔ منطق CTL* هستند که در آن زبان جملات بیشتری قابل بیان هستند هرچند وارسی مدلها سختتر و پیچیدهتر از لحاظ محاسباتی است.
منابع
[ویرایش]- ↑ E.M. Clarke; E.A. Emerson (1981). "Design and synthesis of synchronisation skeletons using branching time temporal logic". Logic of Programs, Proceedings of Workshop, Lecture Notes in Computer Science, vol. 131. Springer, Berlin: 52–71.
- ↑ Michael Huth; Mark Ryan (2004). "Logic in Computer Science (Second Edition)". Cambridge University Press: 207. ISBN 0-521-54310-X.
{{cite journal}}
: Cite journal requires|journal=
(help)
- Micheal Huth, Mark Ryan, Logic in Computer Science, Modeling and reasoning about systems, Cambridge University Press, 2004. ISBN 978-0-511-26401-6
- Christel Baier, Joost-Pieter Katoen, Principles of Model Checking, The MIT Press 2007. ISBN 978-0-262-02649-9
- Emerson, E. A. "Temporal and modal logic". In Jan van Leeuwen (ed.). Handbook of Theoretical Computer Science, vol. B. MIT Press. pp. 955–1072. ISBN 0-262-22039-3.