first commit
This commit is contained in:
commit
52ec9c241e
26 changed files with 372 additions and 0 deletions
20
README.md
Normal file
20
README.md
Normal file
|
@ -0,0 +1,20 @@
|
|||
# HP-42S RPN Programs
|
||||
|
||||
These are my RPN programs to be used with the HP-42S scientific calculator.
|
||||
As I do not own the original calculator, the programs also run on
|
||||
[Free42](http://thomasokken.com/free42/) and the
|
||||
[Swissmicros DM42](https://www.swissmicros.com/dm42.php).
|
||||
|
||||
Notes on the usage might be found in each directory.
|
||||
|
||||
The directories also contain .raw files which are the binaries.
|
||||
This is not the git-way but rather useful and I'll give my best to keep them in
|
||||
sync.
|
||||
|
||||
Compilation is done with [Swissmicros' Online Converter](https://www.swissmicros.com/dm42/decoder/)
|
||||
|
||||
## License
|
||||
Most of the programs (the ones I made) are licensed under **GNU GPLv3**.
|
||||
Some programs were contributed by others and are stored here for convenience.
|
||||
If so, this is mentioned in a local readme and the program is subject to
|
||||
whatever the original author prefers.
|
34
base/README.md
Normal file
34
base/README.md
Normal file
|
@ -0,0 +1,34 @@
|
|||
This is the base conversion program contributed by Ton van de Burgt to the
|
||||
[Free42 Software Collection](http://thomasokken.com/free42/42progs/index.html)
|
||||
|
||||
---
|
||||
|
||||
# Base
|
||||
A program for viewing several bases together.
|
||||
|
||||
## Usage
|
||||
![Usage](images/image001.gif)
|
||||
|
||||
The program shows the ASCII character, the Hexadecimal value, the Decimal value and the Binary value.
|
||||
The maximum value of the word is 1 byte: "FF" in Hex, 255 in Dec, 1111.1111 in Bin.
|
||||
- Pressing [ASCII] you can enter a new ASCII value
|
||||
- Pressing [HEX] you can enter a new Hexadecimal value
|
||||
- Pressing [DEC] you can enter a new Decimal value
|
||||
- Pressing [BIN] you can enter a new Binary value
|
||||
|
||||
## Example
|
||||
Press [ASCII] and enter a "Q":
|
||||
|
||||
![Example 2](images/image002.gif)
|
||||
|
||||
Press [R/S] and the several bases are displayed:
|
||||
|
||||
![Example 3](images/image003.gif)
|
||||
|
||||
Press [HEX] and enter "15"
|
||||
|
||||
![Example 4](images/image004.gif)
|
||||
|
||||
Press [R/S] and the several bases are displayed:
|
||||
|
||||
![Example 5](images/image005.gif)
|
BIN
base/base.raw
Normal file
BIN
base/base.raw
Normal file
Binary file not shown.
75
base/base.txt
Normal file
75
base/base.txt
Normal file
|
@ -0,0 +1,75 @@
|
|||
00 { 181-Byte Prgm }
|
||||
01▸LBL "BASE"
|
||||
02▸LBL 00
|
||||
03 255
|
||||
04 AND
|
||||
05 STO "WORD"
|
||||
06 CLMENU
|
||||
07 "ASCII"
|
||||
08 KEY 1 XEQ 01
|
||||
09 "HEX"
|
||||
10 KEY 2 XEQ 02
|
||||
11 "DEC"
|
||||
12 KEY 3 XEQ 03
|
||||
13 "BIN"
|
||||
14 KEY 4 XEQ 04
|
||||
15 KEY 9 GTO 09
|
||||
16 " "
|
||||
17 XTOA
|
||||
18 10
|
||||
19 X<>Y
|
||||
20 X=Y?
|
||||
21 "LF"
|
||||
22 ├" "
|
||||
23 256
|
||||
24 +
|
||||
25 HEXM
|
||||
26 ARCL ST X
|
||||
27 ├" "
|
||||
28 744
|
||||
29 +
|
||||
30 AIP
|
||||
31 ├" "
|
||||
32 LASTX
|
||||
33 -
|
||||
34 BINM
|
||||
35 ARCL ST X
|
||||
36 4
|
||||
37 AROT
|
||||
38 ATOX
|
||||
39 4
|
||||
40 AROT
|
||||
41 ATOX
|
||||
42 5
|
||||
43 AROT
|
||||
44 ATOX
|
||||
45 8
|
||||
46 AROT
|
||||
47 AVIEW
|
||||
48 MENU
|
||||
49 RCL "WORD"
|
||||
50 STOP
|
||||
51 GTO 00
|
||||
52▸LBL 01
|
||||
53 CLA
|
||||
54 RCL "WORD"
|
||||
55 XTOA
|
||||
56 AON
|
||||
57 STOP
|
||||
58 AOFF
|
||||
59 ATOX
|
||||
60 RTN
|
||||
61▸LBL 02
|
||||
62 HEXM
|
||||
63 GTO 05
|
||||
64▸LBL 03
|
||||
65 DECM
|
||||
66 GTO 05
|
||||
67▸LBL 04
|
||||
68 BINM
|
||||
69▸LBL 05
|
||||
70 INPUT "WORD"
|
||||
71 RTN
|
||||
72▸LBL 09
|
||||
73 EXITALL
|
||||
74 END
|
BIN
base/images/image001.gif
Normal file
BIN
base/images/image001.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.8 KiB |
BIN
base/images/image002.gif
Normal file
BIN
base/images/image002.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.6 KiB |
BIN
base/images/image003.gif
Normal file
BIN
base/images/image003.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.8 KiB |
BIN
base/images/image004.gif
Normal file
BIN
base/images/image004.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.7 KiB |
BIN
base/images/image005.gif
Normal file
BIN
base/images/image005.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.8 KiB |
19
brewery/README.md
Normal file
19
brewery/README.md
Normal file
|
@ -0,0 +1,19 @@
|
|||
# Brewery calculations
|
||||
|
||||
## SPND - Spundungsdruck
|
||||
This is a **solver-program** to calculate the carbonization pressure according
|
||||
to this formula:
|
||||
```
|
||||
2617.25
|
||||
(- 10.73797) + ----------
|
||||
t + 273.15
|
||||
c(p, t) := (p + 1.013) %e 10
|
||||
```
|
||||
|
||||
c: CO₂ concentration in g/l
|
||||
p: Carbonization gauge pressure in bar
|
||||
ϑ: Temperature in °C
|
||||
|
||||
https://elfring.ms/blog/rpn-karbonisierungsrechner
|
||||
|
||||
|
BIN
brewery/spund.raw
Normal file
BIN
brewery/spund.raw
Normal file
Binary file not shown.
22
brewery/spund.txt
Normal file
22
brewery/spund.txt
Normal file
|
@ -0,0 +1,22 @@
|
|||
00 { 77-Byte Prgm }
|
||||
01▸LBL "SPND"
|
||||
02 MVAR "bar"
|
||||
03 MVAR "°C"
|
||||
04 MVAR "g/l"
|
||||
05 2617.25
|
||||
06 273.15
|
||||
07 RCL "°C"
|
||||
08 +
|
||||
09 ÷
|
||||
10 10.73797
|
||||
11 -
|
||||
12 E↑X
|
||||
13 RCL "bar"
|
||||
14 1.013
|
||||
15 +
|
||||
16 ×
|
||||
17 10
|
||||
18 ×
|
||||
19 RCL "g/l"
|
||||
20 -
|
||||
21 END
|
21
diving/README.md
Normal file
21
diving/README.md
Normal file
|
@ -0,0 +1,21 @@
|
|||
# Calculations for Diving
|
||||
|
||||
> Please note:
|
||||
> As diving is potentially dangerous, please be sensible and verify the
|
||||
> calculations on your own.
|
||||
|
||||
## MOD
|
||||
Maximum-Operating-Depth for nitrox
|
||||
|
||||
1. Enter the percentage of oxygen in the gas.
|
||||
2. Execute the program.
|
||||
3. Get the MOD in meters for the O₂-pressures of 1,4 and 1,6 bar.
|
||||
|
||||
## NTRX - Nitrox
|
||||
This is a **solver-program** for the general nitrox formula:
|
||||
```
|
||||
PO₂ x 10
|
||||
EAN = ---------- x 100
|
||||
D + 10
|
||||
```
|
||||
|
BIN
diving/mod.raw
Normal file
BIN
diving/mod.raw
Normal file
Binary file not shown.
25
diving/mod.txt
Normal file
25
diving/mod.txt
Normal file
|
@ -0,0 +1,25 @@
|
|||
00 { 64-Byte Prgm }
|
||||
01▸LBL "MOD"
|
||||
02 100
|
||||
03 ÷
|
||||
04 STO 01
|
||||
05 1.4
|
||||
06 RCL 01
|
||||
07 ÷
|
||||
08 1
|
||||
09 -
|
||||
10 10
|
||||
11 ×
|
||||
12 "MOD1,4= "
|
||||
13 ARCL ST X
|
||||
14 1.6
|
||||
15 RCL 01
|
||||
16 ÷
|
||||
17 1
|
||||
18 -
|
||||
19 10
|
||||
20 ×
|
||||
21 ├"[LF]MOD1,6= "
|
||||
22 ARCL ST X
|
||||
23 AVIEW
|
||||
24 END
|
BIN
diving/nitrox.raw
Normal file
BIN
diving/nitrox.raw
Normal file
Binary file not shown.
18
diving/nitrox.txt
Normal file
18
diving/nitrox.txt
Normal file
|
@ -0,0 +1,18 @@
|
|||
00 { 46-Byte Prgm }
|
||||
01▸LBL "NTRX"
|
||||
02 MVAR "D"
|
||||
03 MVAR "Pp"
|
||||
04 MVAR "EAN"
|
||||
05 RCL "D"
|
||||
06 10
|
||||
07 ÷
|
||||
08 1
|
||||
09 +
|
||||
10 RCL "EAN"
|
||||
11 100
|
||||
12 ÷
|
||||
13 ×
|
||||
14 RCL "Pp"
|
||||
15 -
|
||||
16 END
|
||||
|
6
microwave/README.md
Normal file
6
microwave/README.md
Normal file
|
@ -0,0 +1,6 @@
|
|||
# MWVE - Microwave
|
||||
A little helper for the microwave oven.
|
||||
|
||||
Enter wattage and time for something to cook.
|
||||
The program will return an available powerlevel (from MY oven) and an adjusted time.
|
||||
The time is entered in mm,ss
|
BIN
microwave/mwve.raw
Normal file
BIN
microwave/mwve.raw
Normal file
Binary file not shown.
44
microwave/mwve.txt
Normal file
44
microwave/mwve.txt
Normal file
|
@ -0,0 +1,44 @@
|
|||
00 { 133-Byte Prgm }
|
||||
01▸LBL "MWVE"
|
||||
02 INPUT "Watt"
|
||||
03 INPUT "Zeit"
|
||||
04 →HR
|
||||
05 STO "Zeit"
|
||||
06 100
|
||||
07 STO 00
|
||||
08 RCL "Watt"
|
||||
09 270
|
||||
10 X≤Y?
|
||||
11 STO 00
|
||||
12 RCL "Watt"
|
||||
13 300
|
||||
14 X≤Y?
|
||||
15 STO 00
|
||||
16 RCL "Watt"
|
||||
17 440
|
||||
18 X≤Y?
|
||||
19 STO 00
|
||||
20 RCL "Watt"
|
||||
21 600
|
||||
22 X≤Y?
|
||||
23 STO 00
|
||||
24 RCL "Watt"
|
||||
25 950
|
||||
26 X≤Y?
|
||||
27 STO 00
|
||||
28 RCL "Watt"
|
||||
29 RCL 00
|
||||
30 ÷
|
||||
31 RCL "Zeit"
|
||||
32 ×
|
||||
33 "t= "
|
||||
34 →HMS
|
||||
35 0.01
|
||||
36 ×
|
||||
37 ATIME
|
||||
38 RCL 00
|
||||
39 ├"[LF]P= "
|
||||
40 AIP
|
||||
41 ├"W"
|
||||
42 AVIEW
|
||||
43 END
|
34
split/README.md
Normal file
34
split/README.md
Normal file
|
@ -0,0 +1,34 @@
|
|||
# SPLIT - Split expenditures among people
|
||||
Several people of a group had different expenses.
|
||||
The expenditures shall be shared among the whole group.
|
||||
|
||||
## Usage
|
||||
* Create a 1xN matrix where N is the number of people.
|
||||
* Enter the expenses into the matrix.
|
||||
* Execute this program.
|
||||
* Z will conatin the sum.
|
||||
* Y will contain amount per person.
|
||||
* X will contain a matrix with the compensation cashflow.
|
||||
|
||||
## Annotation
|
||||
```
|
||||
LBL "SPLIT"
|
||||
STO "m"
|
||||
RSUM ─┐ Store the sum of the whole row
|
||||
DET │ It is returned as a 1x1 matrix, the DET will be a scalar
|
||||
STO 01 ─┘
|
||||
RCL "m"
|
||||
DIM? The X-DIM of the matrix is the number of elements, DIM? returns into X, Y
|
||||
RCL 01 ─┐
|
||||
X<>Y │ Sum / number = amount per person
|
||||
÷ ─┘
|
||||
STO 02 Store the amount per person
|
||||
RCL 01 RCL the Sum to have it in Z later on
|
||||
X<>Y Get the amount per person back into X (Could also be RCL 02)
|
||||
RCL "m" ─┐
|
||||
X<>Y │ Matrix - amount p.p. = matrix with comp. cashflow
|
||||
- ─┘
|
||||
RCL 02 ─┐ Put the amount p.p. into Y
|
||||
X<>Y ─┘
|
||||
END
|
||||
```
|
BIN
split/split.raw
Normal file
BIN
split/split.raw
Normal file
Binary file not shown.
20
split/split.txt
Normal file
20
split/split.txt
Normal file
|
@ -0,0 +1,20 @@
|
|||
00 { 35-Byte Prgm }
|
||||
01▸LBL "SPLIT"
|
||||
02 STO "m"
|
||||
03 RSUM
|
||||
04 DET
|
||||
05 STO 01
|
||||
06 RCL "m"
|
||||
07 DIM?
|
||||
08 RCL 01
|
||||
09 X<>Y
|
||||
10 ÷
|
||||
11 STO 02
|
||||
12 RCL 01
|
||||
13 X<>Y
|
||||
14 RCL "m"
|
||||
15 X<>Y
|
||||
16 -
|
||||
17 RCL 02
|
||||
18 X<>Y
|
||||
19 END
|
16
statitics/README.md
Normal file
16
statitics/README.md
Normal file
|
@ -0,0 +1,16 @@
|
|||
# Statistics Tools
|
||||
|
||||
## SnCk
|
||||
Sum of combinations.
|
||||
The usual nCk function returns the number of combinations for k elements out of n.
|
||||
This program sums up the combinations for 1 .. k out of n.
|
||||
|
||||
```
|
||||
k
|
||||
====
|
||||
\ 1
|
||||
n! > -----------
|
||||
/ k! (n - k)!
|
||||
====
|
||||
k = 1
|
||||
```
|
BIN
statitics/SnCk.raw
Normal file
BIN
statitics/SnCk.raw
Normal file
Binary file not shown.
18
statitics/SnCk.txt
Normal file
18
statitics/SnCk.txt
Normal file
|
@ -0,0 +1,18 @@
|
|||
00 { 40-Byte Prgm }
|
||||
01▸LBL "ΣnCk"
|
||||
02 0
|
||||
03 STO 00
|
||||
04 INPUT "n"
|
||||
05 INPUT "k"
|
||||
06▸LBL 06
|
||||
07 RCL "n"
|
||||
08 RCL "k"
|
||||
09 COMB
|
||||
10 STO+ 00
|
||||
11 1
|
||||
12 STO- "k"
|
||||
13 RCL "k"
|
||||
14 X>0?
|
||||
15 GTO 06
|
||||
16 RCL 00
|
||||
17 END
|
Loading…
Add table
Reference in a new issue