A-қалыпты формасы - A-normal form

Жылы Информатика, A-қалыпты формасы (қысқартылған ANF) болып табылады аралық өкілдік туралы бағдарламалар жылы функционалды компиляторлар Сабри және Фелизен 1992 ж[1] қарапайым балама ретінде жалғасу стилі (CPS). CPS-ті аралық ұсыныс ретінде пайдаланудың кейбір артықшылығы - бастапқы тілге қарағанда CPS-тегі бағдарламаларда оңтайландыру оңай, сонымен қатар компиляторлар үшін оларды құру оңайырақ машина коды CPS бағдарламалары үшін. Фланаган және т.б.[2] компиляторлар ANF-ті бір деңгейлік трансформациямен бірдей артықшылықтарға қол жеткізу үшін қалай қолдана алатынын көрсетті; Керісінше, шынайы компиляторлар үшін ҚҚ-ны трансформациялау әдетте қосымша фазаларды қамтиды, мысалы, CPS терминдерін жеңілдету.

ANF-де барлығы дәлелдер а функциясы болмашы болуы керек. Яғни, әр аргументті бағалау бірден тоқтауы керек.

Бұл мақалада терминдермен көрсетілген негізгі анықтама қарастырылған λ-есептеу әлсіз төмендеуімен және өрнектер, онда шектеу орындалады

  1. тек тұрақтыларға, λ-шарттарға және айнымалыларға функционалды қосымшалардың аргументі бола алады, және
  2. тривиальды емес өрнектің нәтижесін а рұқсат етілген айнымалы немесе функциядан қайтарылған.

Грамматика

Келесісі BNF грамматика таза сипаттайды λ-есептеу ANF ​​шектеулерін қолдау үшін өзгертілген:

EXP ::= VAL | EXP | -де VAR = VAL болсын VAR = VAL VAL EXPVAL түрінде болсын ::= VAR | AR VAR. EXP

Компьютерлерде немесе зерттеулерде қолданылатын ANF нұсқалары көбінесе тұрақтыларға, жазбаларға, кортеждерге, көп аргументті функцияларға, қарабайыр операцияларға және шартты өрнектерге мүмкіндік береді.

Мысалдар

Өрнек:

f (g (x), h (y))

ANF-де келесідей жазылады:

v0 = g (x) in v1 = h (y) in f (v0, v1) болсын

Сондай-ақ қараңыз

Әдебиеттер тізімі

  1. ^ Сабри, Амр; Фелизен, Матиас. «Бағдарламалар туралы сабақтар жалғасуда». LFP және функционалды бағдарламалау бойынша 1992 ACM конференциясының материалдары, LFP'92. Сан-Франциско, Калифорния, АҚШ. Сабри 92. Алынған 2020-10-15.
  2. ^ Фланаган, Кормак; Сабри, Амр; Дуба, Брюс Ф.; Фелизен, Матиас. «Жалғасулармен компиляциялаудың мәні» (PDF). Іс жүргізу ACM SIGPLAN 1993 Конф. Бағдарламалау тілін жобалау және енгізу туралы, PLDI'93. Альбукерке, НМ, АҚШ. 933. Алынған 2012-11-16.