Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Konspekt_Trsipv_Ch_2.doc
Скачиваний:
1
Добавлен:
01.07.2025
Размер:
12.41 Mб
Скачать

7.3 Оператор примитивной рекурсии

Оператор примитивной рекурсии позволяет определить вычисления специального вида. Заданы n-местная вычислимая функция и (n+2) –местная вычислимая функция . Эти функции определяют алгоритм (ход вычисления значений) получения (n+1)-местной функции , которая строится путем применения примитивной рекурсии к функциям и (значение получено примитивной рекурсией из функций , ). Обозначив через - входные данные, -индекс шага вычислений, процесс получения значений функции можно представить в виде:

. . . .

(13)

Зависимость функции от определяет особенности использования переменных в вычислениях (на том или ином шаге используется определенные подмножества { } ( ) ; { }={ }). Выражение (14) – схема примитивной рекурсии. Схема примитивной рекурсии есть алгоритм вычисления функции f.

Данная схема может быть детализирована с использованием термального представления (суперпозиции) вычисленных функций(где – обозначение функционального терма) следующим образом:

(14)

т.к. выражение (15) представляет собой способ вычисления функции , то функция определена однозначна для любого (для всех) . Последовательность ( )-го функциональных термов прокомментирована графически на Рис. 7.

Rectangle 100 AutoShape 45 AutoShape 43 AutoShape 101 AutoShape 96 AutoShape 86

Рисунок 7- Процесс вычисления примитивно-рекурсивной функции

Индекс y в (14) определяет использование функциями данных подмножеств переменных из множества { } ( ).

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

Циклическое вычисление операторов суперпозиции позволяет реализовать множество функциональных термов (реализовать представление алгоритмов множеством термов). Ввычисление функции может быть представлено следующим образом:

P: S=k-1;

f [0]:= ;

for i=1 to s do

f[i]:=h ;

f:=f[k-1]; /* f-конечный результат.

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

  1. если известны (определены) алгоритмы вычисления функции и , то функция является вычислимой;

  2. в программе оператор примитивной рекурсии реализуется циклом путем применения определенное число раз оператора суперпозиции.

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

7.4 Распараллеливание алгоритмов примитивной рекурсии

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

Большинство рекурсивных вычислений может быть проинтерпретировано в виде одной из ниже следующих цепочек выражений:

  1. аддитивная функция (операция суммирования):

(15)

Таким образом, каждое последующее значение функции f(.) отличается от предыдущего на величину (т.е. на величину, равную значению функции q(.));

  1. функция мультиплексирования (операция умножения);

(16)

Таким образом, последующее значение функции f(.) отличается от предыдущего в число раз.

В результате применения оператора примитивной рекурсии к выражениям (15) и (16) они (эти выражения) могут быть представлены в следующем виде:

1) , (17)

где функция является примитивно-рекурсивной (по причине выполнения условия примитивной рекурсии для функции q(.)).

2) , (18)

где функция также примитивно-рекурсивна.

В соответствии с исследованиями ряда авторов распараллеливание вычислений, построенных с использованием операторов примитивной рекурсии выполняется на основе выражений (18) и (17).

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]