Message276739
Mark, the code I showed in roots.py is somewhat more accurate and highly significantly faster than the code you just posted. It's not complicated at all: it just uses Decimal to do a single Newton correction with extended precision.
Since it doesn't use the Decimal exp() or ln(), it's faster. It does use the Decimal pow(), but with an integer exponent, so this specific use of pow() doesn't invoke the Decimal exp() or ln() either. And it's still the case that I haven't found a case where its result isn't correctly rounded. My testing framework found multiple not-correctly-rounded cases in your new code within seconds.
Presumably you could boost the precision to improve that, but then it would get even slower. |
|
Date |
User |
Action |
Args |
2016-09-16 19:12:25 | tim.peters | set | recipients:
+ tim.peters, rhettinger, mark.dickinson, vstinner, ned.deily, steven.daprano, martin.panter, serhiy.storchaka |
2016-09-16 19:12:25 | tim.peters | set | messageid: <1474053145.46.0.21204096214.issue27761@psf.upfronthosting.co.za> |
2016-09-16 19:12:25 | tim.peters | link | issue27761 messages |
2016-09-16 19:12:25 | tim.peters | create | |
|