Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gitcordier/reversepolishnotationparser
Parses then computes RPN expressions. Iterative algorithm, not the naive one! Problem originated from http://codingdojo.org/kata/. Further reading at https://en.wikipedia.org/wiki/Reverse_Polish_notation
https://github.com/gitcordier/reversepolishnotationparser
codingdojo parser parsing reverse-polish-notation rpn rpn-calculator rpn-expressions
Last synced: 8 days ago
JSON representation
Parses then computes RPN expressions. Iterative algorithm, not the naive one! Problem originated from http://codingdojo.org/kata/. Further reading at https://en.wikipedia.org/wiki/Reverse_Polish_notation
- Host: GitHub
- URL: https://github.com/gitcordier/reversepolishnotationparser
- Owner: gitcordier
- License: mit
- Created: 2019-04-02T13:37:58.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2020-07-23T21:07:41.000Z (over 4 years ago)
- Last Synced: 2024-11-06T01:50:41.379Z (about 2 months ago)
- Topics: codingdojo, parser, parsing, reverse-polish-notation, rpn, rpn-calculator, rpn-expressions
- Language: Python
- Homepage:
- Size: 18.6 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# RPN
## What is implemented
Package rpn encloses an implementation of computation after the RPN (Reverse
Polish Notation, or 'postfixed notation') norm (
see http://codingdojo.org/kata/RPN/).We aim at mimicking what a human does as it reads a RPN expression.
For instance, '1 2 + 3 +' reads off '3 3 +', which means '3 + 3' in regular
notation.
The algorithm is then iterative, straightforward, and naive:
There are no stack-like abstractions, nor recursive calls.Human-readable structures (namely, dictionaries) were preferred.
In other words, figures like x[i][1] are discarded in favor of the more
self-explanatory x[i]['value'].## Package Structure
### rpn
The core package is rpn, which encloses the routine script rpn.py.
When run, main.py loads rpn.py and eventually displays a famous numerical
result, computed from RPN expressions ([further reading here](https://en.wikipedia.org/wiki/Taxicab_number )).### test_rpn
test_rpn encloses test_rpn.py, which is a unittest script.
Two inputs are given:
1. input_comfirm.json (in ./inputs): The results to comfirm.
2. input_refute.json (in ./inputs): The results to refute.
Those values are intentionally wrong. Any match is then an evidence that the
implementation is flawed. Moreover, it may reveal where the bug is.Symmetrically, two outputs are given:
1. putput_comfirm_errors.json (in ./outputs): Keeps track of results that could
not be comfirmed.
2. output_refute_erros.json (in ./outputs): Keeps track of various
miscomputations.## About the math
Let us stress that numbers are indentified with constant (0-ary) operators.
This means that A = A(B, C, …) given any list (A, B, C, …) of numbers.In terms of RPN, this means that any list of constants '… Z … C B A' reads off
'A'.## Code conventions
We wanted the _if_, _elif_ pattern to emulate the switch one. So, this is why we
wrote **if**, **elif**, …, **elif**, **else**. We believe that repeatedly
writing 'else: pass' is worth the clarity benefit: Sticking to this
convention makes some room for debugging and further improvements.## TODOS
Enrich and organize the input json files. For example, enlist expressions and
all suitable operand permutations (could be done with itertools), in order to
prove that the parsing is stable under such permutation (e.g ' 1 2 3 + + '
must be shown as equivalent to '1 3 2 + +', ' 2 1 3 + + ', and so on).