Вычислимые числа — различия между версиями
AMaltsev (обсуждение | вклад) м (отформатированы дроби) |
м (rollbackEdits.php mass rollback) |
||
| (не показано 11 промежуточных версий 4 участников) | |||
| Строка 22: | Строка 22: | ||
'''for''' <tex> n = 1</tex> '''to''' <tex>\infty </tex> | '''for''' <tex> n = 1</tex> '''to''' <tex>\infty </tex> | ||
'''if''' <tex> x < a \left(\dfrac{1}{n} \right) - \dfrac{1}{n} </tex> | '''if''' <tex> x < a \left(\dfrac{1}{n} \right) - \dfrac{1}{n} </tex> | ||
| − | '''return''' 1 | + | '''return''' <tex>1</tex> |
'''if''' <tex> x > a \left(\dfrac{1}{n} \right) + \dfrac{1}{n} </tex> | '''if''' <tex> x > a \left(\dfrac{1}{n} \right) + \dfrac{1}{n} </tex> | ||
| − | '''return''' 0 | + | '''return''' <tex>0</tex> |
| − | <tex> \Longleftarrow </tex> | + | <tex> \Longleftarrow </tex> |
: Построим функцию <tex> a(\varepsilon) </tex> | : Построим функцию <tex> a(\varepsilon) </tex> | ||
| − | '''function''' <tex> a(\varepsilon) </tex> | + | '''function''' <tex> a(\varepsilon) </tex>: |
'''for''' <tex> x \in A </tex> | '''for''' <tex> x \in A </tex> | ||
'''if''' <tex> x + \varepsilon \notin A </tex> | '''if''' <tex> x + \varepsilon \notin A </tex> | ||
| − | '''return''' x | + | '''return''' <tex>x</tex> |
: Так как <tex> A </tex> разрешимо, <tex> \alpha = \sup A </tex> и для любого <tex> x \in A </tex> проверка в условном операторе завершается за конечное время, то функция <tex> a(\varepsilon) </tex> вычислима для любого рационального <tex> \varepsilon </tex>. | : Так как <tex> A </tex> разрешимо, <tex> \alpha = \sup A </tex> и для любого <tex> x \in A </tex> проверка в условном операторе завершается за конечное время, то функция <tex> a(\varepsilon) </tex> вычислима для любого рационального <tex> \varepsilon </tex>. | ||
| Строка 46: | Строка 46: | ||
Число <tex> \alpha </tex> вычислимо <tex>\iff</tex> последовательность знаков представляющей его двоичной записи вычислима. | Число <tex> \alpha </tex> вычислимо <tex>\iff</tex> последовательность знаков представляющей его двоичной записи вычислима. | ||
|proof= | |proof= | ||
| − | <tex> \Longrightarrow </tex> | + | <tex> \Longrightarrow </tex> |
: Если число <tex> \alpha </tex> {{---}} рациональное, то необходимую последовательность можно получить, воспользовавшись стандартным алгоритмом перевода числа в двоичную систему счисления. Рассмотрим случай, когда <tex> \alpha \in \mathbb R \setminus \mathbb Q </tex>. | : Если число <tex> \alpha </tex> {{---}} рациональное, то необходимую последовательность можно получить, воспользовавшись стандартным алгоритмом перевода числа в двоичную систему счисления. Рассмотрим случай, когда <tex> \alpha \in \mathbb R \setminus \mathbb Q </tex>. | ||
| Строка 55: | Строка 55: | ||
'''function''' <tex>p(n)</tex>: | '''function''' <tex>p(n)</tex>: | ||
| − | l = 0, r = 1 | + | <tex>l = 0, r = 1 </tex> |
'''for''' <tex> k = 1</tex> '''to''' <tex>n </tex> | '''for''' <tex> k = 1</tex> '''to''' <tex>n </tex> | ||
<tex> m = \dfrac{l+r}{2} </tex> | <tex> m = \dfrac{l+r}{2} </tex> | ||
'''if''' <tex> m < \alpha</tex> | '''if''' <tex> m < \alpha</tex> | ||
| − | l = m, t = 1 | + | <tex>l = m, t = 1</tex> |
'''else''' | '''else''' | ||
| − | r = m, t = 0 | + | <tex>r = m, t = 0</tex> |
| − | '''return''' t | + | '''return''' <tex>t</tex> |
| − | <tex> \Longleftarrow </tex> | + | <tex> \Longleftarrow </tex> |
: Для любого рационального <tex> \varepsilon > 0 </tex>, найдем <tex> n: 2^{-n} < \varepsilon </tex>, тогда в качестве значения функции <tex> a(\varepsilon) </tex> можно взять часть последовательности знаков двоичной записи <tex> \alpha </tex> с <tex> n </tex> знаками после запятой. | : Для любого рационального <tex> \varepsilon > 0 </tex>, найдем <tex> n: 2^{-n} < \varepsilon </tex>, тогда в качестве значения функции <tex> a(\varepsilon) </tex> можно взять часть последовательности знаков двоичной записи <tex> \alpha </tex> с <tex> n </tex> знаками после запятой. | ||
}} | }} | ||
| Строка 77: | Строка 77: | ||
Число <tex> \alpha </tex> вычислимо <tex>\iff</tex> существует вычислимая последовательность рациональных чисел, вычислимо сходящаяся к <tex> \alpha </tex>. | Число <tex> \alpha </tex> вычислимо <tex>\iff</tex> существует вычислимая последовательность рациональных чисел, вычислимо сходящаяся к <tex> \alpha </tex>. | ||
|proof= | |proof= | ||
| − | <tex> \Longrightarrow </tex> | + | <tex> \Longrightarrow </tex> |
: Так как <tex> \alpha </tex> вычислимо, то, согласно предыдущей теореме, вычислима и его двоичная запись. Пусть <tex> r_n </tex> {{---}} часть последовательности знаков двоичной записи <tex> \alpha </tex> с <tex> n </tex> знаками после запятой. Данная последовательность вычислима, а также вычислимо сходится к <tex> \alpha </tex>, так как <tex> N(\varepsilon) = \lceil -\log_2 \varepsilon \rceil</tex>. | : Так как <tex> \alpha </tex> вычислимо, то, согласно предыдущей теореме, вычислима и его двоичная запись. Пусть <tex> r_n </tex> {{---}} часть последовательности знаков двоичной записи <tex> \alpha </tex> с <tex> n </tex> знаками после запятой. Данная последовательность вычислима, а также вычислимо сходится к <tex> \alpha </tex>, так как <tex> N(\varepsilon) = \lceil -\log_2 \varepsilon \rceil</tex>. | ||
| − | <tex> \Longleftarrow </tex> | + | <tex> \Longleftarrow </tex> |
: Пусть <tex> a(\varepsilon) = r_{N(\varepsilon)} </tex>, тогда <tex> \alpha </tex> вычислимо по определению. | : Пусть <tex> a(\varepsilon) = r_{N(\varepsilon)} </tex>, тогда <tex> \alpha </tex> вычислимо по определению. | ||
| Строка 95: | Строка 95: | ||
Для того, чтобы получить приближение для результата операции, нам нужно выразить функцию-результат через приближения для операндов. | Для того, чтобы получить приближение для результата операции, нам нужно выразить функцию-результат через приближения для операндов. | ||
| − | Заметим, что <tex> |(\alpha \pm \beta) - (a \pm b)| \ | + | Заметим, что <tex> |(\alpha \pm \beta) - (a \pm b)| \leqslant |\alpha - a| \pm |\beta - b| </tex>, для произвольных рациональных <tex> a, b </tex>, значит, в качестве необходимых функций для <tex> \alpha + \beta </tex> и <tex> \alpha - \beta </tex> можно взять |
<tex > f_{\alpha + \beta}(\varepsilon) = f_{\alpha}\left(\dfrac {\varepsilon} {2}\right) + f_{\beta}\left(\dfrac {\varepsilon} {2}\right) </tex> | <tex > f_{\alpha + \beta}(\varepsilon) = f_{\alpha}\left(\dfrac {\varepsilon} {2}\right) + f_{\beta}\left(\dfrac {\varepsilon} {2}\right) </tex> | ||
| Строка 107: | Строка 107: | ||
Далее, так как | Далее, так как | ||
| − | <tex> |\alpha \beta - ab| = |(\alpha \beta - a \beta) + (a \beta - ab)| \ | + | <tex> |\alpha \beta - ab| = |(\alpha \beta - a \beta) + (a \beta - ab)| \leqslant |\beta||\alpha - a| + |a||\beta - b| \leqslant |b_\beta||\alpha - a| + |a||\beta - b|</tex>, |
где <tex>b_\beta</tex> {{---}} наименьшее рациональное число, большее <tex>\beta</tex> по модулю (т.е. <tex> b_\beta \in \mathbb Q, |b_\beta| > |\beta| </tex>), то | где <tex>b_\beta</tex> {{---}} наименьшее рациональное число, большее <tex>\beta</tex> по модулю (т.е. <tex> b_\beta \in \mathbb Q, |b_\beta| > |\beta| </tex>), то | ||
| Строка 115: | Строка 115: | ||
Убедимся в вычислимости числа <tex> \dfrac {1} {\alpha} </tex>: | Убедимся в вычислимости числа <tex> \dfrac {1} {\alpha} </tex>: | ||
| − | <tex> \left|\dfrac {1} {\alpha} - \dfrac{1}{a}\right| \ | + | <tex> \left|\dfrac {1} {\alpha} - \dfrac{1}{a}\right| \leqslant \dfrac {|a - \alpha|}{a a_\alpha} </tex>, где <tex> a_\alpha \in \mathbb Q, |a_\alpha| < |\alpha| </tex>. |
| − | <tex> f_{\ | + | <tex> f_{\frac {1} {\alpha}}(\varepsilon) = f_{\alpha}(\varepsilon a a_\alpha) </tex>. |
| − | Отсюда, <tex> \dfrac {\alpha} {\beta} = \dfrac{1} {\ | + | Отсюда, <tex> \dfrac {\alpha} {\beta} = \dfrac{1} {\beta} \alpha </tex> также вычислимо. |
}} | }} | ||
| Строка 146: | Строка 146: | ||
Пусть <tex> \alpha = \lim\limits_{n \to \infty} r_n </tex>. Запишем формально данные нам условия: | Пусть <tex> \alpha = \lim\limits_{n \to \infty} r_n </tex>. Запишем формально данные нам условия: | ||
| − | <tex> \forall \varepsilon_1 > 0\ \forall n > (\varepsilon_1): |r(n) - \alpha| < \varepsilon_1 </tex> | + | <tex> \forall \varepsilon_1 > 0\ \forall n > N(\varepsilon_1): |r(n) - \alpha| < \varepsilon_1 </tex> |
<tex> \forall n\ \forall \varepsilon_2 > 0\ |r(n) - p_n(\varepsilon_2)| < \varepsilon_2 </tex> | <tex> \forall n\ \forall \varepsilon_2 > 0\ |r(n) - p_n(\varepsilon_2)| < \varepsilon_2 </tex> | ||
| Строка 158: | Строка 158: | ||
'''return''' <tex> p_n\left(\dfrac {\varepsilon} {2}\right) </tex> | '''return''' <tex> p_n\left(\dfrac {\varepsilon} {2}\right) </tex> | ||
| − | Так как <tex> \left|\alpha - p_{n}\left(\dfrac {\varepsilon} {2}\right)\right| < |\alpha - r(n)| + |r(n) - p_n\left(\dfrac {\varepsilon} {2}\right)| </tex>, оба слагаемых меньше <tex> \dfrac {\varepsilon} {2} </tex> (первое {{---}} по выбору <tex> n </tex>, второе {{---}} в силу вычислимости <tex> p_n </tex>), то <tex> |\alpha - p_n\left(\dfrac \varepsilon 2\right)| < \varepsilon </tex>, и <tex> a(\varepsilon) </tex> действительно вычисляет требуемое приближение. | + | Так как <tex> \left|\alpha - p_{n}\left(\dfrac {\varepsilon} {2}\right)\right| < |\alpha - r(n)| + \left|r(n) - p_n\left(\dfrac {\varepsilon} {2}\right)\right| </tex>, оба слагаемых меньше <tex> \dfrac {\varepsilon} {2} </tex> (первое {{---}} по выбору <tex> n </tex>, второе {{---}} в силу вычислимости <tex> p_n </tex>), то <tex> \left|\alpha - p_n\left(\dfrac \varepsilon 2\right)\right| < \varepsilon </tex>, и <tex> a(\varepsilon) </tex> действительно вычисляет требуемое приближение. |
}} | }} | ||
| Строка 179: | Строка 179: | ||
Число <tex> \alpha </tex> перечислимо снизу <tex>\iff</tex> существует вычислимая возрастающая последовательность рациональных чисел, пределом которой является <tex> \alpha </tex>. | Число <tex> \alpha </tex> перечислимо снизу <tex>\iff</tex> существует вычислимая возрастающая последовательность рациональных чисел, пределом которой является <tex> \alpha </tex>. | ||
|proof= | |proof= | ||
| − | <tex>\Longrightarrow</tex> | + | <tex>\Longrightarrow</tex> |
: По определению <tex> \alpha </tex>, множество <tex> A = \{ a \in \mathbb Q \mid a < \alpha \} </tex> перечислимо. Кроме того, <tex> \sup A = \alpha </tex>. | : По определению <tex> \alpha </tex>, множество <tex> A = \{ a \in \mathbb Q \mid a < \alpha \} </tex> перечислимо. Кроме того, <tex> \sup A = \alpha </tex>. | ||
| − | : По определению нижней грани, <tex> \forall \varepsilon > 0\ \exists x_\varepsilon \in A: \varepsilon > \alpha - x_\varepsilon </tex>. Тогда можно взять, например, последовательность <tex> a_n = x_{\ | + | : По определению нижней грани, <tex> \forall \varepsilon > 0\ \exists x_\varepsilon \in A: \varepsilon > \alpha - x_\varepsilon </tex>. Тогда можно взять, например, последовательность <tex> a_n = x_{\frac{1}{n}} </tex>. |
| − | <tex>\Longleftarrow</tex> | + | <tex>\Longleftarrow</tex> |
: Построим полуразрешитель для множества <tex> A </tex>: | : Построим полуразрешитель для множества <tex> A </tex>: | ||
| Строка 192: | Строка 192: | ||
'''for''' n = <tex>1</tex> '''to''' <tex>\infty</tex> | '''for''' n = <tex>1</tex> '''to''' <tex>\infty</tex> | ||
'''if''' <tex> x < a_n </tex> | '''if''' <tex> x < a_n </tex> | ||
| − | '''return''' 1 | + | '''return''' <tex>1</tex> |
: Если <tex> x \in A</tex>, то <tex> \alpha - x = t > 0 </tex>, и так как <tex> \exists N:\ \forall n > N |a_n - \alpha| < t </tex>, то программа вернет ответ при <tex> n > N </tex>. | : Если <tex> x \in A</tex>, то <tex> \alpha - x = t > 0 </tex>, и так как <tex> \exists N:\ \forall n > N |a_n - \alpha| < t </tex>, то программа вернет ответ при <tex> n > N </tex>. | ||
Текущая версия на 19:07, 4 сентября 2022
В математике натуральные, целые и рациональные числа являются конструктивными объектами, поэтому их использование в теории вычислимости не требует особых уточнений. В то же время, действительные числа, которые необходимы для применения методов математического анализа, определяются неконструктивно. Предложенный далее метод позволяет построить конструктивные объекты, во многом схожие с обычными действительными числами.
Содержание
Вычислимые числа
| Определение: |
| Действительное число называется вычислимым (англ. computable number), если существует вычислимая функция , такая, что для любого рационального . |
Свойства
| Теорема: |
Число вычислимо множество разрешимо. |
| Доказательство: |
|
function : for to if return if return
function : for if return
|
Важное замечание: построенное нами доказательство неконструктивно, так как мы не знаем наперед, рационально ли число , и уж тем более не пытаемся понять в случае его рациональности, чему именно оно равно. Но, так как мы ставим целью исследование свойств вычислимых чисел, а не явное построение соответствующих этим свойствам программ, то нам это доказательство полностью подходит.
С учетом только что доказанной теоремы, далее при проверке на принадлежность числа множеству будем писать просто .
| Теорема: |
Число вычислимо последовательность знаков представляющей его двоичной записи вычислима. |
| Доказательство: |
|
function : for to if else return
|
| Определение: |
| Последовательность рациональных чисел вычислимо сходится к , если существует вычислимая функция , такая, что для любого рационального выполняется . |
| Теорема: |
Число вычислимо существует вычислимая последовательность рациональных чисел, вычислимо сходящаяся к . |
| Доказательство: |
|
|
| Теорема: |
Пусть числа вычислимы. Тогда также вычислимы числа , , и . |
| Доказательство: |
|
В пределах этого доказательства будем обозначать функцию-приближение для произвольного вычислимого числа как . Для того, чтобы получить приближение для результата операции, нам нужно выразить функцию-результат через приближения для операндов. Заметим, что , для произвольных рациональных , значит, в качестве необходимых функций для и можно взять
и
соответственно (при подстановке в неравенство и вместо и каждый модуль в правой части не превосходит , поэтому не превосходит ). Далее, так как , где — наименьшее рациональное число, большее по модулю (т.е. ), то . Убедимся в вычислимости числа : , где . . Отсюда, также вычислимо. |
| Теорема: |
Корень многочлена с вычислимыми коэффициентами вычислим. |
| Доказательство: |
|
Пусть — корень многочлена с вычислимыми коэффициентами. Если , то его можно найти точно, перебрав все рациональные числа. Иначе, выберем некоторый интервал ( — вычислимы), достаточно малый, чтобы полином был монотонным на отрезках и . Заметим, что для вычислимого значение также вычислимо, так как в процессе его вычисления используются только операции, вычислимость значений которых уже была ранее доказана. Теперь, если полином имеет разные знаки на отрезках и , то для поиска можно воспользоваться двоичным поиском нуля на , иначе — троичным поиском экстремума на . Останавливая тот или иной алгоритм, когда текущая длина интервала становится меньше и возвращая левую границу в качестве ответа, получаем функцию . |
| Теорема: |
Предел вычислимо сходящейся вычислимой последовательности вычислимых чисел вычислим. |
| Доказательство: |
|
Пусть . Запишем формально данные нам условия:
Здесь функции , и все вычислимы. Построим функцию , которая дает приближение к с точностью до : function : n = returnТак как , оба слагаемых меньше (первое — по выбору , второе — в силу вычислимости ), то , и действительно вычисляет требуемое приближение. |
Перечислимые числа
| Определение: |
| Действительное число называется перечислимым снизу (англ. recursively enumerable number), если множество перечислимо. |
| Определение: |
| Действительное число называется перечислимым сверху, если множество перечислимо. |
Свойства
| Теорема: |
Число перечислимо снизу существует вычислимая возрастающая последовательность рациональных чисел, пределом которой является . |
| Доказательство: |
|
function : for n = to if return
|
| Теорема: |
Число вычислимо оно перечислимо сверху и снизу. |
| Доказательство: |
|
Обозначим множества и за и соответственно. Если рационально, то необходимые (полу)разрешители строятся тривиально. В противном случае, так как , то перечислимость множеств и равносильна разрешимости множества , которая, в свою очередь, равносильна вычислимости . |
Последовательность Шпеккера
Множество всех программ счётно, поэтому множество вычислимых чисел также счётно. Однако, множество вещественных чисел несчётно, значит, существуют невычислимые вещественные числа. Построим явно пример такого числа.
| Определение: |
| Пусть — некоторое перечислимое, но неразрешимое множество натуральных чисел. Пронумеруем его элементы. Последовательностью Шпеккера называется последовательность рациональных чисел, -ный член которой определяется как . |
Данная последовательность строго возрастает и ограничена числом , следовательно, она сходится по признаку Вейерштрасса.
| Теорема: |
Число перечислимо снизу, но невычислимо. |
| Доказательство: |
|
перечислимо снизу, как предел возрастающей вычислимой последовательности рациональных чисел. Допустим теперь, что — вычислимо. Пусть . Рассмотрим двоичную запись числа , если ее -ный знак после запятой равен 1, то , иначе — . Мы построили разрешитель для множества . Тем не менее, известно, что — неразрешимое множество, а это невозможно, значит, — невычислимо. |
См. также
Источники информации
- Верещагин Н. К., Шень А. — Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции — М.: МЦНМО, 1999 — стр. 14
- Computable number
- Specker sequence