9.4 BinaryExpansion

All rational numbers have repeating binary expansions. Operations to access the individual bits of a binary expansion can be obtained by converting the value to RadixExpansion(2). More examples of expansions are available in DecimalExpansionXmpPage , HexadecimalExpansionXmpPage , and RadixExpansionXmpPage .

The expansion (of type BinaryExpansion) of a rational number is returned by the binarybinaryBinaryExpansion operation.

r := binary(22/7)
\[\]
11.001‾

Type: BinaryExpansion

Arithmetic is exact.

r + binary(6/7)
\[\]
100

Type: BinaryExpansion

The period of the expansion can be short or long ...

[binary(1/i) for i in 102..106]
\[\]
[0.000000101‾,0.000000100111110001000101100101111001110010010101001‾,0.000000100111011‾,0.000000100111‾,0.00000010011010100100001110011111011001010110111100011‾]

Type: List BinaryExpansion

or very long.

binary(1/1007)
\[\]
0.000000000100000100010100100101111000001111110000101111110010110001111101‾000100111001001100110001100100101010111101101001100000000110000110011110‾111000110100010111101001000111101100001010111011100111010101110011001010‾010111000000011100011110010000001001001001101110010101001110100011011101‾101011100010010000011001011011000000101100101111100010100000101010101101‾011000001101101110100101011111110101110101001100100001010011011000100110‾001000100001000011000111010011110001‾

Type: BinaryExpansion

These numbers are bona fide algebraic objects.

p := binary(1/4)*x^2 + binary(2/3)*x + binary(4/9)
\[\]
0.01x2+0.10‾x+0.011100‾

Type: Polynomial BinaryExpansion

q := D(p, x)
\[\]
0.1x+0.10‾

Type: Polynomial BinaryExpansion

g := gcd(p, q)
\[\]
x+1.01‾

Type: Polynomial BinaryExpansion