Машина с произвольным доступом с хранимой программой - Random-access stored-program machine

В теоретическая информатика то хранимая программа с произвольным доступом (РАСП) модель машины абстрактная машина используется в целях алгоритм развитие и теория сложности алгоритмов.

RASP - это машина с произвольным доступом (RAM) модель, которая, в отличие от RAM, имеет программа в его «регистрах» вместе со своим входом. Регистры не ограничены (бесконечны по объему); Конечность числа регистров зависит от модели. Таким образом, RASP является для RAM как Универсальная машина Тьюринга к Машина Тьюринга. RASP является примером фон Неймана архитектура в то время как RAM является примером Гарвардская архитектура.

RASP наиболее близка из всех абстрактных моделей к общему понятию компьютер. Но в отличие от реальных компьютеров модель RASP обычно имеет очень простой набор инструкций, значительно сокращенный по сравнению с CISC и даже RISC к простейшей арифметике, инструкциям «перемещений регистр-регистр» и «тест / переход». Некоторые модели имеют несколько дополнительных регистров, например аккумулятор.

Вместе с зарегистрировать машину, ОЗУ и указатель машины RASP составляет четыре общих последовательная машина модели, названные так, чтобы отличать их от «параллельных» моделей (например, параллельная машина с произвольным доступом ) [ср. ван Эмде Боас (1990)].

Неформальное определение: модель хранимой программы с произвольным доступом (RASP)

Краткое описание RASP:

RASP - это универсальная машина Тьюринга (UTM) на базе машина с произвольным доступом Шасси RAM.

Читатель помнит, что UTM - это Машина Тьюринга с «универсальной» таблицей инструкций с конечным числом состояний, которая может интерпретировать любую правильно сформированную «программу», записанную на ленте, как строку 5-кортежей Тьюринга, отсюда ее универсальность. В то время как классическая модель UTM ожидает найти на своей ленте 5-кортежи Тьюринга, любой вообразимый программный набор может быть помещен туда при условии, что машина Тьюринга ожидает их найти - учитывая, что ее таблица конечных состояний может интерпретировать их и преобразовывать в желаемое действие. Наряду с программой на ленте будут напечатаны входные данные / параметры / числа (обычно справа от программы) и, в конечном итоге, выходные данные / числа (обычно справа от обоих, либо смешанные с вводом, либо заменяющие его. ). «Пользователь» должен расположить голову машины Тьюринга над первой инструкцией, а ввод должен быть помещен в указанное место и формат, соответствующий как программе на ленте, так и таблице команд конечного автомата.

RASP имитирует эту конструкцию: он помещает «программу» и «данные» в отверстия (регистры). Но, в отличие от UTM, RASP последовательно «извлекает» свои инструкции, если условный тест не отправляет их куда-то еще.

Путаница: два набора инструкций: В отличие от UTM, модель RASP имеет два набора инструкций - таблицу инструкций конечного автомата («интерпретатор») и «программу» в отверстиях. Два набора не обязательно должны быть взяты из одного набора.

Пример ОЗУ, работающего как RASP

В следующем примере программы перемещается содержимое регистра (отверстие) # 18 в регистр (отверстие) # 19, стирая содержимое регистра # 18 в процессе.

    5: 03 18 15    JZ 18,15       ; если [18] равно нулю, перейдите к 15, чтобы завершить программу       02 18       DEC 18         ; Декремент [18]       01 19       INC 19         ; Приращение [19]       03 15 05    JZ 15, 5       ; Если [15] равно нулю, перейдите к 5, чтобы повторить цикл (используйте Halt для имитации безусловного перехода)   15: 00          ЧАС              ; Остановка   18:  п                         ; Исходное значение для копирования   19:                            ; Место для копирования

В программа-инструкции, доступные в этой машине RASP, будут простым набором для краткости примера:

ИнструкцияМнемоническийДействие в регистре "r"Действие в регистре инструкций конечного автомата, IR
INCrementINC (r)[r] +1 → r[ИК] +1 → ИК
ДЕКРЕМЕНТDEC (r)[г] -1 → г[ИК] +1 → ИК
Перейти, если нольJZ (г, г)никтоЕСЛИ [r] = 0, ТО z → IR ELSE [IR] +1 → IR
ОстановкаЧАСникто[ИК] → ИК

Чтобы упростить пример, мы оснастим Государственный аппарат RAM-as-RASP с примитивными инструкциями, взятыми из того же набора, но дополненными двумя инструкциями косвенного копирования:

Инструкции конечного автомата RAM:
{ Дюйм; DEC h; JZ h, xxx; CPY << ча>>, а>; CPY <ча>, << hа>> }

Что именно будет делать конечный автомат, когда конечный автомат машины RASP интерпретирует программу в регистрах? Столбец с восклицательным знаком! отобразит во временной последовательности действия конечного автомата, поскольку он «интерпретирует» - преобразует в действие - программу:

ПКИК
отверстие # →12345678910111213141516171819
программа, параметры →5JZ1815DEC18INC19JZ155ЧАСп
закодированная программа →53181521811931550п
инструкции конечного автомата ↓
!

Традиция делит действия государственной машины на две основные «фазы», ​​называемые Принести и Выполнять. Ниже мы увидим, что в этих двух основных фазах есть «подэтапы». Согласованной конвенции нет; каждая модель потребует своего точного описания.

Фаза получения

Конечный автомат имеет доступ ко всем регистрам как прямо, так и косвенно. Таким образом, он принимает №1 в качестве «программного счетчика» ПК. Роль программа фишкой станет "сохранить место" в листинге программы; Государственный автомат имеет собственный государственный реестр для личного пользования.

При запуске конечный автомат ожидает найти номер на ПК - первую «Программу-инструкцию» в программе (то есть в # 5).

(Без использования косвенных копий задача переноса указанной программной инструкции в # 2 является немного сложной. Конечный автомат будет косвенно уменьшать указанный регистр при прямом увеличении (пустого) регистра # 2. на этапе "синтаксического анализа" он восстановит принесенное в жертву содержимое # 5, жертвуя счетчиком в # 2.)

Смысл вышеупомянутого обходного пути - показать, что жизнь намного проще, когда конечный автомат имеет доступ к двум видам косвенных копий:

  • копировать косвенно из i и напрямую в j: CPY << hя>>, j>
  • копировать прямо из i и косвенно в j: CPY я>, << hj>>

В следующем примере показано, что происходит во время фазы «выборки» конечного автомата. Операции конечного автомата перечислены в столбце «Инструкция конечного автомата ↓». Обратите внимание, что в конце выборки регистр № 2 содержит числовое значение 3 «кода операции» («код операции») первой инструкции. JZ:

ПКPIR
отверстие # →12345678910111213141516171819
программа, параметры →5JZ1815DEC18INC19JZ155ЧАСп
закодированная программа →53181521811931550п
шагинструкции конечного автомата ↓
1fetch_instr:CPY <<1>>, <2>5 я[3][3]181521811931550п

Фаза синтаксического анализа

Теперь, когда номер программы-инструкции (например, 3 = "JZ") находится в регистре № 2 - "Регистр программ-инструкций" PIR - конечный автомат продолжает уменьшать номер до тех пор, пока IR не станет пустым:

Если бы IR был пуст перед декрементом, тогда программа-инструкция была бы 0 = HALT, и машина перешла бы к своей подпрограмме «HALT». После первого декремента, если отверстие было пустым, инструкция была бы INC, и машина перешла бы к инструкции inc_routine. После второго декремента пустой IR будет представлять DEC, и машина перейдет к «dec_routine». После третьего декремента IR действительно пуст, и это вызывает переход к подпрограмме "JZ_routine". Если бы неожиданный номер все еще был в IR, то машина обнаружила бы ошибку и могла бы ОСТАНОВИТЬСЯ (например).

ПКИК
отверстие # →12345678910111213141516171819
программа, параметры →5JZ1815DEC18INC19JZ155ЧАСп
закодированная программа →53181521811931550п
инструкции конечного автомата ↓
CPY <<1>>, <2>5 я[3][3]181521811931550п
JZ 2, остановка533181521811931950п
32 декабря523181521811931550п
4JZ 2, inc_routine:523181521811931550п
52 декабря513181521811931550п
6JZ 2, dec_routine513181521811931550п
72 декабря503181521811931550п
8JZ 2, JZ_routine50 !
остановка:HALT533181521811931550п
inc_routine:и Т. Д.533181521811931550п
dec_routine:и Т. Д.533181521811931550п
9JZ_routine:и Т. Д.533181521811931550п

Фаза выполнения, JZ_routine

Теперь конечный автомат знает, какую программу-инструкцию выполнить; действительно, он перешел к последовательности инструкций "JZ_routine". Инструкция JZ имеет 2 операнда - (i) номер регистра для проверки и (ii) адрес, по которому нужно перейти, если проверка прошла успешно (дыра пуста).

(i) Выборка операнда - какой регистр проверять на пустоту?: Аналогично фазе выборки, конечный автомат перемещает содержимое регистра, на который указывает ПК, то есть отверстие # 6, в регистр программных инструкций PIR # 2. Затем он использует содержимое регистра # 2, чтобы указать на регистр, который нужно проверить на ноль, то есть регистр # 18. Отверстие № 18 содержит номер «n». Теперь для проведения теста конечный автомат использует содержимое PIR для косвенного копирования содержимого регистра № 18 в резервный регистр № 3. Итак, есть две возможности (ia), регистр № 18 пуст, (ib) регистр № 18 не пуст.

(ia): Если регистр № 3 пуст, конечный автомат переходит к (ii) Выборка второго операнда - выбор адреса перехода.

(ib): Если регистр # 3 не пуст, конечный автомат может пропустить (ii) выборку второго операнда. Он просто увеличивает в два раза PC, а затем безоговорочно возвращается к фазе выборки инструкций, где она выбирает программную инструкцию # 8 (DEC).

(ii) Выборка операнда - адрес перехода. Если регистр №3 пуст, конечный автомат продолжает использовать ПК для косвенного копирования содержимого регистра, на который он указывает (№8), в сам. Теперь ПК имеет адрес перехода 15. Затем конечный автомат безоговорочно возвращается к фазе выборки инструкций, где он выбирает программную инструкцию # 15 (HALT).

ПКИК
отверстие # →12345678910111213141516171819
программа, параметры →5JZ1815DEC18INC19JZ155ЧАСп
закодированная программа →53181521811931550п
шагинструкции конечного автомата ↓
9JZ_routineINC 1[6]33181521811931550п
10CPY <<1>>, <2>6 я[18]3[18]1521811931550п
11тестовое отверстие:CPY <<2>>, <3>618 я[n]3181521811931550[n]
12тестовое отверстие:JZ 3, прыжок618 я[n]3181521811931550п
пп
13no_jump:INC 1[7]18п3181521811931550п
14INC 1[8]18п3181521811931550п
15J fetch_instr818п3181521811931550п
1fetch_instr:CPY <<1>>, <2>8 я[2]п31815[2]1811931550п
2разобрать:и Т. Д.
13Прыгать:INC 1[7]18п3181521811931550п
14CPY <<1>>, <1>[15]18п318[15]21811931550п
15J fetch_instr1518п3181521811931550п
1fetch_instr:CPY <<1>>, <2>15 я[0]п318152181193155[0]п
2разобрать:и Т. Д.

Выполнить этап INC, DEC

Следующее завершает интерпретацию программных инструкций конечным автоматом RAM, INC h, DEC h и, таким образом, завершает демонстрацию того, как RAM может "олицетворять" RASP:

Набор команд целевой программы: {INC h; DEC h; JZ h, xxx, HALT}

Без косвенных команд конечного автомата INCi и DECi для выполнения INC и DEC программа-инструкции конечный автомат должен использовать косвенную копию, чтобы получить содержимое указанного регистра в резервный регистр # 3, DEC или INC, а затем использовать косвенную копию, чтобы отправить его обратно в указанный регистр.

ПКИК
отверстие # →12345678910111213141516171819
программа, параметры →5JZ1815DEC18INC19JZ155ЧАСп
закодированная программа →53181521811931550п
инструкции конечного автомата ↓
15J fetch_instr818п3181521811931550п
16fetch_instr:CPY <<1>>, <2>8 я[2]п3181521811931550п
17разобрать:JZ 2, остановка82п3181521811931550п
182 декабря8[1]п3181521811931550п
19JZ 2, inc_routine:81п3181521811931550п
202 декабря8[0]п3181521811931550п
21JZ 2, dec_routine:80 !п3181521811931550п
22dec_routine:INC 190п3181521811931550п
23CPY <<1>>, <2>9 я18п3181521811931550п
24CPY <<2>>, <3>918 яп3181521811931550п
25JZ 3, * + 2918п3181521811931550п
263 декабря918п-13181521811931550п
27CPY <3>, <<2>>918 яп-13181521811931550п-1
28INC 11018п-13181521811931550п-1
29J fetch_instr1018п-13181521811931550п-1
30fetch_instr:CPY <<1>>, <2>10 я1п-13181521811931550п-1
31разобрать:JZ 2, остановка101п-13181521811931550п-1
322 декабря100п-13181521811931550п-1
33JZ 2, inc_routine:100 !п-13181521811931550п-1
34inc_routine:INC 1110п-13181521811931550п-1
35CPY <<1>>, <2>11 я19п-13181521811931550п-1
36CPY <<2>>, <3>1119 я03181521811931550п-10
37INC 3111913181521811931550п-10
38CPY <3>, <<2>>1119 я13181521811931550п-11
39INC 1121913181521811931550п-10
40J fetch_instr121913181521811931550п-10
41fetch_instr:и Т. Д.121913181521811931550п-10

Альтернативные инструкции: Хотя демонстрация привела к примитивному RASP, состоящему всего из четырех инструкций, читатель может представить себе, как дополнительная инструкция, такая как «ADD » или «MULT а>, << hб> Может быть сделано.

Самомодифицирующиеся программы RASP

Когда RAM действует как RASP, было получено кое-что новое: в отличие от RAM, RASP может самостоятельно модифицировать свои программа-инструкции (инструкции конечного автомата заморожены и не могут быть изменены машиной). Cook-Reckhow (1971) (стр. 75) комментируют это в своем описании своей модели RASP, как и Хартманис (1971) (стр. 239 и далее).

Раннее описание этого понятия можно найти у Голдстайна-фон Неймана (1946):

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

Такая способность делает возможным следующее:

Программа-инструкция RASP Cook and Reckhow (1973)

В влиятельной газете Стивен А. Кук и Роберт А. Реккау определяют свою версию RASP:

«Машина с хранимыми программами произвольного доступа (RASP), описанная здесь, похожа на RASP, описанную Хартманисом [1971]» (стр. 74).

Их цель состояла в том, чтобы сравнить время выполнения различных моделей: RAM, RASP и многоленточной машины Тьюринга для использования в теории анализ сложности.

Отличительной чертой их модели RASP является отсутствие косвенных программных инструкций (см. Их обсуждение на стр. 75). Они достигают этого, требуя, чтобы программа изменила себя: при необходимости команда может изменить «параметр» (свое слово, то есть «операнд») конкретной инструкции. Они разработали свою модель так, что каждая «инструкция» использует два последовательных регистра, один для «кода операции» (их слово) и параметр «либо адрес, либо целочисленная константа».

Их регистры RASP неограниченны по объему и количеству; аналогично их аккумулятор AC и счетчик команд IC не ограничены. Набор инструкций следующий:

операциямнемоническийкод операцииописание
постоянная нагрузкиLOD, k1положить константу k в аккумулятор
ДобавитьADD, j2добавить содержимое регистра j в аккумулятор
вычестьSUB, j3вычесть содержимое регистра j из аккумулятора
хранитьСТО, j4скопировать содержимое аккумулятора в регистр j
ответвление на плюсовом аккумулятореBPA, xxx5ЕСЛИ содержимое аккумулятора> 0 ТО перейти к xxx ELSE следующая инструкция
читатьRD, j6следующий ввод в регистр j
РаспечататьPRI, j7вывод содержимого регистра j
остановкаHLTлюбое другое - или + целое числоостановка

Рекомендации

Часто машины RAM и RASP представлены вместе в одной статье. Они были скопированы с Машина произвольного доступа; за некоторыми исключениями, эти ссылки такие же, как и на Зарегистрировать машину.

  • Джордж Булос, Джон П. Берджесс, Ричард Джеффри (2002), Вычислимость и логика: четвертое изданиеИздательство Кембриджского университета, Кембридж, Англия. Первоначальный текст Булоса-Джеффри был тщательно отредактирован Берджессом: более продвинутый, чем вводный учебник. Модель "Abacus machine" подробно рассматривается в главе 5. Вычислимость Abacus; это одна из трех моделей, которые тщательно изучаются и сравниваются - машина Тьюринга (все еще в исходной четырехкортежной форме Boolos) и две другие рекурсивные модели.
  • Артур Беркс, Герман Голдстайн, Джон фон Нейман (1946), Предварительное обсуждение логической конструкции электронного вычислительного прибора., перепечатано с. 92ff в Гордон Белл и Аллен Ньюэлл (1971), Компьютерные структуры: литература и примеры, mcGraw-Hill Book Company, Нью-Йорк. ISBN  0-07-004357-4 .
  • Стивен А. Кук и Роберт А. Рекхоу (1972), Машины с ограниченным по времени произвольным доступом, Journal of Computer Systems Science 7 (1973), 354-375.
  • Мартин Дэвис (1958), Вычислимость и неразрешимость, McGraw-Hill Book Company, Inc. Нью-Йорк.
  • Кэлвин Элгот и Авраам Робинсон (1964), Машины с хранимыми программами с произвольным доступом, подход к языкам программирования, Журнал Ассоциации вычислительной техники, Vol. 11, № 4 (октябрь 1964 г.), стр. 365–399.
  • Дж. Хартманис (1971), "Вычислительная сложность машин с хранением программ с произвольным доступом", Математическая теория систем 5, 3 (1971) стр. 232–245.
  • Джон Хопкрофт, Джеффри Уллман (1979). Введение в теорию автоматов, языки и вычисления, 1-е изд., Reading Mass: Addison-Wesley. ISBN  0-201-02988-X. Сложная книга, посвященная проблемам машинной интерпретации «языков», NP-полноты и т. Д.
  • Стивен Клини (1952), Введение в метаматематику, North-Holland Publishing Company, Амстердам, Нидерланды. ISBN  0-7204-2103-9.
  • Дональд Кнут (1968), Искусство программирования, Второе издание 1973 г., Addison-Wesley, Reading, Massachusetts. См. Страницы 462-463, где он определяет «новый вид абстрактной машины или« автомата », который имеет дело со связанными структурами».
  • Иоахим Ламбек (1961 г., получено 15 июня 1961 г.), Как запрограммировать бесконечные счеты, Математический вестник, т. 4, вып. 3. Сентябрь 1961 г., стр. 295–302. В своем Приложении II Ламбек предлагает «формальное определение« программы ». Он ссылается на Мелзака (1961) и Клини (1952). Введение в метаматематику.
  • З. А. Мельзак (1961 г., получено 15 мая 1961 г.), Неформальный арифметический подход к вычислимости и вычислениям, Канадский математический бюллетень, т. 4, вып. 3. Сентябрь 1961 г., стр. 279–293. Мелзак не дает никаких ссылок, но признает «пользу разговоров с докторами Р. Хэммингом, Д. Макилроем и В. Виссотсом из телефонных лабораторий Bell и с доктором Х. Вангом из Оксфордского университета».
  • Марвин Мински (1961 г., получено 15 августа 1960 г.). «Рекурсивная неразрешимость проблемы Поста о« теге »и других тем в теории машин Тьюринга». Анналы математики. Анналы математики. 74 (3): 437–455. Дои:10.2307/1970290. JSTOR  1970290. Проверить значения даты в: | дата = (помощь)
  • Марвин Мински (1967). Вычисления: конечные и бесконечные машины (1-е изд.). Englewood Cliffs, N.J .: Prentice-Hall, Inc. ISBN  0-13-165449-7. В частности, см. Главу 11: Модели, похожие на цифровые компьютеры и глава 14: Очень простые основы вычислимости. В предыдущей главе он определяет «Программные машины», а в более поздней главе он обсуждает «Универсальные программные машины с двумя регистрами» и «... с одним регистром» и т. Д.
  • Джон С. Шепердсон и Х. Э. Стерджис (1961) получен в декабре 1961 г. Вычислимость рекурсивных функций, Journal of the Association of Computing Machinery (JACM) 10: 217-255, 1963. Чрезвычайно ценный справочный документ. В своем Приложении А авторы цитируют еще 4 со ссылкой на «Минимум инструкций, используемых в 4.1: Сравнение с аналогичными системами».
  • Капхенгст, Хайнц, Eine Abstrakte programmgesteuerte Rechenmaschine ', Zeitschrift fur Mathematische Logik und Grundlagen der Mathematik:5 (1959), 366-379.
  • Ершов, А. Об операторных алгоритмах, (Русский) Док. Акад. НАУК, 122 (1958), 967-970. Английский перевод, Автомат. Экспресс 1 (1959), 20-23.
  • Петер, Рожа Графические схемы и рекурсивные функции, Диалектика 12 (1958), 373.
  • Гермес, Ганс Die Universalität programmgesteuerter Rechenmaschinen. Math.-Phys. Semsterberichte (Göttingen) 4 (1954), 42-53.
  • Арнольд Шёнхаге (1980), Машины для модификации хранения, Общество промышленной и прикладной математики, SIAM J. Comput. Vol. 9, No. 3, август 1980. Здесь Шенхаге показывает эквивалентность своего SMM «преемнику RAM» (машина произвольного доступа) и т. Д. Соответственно. Машины для модификации хранения, в Теоретическая информатика (1979), стр. 36–37
  • Питер ван Эмде Боас, Модели машин и симуляции стр. 3–66, появляющиеся в: Ян ван Леувен, изд. Справочник по теоретической информатике. Том A: Алгоритмы и сложность, MIT PRESS / Elsevier, 1990. ISBN  0-444-88071-2 (том А). QA 76.H279 1990.
Трактовка СММ ван Эмде Боасом приводится на стр. 32-35. Это лечение проясняет Schnhage 1980 - оно близко следует, но немного расширяет лечение Schnhage. Обе ссылки могут потребоваться для эффективного понимания.
  • Хао Ван (1957), Вариант теории вычислительных машин Тьюринга, JACM (Журнал Ассоциации вычислительной техники) 4; 63-92. Представлено на заседании Ассоциации 23–25 июня 1954 г.