Замкнутость КС-языков относительно различных операций — различия между версиями
(→Прямой и обратный гомоморфизм) |
Igorjan94 (обсуждение | вклад) м (-- -> —) |
||
Строка 1: | Строка 1: | ||
В отличие от [[Замкнутость регулярных языков относительно различных операций|регулярных языков]], [[Контекстно-свободные грамматики, вывод, лево- и правосторонний вывод, дерево разбора|КС-языки]] не замкнуты относительно всех теоретико-множественных операций. К примеру, дополнение и пересечение КС-языков не обязательно являются КС-языками. | В отличие от [[Замкнутость регулярных языков относительно различных операций|регулярных языков]], [[Контекстно-свободные грамматики, вывод, лево- и правосторонний вывод, дерево разбора|КС-языки]] не замкнуты относительно всех теоретико-множественных операций. К примеру, дополнение и пересечение КС-языков не обязательно являются КС-языками. | ||
− | Здесь и далее считаем, что <tex> L_1 </tex> и <tex> L_2 </tex> | + | Здесь и далее считаем, что <tex> L_1 </tex> и <tex> L_2 </tex> — КС языки. |
== Операции с КС-языками == | == Операции с КС-языками == | ||
Строка 15: | Строка 15: | ||
Покажем, что <tex> S' \Rightarrow^{*} w \iff S \Rightarrow^{*} w \lor T \Rightarrow^{*} w </tex>. В левую сторону: поскольку <tex> S \Rightarrow^{*} w </tex> и есть правило <tex> S' \to S </tex>, то, по определению <tex> \Rightarrow^{*} </tex> получаем, что <tex> S' \Rightarrow^{*} w </tex>. Аналогично и для <tex> T </tex>. | Покажем, что <tex> S' \Rightarrow^{*} w \iff S \Rightarrow^{*} w \lor T \Rightarrow^{*} w </tex>. В левую сторону: поскольку <tex> S \Rightarrow^{*} w </tex> и есть правило <tex> S' \to S </tex>, то, по определению <tex> \Rightarrow^{*} </tex> получаем, что <tex> S' \Rightarrow^{*} w </tex>. Аналогично и для <tex> T </tex>. | ||
− | В обратную сторону, пусть <tex> S' \Rightarrow^{*} w </tex>. Поскольку <tex> S' \to S\,|\,T </tex> | + | В обратную сторону, пусть <tex> S' \Rightarrow^{*} w </tex>. Поскольку <tex> S' \to S\,|\,T </tex> — единственные правила, в которых нетерминал <tex> S' </tex> присутствует в правой части, а значит, либо <tex> S' \Rightarrow S \Rightarrow^{*} w </tex>, либо <tex> S' \Rightarrow T \Rightarrow^{*} w </tex>, что и требовалось доказать. |
}} | }} | ||
Строка 22: | Строка 22: | ||
{{ Утверждение | {{ Утверждение | ||
− | |statement= <tex> L_1 \cdot L_2 </tex> | + | |statement= <tex> L_1 \cdot L_2 </tex> — КС-язык. |
− | |proof=КС-грамматика для <tex> L_1 \cdot L_2 </tex> выглядит следующим образом: <tex> S' \to S T </tex>, и <tex> S </tex> | + | |proof=КС-грамматика для <tex> L_1 \cdot L_2 </tex> выглядит следующим образом: <tex> S' \to S T </tex>, и <tex> S </tex> — стартовый символ. |
Доказательство аналогично случаю с объединением. | Доказательство аналогично случаю с объединением. | ||
}} | }} | ||
Строка 30: | Строка 30: | ||
{{ Утверждение | {{ Утверждение | ||
− | |statement= <tex> L^{*} = \bigcup\limits_{i = 0}^{\infty} L^i </tex> | + | |statement= <tex> L^{*} = \bigcup\limits_{i = 0}^{\infty} L^i </tex> — КС-язык. |
− | |proof=Если <tex> S </tex> | + | |proof=Если <tex> S </tex> — стартовый символ КС-грамматики для языка <tex> L </tex>, то добавим в КС-грамматику для языка <tex> L^{*} </tex> новый стартовый символ <tex> S' </tex> и правила <tex> S' \to S S' \, | \, \varepsilon </tex>. |
}} | }} | ||
Строка 55: | Строка 55: | ||
{{ Утверждение | {{ Утверждение | ||
− | |statement= <tex> L = \{ww \mid w \in \Sigma^{*} \} </tex> не является КС-языком, однако <tex> \overline{L} </tex> | + | |statement= <tex> L = \{ww \mid w \in \Sigma^{*} \} </tex> не является КС-языком, однако <tex> \overline{L} </tex> — КС-язык. |
|proof= | |proof= | ||
− | То, что <tex> L </tex> | + | То, что <tex> L </tex> — не КС язык, доказывается с помощью леммы о разрастании. Для <tex> \overline{L} </tex> можно составить [[Контекстно-свободные грамматики, вывод, лево- и правосторонний вывод, дерево разбора|КС-грамматику]]. |
}} | }} | ||
Строка 80: | Строка 80: | ||
}} | }} | ||
− | Операция <tex> Half </tex> также не сохраняет КС-язык таковым. Рассмотрим язык <tex> L = \{ a^n b a^n b a^m b a^l b a^k b a^k b \} </tex>. <tex> L </tex> | + | Операция <tex> Half </tex> также не сохраняет КС-язык таковым. Рассмотрим язык <tex> L = \{ a^n b a^n b a^m b a^l b a^k b a^k b \} </tex>. <tex> L </tex> — КС-язык. Посмотрим, что есть <tex> Half(L) </tex>. Пусть <tex> \alpha = a^n b a^n b a^m b a^l b a^k b a^k b = ww </tex>. Отсюда следует, что: |
* <tex> n = l </tex> | * <tex> n = l </tex> | ||
* <tex> n = k </tex> | * <tex> n = k </tex> | ||
Строка 91: | Строка 91: | ||
=== Пересечение === | === Пересечение === | ||
− | Тем не менее, хоть пересечение двух КС-языков не обязательно является КС-языком, но пересечение КС-языка и регулярного языка | + | Тем не менее, хоть пересечение двух КС-языков не обязательно является КС-языком, но пересечение КС-языка и регулярного языка — всегда КС-язык. Для доказательства этого построим МП-автомат для пересечения регулярного языка и КС-языка. |
− | Пусть регулярный язык задан своим [[Детерминированные конечные автоматы|ДКА]], а КС-язык | + | Пусть регулярный язык задан своим [[Детерминированные конечные автоматы|ДКА]], а КС-язык — своим МП-автоматом c допуском по допускающему состоянию. Построим прямое произведение этих автоматов так же, как строилось прямое произведение для двух ДКА. |
− | Более формально, пусть <tex> R </tex> | + | Более формально, пусть <tex> R </tex> — регулярный язык, заданный своим ДКА <tex> \langle \Sigma, Q_1, s_1, T_1, \delta_1 \rangle </tex>, и <tex> L </tex> — КС-язык, заданный своим МП-автоматом: <tex> \langle \Sigma, \Gamma, Q_2, s_2, T_2, z_0, \delta_2 \rangle </tex>. Тогда прямым произведением назовем следующий автомат: |
− | * <tex> Q = \{ \langle q_1, q_2 \rangle \mid q_1 \in Q_1, q_2 \in Q_2 \} </tex>. Иначе говоря, состояние в новом автомате | + | * <tex> Q = \{ \langle q_1, q_2 \rangle \mid q_1 \in Q_1, q_2 \in Q_2 \} </tex>. Иначе говоря, состояние в новом автомате — пара из состояния первого автомата и состояния второго автомата. |
* <tex> s = \langle s_1, s_2 \rangle </tex> | * <tex> s = \langle s_1, s_2 \rangle </tex> | ||
* Стековый алфавит <tex> \Gamma </tex> остается неизменным. | * Стековый алфавит <tex> \Gamma </tex> остается неизменным. | ||
− | * <tex> T = \{ \langle t_1, t_2 \rangle \mid t_1 \in T_1, t_2 \in T_2 \} </tex>. Допускающие состояния нового автомата | + | * <tex> T = \{ \langle t_1, t_2 \rangle \mid t_1 \in T_1, t_2 \in T_2 \} </tex>. Допускающие состояния нового автомата — пары состояний, где оба состояния были допускающими в своем автомате. |
* <tex> \delta ( \langle q_1, q_2 \rangle, c, d) = \langle \delta_1 (q_1, c), \delta_2 (q_2, c, d) \rangle </tex>. При этом на стек кладется то, что положил бы изначальный МП-автомат при совершении перехода из состояния <tex> q_2 </tex>, | * <tex> \delta ( \langle q_1, q_2 \rangle, c, d) = \langle \delta_1 (q_1, c), \delta_2 (q_2, c, d) \rangle </tex>. При этом на стек кладется то, что положил бы изначальный МП-автомат при совершении перехода из состояния <tex> q_2 </tex>, | ||
видя на ленте символ <tex> c </tex> и символ <tex> d </tex> на вершине стека. | видя на ленте символ <tex> c </tex> и символ <tex> d </tex> на вершине стека. |
Версия 21:13, 21 октября 2013
В отличие от регулярных языков, КС-языки не замкнуты относительно всех теоретико-множественных операций. К примеру, дополнение и пересечение КС-языков не обязательно являются КС-языками.
Здесь и далее считаем, что
и — КС языки.Содержание
Операции с КС-языками
Объединение
Утверждение: |
также является КС-языком. |
Построим КС-грамматику для языка . Для этого рассмотрим соответствующие КС-грамматики для языков и . Пусть стартовые символы в них имеют имена и соответственно. Тогда стартовый символ для обозначим за и добавим правило .Покажем, что В обратную сторону, пусть . В левую сторону: поскольку и есть правило , то, по определению получаем, что . Аналогично и для . . Поскольку — единственные правила, в которых нетерминал присутствует в правой части, а значит, либо , либо , что и требовалось доказать. |
Конкатенация
Утверждение: |
— КС-язык. |
КС-грамматика для Доказательство аналогично случаю с объединением. выглядит следующим образом: , и — стартовый символ. |
Замыкание Клини
Утверждение: |
— КС-язык. |
Если | — стартовый символ КС-грамматики для языка , то добавим в КС-грамматику для языка новый стартовый символ и правила .
Прямой и обратный гомоморфизм
В случае с прямым гомоморфизмом всё просто: строится КС-грамматика, в которой каждый символ МП-автомат для на основе МП-автомата для языка (назовем его ). Считаем, что допускает слова по пустому стеку. Новый автомат будет действовать следующим образом:
заменяется на . Для обратного гомоморфизма можно построить- Если входное слово закончилось, допускаем либо не допускаем его по пустому стеку.
- Иначе считываем символ .
- Сохраняем в буффере.
- Запускаем на слове, находящемся в буфере.
- После того, как обработал весь буфер, переходим к пункту 2.
Пусть в автомате
было состояний. Для того, чтобы научиться сохранять слова в буфере, создадим дополнительных состояний в новом автомате, где . Это позволит в состоянии кодировать слово, которое находится сейчас в буфере. Переходы в этих состояниях совершаются на основе того, что стоит на первом месте в буфере, состояния автомата и вершины стека. На ленту переходы в этих состояниях не смотрят. Из состояния, в котором буфер пуст, добавим -переход в начальное состояние. Необходима картинка.Разворот
Для того, чтобы построить КС-грамматику для языка
, необходимо развернуть все правые части правил грамматики для .Дополнение, пересечение и разность
В отличие от регулярных языков, дополнение до КС-языка, пересечение КС-языков и разность КС-языков может не быть КС-языком.
Утверждение: |
не является КС-языком, однако — КС-язык. |
То, что КС-грамматику. | — не КС язык, доказывается с помощью леммы о разрастании. Для можно составить
Утверждение: |
Если , то не является КС-языком. |
Но . По замкнутости КС-языков относительно конкатенации получаем, что и являются КС-языками. , что по лемме о разрастании для КС-языков не является КС-языком. |
Для разности достаточно заметить, что
, поэтому разность КС-языков также необязательно является КС-языком.Более того, задачи определения того, является ли дополнение КС-языка КС-языком и проверки непустоты пересечения КС-языков являются алгоритмически неразрешимыми.
Примеры других операций
Определение: |
Операция также не сохраняет КС-язык таковым. Рассмотрим язык . — КС-язык. Посмотрим, что есть . Пусть . Отсюда следует, что:
А значит, лемме о разрастании КС-языком не является.
, и , и поОперации над КС-языком и регулярным языком
Пересечение
Тем не менее, хоть пересечение двух КС-языков не обязательно является КС-языком, но пересечение КС-языка и регулярного языка — всегда КС-язык. Для доказательства этого построим МП-автомат для пересечения регулярного языка и КС-языка.
Пусть регулярный язык задан своим ДКА, а КС-язык — своим МП-автоматом c допуском по допускающему состоянию. Построим прямое произведение этих автоматов так же, как строилось прямое произведение для двух ДКА.
Более формально, пусть
— регулярный язык, заданный своим ДКА , и — КС-язык, заданный своим МП-автоматом: . Тогда прямым произведением назовем следующий автомат:- . Иначе говоря, состояние в новом автомате — пара из состояния первого автомата и состояния второго автомата.
- Стековый алфавит остается неизменным.
- . Допускающие состояния нового автомата — пары состояний, где оба состояния были допускающими в своем автомате.
- . При этом на стек кладется то, что положил бы изначальный МП-автомат при совершении перехода из состояния ,
видя на ленте символ
и символ на вершине стека.Этот автомат использует в качестве состояний пары из двух состояний каждого автомата, а за операции со стеком отвечает только МП-автомат. Слово допускается этим автоматом
слово допускается и ДКА и МП-автоматом, то есть язык данного автомата совпадает с .Разность
Разность КС-языка и регулярного языка выражается следующим образом:
, а, поскольку регулярные языки замкнуты относительно дополнения, то разность можно выразить через пересечение.