Курсовая работа: Понятие предиката. Множество истинности предиката. Классификация предикатов
Алан Тьюринг (Turing) в 1936 году опубликовал в трудах Лондонского математического общества статью «О вычислимых числах в приложении к проблеме разрешения», которая наравне с работами Поста и Черча лежит в основе современной теории алгоритмов.
Дата добавления на сайт: 19 февраля 2025
Курсовая работа
Понятие предиката. Множество истинности предиката. Классификация предикатов
Введение
тьюринг вычислительный предикат
Алан Тьюринг (Turing) в 1936 году опубликовал в трудах Лондонского математического общества статью «О вычислимых числах в приложении к проблеме разрешения», которая наравне с работами Поста и Черча лежит в основе современной теории алгоритмов.
Предыстория создания этой работы связана с формулировкой Давидом Гильбертом на Международном математическом конгрессе в Париже в 1900 году неразрешенных математических проблем. Одной из них была задача доказательства непротиворечивости системы аксиом обычной арифметики, которую Гильберт в дальнейшем уточнил как «проблему разрешимости» - нахождение общего метода, для определения выполнимости данного высказывания на языке формальной логики.
Статья Тьюринга как раз и давала ответ на эту проблему - вторая проблема Гильберта оказалась неразрешимой. Но значение статьи Тьюринга выходило далеко за рамки той задачи, по поводу которой она была написана.
Приведем характеристику этой работы, принадлежащую Джону Хопкрофту: «Работая над проблемой Гильберта, Тьюрингу пришлось дать четкое определение самого понятия метода. Отталкиваясь от интуитивного представления о методе как о некоем алгоритме, т.е. процедуре, которая может быть выполнена механически, без творческого вмешательства, он показал, как эту идею можно воплотить в виде подробной модели вычислительного процесса. Полученная модель вычислений, в которой каждый алгоритм разбивался на последовательность простых, элементарных шагов, и была логической конструкцией, названной впоследствии машиной Тьюринга».
Алан Тьюринг высказал предположение, что любой алгоритм в интуитивном смысле этого слова может быть представлен эквивалентной машиной Тьюринга. Это предположение известно как тезис Черча-Тьюринга. Каждый компьютер может моделировать машину Тьюринга (операции перезаписи ячеек, сравнения и перехода к другой соседней ячейке с учетом изменения состояния машины). Следовательно, он может моделировать алгоритмы в любом формализме, и из этого тезиса следует, что все компьютеры (независимо от мощности, архитектуры и т.д.) эквивалентны с точки зрения принципиальной возможности решения алгоритмических задач.
За время своего существования человечество придумало множество алгоритмов для решения разнообразных практических и научных проблем. Утверждение о существовании алгоритмически неразрешимых проблем является весьма сильным - мы констатируем, что мы не только сейчас не знаем соответствующего алгоритма, но мы не можем принципиально никогда его найти.
Успехи математики к концу XIX века привели к формированию мнения, которое выразил Д. Гильберт - «в математике не может быть неразрешимых проблем», в связи с этим формулировка проблем Гильбертом на конгрессе 1900 года в Париже была руководством к действию, констатацией отсутствия решений в данный момент.
Первой фундаментальной теоретической работой, связанной с доказательством алгоритмической неразрешимости, была работа Курта Гёделя - его известная теорема о неполноте символических логик. Это была строго формулированная математическая проблема, для которой не существует решающего ее алгоритма. Усилиями различных исследователей список алгоритмически неразрешимых проблем был значительно расширен. В частности, не существует алгоритма (машины Тьюринга), позволяющего по описанию произвольного алгоритма и его исходных данных (и алгоритм и данные заданы символами на ленте машины Тьюринга) определить, останавливается ли этот алгоритм на этих данных или работает бесконечно.
Фундаментально алгоритмическая неразрешимость связана с бесконечностью выполняемых алгоритмом действий, т.е. невозможностью предсказать, что для любых исходных данных решение будет получено за конечное количество шагов.
Раскрытие вопроса - что такое машина Тьюринга, какие задачи можно решать с ее помощью и каким образом, является целью данной курсовой работы. Работа состоит введения, заключения, списка использованных источников и двух глав. В первой - теоретической, вводится понятие машины Тьюринга, подробно рассматривается принципы ее работы, раскрываются все основные моменты, сопутствующие данному понятию: функций, вычислимых по Тьюрингу, эквивалентности машины Тьюринга понятию «алгоритм», правила конструирования машин Тьюринга, композиций машин Тьюринга и др. Во второй главе приведены решения задач, реализованных на машинах Тьюринга.
1. Машины Тьюринга
1.1 Определение машины Тьюринга
Введение понятия машины Тьюринга явилось одной из первых и весьма удачных попыток дать точный математический эквивалент для общего интуитивного представления об алгоритме. Это понятие названо по имени английского математика, сформулировавшего его в 1937 г., за 9 лет до появления первой электронно-вычислительной машины.
Машина Тьюринга есть математическая (воображаемая) машина, а не машина физическая. Она есть такой же математический объект, как функция, производная, интеграл, группа и. т.д. И, так же как и другие математические понятия, понятие машины Тьюринга отражает объективную реальность, моделирует некие реальные процессы. Именно Тьюринг предпринял попытку смоделировать действия математика (или другого человека), осуществляющего некую умственную созидательную деятельность. Такой человек, находясь в определенном «умонастроении» («состоянии»), просматривает некоторый текст. Затем он вносит в этот текст какие-то изменения, проникается новым «умонастроением» и переходит к просмотру последующих записей.
Машина Тьюринга действует примерно так же. Ее удобно представлять в виде автоматически работающего устройства. В каждый дискретный момент времени устройство, находясь в некотором состоянии, обозревает содержимое одной ячейки, протягиваемой через устройство ленты и делает шаг, заключающийся в том, что устройство переходит в новое состояние, изменяет (или оставляет без изменения) содержимое обозреваемой ячейки и переходит к обозрению следующей ячейки - справа или слева. Причем шаг осуществляется на основании предписанной команды. Совокупность всех команд представляет собой программу машины Тьюринга.
Опишем теперь машину Тьюринга более тщательно. Машина располагает конечным числом знаков (символов, букв), образующих так называемый внешний алфавит А = {




Далее, в каждый момент времени машина способна находиться в одном состоянии из конечного числа внутренних состояний, совокупность которых Q = {







Работа машины определяется программой (функциональной схемой). Программа состоит из команд. Каждая команда Т (i, j) (i=1,2,…, m; j=0,1, …, n) представляет собой выражение одного из следующих видов:






где 0 ≤ k ≤ m; 0≤ λ ≤ n. В выражениях первого вида символ С будем часто опускать.
Как же работает машина Тьюринга? Находясь в какой-либо момент времени в незаключительном состоянии (т.е. в состоянии, отличном от






) содержимое



) машина переходит в новое состояние


) машина переходит к обозрению следующей правой ячейки от той, которая обозревалась только что, если Х=П, или к обозрению следующей левой ячейки, если Х=Л, или же продолжает обозревать ту же ячейку ленты, если Х = С.
В следующий момент времени (если




Поскольку работа машины, по условию, полностью определяется ее состоянием











Словом в алфавите А или в алфавите Q, или в алфавите A

Если выбрать какую-либо незаключительную конфигурацию машины Тьюринга в качестве исходной, то работа машины будет состоять в том, чтобы последовательно (шаг за шагом) преобразовывать исходную конфигурацию в соответствии с программой машины до тех пор, пока не будет достигнута заключительная конфигурация. После этого работа машины Тьюринга считается закончившейся, а результатом работы считается достигнутая заключительная конфигурация.
Будем говорить, что непустое слово ɑ в алфавите А\\ {





1.2 Применение машин Тьюринга к словам
Проиллюстрируем на примерах все введенные понятия, связанные с машинами Тьюринга.
Пример 2.1. Дана машина Тьюринга с внешним алфавитом А={0,1} (здесь 0-символ пустой ячейки), алфавитом внутренних состояний Q={












Посмотрим, в какое слово переработает эта машина слово 101, исходя из стандартного начального положения. Будем последовательно выписывать конфигурации машины при переработке ею этого слова. Имеем стандартное начальное положение.
Таким образом, исходное слово 101 переработано машиной в слово 10101.
Полученную последовательность конфигураций можно записать более коротким способом. Конфигурация (1) записывается в виде следующего слова в алфавите А









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

Более короткая запись этой последовательности конфигураций, т.е. процесса работы машины, будет







Таким образом, слово 11011 переработано машиной в слово 110111.
Пример 2.2. Машина Тьюринга задается внешним алфавитом А={0,1, *} (как и в предыдущем примере 0 - символ пустой ячейки), алфавитом внутренних состояний Q={






















Посмотрим, как эта машина перерабатывает некоторые слова, и постараемся обнаружить закономерность в ее работе.
Предварительно заметим, что программа машины может быть записана также в виде следующей таблицы:
![]() | ![]() | ![]() | |
0 1 * | ![]() ![]() ![]() | ![]() ![]() ![]() | ![]() ![]() ![]() |
Чтобы определить по таблице, что будет делать машина, находясь, например, в состоянии




Применим эту машину к слову 11*11. Вот последовательность конфигураций, возникающих в процессе работы машины (исходная конфигурация - стандартная начальная):
*1
























Предлагается проверить самостоятельно, что данная машина Тьюринга осуществляет следующие преобразования конфигураций:
*








Нетрудно заметить, что данная машина Тьюринга реализует операцию сложения: в результате ее работы на ленте записано подряд столько единиц, сколько их было всего записано по обе стороны от звездочки перед началом работы машины.
Этот маленький опыт работы с машинами Тьюринга позволяет сделать некоторые выводы. Так тщательно описанное устройство этой машины (разбитая на ячейки лента, считывающая головка) по существу не имеет никакого значения. Машина Тьюринга - не что иное, как некоторое правило (алгоритм) для преобразования слов алфавита A

.3 Конструирование машин Тьюринга
Создание (синтез) машин Тьюринга (т.е. написание соответствующих программ) является задачей значительно более сложной, нежели процесс применения данной машины к данным словам.
Пример 3.1. Построим такую машину Тьюринга, которая из n записанных подряд единиц оставляла бы на ленте n-2 единицы, также записанные подряд, если n ≥ 2, и работала бы вечно, если n=0 или n=1.
В качестве внешнего алфавита возьмем двухэлементное множество A={0, 1}. Количество необходимых внутренних состояний будет определено в процессе составления программы. Считаем, что машина начинает работать из стандартного начального положения, т.е. когда в состоянии

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




Машина находится в состоянии






Теперь остается рассмотреть ситуации, когда на ленте записана всего одна единица или не записано ни одной. Если на ленте записана одна единица, то после первого шага (выполнив команду





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



Запишем составленную программу (функциональную схему) построенной машины Тьюринга в виде таблицы:
![]() | ![]() | ![]() | |
0 1 | ![]() ![]() | ![]() ![]() | ![]() ![]() |
В заключение отметим следующее. Созданная нами машина Тьюринга может применяться не только к словам в алфавите А={0,1}, представляющим собой записанные подряд n единиц (n ≥ 2). Она применима и ко многим другим словам в этом алфавите, например к словам: 1011, 10011, 111011, 11011, 1100111, 1001111, 10111, 10110111, 10010111 и т.д. (исходя из стандартного начального положения). С другой стороны, построенная машина не применима (т.е. при подаче этих слов на вход машины она работает вечно) не только к слову «1» или к слову, состоящему из одних нулей. Она не применима и к следующим словам: 101, 1001, 11101, 101101, 1100101101 и т.д.
1.4 Вычислимые по Тьюрингу функции
Определение 4.1: Функция называется вычислимой по Тьюрингу, если существует машина Тьюринга, вычисляющая ее, т.е. такая машина Тьюринга, которая вычисляет ее значения для тех наборов значений аргументов, для которых функция определена, и работающая вечно, если функция для данного набора значений аргументов не определена.
Остается договориться о некоторых условностях для того, чтобы это определение стало до конца точным. Во-первых, напомним, что речь идет о функциях (или возможно о частичных функциях, т.е. не всюду определенных), заданных на множестве натуральных чисел и принимающих также натуральные значения. Во-вторых, нужно условиться, как записывать на ленте машины Тьюринга значения












Здесь полезно ввести следующие обозначения. Для натурального x обозначаем:



Дополнительно полагаем















Пример 4.1. Построим машину Тьюринга, вычисляющую функцию f(x)= x/2. Эта функция не всюду определена: областью ее определения является лишь множество всех четных чисел. Поэтому, учитывая определение 4.1, нужно сконструировать такую машину Тьюринга, которая при подаче на ее вход четного числа давала бы на входе половину этого числа, а при подаче нечетного - работала бы неограниченно долго.
Сконструировать машину Тьюринга - значит написать (составить) ее программу. В этом процессе два этапа: сначала создается алгоритм вычисления значений функции, а затем он записывается на языке машины Тьюринга (программируется).
В качестве внешнего алфавита возьмем двухэлементное множество A={0,1}. В этом алфавите натуральное число x изображается словом 11…1, состоящим из x единиц, которое на ленте машины Тьюринга записывается в виде х единиц, состоящих в ячейках подряд. Работа машины начинается из стандартного начального положения: 01…1

Сделаем начало вычислительного процесса таким: машина обозревает ячейки, двигаясь справа налево, и каждую вторую единицу превращает в 0. Такое начало обеспечивается следующими командами:
(1):


(2):


(3):


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

(4):


(5):


(6):


В результате их выполнения получим конфигурацию

Заметим 0, перед которым остановились, на 1 и продвинемся вправо до ближайшего 0:
(7):


(8):


Получим конфигурацию 00111

(9):


(10):


Получим конфигурацию 001110101…01010

(11):


(12):


(13):


Получим конфигурацию 001110101…01

(14):


В результате чего получим конфигурацию 001110101…010

(15):


(16):


Получим конфигурацию
…0

в которой левее обозреваемой ячейки записана серия пар 10, 10, …, 10 (если читать справа налево). Теперь на ленте недостает одной единицы, т.е. число единиц равно (х/2) - 1. Продвинемся по ленте влево до последней «пары» 10. Это можно сделать с помощью цикла
(17):


(18):


выполнив который, придем к следующей конфигурации: 001

(19):


(20):


(21):


Получим конфигурацию 001111

Если теперь перешагнем вправо по ленте через обозреваемую единицу и переведем машину в состояние

(22):


то придем к следующей конфигурации: 0011111

Как же завершается работа программы? В некоторый момент конфигурация будет иметь вид 00111…1110



(23):


Заключительная конфигурация имеет вид: 00111…1111

1.5 Правильная вычислимость функций на машине Тьюринга
В предыдущем параграфе мы рассмотрели, каким образом «данная машина Тьюринга вычисляет функцию f (












В дальнейшем нам понадобится более сильное понятие вычислимости функции на машине Тьюринга - понятие правильной вычислимости.
Определение 5.1: Будем говорить, что машина Тьюринга правильно вычисляет функцию f (






Пример 5.1. Приведем программы машин Тьюринга, правильно вычисляющих функции S(x) = x+1 и O(x) = 0. Функция S(x) = x+1 осуществляет перевод:


























Пример 5.2. Построить две машины «левый сдвиг»




Программа машины








1.6 Композиция машин Тьюринга
Определение 6.1: Пусть заданы машины Тьюринга































Введенное понятие является удобным инструментом для конструирования машин Тьюринга. Покажем это на примере.
Пример 6.1. Сконструируем машины Тьюринга, правильно вычисляющие функции-проекторы





Рассмотрим сначала конкретный случай n=3, m=2, т.е. функцию












В:



О:



О:



Таким образом, функция











Теперь мы можем представить себе алгоритм построения композиции машин













Затем, двигаясь влево, транспонировать (с помощью В) массив






Теперь нужно дойти до крайнего правого массива с помощью (n-1) - кратного применения правого сдвига





Наконец, нужно стирать последовательно справа налево все массивы единиц, кроме первого:




Итак, данную функцию (правильно) вычисляет следующая машина Тьюринга:

1.7 Тезис Тьюринга (основная гипотеза теории алгоритмов)
Напомним, одно из свойств алгоритма заключается в том, что он представляет собой единый способ, позволяющий для каждой задачи из некоего бесконечного множества задач за конечное число шагов найти ее решение.
На понятие алгоритма можно взглянуть и с несколько иной точки зрения. Каждую задачу из бесконечного множества задач можно выразить (закодировать) некоторым словом некоторого алфавита, а решение задачи - каким-то другим словом того же алфавита. В результате получим функцию, заданную на некотором подмножестве множества всех слов выбранного алфавита и принимающую значения в множестве всех слов того же алфавита. Решить какую-либо задачу - значит найти значение этой функции на слове, кодирующем данную задачу. А иметь алгоритм для решения всех задач данного класса - значит иметь единый способ, позволяющий в конечное число шагов «вычислять» значения построенной функции для любых значений аргумента из ее области определения. Таким образом, алгоритмическая проблема - по существу, проблема о вычислении значений функции, заданной в некотором алфавите.
Остается уточнить, что значит уметь вычислять значения функции. Это значит вычислять значения функции с помощью подходящей машины Тьюринга. Для каких же функций возможно их тьюрингово вычисление? Многочисленные исследования ученых, обширный опыт показали, что такой класс функций чрезвычайно широк. Каждая функция, для вычисления значений которой существует какой-нибудь алгоритм, оказывалась вычислимой посредством некоторой машины Тьюринга. Это дало повод Тьюрингу высказать следующую гипотезу, называемой основной гипотезой теории алгоритмов, или тезисом Тьюринга:
Для нахождения значений функции, заданной в некотором алфавите, тогда и только тогда существует какой-нибудь алгоритм, когда функция является вычислимой по Тьюрингу, т.е. когда она может вычисляться на подходящей машине Тьюринга.
Это означает, что строго математическое понятие вычислимой (по Тьюрингу) функции является по существу идеальной моделью взятого из опыта понятия алгоритма. Данный тезис есть не что иное, как аксиома, постулат, выдвигаемый нами, о взаимосвязях нашего опыта с той математической теорией, которую мы под этот опыт хотим подвести. Конечно же данный тезис в принципе не может быть доказан методами математики, потому что он не имеет внутриматематического характера (одна сторона в тезисе - понятие алгоритма - не является точным математическим понятием). Он выдвинут исходя из опыта, и именно опыт подтверждает его состоятельность. Точно так же, например, не могут быть доказаны и математические законы механики; они открыты Ньютоном и многократно подтверждены опытом.
Впрочем, не исключается принципиальная возможность того, что тезис Тьюринга будет опровергнут. Для этого должна быть указана функция, которая вычислима с помощью какого-нибудь алгоритма, но невычислима ни на какой машине Тьюринга. Но такая возможность представляется маловероятной (в этом одно из значений гипотезы): всякий алгоритм, который будет открыт, может быть реализован на машине Тьюринга.
1.8 Машины Тьюринга и современные электронно-вычислительные машины
Изучение машин Тьюринга и практика составления программ для них закладывают фундамент алгоритмического мышления, сущность которого состоит в том, что нужно уметь разделять тот или иной процесс вычисления или какой-либо другой деятельности на простые составляющие шаги. В машине Тьюринга расчленение (анализ) вычислительного процесса на простейшие операции доведено до предельной возможности: распознавание единичного рассмотренного вхождения символа, перемещение точки наблюдения данного ряда символов в соседнюю точку и изменение имеющейся в памяти информации. Конечно, такое мелкое дробление вычислительного процесса, реализуемого в машине Тьюринга, значительно его удлиняет. Но вместе с тем логическая структура процесса, расчлененного, образно выражаясь, до атомарного состояния, значительно упрощается и предстает в некотором стандартном виде, весьма удобном для теоретических исследований. (Именно такое расчленение на простейшие составляющие вычислительного процесса на машине Тьюринга дает еще один косвенный аргумент в пользу тезиса Тьюринга, обсуждавшегося в предыдущем параграфе: всякая функция, вычисляемая с помощью какого-либо алгоритма, может быть вычислена на машине Тьюринга, потому что каждый шаг данного алгоритма можно расчленить на еще более мелкие операции, которые реализуются в машине Тьюринга.) Таким образом, понятие машины Тьюринга есть теоретический инструмент анализа алгоритмического процесса, а значит, анализа существа алгоритмического мышления.
В современных ЭВМ алгоритмический процесс расчленен не на столь мелкие составляющие, как в машинах Тьюринга. Наоборот, создатели ЭВМ стремятся к известному укрупнению выполняемых машиной процедур (на этом пути, конечно, есть свои ограничения). Так, для выполнения операции сложения на машине Тьюринга составляет целая программа, а в современной ЭВМ такая операция является простейшей.
Далее, машина Тьюринга обладает бесконечной внешней памятью (неограниченная в обе стороны лента, разбитая на ячейки). Но ни в одной реально существующей машине бесконечной памяти быть не может. Это говорит о том, что машины Тьюринга отображают потенциальную возможность неограниченного увеличения объема памяти современных ЭВМ.
Наконец, можно провести более подробный сравнительный анализ работы современной ЭВМ и машины Тьюринга. В большинстве ЭВМ принята трехадресная система команд, обусловленная необходимостью выполнения бинарных операций, в которых участвует содержимое сразу трех ячеек памяти. Например, число из ячейки a умножается на число из ячейки b, и результат отправляется в ячейку с. Существуют ЭВМ двухадресные и одноадресные. Так, одноадресная ЭВМ работает следующим образом: вызывается (в сумматор) число из ячейки а; в сумматоре происходит, например, умножение этого числа на число из ячейки b; результат отправляется из сумматора в ячейку с. Машину Тьюринга можно считать одноадресной машиной, в которой система одноадресных команд упрощена еще больше: на каждом шаге работы машины команда предписывает замену лишь единственного знака, хранящегося в обозреваемой ячейке, а адрес обозреваемой ячейки при переходе к следующему такту может меняться лишь на единицу (обозрение соседней справа или слева ячейки ленты) или не меняться вовсе. Это удлиняет процесс, но в то же время резко унифицирует его, делает стандартным.
Подводя итоги, можно сказать, что современные ЭВМ есть некие реальные физические модели машин Тьюринга, огрубленные с точки зрения теории, но созданные в целях реализации конкретных вычислительных процессов. В свою очередь, понятие машины Тьюринга и теория машин есть теоретический фундамент и обоснование современных ЭВМ.
2. Реализация алгоритмов в машине Тьюринга
Пример 1. Реализация в машине Тьюринга алгоритма перехода от n к n+1 в десятичной системе счисления.
Пусть дана десятичная запись натурального числа n и требуется указать десятичную запись числа n+1, т.е. вычислить функцию f(n)=n+1.
Ясно, что здесь внешний алфавит машины должен содержать все цифры 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 и символ пустой клетки

Чтобы решить поставленную задачу, машина должна в первом такте работы стереть последнюю цифру числа n, заменить ее цифрой на единицу большей и перейти в стоп - состояние, если последняя цифра была меньше цифры 9.
Если же последняя цифра числа n была 9, то машина должна, стерев цифру 9, записать в освободившуюся клетку цифру 0 и произвести сдвиг влево к соседнему более высокому разряду, оставаясь в том же начальном состоянии. Здесь во втором такте работы машина должна прибавить единицу к цифре более высокого разряда. Очевидно, что в случае сдвига влево, управляющая головка машины может выйти на пустую клетку в случае, в случае когда цифры более высокого разряда нет. При этом машина вписывает в пустую клетку цифру 1. При реализации алгоритма вычисления функции f(n)=n+1 машина может прибывать лишь в двух состояниях


Таким образом, машина Тьюринга, реализующая алгоритм перехода от n к n+1 в десятичной системе счисления будет иметь вид:
![]() | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | |
![]() | 1н![]() | 1н![]() | 2н![]() | 3н![]() | 4н![]() | 5н![]() | 6н![]() | 7н![]() | 8н![]() | 9н![]() | 0^![]() |
Пример 2. Алгоритм сложения натуральных чисел.
Пусть на ленту подается два числа, заданных наборами палочек; например, 2 и 3. Нужно сложить эти числа.
Будем обозначать символ сложения звездочкой. Таким образом, на ленте машины будет записано слово


Требуется предложить функциональную схему, которая будучи примененной к слову (1), давала бы в результате сумму чисел 2 и 3, то есть слово


Опишем процесс работы машины для решения задачи. Пусть в начальный момент обозревается самая левая палочка. Ее нужно сдвинуть вправо, минуя все палочки и звездочку до тех пор, пока не будет достигнута первая пустая клетка. В эту пустую клетку вписывается первая палочка. Затем нужно вернуться за второй палочкой и ее перенести вправо так же, как это делалось с первой палочкой. После этой процедуры нужно вернуться к звездочке, стереть ее и остановиться. Изобразим все такты работы машины в виде соответствующих конфигураций:
1)







1)







3)





4)







5)







6)







7)







8)







9)







10)







Этот процесс позволяет записать алгоритм в виде двумерной таблицы:
![]() | * | | | |
![]() | ![]() ![]() | ![]() ![]() | |
![]() | | н ![]() | *п ![]() | | п ![]() |
![]() | ![]() ![]() | *^ ![]() | | ^ ![]() |
Таким образом, здесь использован внешний алфавит





Заключение
Таким образом, машина Тьюринга представляет собой простейшую вычислительную машину с линейной памятью, которая согласно формальным правилам преобразует входные данные с помощью последовательности элементарных действий. С математической точки зрения машина Тьюринга - просто определенный алгоритм для переработки слов. Несмотря на простоту машины Тьюринга, на ней можно вычислить всё, что можно вычислить на любой другой машине, осуществляющей вычисления с помощью последовательности элементарных действий. Машина Тьюринга может выполнять все возможные преобразования слов, реализуя тем самым все возможные алгоритмы.
Один из естественных способов доказательства того, что алгоритмы вычисления, которые можно реализовать на одной машине, можно реализовать и на другой, - это имитация первой машины на второй. На машине Тьюринга можно имитировать машину Поста, нормальные алгоритмы Маркова и любую программу для обычных компьютеров, преобразующую входные данные в выходные по какому-либо алгоритму. В свою очередь, на различных абстрактных исполнителях можно имитировать Машину Тьюринга. Исполнители, для которых это, возможно, называются полными по Тьюрингу.
Богатство возможностей машины Тьюринга проявляется в том, что если какие-то алгоритмы реализуются машинами Тьюринга, то можно построить машины Тьюринга, реализующие различные композиции этих алгоритмов. Очевидно, что такие композиции также являются алгоритмами, поэтому их реализация посредством машины Тьюринга подтверждает, что конструкция Тьюринга является универсальным исполнителем. На машинах Тьюринга оказалось возможным осуществить или имитировать все алгоритмические процессы, которые когда-либо описывались математиками.
Список использованной литературы
1.Ершов С.С. Элементы теории алгоритмов: учебное пособие [Текст] / С.С. Ершов. - Челябинск: Издательский центр ЮУрГУ, 2009. - 64 с.
2.Игошин В.И. Математическая логика и теория алгоритмов: Учеб. пособие для студ. высш. учеб. заведений [Текст] / Владимир Иванович Игошин. - М.: Издательский центр «Академия», 2012. - 448 с.
.Клини С. Машины Тьюринга и рекурсивные функции [Текст] / С. Клини. - М., 2010.
.Успенский В.А. Теория алгоритмов: основные открытия и приложения [Текст] / В.А. Успенский, А.Л. Семенов. - М.: Наука, 2012. - 288 с.