As promised, some careful results from one of the tests in my
doubled-precision library.

Rows are iteration's of Jean-Michel Muller's roundoff-intolerant Œ()
function:

http://perso.ens-lyon.fr/jean-michel.muller/

Columns are 32-bit floating point,64-bit floating point, my fast 128-bit
library, Go big float, and Go rationals (printed as float)

Answers are good for a while, and then fail as they must. compare always to
the right column.

Also, Dr. Kahan on the topic -- always read his every word!

How Futile are Mindless Assessments of Roundoff In Floating-Point
Computation ?
Professor W. Kahan
§ 5, page 14
https://www.cs.berkeley.edu/~wkahan/Mindless.pdf


=== RUN   TestMuller
  0:   4.000000000   4.000000000000000000
+4.0000000000000000000000000000000e+00 4.0000000000000000000000000000000
4.0000000000000000000000000000000000000000000000000000000000000000000000…
  1:   4.250000000   4.250000000000000000
+4.2500000000000000000000000000000e+00 4.2500000000000000000000000000000
4.2500000000000000000000000000000000000000000000000000000000000000000000…
  2:   4.470588684   4.470588235294115975
+4.4705882352941176470588235294117e+00 4.4705882352941176470588235294118
4.4705882352941176470588235294117647058823529411764705882352941176470588…
  3:   4.644744873   4.644736842105217534
+4.6447368421052631578947368421047e+00 4.6447368421052631578947368421053
4.6447368421052631578947368421052631578947368421052631578947368421052632…
  4:   4.770706177   4.770538243625082941
+4.7705382436260623229461756373816e+00 4.7705382436260623229461756373938
4.7705382436260623229461756373937677053824362606232294617563739376770538…
  5:   4.859214783   4.855700712568562949
+4.8557007125890736342042755341875e+00 4.8557007125890736342042755344418
4.8557007125890736342042755344418052256532066508313539192399049881235154…
  6:   4.983123779   4.910847498660629640
+4.9108474990827932004402592585550e+00 4.9108474990827932004402592637887
4.9108474990827932004402592637886755533814357343769108474990827932004403…
  7:   6.395431519   4.945537395530507752
+4.9455374041239167247733836966321e+00 4.9455374041239167247733838031676
4.9455374041239167247733838031676461798983962546070325729654348042633728…
  8:  27.632629395   4.966962408040998866
+4.9669625817627005987119363335665e+00 4.9669625817627005987119384872579
4.9669625817627005987119384872578590383346845054961655244646085209448470…
  9:  86.993759155   4.980042204293013697
+4.9800457013556311612685646399287e+00 4.9800457013556311612686079942904
4.9800457013556311612686079942903718963021236734644222853921922457735370…
 10:  99.255508423   4.987909232795786352
+4.9879794484783922601392624051427e+00 4.9879794484783922601401328939769
4.9879794484783922601401328939769400999972111033913186330660946103656976…
 11:  99.962585449   4.991362641314552206
+4.9927702880620680974721416957309e+00 4.9927702880620680974895925483283
4.9927702880620680974895925483282696604561239860070565468956074766812844…
 12:  99.998130798   4.967455095552267608
+4.9956558915066340262745164361610e+00 4.9956558915066340266240282615671
4.9956558915066340266240282615670560447223264138375322338595040105640829…
 13:  99.999908447   4.429690498308829660
+4.9973912683813441058976817599037e+00 4.9973912683813441128938690216426
4.9973912683813441128938690216425944791795065582105346913888017869771418…
 14: 100.000000000  -7.817236578459315410
+4.9984339439448167790186456309858e+00 4.9984339439448169190138971781902
4.9984339439448169190138971781902382881448247682045125641413593279228615…
 15: 100.000000000 168.939167671064581100
+4.9990600719708910670530314075958e+00 4.9990600719708938678168396062869
4.9990600719708938678168396062869249162956010827138675312945769521384463…
 16: 100.000000000 102.039963152059272034
+4.9994359371467831224113039612204e+00 4.9994359371468391479978508864998
4.9994359371468391479978508864997899689960802031068986343509970885820809…
 17: 100.000000000 100.099947516249699220
+4.9996615241026469022949297281691e+00 4.9996615241037675377868879857271
4.9996615241037675377868879857270921122953326315959962489248369318086283…
 18: 100.000000000 100.004992040972439327
+4.9997969006910037174292363662054e+00 4.9997969007134179126629930746330
4.9997969007134179126629930746330014204806141590496819671038715851326606…
 19: 100.000000000 100.000249579237305397
+4.9998781350296295179302235821482e+00 4.9998781354779312492317320300204
4.9998781354779312492317320300204045157850179321411177471298083841044938…
 20: 100.000000000 100.000012478620163847
+4.9999268705383513445350585201744e+00 4.9999268795045999044664529810255
4.9999268795045999044664529810255297667014507019629318651153480676099193…
 21: 100.000000000 100.000000623921607712
+4.9999559477336189227766623157740e+00 4.9999561270611577381190152822945
4.9999561270611577381190152822944886054388799381889725655444194135741792…
 22: 100.000000000 100.000000031195796169
+4.9999700894239992550386653856177e+00 4.9999736760057124445790151493568
4.9999736760057124445790151493567643737503007922741653125691208832859521…
 23: 100.000000000 100.000000001559783414
+4.9999124734648500146469791816450e+00 4.9999842055202727079241797881427
4.9999842055202727079241797881426658531818881745189289851152851242815919…
 24: 100.000000000 100.000000000077989171
+4.9985558571549103233951637188660e+00 4.9999905232822276594072074700222
4.9999905232822276594072074700221895687712348995633004631696331458335230…
 25: 100.000000000 100.000000000003893774
+4.9712927027118246836857185407072e+00 4.9999943139585595936498116895205
4.9999943139585595936498116895205444125570648227907768610955390115520007…
 26: 100.000000000 100.000000000000198952
+4.4226495626383376905144334349236e+00 4.9999965883712560237063808793366
4.9999965883712560237063808793366290715938072692305936798744398732101066…
 27: 100.000000000 100.000000000000014211
-8.0543263668793762606068650955197e+00 4.9999979530213569079884128681396
4.9999979530213569079884128681395624212191657293654124963639370253143521…
 28: 100.000000000 100.000000000000000000
+1.6707840996047266994803982209542e+02 4.9999987718123113299993645145089
4.9999987718123113299993645145089043394808989018478270361242267297207022…
 29: 100.000000000 100.000000000000000000
+1.0200739261142367556227366287163e+02 4.9999992630872057845553229449429
4.9999992630872057845553229449428974248701745617859182826712196402811665…
 30: 100.000000000 100.000000000000000000
+1.0009839445249753858622122905694e+02 4.9999995578522583058676361926155
4.9999995578522583058676361926155306470579794114384348546804011194603975…
 31: 100.000000000 100.000000000000000000
+1.0000491488620529657993721950960e+02 4.9999997347113315241634489886704
4.9999997347113315241634489886703873209071815584704240641160206715019947…
 32: 100.000000000 100.000000000000000000
+1.0000024573221949273744163542145e+02 4.9999998408267904691283066991447
4.9999998408267904691283066991447461401245221411111941292349839150736202…
 33: 100.000000000 100.000000000000000000
+1.0000001228658038317581341424617e+02 4.9999999044960712411436113485087
4.9999999044960712411436113485086619025952254222132465962859727857685148…
 34: 100.000000000 100.000000000000000000
+1.0000000061432893169757060234937e+02 4.9999999426976416501660968977059
4.9999999426976416501660968977058746597449338657490050051607246193821182…
 35: 100.000000000 100.000000000000000000
+1.0000000003071644603674249773981e+02 4.9999999656185845960724209285520
4.9999999656185845960724209285520274032984329752720101455505569667883150…
 36: 100.000000000 100.000000000000000000
+1.0000000000153582229058229440059e+02 4.9999999793711506157936445604403
4.9999999793711506157936445604403478825768055203979330788072542784010734…
 37: 100.000000000 100.000000000000000000
+1.0000000000007679111420444293124e+02 4.9999999876226903184102552956254
4.9999999876226903184102552956254154564530233074230759247801804451248680…
 38: 100.000000000 100.000000000000000000
+1.0000000000000383955570051442571e+02 4.9999999925736141726624177373900
4.9999999925736141726624177373899846521814871450561974997770093507650710…
 39: 100.000000000 100.000000000000000000
+1.0000000000000019197778473457074e+02 4.9999999955441684969793058578266
4.9999999955441684969793058578265507221613846754127192411902416952952377…
 40: 100.000000000 100.000000000000000000
+1.0000000000000000959888922799422e+02 4.9999999973265010958050513865753
4.9999999973265010958050513865752991029792463868833735614796518031109060…
 41: 100.000000000 100.000000000000000000
+1.0000000000000000047994446113768e+02 4.9999999983959006566253192645988
4.9999999983959006566253192645987703517412541034104279060966324365686654…
 42: 100.000000000 100.000000000000000000
+1.0000000000000000002399722304902e+02 4.9999999990375403936664153942504
4.9999999990375403936664153942503908554421709588719708303898585404793654…
 43: 100.000000000 100.000000000000000000
+1.0000000000000000000119986115222e+02 4.9999999994225242360886898172700
4.9999999994225242360886898172699813847756164760214959144068009828924029…
 44: 100.000000000 100.000000000000000000
+1.0000000000000000000005999305760e+02 4.9999999996535145416131964994088
4.9999999996535145416131964994087728654592174856780594689249370593190948…
 45: 100.000000000 100.000000000000000000
+1.0000000000000000000000299965288e+02 4.9999999997921087249535116388994
4.9999999997921087249535116388994438064719403073280296047563240880153629…
 46: 100.000000000 100.000000000000000000
+1.0000000000000000000000014998264e+02 4.9999999998752652349669207294706
4.9999999998752652349669207294705960875781484796796781602905760999707614…
 47: 100.000000000 100.000000000000000000
+1.0000000000000000000000000749913e+02 4.9999999999251591409782853862894
4.9999999999251591409782853862893681758947903446625524375301891071583939…
 48: 100.000000000 100.000000000000000000
+1.0000000000000000000000000037496e+02 4.9999999999550954845862990932721
4.9999999999550954845862990932721178654499411656001666991067834528381427…
 49: 100.000000000 100.000000000000000000
+1.0000000000000000000000000001875e+02 4.9999999999730572907515374861027
4.9999999999730572907515374861027238298843581825471452918011046606547147…
 50: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000094e+02 4.9999999999838343744508353825118
4.9999999999838343744508353825118361660416654324053402436169810652257114…
 51: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000005e+02 4.9999999999903006246704698702132
4.9999999999903006246704698702131741017755891186085659779488544485080641…
 52: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999941803748022706327821
4.9999999999941803748022706327820904674397779407686765412987426353340860…
 53: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999965082248813583155048
4.9999999999965082248813583155047612301443053914242084554581965117999475…
 54: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999979049349288135262036
4.9999999999979049349288135262036392372468406372184837633675327240105601…
 55: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999987429609572875890065
4.9999999999987429609572875890064652414572617384587447652026097603020003…
 56: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999992457765743723637862
4.9999999999992457765743723637862205564265300645967804237671219621887640…
 57: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999995474659446233500094
4.9999999999995474659446233500093752419872416231419626221316696321618204…
 58: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999997284795667739854312
4.9999999999997284795667739854311765921136903843367833565912666882127043…
 59: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999998370877400643824119
4.9999999999998370877400643824119044761586174651005029403286560095136689…
 60: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999022526440386262623
4.9999999999999022526440386262622941532154389230146822149898257515887795…
 61: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999413515864231746108
4.9999999999999413515864231746108310202365002220119343179337646326275894…
 62: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999648109518539043537
4.9999999999999648109518539043537422423324924950902679597114922320542682…
 63: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999788865711123424637
4.9999999999999788865711123424636530522681059586273556210959868830755301…
 64: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999873319426674054247
4.9999999999999873319426674054246986058335627389825431745090925770748517…
 65: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999923991656004432356
4.9999999999999923991656004432355616023103092122499250394020004968086813…
 66: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999954394993602659344
4.9999999999999954394993602659344042393578472640359802718342049154159509…
 67: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999972636996161595581
4.9999999999999972636996161595581467636845065775581540693456601285917415…
 68: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999983582197696957340
4.9999999999999983582197696957339895774358313041128490803051031466354659…
 69: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999990149318618174401
4.9999999999999990149318618174400702933825446309125531072033187866180516…
 70: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999994089591170904639
4.9999999999999994089591170904639257329211032839264999036925254782439621…
 71: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999996453754702542783
4.9999999999999996453754702542783135202336295122791144899675278048175021…
 72: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999997872252821525670
4.9999999999999997872252821525669730211133260224569717187442231522023258…
 73: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999998723351692915402
4.9999999999999998723351692915401783798983290069057876102772323241125098…
 74: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999234011015749241
4.9999999999999999234011015749241050721419174257787170484823958766829884…
 75: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999540406609449545
4.9999999999999999540406609449544623391982016632558894788380589496296748…
 76: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999724243965669727
4.9999999999999999724243965669726771500476194327574448042131447577254700…
 77: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999834546379401836
4.9999999999999999834546379401836061987789030961838735426077722601924147…
 78: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999900727827641102
4.9999999999999999900727827641101636864174611748609102333197316917095417…
 79: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999940436696584661
4.9999999999999999940436696584660982000245196590907570761709464871917991…
 80: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999964262017950797
4.9999999999999999964262017950796589157573672589571701692026996825069414…
 81: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999978557210770478
4.9999999999999999978557210770477953479217763222352798310604083236190434…
 82: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999987134326462287
4.9999999999999999987134326462286772082013139414111198806392169302962769…
 83: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999992280595877372
4.9999999999999999992280595877372063247221576981518546417683057985281073…
 84: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999995368357526423
4.9999999999999999995368357526423237947617875788809785618500631502055925…
 85: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999997221014515854
4.9999999999999999997221014515853942768313300129249388167477476268768203…
 86: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999998332608709512
4.9999999999999999998332608709512365660895306953696498947168505492722285…
 87: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999998999565225707
4.9999999999999999998999565225707419396503821847630771145103663569655621…
 88: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999399739135424
4.9999999999999999999399739135424451637890282671727096526710479005311754…
 89: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999639843481255
4.9999999999999999999639843481254670982729845845769766098299530093665669…
 90: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999783906088753
4.9999999999999999999783906088752802589636350954845922604598055525967896…
 91: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999870343653252
4.9999999999999999999870343653251681553781250213965816223181428346555773…
 92: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999922206191951
4.9999999999999999999922206191951008932268548399160464291660989824125886…
 93: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999953323715171
4.9999999999999999999953323715170605359361056416977429415787361406993748…
 94: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999971994229102
4.9999999999999999999971994229102363215616607706079671952157093083619619…
 95: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999983196537461
4.9999999999999999999983196537461417929369955211769360320260739282306216…
 96: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999989917922477
4.9999999999999999999989917922476850757621969738785376765784377601915608…
 97: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999993950753486
4.9999999999999999999993950753486110454573180623491779865976682812204953…
 98: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999996370452092
4.9999999999999999999996370452091666272743907934974467289928189937561311…
 99: 100.000000000 100.000000000000000000
+1.0000000000000000000000000000000e+02 4.9999999999999999999997822271255
4.9999999999999999999997822271254999763646344602901264147280098852591988…
--- PASS: TestMuller (0.00s)
PASS
ok   float128 0.011s

Be thoughtful in numerical computation.

Michael

On Sat, Feb 1, 2020 at 5:54 PM Jason E. Aten <j.e.a...@gmail.com> wrote:

> I appreciate the sophisticated and math conscious discussion here.
>
> For those reading this thread in the future, I note the state of the art
> in Go at the moment seems to be this
> arbitrary precision decimal library created by the CockroachDB guys for
> APD standard/postgresql conformance.
> Note that arbitrary doesn't mean infinite, it means you can pick the
> precision your application needs.
>
> https://github.com/cockroachdb/apd
>
> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> To view this discussion on the web visit
> https://groups.google.com/d/msgid/golang-nuts/dde824b9-f200-43df-8461-1d5fc26c1cce%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/dde824b9-f200-43df-8461-1d5fc26c1cce%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>


-- 

*Michael T. jonesmichael.jo...@gmail.com <michael.jo...@gmail.com>*

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/CALoEmQzxi4o35ONtqpdJyQQy%3DCd3Zt_JU6k0dTGCCsnMDrWCkw%40mail.gmail.com.

Reply via email to