Реферат: Нормальные Алгоритмы Маркова Построение алгоритмов из алгоритмов
Тезис Маркова: Для любой интуитивно вычислимой функции существует алгоритм, ее вычисляющий.
Построение алгоритмов из алгоритмов.
До сих пор, строя ту или иную МТ, или НАМ мы каждый раз все делали заново. Естественно задать вопрос, а нельзя ли при построении, например, новой МТ пользоваться уже построенной ранее МТ.
Например, МТ3 из примера 3
U3 ((n)1 )=(n)10
по существу есть надлежащим образом объединенные МТ для U1 (n)=n+1 и U2 ((n)1 )=(n-1)1 .
Аналогичный вопрос можно сформулировать для НАМ. Другими словами можно ли аккумулировать знания в форме алгоритмов так, чтобы из них можно было строить другие алгоритмы.
Мы рассмотрим эту проблему применительно к МТ. Однако все сформулированные нами утверждения будут справедливы и для НАМ и для других эквивалентных уточнений понятия алгоритма. Эквивалентость уточнений понятия алгоритма мы рассмотрим позже.
Определение.3.2. Будем говорить, что МТ1 можно эффективно построить из МТ2 и МТ3 если существует алгоритм, который позволяет, имея программу для МТ2 и МТ3 , построить программу для МТ3 .
Определение.3.3.Последовательной композицией МТ А и В называется такая МТ С, что
область применимости МТ А и С совпадают;
C(a)=B(A(a)).
Другими словами, применение С к слову a дает такой же результат, как последовательное применение к этому же слову сначала А, а потом к результату применения А - В.
Последовательную композицию МТА и МТВ будем обозначать АoВ.
Теорема 3.1. Пусть даны МТ А и В, такие, что В применима к результатам работы А и QA QB =Æ.
Тогда можно эффективно построить МТ С такую, что С= АoВ.
Доказательство.
В качестве алфавита данных и множества состояний для МТС возьмем объединение алфавитов данных и множеств состояний для А и В, т.е.
DC =DA DВ , QC = QA QB
В программе для А все правила ap®b!w, где a,bÎDA *, wÎ{Л, П, Н} заменим на ap®bqo B w, где qo B ÎQB - начальное состояние для В. Это обеспечит включение В в тот момент, когда А свою работу закончила и не раньше, т.к. QA QB =Æ.
Что и т.д.
Табличная запись программы для С показана на рисунке 3.3.
Рис 3.3 Структура табличной записи программ для Машины С.
Определение3.4.Параллельной композицией Машин Тьюринга А и В назовем такую Машину С, для которой:
DC =DA DB
QC =QA QB
C(a||b)=A(a||b)°B=B(a||b)°A=A(a)||B(b).
Из этого определения видно, что порядок применения МТА и МТВ не влияет на результат. Он будет такой же как если бы мы независимо применили А к слову a, а В к слову b.
Теорема 3.2 Для любых МТ А и МТ В можно эффективно построить МТ С такую, что С=А||В