Contemporary linguistic theories (in particular, HPSG) are declarative in nature: they specify constraints on permissible structures, not how such structures are to be computed. Grammars designed under such theories are, therefore, suitable for both parsing and generation. However, practical implementations of such theories don't usually support bidirectional processing of grammars. We present a grammar development system that includes a compiler of grammars (for parsing and generation) to abstract machine instructions, and an interpreter for the abstract machine language. The generation compiler inverts input grammars (designed for parsing) to a form more suitable for generation. The compiled grammars are then executed by the interpreter using one control strategy, regardless of whether the grammar is the original or the inverted version. We thus obtain a unified, efficient platform for developing reversible grammars.
[1]
David H. D. Warren,et al.
Definite Clause Grammars for Language Analysis - A Survey of the Formalism and a Comparison with Augmented Transition Networks
,
1980,
Artif. Intell..
[2]
Gregor Erbach,et al.
ProFIT: Prolog with Features, Inheritance and Templates
,
1995,
EACL.
[3]
Carl Pollard,et al.
Parsing Head-Driven Phrase Structure Grammar
,
1985,
ACL.
[4]
Andreas Podelski,et al.
Towards a Meaning of LIFE
,
1991,
J. Log. Program..
[5]
Nissim Francez,et al.
Abstract Machine for Typed Feature Structures
,
1995,
ArXiv.
[6]
Bob Carpenter,et al.
Compiling Typed Attribute-Value Logic Grammars
,
1993,
IWPT.