Недетерминированные вычисления

Материал из Викиконспекты
Версия от 16:56, 4 июня 2012; 194.85.161.2 (обсуждение) (Классы NTIME и NSPACE)
(разн.) ← Предыдущая | Текущая версия (разн.) | Следующая → (разн.)
Перейти к: навигация, поиск
Определение:
Недетерминированная машина Тьюринга (НМТ) — машина Тьюринга, управляющее устройство которой представляет собой недетерминированный конечный автомат, то есть из каждого состояния может быть несколько переходов по одному и тому же символу на входной ленте.

Такая машина допускает слово, если существует последовательность переходов, переводящая машину в допускающее состояние. В связи с этим есть несколько вариантов представления работы НМТ:

  1. Можно считать, что машина «очень удачлива», то есть если есть способ попасть в допускающее состояние, то машина всегда делает верный выбор пути.
  2. Если есть несколько вариантов пути, то машина делится на копии, каждая из которых следует по одному из возможных переходов. Слово считается допущенным, если его допускает хотя бы одна из копий.


Для записи недетерминированных программ используется специальный оператор.

Определение:
Оператор [math]\leftarrow?[/math]недетерминированный выбор (недетерминированное присваивание). Запись [math]x\leftarrow?A[/math] означает, что переменной [math]x[/math] недетерминированно присваивается некоторое значение из множества [math]A[/math].


Не следует связывать недетерминированный выбор с вероятностями. Программа как бы присваивает переменной все возможные значения одновременно.


Определение:
Недетерминированная программа — программа, в которой допускается использование недетерминированного выбора.


Определение:
Язык недетерминированной программы — множество слов, для которых существует такая последовательность недетерминированных выборов, что программа допустит это слово.


Классы NTIME и NSPACE[править]

Определение:
[math]\mathrm{NTIME}(f(n))[/math] — множество языков, для которых существует недетерминированная распознающая программа, время работы которой на входе длины [math]n[/math] есть [math]O(f(n))[/math].
[math]\mathrm{NSPACE}(f(n))[/math] — множество языков, для которых существует такая недетерминированная распознающая программа, что на любом входе длины [math]n[/math] ей требуется [math]O(f(n))[/math] памяти.


См. также[править]