/precedence-parser

PEMDAS (or, more correctly, PEDMSA) parser

Primary LanguageScheme

PEMDAS Parser

The inventor's paradox is that often a general solution is easier than a specific solution. So I implemented a general order-of-precedence parser that takes in a list of symbols, a list of commands, and a string. It splits the string recursively by each symbol in the list, forming a tree of commands. It also parses the leafs as numbers.

During implementation, I discovered that PEMDAS is a lie! If we group multiplication before division we get this:

$$ 2 × 3 / 4 × 5 = (2 × 3) / (4 × 5) $$

Instead of the correct version:

$$ 2 × 3 / 4 × 5 = 2 × ( 3 / 4) × 5 $$

So the correct order of precedence is actually PEDMSA along with a left-to-right rule on division and a right-to-left rule on exponentiation.

Testing

You can run tests using

make test

or

guile -l precedence-parser.scm -c '(test)'