hp/README.md

67 lines
2.2 KiB
Markdown
Raw Normal View History

2023-06-09 20:52:22 +01:00
# hp
2023-06-09 21:04:57 +01:00
## Command-line calculator
This is an *rpn* calclulator with a maximum stack size of 5. It has full support for real and complex numbers
and will calculate summary statistics for a set of reals of real pairs. Spaces are important since they are used
to distinguish tokens.
## Building
The source code is written in *Fortran*. The only compilers I've found that will build it are *ifort* and *ifx* from Intel's
OneApi suite. Makefiles are provides for GNU make (Linux) and nmake (Windows).
```
hp -h
Command Calculator
==================
Introduction
------------
This is a command-line calculator. It supports both real and complex modes, as well
as degrees/radians selection and precision control. It can be run interactively or as an
expression parser. This help is deliberately terse to encourage exploration.
-------------------------------------------------------------------------------
Operators: + - * / ^ ^/x ^x ^2 ^/2 ^3 ^/3 ^*2 ^*10 || ! %
Constants: pi e g G c two_pi pi_over_2
Functions: sin cos tan asin acos atan sinh cosh tanh log2 log lg len sq sqrt cb cbrt
alog2 alog alog10 gamma ncr npr rem int nint
Controls: fix[0-9] clx cl cla
Modes: real complex verbose terse degrees radians
Memories: n=0...9 st<n> sw<n> rc<n> cl<n> m<n>+ m<n>- m<n>* m<n>/ msh
Complex: ri _ || to_pol to_cart
Actions: 1/ -- R r ? > < split drop
Stats: { x1 x2 ... } { x1,y1 x2,y2 ... }
n ux sx mx lqx uqx uy sy my lqy uqy a b cov corr
Quits: q
-------------------------------------------------------------------------------
Examples
--------
hp "fix2 18 2 - 8 2 / * =" -> 64.00
hp "2 -- complex sqrt =" -> (0.00000,-1.414214)
hp -c "radians (1,pi_over_2)p ^ * degrees =" -> (1.000000,180.000000) p
```
2023-06-09 19:25:34 -04:00
## Build and Test with FPM
To build with fpm(1)
( as described at [Fortran Package Manager](https://github.com/fortran-lang/fpm) )
enter:
```bash
git clone https://github.com/sgeard/hp.git
cd hp
fpm test
fpm run
```
or just list it as a dependency in your fpm.toml project file.
```toml
[dependencies]
hp = { git = "https://github.com/sgeard/hp.git" }
```