rpn/README.md
2017-05-25 18:56:27 +02:00

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