BUG: prevent underflow/overflow when finding roots in IRR#25
Merged
Conversation
NumPy's roots function uses the companion matrix to find polynomial roots. In the process it makes the polynomial monic by dividing by the leading coefficient, which can cause overflow/underflow. This can be avoided by working with a scaled version of the companion matrix instead. Since scaling the matrix simply scales the eigenvalues (i.e. the roots of the polynomial in this case), the original roots can easily be recovered. Closes numpygh-15.
Kai-Striega
approved these changes
Nov 4, 2019
Member
Kai-Striega
left a comment
There was a problem hiding this comment.
LGTM. 👍 for neatening the tests to. It's nice to see all of these bugs being fixed.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
NumPy's roots function uses the companion matrix to find polynomial
roots. In the process it makes the polynomial monic by dividing by the
leading coefficient, which can cause overflow/underflow. This can be
avoided by working with a scaled version of the companion matrix
instead. Since scaling the matrix simply scales the eigenvalues
(i.e. the roots of the polynomial in this case), the original roots
can easily be recovered.
Closes gh-15.