Problem: Given a polynomial of degree n (with coefficients a0 through an-1) that is guaranteed to be increasing from x = 0 to xmax, what is the most efficient algorithm to find the first m points with equally-spaced y values (i.e. yi – yi-1 == c, for all i)?
Example: If I want the spacing to be c = 1, and my polynomial is f(x) = x^2, then the first three points would be at y=1 (x=1), y=2 (x~=1.4142), and y=3 (x~=1.7321).
I’m not sure if it will be significant, but my specific problem involves the cube of a polynomial with given coefficients. My intuition tells me that the most efficient solution should be the same, but I’m not sure.
I’m encountering this working through the problems in the ACM’s problem set for the 2012 World Finals (problem B), so this is mostly because I’m curious.
Edit: I’m not sure if this should go on the Math SE?
You can find an X for a given Y using a binary search. It’s logarithmic time complexity, proportional to the size of the range of x values, divided by your error tolerance.
output:
Edit: to expand on an idea in the comments, if you know you will be searching for multiple X values, it’s possible to narrow down the [minX, maxX] search range.
output: