How to calculate expm of a badly scaled matrix?
Show older comments
I'm using expm for a matrix with big and small coefficients and I get NaN in the result. Is there a method to get the good matrix exponential even if the matrix is badly scaled? Normally there is a exponential for every matrix.
ALEX
2 Comments
Suppose you had a simple badly scaled matrix like
>> A=diag( [1e6,1] )
A =
1000000 0
0 1
What would you like the result of expm(A) to be? The following has no NaNs. Would it be an okay answer?
>> expmA=diag( exp([1e6,1]) )
expmA =
Inf 0
0 2.7183
alex corno
on 4 Jun 2013
Accepted Answer
More Answers (2)
I think I have a different problem. My matrix isn't even invertible, there are two zero lines, moreover there are some coefficients that are of order of 1e6. In my opinion at some point Matlab is doing some inversion that's why expm doesn't work properly with badly scaled matrices.
No, it's not an invertibility issue. The reason for the NaNs is the big 1e6 order numbers. Below is an example of a non-invertible matrix on which EXPM works fine.
>> expm(diag([1,0]))
ans =
2.7183 0
0 1.0000
3 Comments
Matt J
on 4 Jun 2013
Conversely, just by multiplying this matrix by 1e6,
>> expm(diag([1e6,0]))
ans =
NaN NaN
NaN NaN
alex corno
on 4 Jun 2013
Even if the matrix is well-scaled, you could have the same problem, for example:
>> A=diag([1e6,1e6]); %a well-scaled matrix
>> expm(A)
ans =
NaN NaN
NaN NaN
The bottom line is, you must avoid matrices with large eigenvalues, and then things should be fine. Otherwise, they will not be fine.
There are any number of transformations you could consider to reduce the magnitude of the eigenvalues. Dividing the matrix by a large number is one way, but I can't know if that suits your application.
alex corno
on 5 Jun 2013
0 votes
Categories
Find more on Creating and Concatenating Matrices in Help Center and File Exchange
Products
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!