Tompsonlar qurilishi - Thompsons construction - Wikipedia

Yilda Kompyuter fanlari, Tompsonning qurilishi algoritm, shuningdek, McNaughton-Yamada-Tompson algoritmi deb nomlangan[1], a ni o'zgartirish usuli doimiy ifoda ekvivalenti ichiga nondeterministik cheklangan avtomat (NFA).[2] Ushbu NFA uchun ishlatilishi mumkin gugurt satrlari doimiy ifodaga qarshi. Ushbu algoritm hisobga olinadi Ken Tompson.

Muntazam iboralar va nondeterministik cheklangan avtomatlar ikkitadir rasmiy tillar. Masalan; misol uchun, matnni qayta ishlash kommunal xizmatlar kengaytirilgan qidiruv naqshlarini tavsiflash uchun odatiy iboralardan foydalanadilar, ammo NFAlar kompyuterda bajarilishi uchun ko'proq mos keladi. Demak, bu algoritm amaliy qiziqish uyg'otadi, chunki mumkin kompilyatsiya qilish odatdagi iboralar Nazariy nuqtai nazardan, bu algoritm ularning ikkalasi ham aynan bir xil tillarni qabul qilishining isbotining bir qismidir, ya'ni oddiy tillar.

NFA-ni deterministik qilish mumkin poweret qurilishi va keyin bo'ling minimallashtirilgan berilgan doimiy ifodaga mos optimal avtomat olish. Biroq, NFA ham bo'lishi mumkin to'g'ridan-to'g'ri talqin qilingan.

Berilgan ikkita doimiy ibora bir xil tilni tavsiflaydimi yoki yo'qligini hal qilish uchun ularning har birini ekvivalent minimalga aylantirish mumkin aniqlangan cheklangan avtomat Tompson qurilishi orqali, poweret qurilishi va DFA minimallashtirish. Natijada va faqat agar natijada paydo bo'lgan avtomatlar rozi bo'lsa qadar davlatlarning nomini o'zgartirish, doimiy iboralar tillariga mos keladi.

Algoritm

Algoritm ishlaydi rekursiv ifodani uning tarkibiy subekresiyalariga ajratish orqali, ulardan NFA bir qator qoidalar yordamida tuziladi.[3] Aniqrog'i, doimiy iboradan E, olingan avtomat A o'tish funktsiyasi bilan δ quyidagi xususiyatlarni hurmat qiladi:

  • A to'liq bitta boshlang'ich holatga ega q0, boshqa davlatlardan foydalanish imkoniyati yo'q. Ya'ni har qanday davlat uchun q va har qanday xat a, o'z ichiga olmaydi q0.
  • A to'liq bitta yakuniy holatga ega qf, boshqa davlatlardan birgalikda foydalanish imkoniyati mavjud emas. Ya'ni har qanday xat uchun a, .
  • Ruxsat bering v doimiy iborani biriktiruvchi soni bo'ling E va ruxsat bering s qavsdan tashqari belgilar soni bo'lsin - ya'ni |, *, a va ε. Keyin, holatlarining soni A bu 2sv (o'lchamdagi chiziqli E).
  • Har qanday holatni tark etadigan o'tish soni ko'pi bilan ikkitadir.
  • NFA dan beri m davlatlar va ko'pi bilan e har bir holatdan o'tish uzunlik qatoriga to'g'ri kelishi mumkin n o'z vaqtida O(emn), Tompson NFA aniq o'lchamdagi alfavitni nazarda tutgan holda, chiziqli vaqt ichida naqshlarni bajarishi mumkin.[4][yaxshiroq manba kerak ]

Qoidalar

Aho va boshqalarga ko'ra quyidagi qoidalar tasvirlangan. (2007),[1] p. 122. Keyingi narsada, N(s) va N(t) pastki ifodalarning NFA'sidir s va tnavbati bilan.

The bo'sh ifoda ε ga aylantirildi

mos ravishda

A belgi a Kirish alfavitiga aylantirildi

mos ravishda

The kasaba uyushma ifodasi s|t ga aylantiriladi

mos ravishda

Shtat q ε orqali boshlang'ich holatiga o'tadi N(s) yoki N(t). Ularning yakuniy holatlari butun NFA ning oraliq holatiga aylanadi va ikkita b-o'tish orqali NFAning oxirgi holatiga qo'shiladi.

The birikma ifodasi st ga aylantiriladi

mos ravishda

Ning boshlang'ich holati N(s) butun NFA ning dastlabki holatidir. Ning yakuniy holati N(s) ning boshlang'ich holatiga aylanadi N(t). Ning yakuniy holati N(t) butun NFAning yakuniy holatidir.

The Kleene yulduzi ifoda s* ga aylantiriladi

mos ravishda

B-o'tish NFA ning boshlang'ich va oxirgi holatini sub-NFA bilan bog'laydi N(s) orasida. Ning ichki yakuniy holatidan ichki boshlang'ich holatiga yana bir b-o'tish N(s) ifodani takrorlashga imkon beradi s yulduz operatoriga ko'ra.

  • The qavs ichidagi ifoda (s) ga aylantirildi N(s) o'zi.


Ushbu qoidalar yordamida bo'sh ifoda va belgi qoidalarni asosiy holatlar sifatida isbotlash mumkin matematik induksiya har qanday odatiy ifoda ekvivalent NFAga aylantirilishi mumkin.[1]

Misol

Endi ikkita misol keltirilgan, natijada kichik norasmiy va algoritmni bosqichma-bosqich qo'llash bilan kattaroq.

Kichik misol

Ning misoli (ε | a * b) Tompson qurilishidan foydalanib, bosqichma-bosqich

Quyidagi rasmda Tompson qurilishining natijasi ko'rsatilgan (ε | a * b). Pushti oval mos keladi a, choyshab ovaliga mos keladi a *, yashil oval mos keladi b, to'q sariq oval mos keladi a * b, va ko'k oval mos keladi ε.

Algoritmni qo'llash

NFA muntazam ekspressiondan olingan (0|(1(01*(00)*0)*1)*)*

Misol tariqasida, rasmda Tompsonning konstruktsiya algoritmining doimiy ifoda bo'yicha natijasi ko'rsatilgan (0|(1(01*(00)*0)*1)*)* bu 3 ga ko'paytirilgan ikkilik sonlar to'plamini bildiradi:

{ε, "0", "00", "11", "000", "011", "110", "0000", "0011", "0110", "1001", "1100", "1111" , "00000", ...}.

O'ng yuqori qismida "" bilan ifodaning mantiqiy tuzilishi (sintaksis daraxti) ko'rsatilgan. biriktirishni bildiruvchi (o'zgaruvchan aritaga ega deb taxmin qilingan); sub expressions nomlari berilgan a-q ma'lumot uchun. Chap qismida Tompson algoritmidan kelib chiqadigan nondeterministik cheklangan avtomat ko'rsatilgan kirish va Chiqish rangdagi har bir subekspressiyaning holati magenta va moviyO'tish yorlig'i aniqligi uchun chiqarib tashlangan - etiketlenmemiş o'tishlar aslida ε o'tish. Ildiz ifodasiga mos keladigan kirish va chiqish holati. q avtomatik ravishda boshlash va qabul qilish holatidir.

Algoritmning qadamlari quyidagicha:

q:Kleene yulduzi ifodasini o'zgartirishni boshlang(0|(1(01*(00)*0)*1)*)*
b:birlashma ifodasini o'zgartirishni boshlang0|(1(01*(00)*0)*1)*
a:konvertatsiya qilish belgisi0
p:Kleene yulduzi ifodasini o'zgartirishni boshlang(1(01*(00)*0)*1)*
d:birikma ifodasini konvertatsiya qilishni boshlang1(01*(00)*0)*1
v:konvertatsiya qilish belgisi1
n:Kleene yulduzi ifodasini o'zgartirishni boshlang(01*(00)*0)*
f:birikma ifodasini konvertatsiya qilishni boshlang01*(00)*0
e:konvertatsiya qilish belgisi0
h:Kleene yulduzi ifodasini o'zgartirishni boshlang1*
g:konvertatsiya qilish belgisi1
h:Kleene yulduz ifodasini konvertatsiya qilishni yakunladi1*
l:Kleene yulduzi ifodasini o'zgartirishni boshlang(00)*
j:birikma ifodasini konvertatsiya qilishni boshlang00
men:konvertatsiya qilish belgisi0
k:konvertatsiya qilish belgisi0
j:birikma ifodasini konvertatsiya qilishni yakunladi00
l:Kleene yulduz ifodasini konvertatsiya qilishni yakunladi(00)*
m:konvertatsiya qilish belgisi0
f:birikma ifodasini konvertatsiya qilishni yakunladi01*(00)*0
n:Kleene yulduz ifodasini konvertatsiya qilishni yakunladi(01*(00)*0)*
o:konvertatsiya qilish belgisi1
d:birikma ifodasini konvertatsiya qilishni yakunladi1(01*(00)*0)*1
p:Kleene yulduz ifodasini konvertatsiya qilishni yakunladi(1(01*(00)*0)*1)*
b:birlashma ifodasini o'zgartirishni tugatdi0|(1(01*(00)*0)*1)*
q:Kleene yulduz ifodasini konvertatsiya qilishni yakunladi(0|(1(01*(00)*0)*1)*)*

Ekvivalent minimal deterministik avtomat quyida keltirilgan.

DFA misoli 3.svg ga ko'payadi

Boshqa algoritmlarga aloqadorlik

Tompson's - doimiy ifodalardan NFA qurish uchun bir nechta algoritmlardan biri;[5] oldingi algoritm McNaughton va Yamada tomonidan berilgan.[6] Tompsonning qurilishiga teskari, Klaynning algoritmi cheklangan avtomatni doimiy ifodaga aylantiradi.

Glushkovning qurilish algoritmi b-o'tishlarni olib tashlaganidan so'ng, Tompsonning qurilishiga o'xshaydi.

Adabiyotlar

  1. ^ a b v Alfred Vaino Aho; Monika S. Lam; Ravi Seti; Jeffri D. Ullman (2007). "3.7.4 Muntazam ifodadan NFA qurilishi" (chop etish). Tuzuvchilar: printsiplar, usullar va vositalar (2-nashr). Boston, MA, AQSh: Pearson Addison-Uesli. p.159–163. ISBN  9780321486813.
  2. ^ Louden, Kennet C. (1997). "2.4.1 Muntazam ifodadan NFAga" (chop etish). Tuzuvchi tuzilishi: printsiplari va amaliyoti (3-nashr). 20 Park Plaza Boston, MA 02116-4324, AQSh: PWS nashriyot kompaniyasi. 64-69 betlar. ISBN  978-0-534-93972-4.CS1 tarmog'i: joylashuvi (havola)
  3. ^ Ken Tompson (iyun 1968). "Dasturlash usullari: Muntazam ifodalarni qidirish algoritmi". ACM aloqalari. 11 (6): 419–422. doi:10.1145/363347.363387.
  4. ^ Sin, Guangming. "Minimallashtirilgan Tompson NFA" (PDF).
  5. ^ Uotson, Bryus V. (1995). Cheklangan avtomatlarni yaratish algoritmlari taksonomiyasi (PDF) (Texnik hisobot). Eyndxoven texnologiya universiteti. Hisoblash fanlari bo'yicha hisobot 93/43.
  6. ^ R. McNaughton, H. Yamada (1960 yil mart). "Avtomatika uchun muntazam ifodalar va holat grafikalari". Elektron kompyuterlarda IEEE operatsiyalari. 9 (1): 39–47. doi:10.1109 / TEC.1960.5221603.