Колмогоровская сложность — различия между версиями
| м (rollbackEdits.php mass rollback) | |||
| (не показано 18 промежуточных версий 6 участников) | |||
| Строка 5: | Строка 5: | ||
| Понятно, что эту строку можно описать более компактно на естественном языке, "128 нулей", всего 9 символов. | Понятно, что эту строку можно описать более компактно на естественном языке, "128 нулей", всего 9 символов. | ||
| − | Можем дать следующее определение. ''Количество информации'', которое несет строка {{---}} это размер  | + | Можем дать следующее определение. ''Количество информации'', которое несет строка {{---}} это размер файла, полученного сжатием строки каким-то конкретным компрессором (например, [[Алгоритм LZW|LZW]]). Но мы по-прежнему можем придумать строку, которая явно несет в себе мало информации, но которую компрессор тем не менее не сожмет. | 
| − | Еще более сильное определение. ''Количество информации'', которое несет строка {{---}} это размер  | + | Еще более сильное определение. ''Количество информации'', которое несет строка {{---}} это размер файла, сжатого максимальным образом, самым лучшим компрессором. Но тогда встает вопрос, почему такой компрессор существует. На самом деле он есть, и в некотором смысле '''колмогоровская сложность''' строки {{---}} это размер наименьшей программы, которая печатает эту строку. | 
| ==Определения== | ==Определения== | ||
| Строка 30: | Строка 30: | ||
| {{Определение | {{Определение | ||
| |definition= | |definition= | ||
| − | Будем говорить, что декомпрессор <tex>D_1</tex>  | + | Будем говорить, что декомпрессор <tex>D_1</tex> не хуже, чем декомпрессор <tex>D_2</tex>, если <tex>\exists c > 0:\forall x \in \{0, 1\}^*\ K_{D_1}(x) \leqslant K_{D_2}(x) + c</tex>. | 
| }} | }} | ||
| {{Теорема | {{Теорема | ||
| − | |statement = Существует '''оптимальный декомпрессор''' (англ. ''optimal decompressor'') <tex>U</tex>, который  | + | |statement = Существует '''оптимальный декомпрессор''' (англ. ''optimal decompressor'') <tex>U</tex>, который не хуже всех остальных. | 
| |proof = Пусть <tex>p</tex> {{---}} некоторая строка, <tex>|p| = n</tex>. Обозначим за <tex>\hat{p}</tex> строку <tex>p_1 p_1 p_2 p_2 \dots p_n p_n 0 1</tex> (мы удвоили каждый бит строки <tex>p</tex> и добавили в конце <tex>01</tex>).<br> | |proof = Пусть <tex>p</tex> {{---}} некоторая строка, <tex>|p| = n</tex>. Обозначим за <tex>\hat{p}</tex> строку <tex>p_1 p_1 p_2 p_2 \dots p_n p_n 0 1</tex> (мы удвоили каждый бит строки <tex>p</tex> и добавили в конце <tex>01</tex>).<br> | ||
| Оптимальный декомпрессор будет работать следующим образом: <tex>U(\hat{p}x) = \langle p \rangle(x)</tex>, т.е. он интерпретирует <tex>p</tex> как программу, а <tex>x</tex> как входные данные и запускает <tex>p</tex> на входе <tex>x</tex>. | Оптимальный декомпрессор будет работать следующим образом: <tex>U(\hat{p}x) = \langle p \rangle(x)</tex>, т.е. он интерпретирует <tex>p</tex> как программу, а <tex>x</tex> как входные данные и запускает <tex>p</tex> на входе <tex>x</tex>. | ||
| − | Покажем, что такой декомпрессор будет  | + | Покажем, что такой декомпрессор будет не хуже любого другого. <br> Пусть <tex>D</tex> {{---}} другой декомпрессор. По определению <tex>D</tex> {{---}} это алгоритм, значит есть программа, которая исполняет <tex>D</tex>. <br> | 
| <tex>p</tex> {{---}} номер алгоритма <tex>D,\ p = \#D</tex>. Тогда:<br> | <tex>p</tex> {{---}} номер алгоритма <tex>D,\ p = \#D</tex>. Тогда:<br> | ||
| <tex>K_U(x) \leqslant K_D(x) + 2|p| + 2</tex>, т.к. <tex>K_D(x)</tex> достигается на <tex>D(y) = U(\hat{p}y) = x</tex>, т.е. для этого <tex>y</tex> есть строка <tex>\hat{p}y</tex>, которая даёт тот же самый результат и имеет длину не больше, чем на <tex>2|p| + 2</tex>. <br> | <tex>K_U(x) \leqslant K_D(x) + 2|p| + 2</tex>, т.к. <tex>K_D(x)</tex> достигается на <tex>D(y) = U(\hat{p}y) = x</tex>, т.е. для этого <tex>y</tex> есть строка <tex>\hat{p}y</tex>, которая даёт тот же самый результат и имеет длину не больше, чем на <tex>2|p| + 2</tex>. <br> | ||
| Строка 63: | Строка 63: | ||
| * <tex>KS(x,y) \leqslant KS(x) + KS(y) + 2\lceil \log_2 KS(x) \rceil + 2</tex>   | * <tex>KS(x,y) \leqslant KS(x) + KS(y) + 2\lceil \log_2 KS(x) \rceil + 2</tex>   | ||
| * Если <tex>A</tex> {{---}} алгоритм, то <tex>KS(A(x)) \leqslant KS(x) + c_A</tex> <br> (<tex>A(x)</tex> запишем как пару {{---}} информация об алгоритме <tex>A</tex> и информация о строке <tex>x</tex>, по предыдущему пункту нам нужно закодировать только сложность первого аргумента, что есть константа) | * Если <tex>A</tex> {{---}} алгоритм, то <tex>KS(A(x)) \leqslant KS(x) + c_A</tex> <br> (<tex>A(x)</tex> запишем как пару {{---}} информация об алгоритме <tex>A</tex> и информация о строке <tex>x</tex>, по предыдущему пункту нам нужно закодировать только сложность первого аргумента, что есть константа) | ||
| − | * '''Принцип несжимаемости:''' <tex>\exists x \in \{0,1\}^n : KS(x) \geqslant n</tex> <br> (Какой бы у нас ни был  | + | * '''Принцип несжимаемости:''' <tex>\exists x \in \{0,1\}^n : KS(x) \geqslant n</tex> <br> (Какой бы у нас ни был компрессор, он не может все строки фиксированной длины делать меньше. Строк длины меньшей, чем <tex>n</tex> {{---}} <tex>(2^n-1)</tex>, мы не сможем декомпрессировать) | 
| * <tex>KS</tex> {{---}} невычислимая функция. | * <tex>KS</tex> {{---}} невычислимая функция. | ||
| Докажем последнее свойство: | Докажем последнее свойство: | ||
| ===Невычислимость=== | ===Невычислимость=== | ||
| − | {{Лемма | + | {{Утверждение | 
| + | |about=Лемма | ||
| |statement= | |statement= | ||
| Если <tex>f:\{0,1\}^* \rightarrow  N</tex> {{---}} [[Вычислимые функции|вычислимая функция]], такая, что <tex>\forall x : f(x) \leqslant KS(x)</tex>, тогда <tex>f = O(1)</tex>. | Если <tex>f:\{0,1\}^* \rightarrow  N</tex> {{---}} [[Вычислимые функции|вычислимая функция]], такая, что <tex>\forall x : f(x) \leqslant KS(x)</tex>, тогда <tex>f = O(1)</tex>. | ||
| Строка 82: | Строка 83: | ||
| |statement= | |statement= | ||
| <tex>KS(x)</tex> невычислима. | <tex>KS(x)</tex> невычислима. | ||
| − | |||
| − | |||
| }} | }} | ||
| + | |||
| + | Пусть <tex>KS(x)</tex> вычислима. Возьмем вместо <tex>f(x)\  KS(x)</tex>. Очевидно, что <tex>\forall x : f(x) \leqslant KS(x)</tex>, но из принципа несжимаемости ясно, что <tex>KS(x)</tex> неограничена. Противоречие. Следовательно, <tex>KS(x)</tex> невычислима. | ||
| + | |||
| + | <tex> \forall x > x_0: K(x) > f(x)</tex>, если только <tex>f \leqslant const </tex> или <tex> f </tex> {{---}} невычислима. | ||
| + | |||
| + | ====Альтернативное доказательство с использованием теоремы о рекурсии==== | ||
| + | Функция <tex> K(x) </tex> {{---}} это минимальная длина программы <tex> p : p(\varepsilon) = x </tex>. | ||
| + | Допустим, что <tex> K </tex> вычислима, тогда напишем такую программу: | ||
| + | <code> | ||
| + |   <tex>p(\varepsilon){:}</tex> | ||
| + |     '''foreach''' <tex>x\in ~ \Sigma^* </tex> <span style="color:Green">//перебираем слова по возрастанию длины</span> | ||
| + |       '''if''' <tex> K(x) > |p|</tex> <span style="color:Green">//теорема о рекурсии используется здесь</span> | ||
| + |         '''return'''<tex>(x)</tex>      | ||
| + | </code> | ||
| + | |||
| + | Длина этой программы меньше длины минимальной программы, которая возвращает <tex>x</tex> на пустом входе. Поэтому возникает противоречие.  Следовательно <tex> K </tex> невычислима. | ||
| ==Применение== | ==Применение== | ||
| Строка 107: | Строка 122: | ||
| == См. также ==   | == См. также ==   | ||
| * [[Busy beaver]] | * [[Busy beaver]] | ||
| − | |||
| − | |||
| − | |||
| − | |||
| == Примечания == | == Примечания == | ||
| Строка 116: | Строка 127: | ||
| <ref name=chaitin> [https://ru.wikipedia.org/wiki/%D0%A5%D0%B0%D0%B9%D1%82%D0%B8%D0%BD,_%D0%93%D1%80%D0%B5%D0%B3%D0%BE%D1%80%D0%B8 Грегори Джон Хайтин] {{---}} аргентино-американский математик и информатик, внёс вклад в метаматематику, совместно с Андреем Колмогоровым считается основателем алгоритмической теории информации. </ref> | <ref name=chaitin> [https://ru.wikipedia.org/wiki/%D0%A5%D0%B0%D0%B9%D1%82%D0%B8%D0%BD,_%D0%93%D1%80%D0%B5%D0%B3%D0%BE%D1%80%D0%B8 Грегори Джон Хайтин] {{---}} аргентино-американский математик и информатик, внёс вклад в метаматематику, совместно с Андреем Колмогоровым считается основателем алгоритмической теории информации. </ref> | ||
| </references> | </references> | ||
| + | |||
| + | == Источники информации == | ||
| + | * [https://www.lektorium.tv/lecture/13494?id=13494 Лекция Дмитрия Ицыксона в CS центре] | ||
| + | * [https://ru.wikipedia.org/wiki/%D0%9A%D0%BE%D0%BB%D0%BC%D0%BE%D0%B3%D0%BE%D1%80%D0%BE%D0%B2%D1%81%D0%BA%D0%B0%D1%8F_%D1%81%D0%BB%D0%BE%D0%B6%D0%BD%D0%BE%D1%81%D1%82%D1%8C Wikipedia — Колмогоровская сложность] | ||
| + | |||
| [[Категория: Теория формальных языков]] | [[Категория: Теория формальных языков]] | ||
| [[Категория: Теория вычислимости]] | [[Категория: Теория вычислимости]] | ||
Текущая версия на 19:26, 4 сентября 2022
Колмогоровскую сложность (англ. Kolmogorov complexity) можно рассматривать как способ измерения количества информации в строке.
Но как понять, какое количество информации содержит в себе строка? Один из классических способов — это подсчет количества битов (число, пропорциональное длине строки). Рассмотрим следующий пример:
00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
Понятно, что эту строку можно описать более компактно на естественном языке, "128 нулей", всего 9 символов.
Можем дать следующее определение. Количество информации, которое несет строка — это размер файла, полученного сжатием строки каким-то конкретным компрессором (например, LZW). Но мы по-прежнему можем придумать строку, которая явно несет в себе мало информации, но которую компрессор тем не менее не сожмет.
Еще более сильное определение. Количество информации, которое несет строка — это размер файла, сжатого максимальным образом, самым лучшим компрессором. Но тогда встает вопрос, почему такой компрессор существует. На самом деле он есть, и в некотором смысле колмогоровская сложность строки — это размер наименьшей программы, которая печатает эту строку.
Определения
Декомпрессор
| Определение: | 
| Назовём декомпрессором (англ. decompressor) алгоритм, восстанавливающий разжатый текст из сжатого. | 
Примечание: для простоты мы будем рассматривать бинарный алфавит, но все утверждения мы можем обобщить на строки произвольного алфавита.
Относительно каждого декомпрессора мы можем определить понятие сложности строки:
| Определение: | 
| Пусть , тогда назовем колмогоровской сложностью строки , размер минимальной строки , такой, что . Если такого не существует, тогда . | 
Примеры
- , тогда
- , тогда
| Определение: | 
| Будем говорить, что декомпрессор не хуже, чем декомпрессор , если . | 
| Теорема: | 
| Существует оптимальный декомпрессор (англ. optimal decompressor) , который не хуже всех остальных. | 
| Доказательство: | 
| Пусть  — некоторая строка, . Обозначим за  строку  (мы удвоили каждый бит строки  и добавили в конце ). | 
| Определение: | 
| Пусть — это оптимальный декомпрессор, тогда колмогоровская сложность . | 
| Утверждение: | 
| Очевидно, что если  и  — оптимальные декомпрессоры, то  | 
Свойства
Тривиальные свойства
-  Если  — алгоритм, то  
 ( запишем как пару — информация об алгоритме и информация о строке , по предыдущему пункту нам нужно закодировать только сложность первого аргумента, что есть константа)
-  Принцип несжимаемости:  
 (Какой бы у нас ни был компрессор, он не может все строки фиксированной длины делать меньше. Строк длины меньшей, чем — , мы не сможем декомпрессировать)
- — невычислимая функция.
Докажем последнее свойство:
Невычислимость
| Утверждение (Лемма): | 
| Если  — вычислимая функция, такая, что , тогда . | 
| Пусть , где , тогда  — вычислимая (т.к  — вычислима и ограничена), всюду определенная функция.  Вспомним, что , следовательно . Отсюда: , но ясно, что при больших это неравенство не выполняется. Противоречие. | 
Примечание: если функция определена только на , то лемма остается в силе с единственным отличием, что пробегает все значения из в порядке перечисления.
| Утверждение (следствие из леммы): | 
|  невычислима. | 
Пусть вычислима. Возьмем вместо . Очевидно, что , но из принципа несжимаемости ясно, что неограничена. Противоречие. Следовательно, невычислима.
, если только или — невычислима.
Альтернативное доказательство с использованием теоремы о рекурсии
Функция  — это минимальная длина программы .
Допустим, что  вычислима, тогда напишем такую программу:
foreach //перебираем слова по возрастанию длины if //теорема о рекурсии используется здесь return
Длина этой программы меньше длины минимальной программы, которая возвращает на пустом входе. Поэтому возникает противоречие. Следовательно невычислима.
Применение
Альтернативное доказательство теоремы Гёделя о неполноте
Г. Хайтин[1] заметил следующее:
| Утверждение: | 
| В данной фиксированной системе вывода существует недоказуемое утверждение вида  | 
| Выпишем множество пар утверждение доказуемо . Возможны два варианта: 
 | 
Заметим, что во всех множествах пар все ограничены какой-то константой, следовательно существует огромное число истинных, но недоказуемых утверждений вида
Доказательство бесконечности простых чисел
| Утверждение: | 
| Простых чисел бесконечно много. | 
| Предположим, что простых чисел конечное число. Тогда любое число , где — это некоторая константа. Возьмём наибольшей колмогоровской сложности. Тогда , но также , т.к. . Но это неравенство не будет выполняться на достаточно больших , противоречие. | 
См. также
Примечания
- ↑ Грегори Джон Хайтин — аргентино-американский математик и информатик, внёс вклад в метаматематику, совместно с Андреем Колмогоровым считается основателем алгоритмической теории информации.
