12.7: Поєднання машин Тьюринга
- Page ID
- 52982
Приклади машин Тьюринга, які ми бачили досі, були досить простими за своєю природою. Але насправді будь-яка проблема, яку можна вирішити будь-яким сучасним мовою програмування, також може бути вирішена за допомогою машин Тьюринга. Щоб побудувати більш складні машини Тьюринга, важливо переконати себе, що ми можемо їх комбінувати, щоб ми могли будувати машини для вирішення більш складних проблем, розбиваючи процедуру на простіші частини. Якщо ми зможемо знайти природний спосіб розбити складну проблему на складові частини, ми можемо вирішити проблему в кілька етапів, створивши кілька простих машин Тьюринга і об'єднавши їх в одну машину, яка може вирішити проблему. Цей момент особливо важливий при вирішенні проблеми зупинки в наступному розділі.
Приклад\(\PageIndex{1}\)
Поєднання машин: Створіть машину, яка обчислює функцію\(f(m,n) = 2(m+n)\).
Для того, щоб побудувати цю машину, ми можемо об'єднати дві машини, з якими ми вже знайомі: машина додавання та дублер. Починаємо з малювання схеми стану машини складання.
Замість зупинки в стані\(q_2\), ми хочемо продовжити роботу, щоб подвоїти вихід. Нагадаємо, що машина дублер стирає перший штрих на вході і записує два штрихи в окремий висновок. Давайте додамо інструкцію, щоб переконатися, що головка стрічки читає перший хід виходу машини додавання.
Тепер легко подвоїти вхід - все, що нам потрібно зробити, це підключити машину подвійника до стану\(q_4\). Це вимагає перейменування станів машини подвійника, щоб вони починалися\(q_4\) замість\(q_0\) —таким чином ми не закінчуємо двома початковими станами. Остаточна схема повинна виглядати так, як на малюнку\(\PageIndex{1}\).