4.7 KiB
Reverse Polish Notation language
-
rpn is a reverse polish notation mathematical language, which brings powerfull calculation facilities on floating point number with arbitrary precision
-
The special feature of this language is to make no difference between keywords and functions, even user functions
-
Following objects are managed: floating numbers, symbols, strings, programs, plus language keywords (commands and flow controls)
-
Inspired by Hewlett-Packard RPL language (HP28S user manual is provided as a reference), it includes at least STACK, STORE, BRANCH, TEST, TRIG and LOGS commands of HP28S RPL implementation
-
A GNU-readline-based interactive editor with autocompletion is provided.
Multiple-precision floating-point computations with correct rounding are ensured by MPFR library under LGPL v3
Implemented commands
GENERAL | |
---|---|
nop | no operation |
help | (or h or ?) this help message |
quit | (or q or exit) quit software |
version | show rpn version |
uname | show rpn complete identification string |
type | show type of stack first entry |
default | set float representation and precision to default |
prec | get float precision in bits when first stack is not a number, set float precision in bits when first stack entry is a number. ex: 256 prec |
round | set float rounding mode. Authoerized values are: ["nearest", "toward zero", "toward +inf", "toward -inf", "away from zero"] round . ex: "nearest" round |
REAL | |
---|---|
+ | addition |
- | substraction |
neg | negation |
* | multiplication |
/ | division |
inv | inverse |
% | purcent |
% | CH inverse purcent |
^ | (or pow) power |
sqrt | square root |
sq | (or sqr) square |
mod | modulo |
abs | absolute value |
REAL REPRESENTATION | |
---|---|
dec | decimal representation |
hex | hexadecimal representation |
bin | binary representation |
std | standard floating numbers representation. ex: [25] std |
fix | fixed point representation. ex: 6 fix |
sci | scientific floating point representation. ex: 20 sci |
TEST | |
---|---|
> | binary operator > |
>= | binary operator >= |
< | binary operator < |
<= | binary operator <= |
!= | binary operator != (different) |
== | binary operator == (equal) |
and | boolean operator and |
or | boolean operator or |
xor | boolean operator xor |
not | boolean operator not |
same | boolean operator same (equal) |
STACK | |
---|---|
swap | swap 2 first stack entries |
drop | drop first stack entry |
drop2 | drop 2 first stack entries |
erase | drop all stack entries |
rot | rotate 3 first stack entries |
dup | duplicate first stack entry |
dup2 | duplicate 2 first stack entries |
pick | push a copy of the given stack level onto the stack |
depth | give stack depth |
STRING | |
---|---|
->str | convert an object into a string |
str-> | convert a string into an object |
BRANCH | |
---|---|
if | |
then | |
else | |
end | (end of if structure) |
start | repeat instructions several times |
for | repeat instructions several times with variable |
next | ex: 1 10 start <instructions> next |
step | ex: 1 100 start <instructions> 4 step |
STORE | |
---|---|
sto | store a variable. ex: 1 'name' sto |
rcl | recall a variable. ex: 'name' rcl |
purge | delete a variable. ex: 'name' purge |
vars | list all variables |
edit | edit a variable content |
PROGRAM | |
---|---|
eval | evaluate (run) a program, or recall a variable. ex: 'my_prog' eval |
-> load program local variables. ex: << -> n m << 0 n m for i i + next >> >> |
TRIG | |
---|---|
pi | PI constant |
sin | sinus |
asin | arg sinus |
cos | cosinus |
acos | arg cosinus |
tan | tangent |
atan | arg tangent |
d | ->r convert degrees to radians |
r | ->d convert radians to degrees |
LOGS | |
---|---|
e | exp(0) constant |
log | logarithm base 10 |
alog | (or exp10) exponential base 10 |
log2 | logarithm base 2 |
alog2 | (or exp2) exponential base 2 |
ln | logarithm base e |
exp | exponential |
sinh | hyperbolic sine |
asinh | inverse hyperbolic sine |
cosh | hyperbolic cosine |
acosh | inverse hyperbolic cosine |
tanh | hyperbolic tangent |
atanh | inverse hyperbolic tangent |
Default float mode is 'std' with 20 digits
Default floating point precision is 128 bits
Default rounding mode is 'nearest'
Tests
Unit tests are given as txt files in the test subdirectory.
Use the command 'test' to run a test file, eg
# cd src_directory/
# rpn
rpn> "test/01-all.txt"
rpn> test
## ENTRY TEST
(...)
# real decimal PASSED
# real hex PASSED
# real binary PASSED
(...)
The test output is done on stdout and is not stacked in rpn.
test sheet | description |
---|---|
entry.txt | testing real, binary, symbol, string and program entries |
Notes
Compiled with g++ Makefile generated by automake. External dependencies needed: automake, readline (libreadline-dev), MPFR library, GNU MP library