Skip to content

An implementation of the Earley parser algorithm in TypeScript and in Python

Notifications You must be signed in to change notification settings

sbneelu/earley-parser

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 

Repository files navigation

Earley Parser

An implementation of the Earley parser algorithm in TypeScript and in Python (the TypeScript implementation is cleaner at the moment).

Usage

Python: Use the parse or printParseChart functions from parser.py for a generic parser, or run python3 python/parser.py <sentence to parse> for the toy grammar.

TypeScript: Use the parse or printParseChart functions exported from typescript/parser for a generic parser, or the main() function in typescript/main.ts for the toy grammar.

Toy Grammar

The toy grammar in the toygrammar() / toyGrammar() functions is:

Non-terminals: { S, NP, VP, PP, N, V, P }

Terminals: { can, fish, in, rivers, they, december }

Start symbol: S

Productions:

S -> NP | VP
NP -> N | N PP
PP -> P NP
VP -> V | V NP | V VP | VP PP
N -> can | fish | rivers | they | december
P -> in
V -> fish | can

About

An implementation of the Earley parser algorithm in TypeScript and in Python

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published