-
Notifications
You must be signed in to change notification settings - Fork 227
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Documentation bug for TOMS 748 #1166
Comments
So the recommended diff is?
That seems ok. FWIW, we do have a cubic solver. |
@NAThompson I would probably go with "...must bracket at least one root". Thanks for the reference to the cubic solver. I believe the bracketing approaches are more appropriate for my use case, but speed is also a concern, so I will probably experiment with both. |
Hmmm, I'm nervous about this, I suspect a more accurate wording would be "must bracket an odd number of roots", because an even number could be zero and would break the algorithms invariants? If you have a concrete use case (or can concoct some examples), I'll add it to the tests as well just to be sure ;) |
@jzmaddock I am pretty sure "at least one" is correct (and rules out zero). |
My point is that any bracketing algorithm can not tell the difference between 2 roots and zero roots, consider bisecting a function with two roots at say x=2 and x=3 with a starting range of [0,10]. Now, f(0) and f(10) have the same sign, we then examine f(5) and hey... that has the same sign as well! So which way do we jump next? There is simply no way to tell that the [0,5] interval has those two roots. |
Your example does not satisfy the preconditions.
As far as I know, all of these "bracketing" algorithms work similarly, falling back to bisection when things get weird. They all require that f(a) and f(b) have opposite signs and that [a,b] contain at least one root. TOMS 748 fits this description, anyway. Note that the number of roots in [a,b] can be even if some have multiplicity. TOMS 748 (and pretty much any "bracketing" algorithm, I think) will still work. |
Well.. that's why I gave it as an example, if we exclude the special cases of roots that touch but do not cross the origin, then requiring Whatever, I'll tidy up the language, and add some tests on multiple roots in oscillating functions just to be sure. |
I am sorry, but I still do not see the problem. Why would we exclude the case of roots that touch but do not cross the origin? As far as I know, TOMS 748 imposes no such restriction. And the requirement So I am pretty sure the documentation is fine as it is, except that "a single root" should read "at least one root".
Thank you. The multiplicity case -- e.g. touching but not crossing the axis -- is actually somewhat interesting, since it is the sort of thing the derivative-based solvers sometimes struggle with. This is one reason I am leaning towards the bracketing solvers. |
It's not just derivative solvers-in this case the condition number of rootfinding is infinite. In other words, this is a property of the problem, not of the method to solve it. See Corless, A Graduate Introduction to Numerical Methods from the Viewpoint of Backward Error Analysis, equation (3.20). As a practical matter, however, you may be right-when you have infinite ill-conditioning different methods can do better or worse-though it may be quite difficult to know if its just a particular tested case or a fundamentally better interaction of the method with the problem. |
At least, I am pretty sure this is a documentation bug.
I asked this question on StackOverflow:
https://stackoverflow.com/q/78795676/
The TOMS 748 documentation states:
The responses -- and a straightforward reading of the TOMS 748 paper -- suggests that this is not correct, and that the bounds merely must bracket at least one root.
This may seem like a trivial difference, but for my application it matters a lot. Thanks.
The text was updated successfully, but these errors were encountered: