Small challenge
|
04-22-2023, 02:33 PM
(This post was last modified: 04-22-2023 03:08 PM by J-F Garnier.)
Post: #1
|
|||
|
|||
Small challenge
Here is simple yet hopefully funny challenge.
A page at the HP Computer Museum shows this image of a HP 9835 screen, to demonstrate the quality of a restoration of the display: The challenge is: 1 (easy): Can you find out the formula used to generate this series? 2 (more difficult): Can you find a HP 12-digit calculator that gives the very same and accurate results? Hint: a surprise here. HP 12-digit calculator excludes the 10-digit machines (HP-41, Voyager) of course, but also the DM-42/Free42 and HP calculators in exact mode. True HP calculator emulators are welcome. Math gurus would solve the part 1 almost immediately, but please refrain to spoil the game too quickly, until you can find which HP machine(s) can generate the very same 12-digit results for the series. J-F |
|||
04-22-2023, 03:29 PM
Post: #2
|
|||
|
|||
RE: Small challenge
.
Hi, J-F, (04-22-2023 02:33 PM)J-F Garnier Wrote: 1 (easy): Can you find out the formula used to generate this series? Yes. It took me all of 5 seconds to deduce it. According to your wishes I won't spoil it for everyone else but will give a couple of hints: (1) look at the last digit of each entry. (2) look at the sixth entry. Quote:2 (more difficult): Can you find a HP 12-digit calculator that gives the very same and accurate results? Hint: a surprise here. Yes. The "surprise here" may refer to the fact that the HP-71B has the next-to-last entry differ by just 1 ulp if using the default values at machine reset. Quote:Math gurus would solve the part 1 almost immediately, but please refrain to spoil the game too quickly, until you can find which HP machine(s) can generate the very same 12-digit results for the series. Don't worry, I won't post a solution to avoid ruining the fun, as per your request. Thanks for the fun an best regards. V. All My Articles & other Materials here: Valentin Albillo's HP Collection |
|||
04-22-2023, 03:33 PM
Post: #3
|
|||
|
|||
RE: Small challenge
Found the series, but cannot display the exponent with positive sign on the 71B...
Greetings, Massimo -+×÷ ↔ left is right and right is wrong |
|||
04-22-2023, 03:41 PM
Post: #4
|
|||
|
|||
RE: Small challenge
(04-22-2023 03:33 PM)Massimo Gnerucci Wrote: Found the series, but cannot display the exponent with positive sign on the 71B... Use an adequate IMAGE. V. All My Articles & other Materials here: Valentin Albillo's HP Collection |
|||
04-22-2023, 03:41 PM
(This post was last modified: 04-22-2023 03:49 PM by J-F Garnier.)
Post: #5
|
|||
|
|||
RE: Small challenge
(04-22-2023 03:29 PM)Valentin Albillo Wrote: It took me all of 5 seconds to deduce it. Wow, so fast. When I searched for the formula some times ago, I needed a little more time... (04-22-2023 03:33 PM)Massimo Gnerucci Wrote: Found the series, but cannot display the exponent with positive sign on the 71B...No, the exponent sign doesn't matter. As Valentin found it, the problem is that the (e.g.) 71B doesn't give the same exact results. Now, 2nd part: which HP machine gives the same numeric results, independently of the display format? J-F |
|||
04-22-2023, 04:30 PM
Post: #6
|
|||
|
|||
RE: Small challenge | |||
04-22-2023, 04:38 PM
(This post was last modified: 04-22-2023 04:41 PM by John Keith.)
Post: #7
|
|||
|
|||
RE: Small challenge
(04-22-2023 03:29 PM)Valentin Albillo Wrote: Yes. The "surprise here" may refer to the fact that the HP-71B has the next-to-last entry differ by just 1 ulp if using the default values at machine reset. Exactly the same result on the 50g in approximate mode, as expected. We can assume that the "mystery calculator" is not a Saturn-based machine. |
|||
04-22-2023, 05:15 PM
Post: #8
|
|||
|
|||
RE: Small challenge | |||
04-22-2023, 05:29 PM
Post: #9
|
|||
|
|||
RE: Small challenge
(04-22-2023 02:33 PM)J-F Garnier Wrote: Here is simple yet hopefully funny challenge. I’m away from home and have only my HP 50g at hand otherwise I would try the HP-12C Platinum (a 12-digit calculator actually) and the HP-33s. |
|||
04-22-2023, 06:30 PM
(This post was last modified: 04-22-2023 06:37 PM by C.Ret.)
Post: #10
|
|||
|
|||
RE: Small challenge
Hello everyone !
It's a good question and a fun challenge to research. Obviously, the HP machine to find is not a Ti-58C nor a SHARP PC-E500. These two machines gave me bad impressions (see below) obtained respectively on a very recently acquired PC-100B and an already more than thirty years old CE-126P: My HP-28S also gave me funny impressions. But it depends on how I program the term's calculation of the sequence. I give below three listings obtained on the same machine from three very slightly different programs: The latest listing was created with the RPL translation for HP-28S of the following Ti-58C program: 000 43 00 45 01 00 95 99 69 20 61 00 00 Your turn to judge. The last looks damned like the greenish screenshot! All that's missing are a few insignificant trailing zeros. Sincerely. C.Ret Multiple editions to correct spelling and resizes print captures. |
|||
04-22-2023, 07:24 PM
Post: #11
|
|||
|
|||
RE: Small challenge
The following produces the exact same sequence on an HP-48G:
'n^5^2' 'n' 5 24 1 SEQ |
|||
04-22-2023, 09:42 PM
Post: #12
|
|||
|
|||
RE: Small challenge
(04-22-2023 06:30 PM)C.Ret Wrote: It's a good question and a fun challenge to research.Thanks! Quote:My HP-28S also gave me funny impressions. But it depends on how I program the term's calculation of the sequence. I give below three listings obtained on the same machine from three very slightly different programs: Well , not exactly, neither of the last two 28S listing give the 'correct' answers for all items ! And the first listing very likely doesn't use 12-digit numbers :-) (04-22-2023 07:24 PM)Thomas Klemm Wrote: The following produces the exact same sequence on an HP-48G: Very nice! Although not what I had in mind for the challenge of course. J-F |
|||
04-23-2023, 12:58 AM
Post: #13
|
|||
|
|||
RE: Small challenge
.
Hi again, J-F, Well, since alleged solutions have already been posted, here's mine. First of all, the function being evaluated is at its simplest y = x10. The ending digits (5,6,9,4,1,0,1,4,9,6,5,) which are the ending digits of consecutive squares, plus the ten zeros in 10000000000 are hinting enough at the correct expression. Now, if using the HP-71B, executing this from the command line produces your values exactly (suppresion of irrelevant trailing zeros in the scientific format aside):
V. All My Articles & other Materials here: Valentin Albillo's HP Collection |
|||
04-23-2023, 06:24 AM
(This post was last modified: 04-23-2023 06:48 AM by C.Ret.)
Post: #14
|
|||
|
|||
RE: Small challenge
Ah! That's nice, I really get a near close !
I try different ways to compute the 10th exponent but completely miss the two stage one. With a little effort, the HP-28C/S can print the exact sequence without omission of any trailing zeros: « FOR n n 5 ^ SQ PR1 NEXT » 'PRx¹º' STO « CR STD 5 15 PRx¹º 12 SCI 16 24 PRx¹º CR » EVAL (04-23-2023 12:58 AM)Valentin Albillo Wrote: The ending digits (5,6,9,4,1,0,1,4,9,6,5,) which are the ending digits of consecutive squares, plus the ten zeros in 10000000000 are hinting enough at the correct expression. I'm not as clever as Valentin. I did not know by hearth the list of the last digits of any square. I only used this trick to detect out certain multiples (of 2, 3 or 5 in most cases). But it's a good trick to use. I found the general phrase while chatting with a new cyber friend of mine lining in San Francisco CA that has been very popular lately. ChatGPT 3.5 (23 March) (c) OpenAI, L.L.C. Wrote:Based on the consecutive terms you provided, it appears that each term is an exact power of a fixed integer. More specifically, each term is an exact power of 10. |
|||
04-23-2023, 08:00 AM
Post: #15
|
|||
|
|||
RE: Small challenge
There must be several ways to compute x^10:
raise to power ten raise to power 5 then square square then raise to power 5 and in each case, do this using repeated multiplication, or by the power operator. How differently accurate are each of those 6 ways on the machines considered? Hang on, it's more than 6 - the squares and fifth powers can also be done in at least two ways, perhaps even three ways if x^2 is available. (And there's also the less-accurate option of using log and exp and multiplication.) |
|||
04-23-2023, 11:10 AM
(This post was last modified: 04-23-2023 11:15 AM by robve.)
Post: #16
|
|||
|
|||
RE: Small challenge
(04-23-2023 08:00 AM)EdS2 Wrote: There must be several ways to compute x^10: Indeed! It is common to find exponentiation by squaring for integer powers, which tends to be more accurate than repeated multiplication and log*exp closed forms. It's pretty straightforward to do. Here is the way I've implemented it in Forth850 MATH.FTH: Code: : F** ( r1 r2 -- r3 ) x^10 is broken down to three squarings and one multiplication \( \left(x\left((x^2)^2\right)\right)^2 \) hence 4 multiplications suffice. - Rob "I count on old friends to remain rational" |
|||
04-23-2023, 01:01 PM
Post: #17
|
|||
|
|||
RE: Small challenge
(04-23-2023 11:10 AM)robve Wrote: Indeed! It is common to find exponentiation by squaring for integer powers, which tends to be more accurate than repeated multiplication and log*exp closed forms. We can use the Chains of Recurrences algebra to optimize sequence evaluations such as x^10. We only need 10 additions to produce the next value in the sequence. To expand \( x^{10} \) to CR form, let \( x \) be the integer sequence CR \( x =\{1,+,1\} \) expand to the CR \( \{1,+,1\}\times\{1,+,1\}\times\{1,+,1\}\times\{1,+,1\}\times\{1,+,1\}\times\{1,+,1\}\times\{1,+,1\}\times\{1,+,1\}\times\{1,+,1\}\times\{1,+,1\} \). Simplify using the CR rule \( \{\phi_0,+,f_1\} \times \{\psi_0,+,g_1\} \Rightarrow \{\phi_0\times\psi_0,+,\{\phi_0,+,f_1\}\times g_1+\{\psi_0,+,g_1\}\times f_1+f_1\times g_1\} \) giving the polynomial CR \( \{1,+,1023,+, 57002,+, 874500,+, 5921520,+, 21538440,+, 46070640,+, 59875200,+, 46569600,+, 19958400,+, 3628800 \} \). Note that each value is produced with just 10 additions. Written in C: Code: #include <stdio.h> Output: 1 1024 59049 1048576 9765625 60466176 282475249 1073741824 3486784401 10000000000 25937424601 61917364224 137858491849 289254654976 576650390625 1099511627776 2015993900449 3570467226624 6131066257801 10240000000000 16679880978201 26559922791424 41426511213649 63403380965376 With floating point we need to be a bit careful with error accumulation in long CR iterations. The polynomial case, such as \( x^{10} \), is stable. The product case such as \( 10^x \) may not be stable. The above code uses integers, which is always stable (but may overflow eventually). - Rob "I count on old friends to remain rational" |
|||
04-23-2023, 01:56 PM
Post: #18
|
|||
|
|||
RE: Small challenge
(04-23-2023 01:01 PM)robve Wrote: We can use the Chains of Recurrences algebra to optimize sequence evaluations such as x^10. We only need 10 additions to produce the next value in the sequence. Now you may ask, what's the difference here with difference tables? These CR coefficients look familiar. And you are correct! Polynomial CR forms are identical to difference table upper diagonals of polynomials evaluated over equidistant grids. CRs are not restricted to polynomials, it's just that CRs of polynomials are easy to construct with difference tables or with the CR algebra. A difference table for the sequence shown in the picture reveals that the sequence is an x^10 polynomial since the 11th difference column is zero: Not surprising, starting from x=1 you get the diagonal that matches the CR coefficients: - Rob "I count on old friends to remain rational" |
|||
04-23-2023, 02:08 PM
Post: #19
|
|||
|
|||
RE: Small challenge
That's remarkable!
|
|||
04-23-2023, 02:13 PM
(This post was last modified: 04-23-2023 04:19 PM by J-F Garnier.)
Post: #20
|
|||
|
|||
RE: Small challenge
Thanks all for your interest!
As many of you found it (sometimes easily, too easily!) the formula to get the series is n^10 for n=5 to 24. Trying to reproduce the series on a common Saturn-based calculator quickly shows that the term n^10 for n=23 is computed with an error of 1 ulp, whereas the 9835 correctly gives the right value (in the sense of closest representation of the exact value). Congrat to Thomas and Valentin for finding the unexpected workaround n^5^2 ! Let's test more machines:
HP-71B, all Saturn-based machines (in approx. mode): 4.14265112137E13 (1 ulp error) HP-35S: 23^10 = 4.14265112136E13 (back to the correct value) I don't have a 33S to test, but I expect it to give the same value as the 35S. I found it quite funny that old computers of the late 70 / early 80 on one side, and the poor unloved 35S on the other side, all give a better result (for that particular case) than the whole generation of Saturn-based machines that spanned about 3 decades. What we can learn from all this:
Most of the time, the 35S math code is giving the same result as the 32SII (as surely intended), but since it's a rewrite and not a emulation, it can sometimes give slightly different (in this case better) answers. |
|||
« Next Oldest | Next Newest »
|
User(s) browsing this thread: 1 Guest(s)