analyticalengine:bernoullinumbercalculation
Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende Überarbeitung | ||
analyticalengine:bernoullinumbercalculation [2015-04-21 13:04] – added calculation trace rainer | analyticalengine:bernoullinumbercalculation [2015-08-26 13:23] (aktuell) – compacted B_7 example calculation rainer | ||
---|---|---|---|
Zeile 15: | Zeile 15: | ||
In //Note G//, equation 8 shows the recursion formula used by AAL: | In //Note G//, equation 8 shows the recursion formula used by AAL: | ||
- | < | + | < |
and in terms of the number to be calculated: | and in terms of the number to be calculated: | ||
Zeile 25: | Zeile 25: | ||
< | < | ||
- | In the text, AAL wrotes: // | + | In the text, AAL wrote: // |
- | Thus, the coefficients – which are not given in //Note G//, are: | + | Thus, the coefficients – which are not given in //Note G// – are: |
- | `A_0(n) = 1/2 %%*%% (2n-1)/ | + | `A_0(n) = 1/2 * (2n-1)/ |
`A_1(n) = -(2n) / 2` | `A_1(n) = -(2n) / 2` | ||
- | `A_3(n) = A_1(n) | + | `A_3(n) = A_1(n) * (2n-1)/3 * (2n-2)/4` |
- | `A_5(n) = A_3(n) | + | `A_5(n) = A_3(n) * (2n-3)/5 * (2n-4)/6` |
- | This makes clear, that for `A_5` and the following the calculation steps are structurally equal and thus can be calculated | + | As each `A_i(n)` depends only on the previous |
- | Note the signs in contrast | + | However, to calculate the n-th Bernoulli number, all previuos ones must be present, used each for multiplication, |
+ | |||
+ | This is done in later computers by either using an index register or dynamically modifying operation addresses during execution. | ||
+ | |||
+ | Note that the signs are different to those in //Note G//. | ||
+ | |||
+ | ====== Why not equation 2 or 3? ====== | ||
+ | |||
+ | On page 725, AAL shows two commonly used formulas in equation 2 and 3, that do calculate the n-th Bernoulli number just as a series without recursion | ||
+ | > As however our object is not simplicity or facility of computation, | ||
+ | |||
+ | Thus she probably delibrately took into account the indexing problem. | ||
+ | |||
+ | While equation (2.) looks fairly simple, it is an inifinite sum of terms, which by itself would rule out using the AE. (Still need to write down examples, as elements to be summed up are not integer numbers.) | ||
+ | |||
+ | Equation (3.) looks like a finite sequence, but needs some rewriting to avoid arbitrary large numbers as intermediate results. (Would required deeper inspection too.) | ||
+ | |||
+ | So the version in equation (8.) looks to me the most simple soulution that has a facility of computation; | ||
+ | |||
+ | |||
+ | ====== The problem in line 21 ====== | ||
+ | |||
+ | The tabular programme in the //Diagram accompanying Translator' | ||
+ | |||
+ | To calculate `B_7`, the lines 13 to 23 are executed once, then in line 24 and 25 the result is stored. | ||
+ | |||
+ | To calculate `B_9` afterwards, lines 13 to 23 are a loop executed twice, i.e. until `V_10` is reduced to `1`. Let us ignore that the lines are missing that compare `V_10` to one, and raise the overflow lever in the mill, as to control the loop exit condition. This would be added easily. | ||
+ | |||
+ | Howerver, in line 21 during the second round, the value to be multiplied is not `V_22`, containing `B_5`, but `V_23`, contining the just calculated `B_7`. | ||
+ | |||
+ | AAL has evidently see that problem and writes on page 729 bottom: | ||
+ | >The only exception to a //perfect identity// | ||
+ | |||
+ | However, while it is correctly assumed that this may be solved, there is no hint of how this is //easily provided//, that the loom of variable cards are changed with each round. | ||
+ | |||
+ | It may be considered only to loop the operation cards, and to //unravel the loop//, although that contradicts her remark earlier on the page, that >when `n>2`, twenty-five Operation-cards are used; but no // | ||
+ | |||
+ | On page 729, there is a footnote (for which I did not found the corresponding reference place), that millions of Bernoulli numbers could be calculated this way. | ||
+ | |||
+ | However, to calculate millions of Bernoulli numbers, the AE would need a store of millions of numbers; this may be a place where she did not fully understand the problem. | ||
+ | |||
+ | Alan Bromley in his 1998 article on page 44 left column, second to last paragraph, writes: | ||
+ | >With hindsight, we can note that in the Analytical Engine (at least until 1840), Babbage did not posess the variable-address concept; that is, there was no mechanism by which the machine could, as a result of a calculation, | ||
+ | |||
+ | He refers this to solving matrices, and thus to a much much more complex problem. | ||
- | (to be continued) | ||
====== Actual Calculation ====== | ====== Actual Calculation ====== | ||
- | < | + | `A_0(1) = 1/2 * 1/3 = 1/6` |
`B_1 = A_0(1) = 1/6` | `B_1 = A_0(1) = 1/6` | ||
Zeile 50: | Zeile 93: | ||
`A_0(2) = 3/10` | `A_0(2) = 3/10` | ||
- | < | + | `A_1(2) = -2` |
`B_3 = A_0(2) + A_1(2) * B_1 = 3/10 - 2/6 = (9 - 10)/30 = - 1/30` | `B_3 = A_0(2) + A_1(2) * B_1 = 3/10 - 2/6 = (9 - 10)/30 = - 1/30` | ||
Zeile 71: | Zeile 113: | ||
`A_5(4) = -14 * 5/5 * 4/6 = - 28/3` | `A_5(4) = -14 * 5/5 * 4/6 = - 28/3` | ||
- | `B_7 = 7/18 - 4/6 + 14/30 - 28/(3*42) = (7 - 12)/18 + 7/15 - 14/63 = -5/18 + 7/15 - 14/63 = (-25 + 28)/90 + 14/63 = 17/90 -14/63 = (119 - 140 ) / (7*9*10) = - 21/ | + | `B_7 = 7/18 - 4/6 + 14/30 - 28/(3*42) = (7 - 12)/18 + 7/15 - 2/9 = -5/18 + (21-10)/45 = (-25 + 22)/90 = -3/90 = - 1/30` |
analyticalengine/bernoullinumbercalculation.1429614288.txt.gz · Zuletzt geändert: 2015-04-21 13:04 von rainer