Клинијево затворење

Извор: testwiki
Датум измене: 15. јануар 2024. у 08:51; аутор: imported>FelixBot (нормативна контрола)
(разл) ← Старија измена | Тренутна верзија (разл) | Новија измена → (разл)
Пређи на навигацију Пређи на претрагу

У математичкој логици и рачунарству, Клинијево затворење (или Клинијева звезда) је унарна операција, на скуповима ниски или на скуповима симбола или карактера. Примена Клинијевог затворења на скуп -{V}- се записује као -{V*}-. Овај оператор је у широкој употреби у регуларним изразима, што је и контекст у коме га је увео Стивен Клини да карактерише одређене аутомате.

  1. Ако је -{V}- скуп ниски, онда се -{V*}- дефинише као најмањи надскуп од -{V}-, који садржи ε (празну ниску) и затворен је у односу на конкатенацију ниски. Овај скуп се такође може описати као скуп ниски које се могу добити дописивањем нула или више ниски из -{V}-.
  2. Ако је -{V}- скуп симбола или карактера, онда је -{V*}- скуп свих ниски над симболима -{V}-, укључујући и празну ниску.

Дефиниција и нотација

Дат је скуп

V0={ϵ}

рекурзивно дефинишемо скуп

Vi+1={wv:wVivV} где i0.

Ако је V формални језик, онда i-ти степен скупа V представља конкатенацију скупа V са самим собом i пута. То јест, Vi се може разумети као скуп свих ниски дужине i, добијених од симбола из V.

Дефиниција Клинијеве звезде над V је V*=i=0Vi={ϵ}V1V2V3

То јест, то је колекција свих могућих ниски коначне дужине, генерисаних од симбола из V.

У неким истраживањима формалних језика, користи се варијације операције Клинијеве звезде, операција Клинијев плус. Клинијев плус искључује V0 из горње уније. Другим речима, Клинијев плус над V је V+=i=1Vi=V1V2V3

Примери

Пример Клинијевог затворења скупа ниски:

-{ {"ab", "c"}* = {ε, "ab", "c", "abab", "abc", "cab", "cc", "ababab", "ababc", "abcab", "abcc", "cabab", "cabc", "ccab", "ccc", ...} }-

Пример Клинијевог затворења скупа карактера:

-{ {'a', 'b', 'c'}* = {ε, "a", "b", "c", "aa", "ab", "ac", "ba", "bb", "bc", ...} }-

Уопштење

Клинијева звезда се често генерализује за било који моноид -{(M, )}-, то јест, скуп -{M}- и бинарну операцију над -{M}-, такву да важи

Види још

Шаблон:Нормативна контрола