diff options
author | Elizabeth Hunt <elizabeth.hunt@simponic.xyz> | 2023-11-27 10:14:50 -0700 |
---|---|---|
committer | Elizabeth Hunt <elizabeth.hunt@simponic.xyz> | 2023-11-27 10:14:50 -0700 |
commit | aa77d733b0cb100b63a824c60548f19526711bbc (patch) | |
tree | 3f65e1e3381afd5dc43dcdc26317cd7085ca4061 /test | |
parent | 4d2d4f5d7a9f584061b85ef707b3cccee814cbc6 (diff) | |
download | cmath-aa77d733b0cb100b63a824c60548f19526711bbc.tar.gz cmath-aa77d733b0cb100b63a824c60548f19526711bbc.zip |
add leslie matrix dominant eigenvalue unit test
Diffstat (limited to 'test')
-rw-r--r-- | test/eigen.t.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/test/eigen.t.c b/test/eigen.t.c index 9b2f6f0..31c3500 100644 --- a/test/eigen.t.c +++ b/test/eigen.t.c @@ -17,6 +17,30 @@ UTEST(eigen, leslie_matrix) { free_matrix(leslie); free_matrix(m); + free_vector(felicity); + free_vector(survivor_ratios); +} + +UTEST(eigen, leslie_matrix_dominant_eigenvalue) { + Array_double *felicity = InitArray(double, {0.0, 1.5, 0.8}); + Array_double *survivor_ratios = InitArray(double, {0.8, 0.55}); + Matrix_double *leslie = leslie_matrix(survivor_ratios, felicity); + Array_double *v_guess = InitArrayWithSize(double, 3, 1.0); + double tolerance = 0.0001; + uint64_t max_iterations = 64; + + double expect_dominant_eigenvalue = 1.22005; + + double approx_dominant_eigenvalue = + dominant_eigenvalue(leslie, v_guess, tolerance, max_iterations); + + EXPECT_NEAR(expect_dominant_eigenvalue, approx_dominant_eigenvalue, + tolerance); + + free_vector(v_guess); + free_vector(survivor_ratios); + free_vector(felicity); + free_matrix(leslie); } UTEST(eigen, dominant_eigenvalue) { |