WikiDer > Детерминированный алгоритм

Deterministic algorithm

В Информатика, а детерминированный алгоритм является алгоритм который при конкретном вводе всегда будет производить один и тот же вывод, при этом базовая машина всегда проходит через одну и ту же последовательность состояний. Детерминированные алгоритмы на сегодняшний день являются наиболее изученным и знакомым видом алгоритмов, а также одним из наиболее практичных, поскольку их можно эффективно запускать на реальных машинах.

Формально детерминированный алгоритм вычисляет математическая функция; функция имеет уникальное значение для любого входа в ее домен, а алгоритм - это процесс, который производит это конкретное значение на выходе.

Формальное определение

Детерминированные алгоритмы можно определить в терминах Государственный аппарат: а штат описывает, что машина делает в определенный момент времени. Конечные автоматы дискретным образом переходят из одного состояния в другое. Сразу после того, как мы вводим ввод, машина находится в начальное состояние или начальное состояние. Если машина детерминирована, это означает, что с этого момента ее текущее состояние определяет, каким будет ее следующее состояние; его ход через множество состояний предопределен. Обратите внимание, что машина может быть детерминированной и при этом никогда не останавливаться или заканчиваться и, следовательно, не выдавать результат.

Примеры конкретных абстрактные машины которые являются детерминированными, включают детерминированная машина Тьюринга и детерминированный конечный автомат.

Что делает алгоритмы недетерминированными?

Различные факторы могут привести к тому, что алгоритм будет вести себя недетерминированным или недетерминированным образом:

  • Если он использует внешнее состояние, отличное от ввода, такое как ввод пользователя, глобальная переменная, значение аппаратного таймера, случайный значение или сохраненные данные на диске.
  • Если он работает с учетом времени, например, если несколько процессоров записывают одни и те же данные в одно и то же время. В этом случае точный порядок, в котором каждый процессор записывает свои данные, будет влиять на результат.
  • Если аппаратная ошибка вызывает неожиданное изменение его состояния.

Хотя настоящие программы редко бывают чисто детерминированными, людям, как и другим программам, легче рассуждать о программах, которые являются детерминированными. По этой причине большинство языки программирования и особенно функциональное программирование языки делают все возможное, чтобы указанные выше события не происходили, за исключением контролируемых условий.

Распространенность многоядерные процессоры привела к всплеску интереса к детерминизму в параллельном программировании, и проблемы недетерминизма были хорошо задокументированы.[1][2] Был предложен ряд инструментов, помогающих справиться с проблемами.[3][4][5][6] иметь дело с тупиковые ситуации и условия гонки.

Недостатки детерминизма

В некоторых случаях полезно, чтобы программа демонстрировала недетерминированное поведение. Поведение программы тасования карт, используемой в игре Блэк Джек, например, не должно быть предсказуемо игроками - даже если исходный код программы виден. Использование генератор псевдослучайных чисел часто бывает недостаточно для того, чтобы игроки не могли предсказать результат тасования. Умный игрок может точно угадать числа, которые выберет генератор, и таким образом заранее определить все содержимое колоды, позволяя ему обмануть; например, Software Security Group в Reliable Software Technologies смогла сделать это для реализации Texas Hold 'em Poker, распространяемой ASF Software, Inc., что позволяет им заранее предсказывать исход рук.[7] Отчасти этих проблем можно избежать за счет использования криптографически безопасный генератор псевдослучайных чисел, но это все еще необходимо для непредсказуемого случайное семя для инициализации генератора. Для этой цели необходим источник недетерминизма, такой как аппаратный генератор случайных чисел.

Обратите внимание, что отрицательный ответ на P = проблема NP не означает, что программы с недетерминированным выводом теоретически более мощные, чем программы с детерминированным выводом. НП (сложность) можно определить без какой-либо ссылки на недетерминизм, используя определение на основе верификатора.

Категории детерминизма в языках

Меркурий

Этот язык логико-функционального программирования устанавливает различные категории детерминизма для режимов предикатов, как описано в справочнике.[8][9]

Haskell

Haskell предоставляет несколько механизмов:

недетерминизм или понятие провала
  • то Может быть и Либо типы включают понятие успеха в результате.
  • то провал метод класса Monad, может использоваться для сигнализации провал как исключение.
  • Может быть монада и преобразователь монады MaybeT обеспечивают отказ в вычислениях (останавливают последовательность вычислений и не возвращают ничего)[10]
детерминизм / non-det с множественными решениями
вы можете получить все возможные результаты вычисления нескольких результатов, заключив его тип результата в MonadPlus монада. (его метод mzero делает результат неудачным и mplus собирает успешные результаты).[11]

Семейство ML и производные языки

Как видно в Стандартный ML, OCaml и Scala

  • В вариант Тип включает понятие успеха.

Ява

  • В значение NULL ссылочное значение может представлять собой неудачный результат (вне домена).

использованная литература

  1. ^ Эдвард А. Ли. «Проблема с нитями» (PDF). Получено 2009-05-29.
  2. ^ Боккино младший, Роберт Л .; Adve, Vikram S .; Adve, Sarita V .; Снир, Марк (2009). Параллельное программирование по умолчанию должно быть детерминированным. USENIX Мастер-класс по актуальным темам параллелизма.
  3. ^ «Средство проверки потоков Intel Parallel Inspector». Получено 2009-05-29.
  4. ^ Юань Линь. «Обнаружение гонки данных и взаимоблокировок с помощью анализатора потоков Sun Studio» (PDF). Получено 2009-05-29.
  5. ^ Intel. "Intel Parallel Inspector". Получено 2009-05-29.
  6. ^ Дэвид Уортингтон. «Intel решает жизненный цикл разработки с помощью Parallel Studio». Архивировано из оригинал на 2009-05-28. Получено 2009-05-26.
  7. ^ Гэри МакГроу и Джон Вьега. Заставьте свою программу вести себя: Игра цифрами: Как обмануть в азартных играх онлайн. http://www.ibm.com/developerworks/library/s-playing/#h4
  8. ^ «Категории детерминизма в языке программирования Mercury». Архивировано из оригинал на 2012-07-03. Получено 2013-02-23.
  9. ^ "Режимы предиката Меркурия". Архивировано из оригинал на 2012-07-03. Получено 2013-02-25.
  10. ^ Представление неудачи с помощью монады Maybe
  11. ^ Класс MonadPlus