Skip to content

Commit

Permalink
Update principal_eigenvalue.jl
Browse files Browse the repository at this point in the history
  • Loading branch information
matthieugomez committed Feb 15, 2023
1 parent 76401b6 commit 95bff3a
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions src/principal_eigenvalue.jl
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,14 @@ In other words, all eigenvalues of 𝕋 have real part <= 0. This means that
"""
function principal_eigenvalue(𝕋; r0 = ones(size(𝕋, 1)))
Ξ·, r = 0.0, r0
# faster in certain cases
if maximum(abs.(sum(𝕋, dims = 1))) < 1e-9
a = 0.0
vals, vecs = Arpack.eigs(𝕋 + a * I; v0 = collect(r0), nev = 1, which = :SM)
a, Ξ·, r = 0.0, 0.0, r0
# faster in certain cases. Check that all sum up to zero
try
@assert maximum(abs.(sum(𝕋, dims = 1))) < 1e-9
vals, vecs = Arpack.eigs(𝕋; v0 = collect(r0), nev = 1, which = :SM)
Ξ· = vals[1]
r = vecs[:, 1]
else
catch
a = - minimum(diag(𝕋))
try
vals, vecs = Arpack.eigs(𝕋 + a * I; v0 = collect(r0), nev = 1, which = :LM)
Expand Down

0 comments on commit 95bff3a

Please sign in to comment.