3 pc \- programmer's calculator
11 is an arbitrary precision calculator with a special emphasis on supporting two's complement bit operations and working with different number bases.
14 reads input statements which are either expressions or control statements.
15 Multiple statements in one line can be separated by semicolons.
17 prints the value of all expressions that are not terminated by a semicolon.
20 can be run non-interactively by using the
22 switch. In this case no input prompt is printed.
24 Expressions can use the C-like operators
26 .B + - * ** \fR(exponentiation\fR)
28 .B / % \fR(Euclidean division, by default\fR)
32 .B "&& || \fR(returning the second argument, if appropriate)"
36 Variables can be defined using
40 always refers to the last printed result.
42 Numbers can use the prefixes
52 in numbers can be added for readability and is ignored.
54 .TF \fIcat(a0,n0,...,aN,nN)
57 Display \fIn\fR in binary.
60 Display \fIn\fR in octal.
63 Display \fIn\fR in decimal.
66 Display \fIn\fR in hexadecimal.
69 Absolute value of \fIn\fR.
72 \fIn\fR rounded to the nearest multiple of \fIm\fR.
73 Numbers exactly halfway between are rounded to the next even multiple.
76 \fIn\fR rounded down to the next multiple of \fIm\fR.
79 \fIn\fR rounded up to the next multiple of \fIm\fR.
82 \fIn\fR truncated to \fIm\fR bits.
85 \fIn\fR truncated to \fIm\fR bits, with the highest bit interpreted as a sign bit.
88 \fIn\fR truncated to \fIm\fR bits, with the order of bits reversed.
91 The minimum number of bits required to represent \fIn\fR as an unsigned number.
94 The minimum number of bits required to represent \fIn\fR as an signed number.
96 .I cat(a\d\s70\s10\u,n\d\s70\s10\u,...,a\d\s7N\s10\u,n\d\s7N\s10\u)
97 Truncate each of the \fIa\d\s7i\s10\u\fR arguments to \fIn\d\s7i\s10\u\fR bits and concatenate their binary representation.
100 The greatest common divisor of \fIn\fR and \fIm\fR.
103 The inverse of \fIn\fR mod \fIm\fR.
106 A random number satisfying 0 ≤ \fIrand(n)\fR < \fIn\fR.
107 .SS Control statements
109 Control statements are always evaluated with default input base 10.
112 If \fIn\fR ≠ 0, insert
114 in all printed numbers, every
119 Set the default input base to \fIn\fR (default 10).
120 The input base can always be overriden by the base prefixes defined above.
123 Set the output base to \fIn\fR.
124 If \fIn\fR = 0 (default), print each number in the base it was input in.
127 Use Euclidean division (default).
128 \fIa\fR / \fIb\fR is rounded towards ±∞ (opposite sign as \fIb\fR).
129 \fIa\fR % \fIb\fR is always non-negative.
132 Use truncating division (same as C).
133 \fIa\fR / \fIb\fR is rounded towards zero.
134 \fIa\fR % \fIb\fR can be negative.
141 With the input base set to 16, terms such as
144 They are interpreted as numbers only if there is no function or variable of the same name.
145 To force interpretation as a number, use the \fL0x\fR prefix.
147 Arbitrary bases should be supported, but are not supported by the
152 first appeared in 9front (August, 2016).