|
Здравствуйте! Записался на ваш курс, но не понимаю как произвести оплату. Надо ли писать заявление и, если да, то куда отправлять? как я получу диплом о профессиональной переподготовке? |
Функции высших порядков
Конструирование распознавателей
Результативность функций высших порядков Хендерсон показывает на модельной задаче построения распознавателя контекстно-свободного языка [ 3 ] .
В качестве примера такого языка рассмотрен синтаксис понятия "слог", образованный по правилам из гласных и согласных букв, что можно представить грамматикой вида:
<а-гр> ::= А | А <а-гр>
<в-гр> ::= В | В <в-гр>
<слог> ::= <а-гр> <в-гр>
| <в-гр> <а-гр>
| <в-гр> <а-гр> <в-гр>В этой грамматике " А " и " В " — терминальные символы, "слог", "а-гр" и "в-гр" — нетерминальные символы (метапонятия), "слог" — основное понятие. Необходимо быстро построить предикат is-syllable, выделяющий списки, представляющие правильно построенные слоги в соответствии с приведенными правилами.
Такое построение можно выполнить с помощью ряда функций высокого порядка, конструирующих распознаватели для альтернатив и цепочек из понятий, к которым сводится определение грамматики языка. Предполагается, что каждому правилу будет соответствовать свой распознающий предикат. Для простоты ограничимся случаями из пар альтернатив и двухзвенных цепочек.
Пусть тексты этого языка представляются списками из однобуквенных атомов A и B. Допустим, имеются предикаты is-A и is-B, выделяющие одноэлементные списки (A) и (B), соответственно.
(DEFUN is-a (x)(COND ((EQ(CAR x) 'a)
(null (CDR x))) ))
; распознаватель A
(DEFUN is-b (x)(COND ((EQ(CAR x) 'b)
(null (CDR x))) ))
; распознаватель BТиповые ранги этих функций одинаковы: List (X) -> Bool. Таким же должен быть и ранг результирующей функции is-syllable. При ее построении будет применена вспомогательная функция более высокого порядка is-alt, которая из произвольных предикатов конструирует новый предикат, перебирающий варианты правил и выдающий NIL, если ни одно из них не подходит. Функция is-alt может быть определена следующим образом:
(DEFUN is-alt (p q)
; конструктор распознавателя альтернатив
#'(LAMBDA (x)
(COND ((funcall p x )T)
((funcall q x) T)
(T NIL))))(List(X)->Bool List(X))->Bool ) )-> List(X))->Bool
Можно использовать эквивалент:
(DEFUN is-alt (p q)
#'(LAMBDA (x)
(if (funcall p x) T (funcall q x))
)Предикат both, работающий как логическая связка "и", можно реализовать как обычную функцию с типовым рангом (Bool Bool) -> Bool.
(DEFUN both (x y) (COND ( x y)(T NIL)) ) ; проверка одновременности условий
Еще одна вспомогательная функция высокого порядка is-chain из произвольных предикатов конструирует новый предикат, выясняющий, не выделяют ли исходные предикаты смежные звенья цепочки. Типовый ранг этой функции должен быть таким же, как у is-alt, т.к. их результаты используются при разборе и анализе текста в одинаковых позициях.
(DEFUN is-chain (p q) #'(LAMBDA (x )
; конструктор распознавателя цепочек
(COND ((null x) (both (funcall p x)
(funcall q NIL)) )
; пустая цепочка
((both (funcall p x) (funcall q NIL)) T)
; префикс без суффикса
((both (funcall p NIL) (funcall q x)) T)
; суффикс без префикса
((both (funcall p (CONS (CAR x)NIL))
(funcall q (CDR x)) ) T)
; допустимое разбиение
(T(funcall (is-chain (LAMBDA(y)(funcall p(CONS(CAR x)y)))
q )
( CDR x) ))
; сдвиг границы разбиения вправо
)))Из данного распознавателя is-a можно бы и без функций высших порядков построить распознаватель is-a-gr, распознающий группу из любого числа символов A:
(defun is-a-gr (x ) (if x ; распознаватель цепочек из A (cond ((eq (car x) 'a) (is-a-tl (cdr x)) ) ; <а-гр> ::= А | А <а-гр> (t nil) ) Nil)) (defun is-a-tl (x)(cond ((null x)T)((eq (car x)'A)(is-a-tl (cdr x )) )))) ; хвост цепочки из A
Но использование конструкторов is-alt и is-chain, показанное на примере распознавателя is-b-gr, позволяет построить определение, синтаксически подобное правилу грамматики:
(DEFUN is-b-gr (x ) (funcall (is-alt #'is-b is-chain #'is-b #'is-b-gr)) x )) ; распознаватель цепочек из B ; <в-гр> ::= В | В <в-гр>
Теперь опробованные приемы конструирования распознавателей применяем к построению функции is-syllable, активно опираясь на чисто внешнее, синтаксическое подобие определению заданной грамматики:
(DEFUN is-syllable (x )
; распознаватель слога
(funcall (is-alt (is-chain #'is-b-gr #'is-a-gr)
; слог вида BA
(is-alt (is-chain #'is-a-gr #'is-b-gr)
; слог вида AB
(is-chain #'is-b-gr (is-chain #'is-a-gr #'is-b-gr))
; слог вида BAB
) ) x ))
(is-syllable '(a b))
(is-syllable '(b a))
(is-syllable '(b a b ))
(is-syllable '(b b b b a a b b ))Сопоставляя правила и полученное определение распознавателя, можно убедиться, что собственно конструирование распознавателя осуществляется и модернизируется сравнительно быстро: достаточно свести распознаваемый язык к композиции альтернатив и цепочек.
Результат сопоставления показывает, что достигнуто синтаксическое подобие определения грамматики и построенного распознавателя. Это значит, что определение можно автоматически отобразить в такой распознаватель . Отображение — функция высокого порядка, вырабатывающая в качестве результата распознаватель языка, порождаемого исходной грамматикой.
