Issue Details (XML | Word | Printable)

Key: MATH-274
Type: Bug Bug
Status: Closed Closed
Resolution: Fixed
Priority: Minor Minor
Assignee: Luc Maisonobe
Reporter: Manuel Rossetti
Votes: 0
Watchers: 0
Operations

If you were logged in you would be able to see more operations.
Commons Math

testing for symmetric positive definite matrix in CholeskyDecomposition

Created: 04/Jun/09 07:24 PM   Updated: 07/Aug/09 09:16 AM
Return to search
Component/s: None
Affects Version/s: 2.0
Fix Version/s: 2.0

Time Tracking:
Not Specified

Environment: Mac OS X, NetBeans

Resolution Date: 04/Jun/09 08:11 PM


 Description  « Hide
I used this matrix:

double[][] cv = {
{0.40434286, 0.09376327, 0.30328980, 0.04909388},
{0.09376327, 0.10400408, 0.07137959, 0.04762857},
{0.30328980, 0.07137959, 0.30458776, 0.04882449},
{0.04909388, 0.04762857, 0.04882449, 0.07543265}
};

And it works fine, because it is symmetric positive definite

I tried this matrix:

double[][] cv = {
{0.40434286, -0.09376327, 0.30328980, 0.04909388},
{-0.09376327, 0.10400408, 0.07137959, 0.04762857},
{0.30328980, 0.07137959, 0.30458776, 0.04882449},

{0.04909388, 0.04762857, 0.04882449, 0.07543265}

};

And it should throw an exception but it does not. I tested the matrix in R and R's cholesky decomposition method returns that the matrix is not symmetric positive definite.

Obviously your code is not catching this appropriately.

By the way (in my opinion) the use of exceptions to check these conditions is not the best design or use for exceptions. If you are going to force the use to try and catch these exceptions at least provide methods to test the conditions prior to the possibility of the exception.



 All   Comments   Work Log   Change History   Subversion Commits      Sort Order: Ascending order - Click to sort in descending order