ماشین صف
ماشین صف (به انگلیسی: queue machine)یک ماشین حالت متناهی است که توانایی ذخیره و بازیابی اطلاعات را از یک صف با حافظه بینهایت دارد. این یک مدل محاسباتی معادل ماشین تورینگ است و بنابراین میتواند همان کلاس زبان رسمی را پردازش کند.
تئوری
[ویرایش]یک ماشین صف با شش تایی زیر تعریف میشود:
- مجوعه حالات متناهی
- مجموعه متناهی الفبای ورودی
- صف محدود الفبا
- نماد اولیه صف است.
- حالت شروع
- تابع انتقال
یک پیکر بندی ماشین، به صورت دوتایی حالت و محتوای صف است و به صورت نشان داده میشود، که به معنای ستاره کلین میباشد. پیکربندی شروع با رشته ورودی به صورت تعریف میشود و انتقال از یک پیکربندی به پیکربندی بعدی به صورت زیر بیان میشود:
که نشانه ای از صف الفبا، یک دنباله از نمادهای صف()، و . توجه داشته باشید که ویژگی "first-in-first-out" از صف در رابطه وجود دارد.
ماشین رشته را قبول میکند اگر پس از یک تعداد محدودی از انتقال، پیکربندی شروع آنقدر پیش برود تا رشته را تهی کند (به رشته صفر برسد) یا.[۱]
تکامل تورینگ
[ویرایش]ما میتوانیم ثابت کنیم که یک ماشین صف معادل یک ماشین تورینگ است. با نشان دادن اینکه ماشین صف میتواند دستگاه تورینگ را شبیهسازی کند و برعکس این امر اثبات میشود.
ماشین تورینگ را میتوان با یک ماشین صف شبیهسازی کرد که محتویات ماشین تورینگ را در صف خود در همه زمانها نگهداری میکند و دو نشانگر مخصوص در نظر گرفته میشود: یکی برای موقعیت آغاز TM و یکی برای پایان.انتقالات آن، از طریق آن دسته از TM که در سراسر صف اجرا میشود شبیهسازی میشود.
یک ماشین صف میتواند توسط یک ماشین تورینگ شبیهسازی شود، اما این شبیهسازی توسط ماشین تورینگ چندنواره بسیار راحتتر است. ماشین صف شبیهسازی شده ورودی را از یک نوار میخواند و در دومی ذخیره میکند و push و pop از صف با یک انتقال ساده به موقعیت آغاز و پایان نوار تعریف میشود.[۲]
کاربرد
[ویرایش]ماشینهای صف میتوانند مدل ساده ای را برای ایجاد معماریهای کامپیوتری،[۳][۴]زبانهای برنامهنویسی یا الگوریتم ارائه دهند.[۵][۶]
منابع
[ویرایش]- ↑ Kozen, Dexter C. (1997) [1951]. David Gries, Fred B. Schneider (ed.). Automata and Computability (hardcover). Undergraduate Texts in Computer Science (1 ed.). New York: Springer-Verlag. pp. 368–370. ISBN 0-387-94907-0.
- ↑ Rus, Teodor. "Variants of Turing Machines" (PDF). Lecture Notes Covering Theory of Computation. University of Iowa, Iowa City, IA, 52242-1419. Archived from the original (PDF) on 21 September 2008. Retrieved 2007-11-06.
- ↑ Feller, M.; M.D. Ercegovac (1981). "Queue machines: An organization for parallel computation". Lecture Notes in Computer Science. 111: 37. doi:10.1007/BFb0105108. Retrieved 2007-11-06.[پیوند مرده]
- ↑ Schmit, Herman; Benjamin Levine; Benjamin Ylvisaker (2002). "Queue Machines: Hardware Compilation in Hardware". 10th Annual IEEE Symposium on Field-Programmable Custom Computing Machines (FCCM'02): 152. doi:10.1109/FPGA.2002.1106670. Retrieved 2007-11-06.
- ↑ Moore, Christopher (1999-09-20). "Queues, Stacks, and Transcendentality at the Transition to Chaos". Algorithms Project's Seminar. INRIA. Retrieved 2007-11-06.
- ↑ von Thum, Manfred (2007). "A queue machine for evaluating expressions". LaTrobe University. Archived from the original on 7 August 2007. Retrieved 2007-11-06.