10 KiB
rpn v2.2- reference manual
rpn
- is a math-oriented language inspired by Hewlett-Packard Reverse Polish Lisp (HP28S user manual is provided as a reference), it includes at least stack, store, branch, test, trig and logs commands
- is implemented as a a command-line calculator for GNU/Linux
- brings powerfull calculation facilities on floating point numbers with arbitrary precision, provided by GNU MP and GNU MPFR libraries
- uses that so cool reverse polish notation
Quick examples
easy calculation with stacked results
rpn> 1 2 +
3
rpn> 2 sqrt
2> 3
1> 1.4142135623730950488
programs and variables
rpn> << rot * swap 2 / neg dup sq rot - sqrt >> 'quadratic_solution' sto
rpn> 1 2 -3 quadratic_solution
2> -1
1> 2
rpn> vars
var 1: name 'quadratic_solution', type program, value << rot * swap 2 / chs dup sq rot - sqrt >>
local variables
rpn> << -> x y << x y + ln >> >> 'P' sto
rpn> 1 2 P
rpn> 1.0986122886681096914
arbitrary precision
Precision can be really high, up to 0x7FFFFFFFFFFFFFFF bits with GNU MPFR
rpn> 256 prec
rpn> pi
3.1415926535897932384626433832795028841971693993751058209749445923078164062862
rpn>
Objects
Following objects are managed: floating numbers, complexes, symbols, strings, programs, plus language keywords (commands and flow controls)
5> (1,-2.33)
4> 'symbol'
3> "string"
2> 12.3456
1> << -> n << 0 1 n for i i 2 * inv + next >> >>
rpn>
Command line
rpn is a cli interface with an interactive editor with autocompletion provided by linenoise-ng, see https://github.com/arangodb/linenoise-ng
rpn>
Display all 142 possibilities? (y or n)
nop test neg sq %CH ip arg sci < not rot rolld pos for unti purge sto/ asin e log2 tanh
? version * sqr mod fp c->r prec <= same dup over sub next while vars sneg cos ln alog2 atanh
h uname / abs fact min r->c round != swap dup2 ->str if step whil clusr sinv acos log exp2
help history inv dec mant max p->r default == drop dupn str-> then ift repeat edit eval tan exp sinh
q + ^ hex xpon re r->p type and drop2 pick chr else ifte repea sto+ -> atan log10 asinh
quit - pow sign floor im std > or dropn depth num end do sto sto- pi d->r alog10 cosh
exit chs sqrt % ceil conj fix >= xor erase roll size start until rcl sto* sin r->d exp10 acosh
keywords
general
keyword | description |
---|---|
nop |
no operation |
help|h|? |
this help message |
quit|q|exit |
quit software |
version |
show rpn version |
uname |
show rpn complete identification string |
history |
see commands history |
usual operations - real and complex
keyword | description |
---|---|
+ |
addition |
- |
substraction |
neg|chs |
negation |
* |
multiplication |
/ |
division |
inv |
inverse |
^|pow |
power |
sqrt |
square root |
sq|sqr |
square |
abs |
absolute value for a number or sqrt(re*re+im*im) for a complex |
dec |
decimal representation |
hex |
hexadecimal representation |
sign |
sign of a real, unary vector in the same direction for a complex |
operations on reals
keyword | description |
---|---|
% |
purcent |
%CH |
inverse purcent |
mod |
modulo |
fact |
n! for integer n or Gamma(x+1) for fractional x |
mant |
mantissa of a real number |
xpon |
exponant of a real number |
floor |
largest number <= |
ceil |
smallest number >= |
ip |
integer part |
fp |
fractional part |
min |
min of 2 real numbers |
max |
max of 2 real numbers |
operations on complexes
keyword | description |
---|---|
re |
complex real part |
im |
complex imaginary part |
conj |
complex conjugate |
arg |
complex argument in radians |
r->p |
rectangular to polar coordinates |
p->r |
polar to rectangular coordinates |
r->c |
transform 2 reals in a complex |
c->r |
transform a complex in 2 reals |
mode
keyword | description |
---|---|
std |
standard floating numbers representation. ex: std |
fix |
fixed point representation. ex: 6 fix |
sci |
scientific floating point representation. ex: 20 sci |
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. Authorized values are: ["nearest" | "toward zero" | "toward +inf" | "toward -inf" | "away from zero"] round. ex: "nearest" round` |
default |
set float representation and precision to default |
type |
show type of stack first entry |
test
keyword | description |
---|---|
> |
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
keyword | description |
---|---|
swap |
swap 2 first stack entries |
drop |
drop first stack entry |
drop2 |
drop 2 first stack entries |
dropn |
drop n 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 |
dupn |
duplicate n first stack entries |
pick |
push a copy of the given stack level onto the stack |
depth |
give stack depth |
roll |
move a stack entry to the top of the stack |
rolld |
move the element on top of the stack to a higher stack position |
over |
push a copy of the element in stack level 2 onto the stack |
string
keyword | description |
---|---|
->str |
convert an object into a string |
str-> |
convert a string into an object |
chr |
convert ASCII character code in stack level 1 into a string |
num |
return ASCII code of the first character of the string in stack level 1 as a real number |
size |
return the length of the string |
pos |
seach for the string in level 1 within the string in level 2 |
sub |
return a substring of the string in level 3 |
branch
keyword | description |
---|---|
if |
if (test-instruction) then (true-instructions) else (false-instructions) end |
then |
used with if |
else |
used with if |
end |
used with various branch instructions |
ift |
similar to if-then-end: (test-instruction) (true-instruction) ift" |
ifte |
similar to if-then-else-end: (test-instruction) (true-instruction) (false-instruction) ifte" |
start |
(start) (end) start (instructions) next |
for |
(start) (end) for (variable) (instructions) next |
next |
used with start and for |
step |
used with start and for |
do |
do (instructions) until (condition) end |
until|unti |
used with do |
while|whil |
while (test-instruction) repeat (loop-instructions) end |
repeat|repea |
used with while |
store
keyword | description |
---|---|
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 |
clusr |
erase all variables |
edit |
edit a variable content |
sto+ |
add to a stored variable. ex: 1 'name' sto+ 'name' 2 sto+ |
sto- |
substract to a stored variable. ex: 1 'name' sto- 'name' 2 sto- |
sto* |
multiply a stored variable. ex: 3 'name' sto* 'name' 2 sto* |
sto/ |
divide a stored variable. ex: 3 'name' sto/ 'name' 2 sto/ |
sneg |
negate a variable. ex: 'name' sneg |
sinv |
inverse a variable. ex: 1 'name' sinv |
program
keyword | description |
---|---|
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 on reals and complexes
keyword | description |
---|---|
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 on reals and complexes
keyword | description |
---|---|
e |
Euler constant |
ln|log |
logarithm base e |
exp |
exponential |
log10 |
logarithm base 10 |
alog10|exp10 |
exponential base 10 |
log2 |
logarithm base 2 |
alog2|exp2 |
exponential base 2 |
sinh |
hyperbolic sine |
asinh |
inverse hyperbolic sine |
cosh |
hyperbolic cosine |
acosh |
inverse hyperbolic cosine |
tanh |
hyperbolic tangent |
atanh |
inverse hyperbolic tangent |
default
Default float mode is 'std' with 39 digits
Default floating point precision is 128 bits
Default rounding mode is 'nearest'
Tests
-
A set of complete test sheets are given in the test subdirectory. Each version is fully tested before delivery
-
Test sheets syntax is
# cat my_test_sheet.txt ## Test sheet example default erase # test step 1 1 dup 1 + -> stack size should be 2 -> stack should be 1, 2 -> error should be 0 erase # test step 2 2 4 / 0.5 == -> stack should be 1 erase
-
Test sheet can be played with the command
test
rpn> "my_test_sheet.txt" "my_test_sheet.txt" rpn> test my_test_sheet.txt: Test sheet example # test step 1 PASSED # test step 2 PASSED my_test_sheet.txt: run 2 tests: 2 passed, 0 failed (4 steps: 4 passed, 0 failed) Total: run 2 tests: 2 passed, 0 failed (4 steps: 4 passed, 0 failed) rpn>
-
Please follow these rules to write correct test sheets:
-
make the test sheet begin by
default erase
-
the 3 existing tests are
-> stack size should be (number)
-> stack should be (values separated by commas)
-> error should be (error number)
-
put a command
erase
after each test step -
test output is done on stdout and is not stacked in rpn.
-