Навигация
Главная
Поиск
Форум
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
Приложение «Про... 64233
Организация зап... 62819
Оператор выбора... 62675
Invision Power ... 62219
Подключение Mic... 61038
Модуль Forms 59935
Создание отчето... 59864
ТЕХНОЛОГИИ ДОСТ... 56078
Программируемая... 55600
Пример работы с... 53188
Имитационное мо... 51450
21 ошибка прогр... 46440
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

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

База данных студентов на Delphi + Microsoft SQL Server
Диплом - база данных поставщиков на Delphi (MS Sql Server)+ Пояснительна...
Метод половинного деления для нахождения корня уровнения на Turbo Pascal...

Реклама



Подписывайся на 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 15:32:19 · 0 Комментариев · 1276 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Панель "ссылки"
Mass Photo Upload
C++ Builder 6 СПР...
DiskInfo
Создание отчетов ...
База Allsubmitter...
Редактор анимаций
C++ Стандартная б...
Библия хакера 2. ...
PCX
DirHTMLReportBuil...
PHP/MySQL для нач...
Web Регистрация
Разработка клиент...
Crypt32
Microsoft SQL Ser...
DelphiXIsoDemo1
C# в кратком изло...
Delphi 7 Enterpri...
Atb

Топ загрузок
Приложение Клие... 100366
Delphi 7 Enterp... 82180
Converter AMR<-... 20046
Borland C++Buil... 11050
GPSS World Stud... 10421
Borland Delphi ... 8035
Turbo Pascal fo... 6959
Visual Studio 2... 4961
Калькулятор [Ис... 4259
FreeSMS v1.3.1 3508
Случайные статьи
ГЕНОЛОГ
Судно следует по м...
Исключительные сит...
Как найти качестве...
Диагональные элементы
КОНЪЮНКЦИЯ ЦЕЛЕВЫХ...
Как маршрутизаторы...
Интеграция разноро...
Предварительная по...
Вариант решения за...
Создание пользоват...
Счет в Сингапуре
Инициализация Тайм...
Холодный ядерный с...
Попрактикуйтесь в ...
Выбор переключателя
Наиболее элементар...
Настройка плагина ...
Компонент метка
Крупный шрифт не я...
doc и \chapt07\Gro...
5.4.1. Запись в ф...
Задачи клиентского...
Управление ссылками
поддеревьев: какие...
Статистика



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


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