Open in Cloud | Download to Desktop via Attachments Below
Briefly, a continued logarithm is an arbitrarily long bit string approximating a real number arbitrarily well, and supports arbitrarily precise bit-at-a-time algorithms for rational functions of these numbers. (See http://www.tweedledum.com/rwg/cfup.htm , p 47+)
A six-bits-per-term $\pi$ series:
Product[MatrixForm@{{512 k^3, 0}, {32 k^3 (-37 + 42 k), (-1 + 2 k)^3}}, {k, ?}] ==
MatrixForm[{{oo ?, 0}, {oo, "?"}}]
data:image/s3,"s3://crabby-images/127e6/127e689580cf3b81d36a049457335b80c5af384c" alt="enter image description here"
Where ? means matrix product, not Mathematica product, and oo is some quantity that blows up with the number of product terms, the same way you compute continued fractions with 2*2 matrices. An incorrect form of this series is derived in https://dspace.mit.edu/handle/1721.1/6088 . We initialize the work matrix m to the first term of the matrix product:
MatrixForm[ m = {{512 k^3, 0}, {32 k^3 (-37 + 42 k), (-1 + 2 k)^3}} /. k -> 1]
data:image/s3,"s3://crabby-images/3f3d8/3f3d8cff96fab9c962a6b923b9e6f5d70243f91e" alt="enter image description here"
This represents the function
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/4f0f7/4f0f79dd1004806851a8248af56eec8f11e0d93e" alt="enter image description here"
where t is the tail of the series, starting with k=2 rather than 1. It should be easy to show that, in general,
3/8/k < t < 3/8/(k + 1)
data:image/s3,"s3://crabby-images/23d53/23d53ef38977ece59775a0775316f2a65fde7b95" alt="enter image description here"
giving bounds
m /. {{t -> 3/8/1.}, {t -> 3/8/2.}}
{3.14754, 3.09677}
Since these both exceed 2, we commence output with
Style[cl@? = {1}, 22]
data:image/s3,"s3://crabby-images/6123d/6123d2fd520644a273ab56b80c84a282c456a7a4" alt="enter image description here"
and left multiply m by the divide-by-2 matrix:
MatrixForm[m = {{1, 0}, {0, 2}}.m]
data:image/s3,"s3://crabby-images/9428d/9428d36ff58fc4db50c62c111893887da1c002ff" alt="enter image description here"
It costs almost nothing to remove the common power of 2:
MatrixForm[m = m/2]
data:image/s3,"s3://crabby-images/585f8/585f80a62413c0253f460c9741a0e0210706f62a" alt="enter image description here"
representing the function
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/3eabf/3eabf25c15784ece9f2bca989c91e15269de20d0" alt="enter image description here"
We still are on input term k=1, and can still use
% /. {{t -> 3/8/1.}, {t -> 3/8/2.}}
{1.57377, 1.54839}
which is smack between 1 and 2, which we celebrate with
Style[AppendTo[cl@?, 0], 22]
data:image/s3,"s3://crabby-images/1f879/1f879a8c952a4fd5d9e2074dbfb89fcdb691a497" alt="enter image description here"
and left multiply m by the subtract-1-and-reciprocate matrix:
(m = {{0, 1}, {1, -1}}.m) // MatrixForm
data:image/s3,"s3://crabby-images/a4011/a40114a86b9564cd33e2d8f47a732f418001af23" alt="enter image description here"
representing
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/8a887/8a88743806e4a8d18759bff7156e145955a6654d" alt="enter image description here"
Again using
% /. {{t -> 3/8/1.}, {t -> 3/8/2.}}
{1.74286, 1.82353}
which dictates another
Style[AppendTo[cl@?, 0], 22]
data:image/s3,"s3://crabby-images/bc4b1/bc4b11399609a2aef240fdf001882aa92242d743" alt="enter image description here"
and
(m = {{0, 1}, {1, -1}}.m) // MatrixForm
data:image/s3,"s3://crabby-images/64515/64515b3790ab83242f4e849cc698e3b7c7dfd00b" alt="enter image description here"
representing
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/debe5/debe53ec7df1d1d500f484d806c7e098a52b48e6" alt="enter image description here"
% /. {{t -> 3/8/1.}, {t -> 3/8/2.}}
{1.34615, 1.21429}
Style[AppendTo[cl@?, 0], 22]
data:image/s3,"s3://crabby-images/c7a34/c7a342771073facb1ee565793a7c318ee9bcf630" alt="enter image description here"
(m = {{0, 1}, {1, -1}}.m) // MatrixForm
data:image/s3,"s3://crabby-images/ee27b/ee27b9c17d94a1c7d9709b2cb44054135cad8825" alt="enter image description here"
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/b050f/b050f276b6bbf06fec594ce7460bfb284642d63d" alt="enter image description here"
% /. {{t -> 3/8/1.}, {t -> 3/8/2.}}
{2.88889, 4.66667}
This unambiguously exceeds 2, so
Style[AppendTo[cl@?, 1], 22]
data:image/s3,"s3://crabby-images/66ff0/66ff0f215594c10973a4edcc4886db92c9cf4206" alt="enter image description here"
MatrixForm[m = {{1, 0}, {0, 2}}.m]
data:image/s3,"s3://crabby-images/7e9c5/7e9c5b376f7c06bf67073c8188c0434b0f603a81" alt="enter image description here"
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/8ab77/8ab77f38780761c8493c16d331601db528116ffb" alt="enter image description here"
% /. {{t -> 3/8/1.}, {t -> 3/8/2.}}
{1.44444, 2.33333}
Our interval of uncertainty contains 2! At last we gobble (right multiply) the k=2 term.
MatrixForm[ m = m.{{512 k^3, 0}, {32 k^3 (-37 + 42 k), (-1 + 2 k)^3}} /. k -> 2]
data:image/s3,"s3://crabby-images/99519/99519d63861b999b1bbe82355774565349caf747" alt="enter image description here"
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/f2c8e/f2c8ee7be151db310aeaf8befe83ad6988f10809" alt="enter image description here"
(Remembering to bump k !)
% /. {{t -> 3/8/2.}, {t -> 3/8/3.}}
{1.51515, 1.51938}
(Giving six more bits of precision!)
Style[AppendTo[cl@?, 0], 22]
data:image/s3,"s3://crabby-images/c9702/c970227fcbae2695dde4986b16ef3b15aea8711d" alt="enter image description here"
(m = {{0, 1}, {1, -1}}.m) // MatrixForm
data:image/s3,"s3://crabby-images/cdebc/cdebc60202aa8e02becdfe698e39e15c0878ef5a" alt="enter image description here"
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/81ef6/81ef61730da50d9cff1c6a3490224c6ce820bdb6" alt="enter image description here"
% /. {{t -> 3/8/2.}, {t -> 3/8/3.}}
{1.9412, 1.92538}
Style[AppendTo[cl@?, 0], 22]
data:image/s3,"s3://crabby-images/54fea/54feae8c0503788461ec227a024b5e3016fe7984" alt="enter image description here"
(m = {{0, 1}, {1, -1}}.m) // MatrixForm
data:image/s3,"s3://crabby-images/7111e/7111ee0014ab1945b00d1a2a5405daa79385159d" alt="enter image description here"
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/e543e/e543eeafeaf5d9042c05b3c674c1cb9cc3a07b40" alt="enter image description here"
% /. {{t -> 3/8/2.}, {t -> 3/8/3.}}
{1.06248, 1.08064}
Style[AppendTo[cl@?, 0], 22]
data:image/s3,"s3://crabby-images/382e9/382e979038e34ce9d0d37a85af41d8ed7955c708" alt="enter image description here"
(m = {{0, 1}, {1, -1}}.m) // MatrixForm
data:image/s3,"s3://crabby-images/16342/1634254a83535923fb6ceaef6d7ed96c999db0e1" alt="enter image description here"
Divide @@ (m.{t, 1})
data:image/s3,"s3://crabby-images/2858b/2858b9bbc9294c45349d68387858871be2c154b9" alt="enter image description here"
% /. {{t -> 3/8/2.}, {t -> 3/8/3.}}
{16.0056, 12.4004}
Whoa, a burst of three 1s!
Style[AppendTo[cl@?, 1]; AppendTo[cl@?, 1]; AppendTo[cl@?, 1], 22]
data:image/s3,"s3://crabby-images/66dbc/66dbc307f90b5d7a09420ab6a07f71c6c91523ac" alt="enter image description here"
MatrixForm[m = {{1, 0}, {0, 8}}.m]
data:image/s3,"s3://crabby-images/1efa8/1efa8a4519a62a34d7990bab5d727e3d262ab32b" alt="enter image description here"
MatrixForm[m = m/2]
data:image/s3,"s3://crabby-images/4f6e9/4f6e986499b4bc7e7da1b6db22fee862e509013c" alt="enter image description here"
(Since we knew it was three ones and not four, we could have output 1,1,1,0 and left multiplied m by
MatrixForm[{{0, 1}, {1, -1}}.{{1, 0}, {0, 8}}]
data:image/s3,"s3://crabby-images/942ae/942ae50a88d21004fe5d3a2da08010c02cab525c" alt="enter image description here"
This process may be continued indefinitely, or until the integers in m overflow.
Attachments: