Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Содержание сайт... 65535
Вызов хранимых ... 65535
Эмулятор микроп... 65535
Приложение «Про... 61641
Организация зап... 61342
Invision Power ... 60993
Оператор выбора... 60305
Подключение Mic... 59125
Модуль Forms 58965
Создание отчето... 58540
ТЕХНОЛОГИИ ДОСТ... 54782
Программируемая... 53510
Пример работы с... 51500
Имитационное мо... 50207
21 ошибка прогр... 45165
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

Пользователей: 13,054
новичок: Prom
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Выбор наилучших альтернатив с использованием методов оптимизации на Delp...
Моделирование станции технического обслуживания на GPSS + Отчет
Обработка задач на ЭВМ на GPSS + Пояснительная записка

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Другие способы ламбда-подъема
Представленная в предыдущих подразделах методика не является
единственным способом ламбда-подъема рекурсивных функций. Су-
ществует алгоритм, который строит суперкомбинаторы для структур
данных, а не для функций. Этот алгоритм работает следующим обра-
зом. Пусть имеется программа, содержащая рекурсивную функцию
f со свободной переменной v:

(. . .
letrec f = [x].(. . . f . . . v
. . .)
in (. . . f . . .)
. . .)



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

$f v x = . . .($f v). . . v . . .
(. . .
(. . .($f v). . .)
. . .)



Посмотрим, как работает данный алгоритм на примере из подраздела
16.6. Исходная программа имеет вид:
letrec
SumInts
[m].letrec
count = [n].IF(> n m)NIL
(cons n (count(+ n 1)))
in sum (count 1)
sum
= [ns].IF(= ns NIL) 0 (+(head ns)
(sum(tail ns)))
in SumInts 100



Поднимем [n].абстракцию, абстрагируя свободную переменную m,
но не count, и заменим все вхождения count на ($count m):

$count m n = IF(> n m)NIL(cons n($count m (+ n 1)))
letrec
SumInts = [m].sum($count m 1)
sum = [ns].IF(= ns NIL)0(+(head ns)
(sum(tail ns)))
in
SumInts 100



В исходной программе имеется два обращения к count: в [n].- аб-
стракции и в определении SumInts; оба эти обращения заменены
на ($count m). Теперь видно, что и SumInts, и sum являются су-
перкомбинаторами, поэтому можно выполнить их ламбда-подъем:
$count m n = IF(> n m)NIL(cons n($count m (+ n 1)))
$sum ns = IF(= ns NIL)0(+(head ns)($sum(tail ns)))
$SumInts m = sum ($count m 1)
$P rog = $SumInts 100
______________
$P rog



Основное преимущество этого метода по отношению к предыдуще-
му заключается в следующем. В примере из подраздела 16.6 рекур-
сивное обращение к $count в суперкомбинаторе $count осуществля-
лось через его параметр, названный count. В новом методе выполня-
ется вызов самого суперкомбинатора $count непосредственно. По-
строенный на этом методе компилятор работает более эффективно.
Упражнение 16.8 Выполнить предложенным методом компиляцию
программы из упражнения 16.7.
Опубликовал Kest May 04 2014 16:32:19 · 0 Комментариев · 1212 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Сложный калькулятор
Паскаль и Дельфи....
Delphi7 Для профе...
ProLIB18
Шаблон для новост...
UmEdit
Создание лабиринт...
Шейдеры в Delphi
PHP 5. Полное рук...
Просмотр коммент...
PRNDbgrid
Xrumer 4 Platinum...
Основы программир...
Delphi 2005 Учимс...
Длинный заголовок...
Domen Name IP
Мод "register.php...
Искусство програм...
Экспорт базы данн...
Plasma

Топ загрузок
Приложение Клие... 100356
Delphi 7 Enterp... 81312
Converter AMR<-... 20037
Borland C++Buil... 10907
GPSS World Stud... 10004
Borland Delphi ... 7962
Turbo Pascal fo... 6939
Visual Studio 2... 4946
Калькулятор [Ис... 4194
FreeSMS v1.3.1 3500
Случайные статьи
5.1. Принципы
Умножение
Указатель "примеча...
Устройство тем в P...
Презентации Prezi
• попытка соединен...
Для тех у кого не ...
ESP защищает целос...
Итератор для после...
Обеспечение основн...
Содержание
Последовательный к...
Возможности имитац...
• На какой уровень...
Оригинальная полно...
Миниатюризация ком...
Легенда
Процедура поиска в...
Глава 15. Страт...
туннельного сервер...
Причинные КОДЫ
АНТИПАТТЕРН: ЗАДАН...
Синтез нового объекта
Управление синхрон...
Всплывающие сообще...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?