Added additional doctest and fixed indices (#141)

This commit is contained in:
Chris McComb
2022-08-12 17:38:13 -04:00
committed by GitHub
parent b482acdc8d
commit d905ebea15
6 changed files with 22 additions and 9 deletions
+16 -3
View File
@@ -25,6 +25,19 @@
//! let eigenvectors: DenseMatrix<f64> = evd.V;
//! let eigenvalues: Vec<f64> = evd.d;
//! ```
//! ```
//! use smartcore::linalg::naive::dense_matrix::*;
//! use smartcore::linalg::evd::*;
//!
//! let A = DenseMatrix::from_2d_array(&[
//! &[-5.0, 2.0],
//! &[-7.0, 4.0],
//! ]);
//!
//! let evd = A.evd(false).unwrap();
//! let eigenvectors: DenseMatrix<f64> = evd.V;
//! let eigenvalues: Vec<f64> = evd.d;
//! ```
//!
//! ## References:
//! * ["Numerical Recipes: The Art of Scientific Computing", Press W.H., Teukolsky S.A., Vetterling W.T, Flannery B.P, 3rd ed., Section 11 Eigensystems](http://numerical.recipes/)
@@ -799,10 +812,10 @@ fn sort<T: RealNumber, M: BaseMatrix<T>>(d: &mut [T], e: &mut [T], V: &mut M) {
}
i -= 1;
}
d[i as usize + 1] = real;
e[i as usize + 1] = img;
d[(i + 1) as usize] = real;
e[(i + 1) as usize] = img;
for (k, temp_k) in temp.iter().enumerate().take(n) {
V.set(k, i as usize + 1, *temp_k);
V.set(k, (i + 1) as usize, *temp_k);
}
}
}