mirror of
https://github.com/cirosantilli/linux-kernel-module-cheat.git
synced 2026-01-23 18:25:57 +01:00
eigen: svd example, use pkg-config
This commit is contained in:
24
kernel_module/user/eigen_svd.cpp
Normal file
24
kernel_module/user/eigen_svd.cpp
Normal file
@@ -0,0 +1,24 @@
|
||||
/* Adapted from: https://eigen.tuxfamily.org/dox/classEigen_1_1JacobiSVD.html */
|
||||
|
||||
#include <iostream>
|
||||
using std::cout;
|
||||
using std::endl;
|
||||
|
||||
#include <Eigen/Core>
|
||||
#include <Eigen/SVD>
|
||||
using Eigen::ComputeThinU;
|
||||
using Eigen::ComputeThinV;
|
||||
using Eigen::JacobiSVD;
|
||||
using Eigen::MatrixXf;
|
||||
using Eigen::Vector3f;
|
||||
|
||||
int main() {
|
||||
MatrixXf m = MatrixXf::Random(3,2);
|
||||
JacobiSVD<MatrixXf> svd(m, ComputeThinU | ComputeThinV);
|
||||
Vector3f rhs(1, 0, 0);
|
||||
cout << "m = " << endl << m << endl << endl;
|
||||
cout << "svd.singularValues() = " << endl << svd.singularValues() << endl << endl;
|
||||
cout << "svd.MatrixU() = " << endl << svd.matrixU() << endl << endl;
|
||||
cout << "svd.MatrixV() = " << endl << svd.matrixV() << endl << endl;
|
||||
cout << "svd.solve() = " << endl << svd.solve(rhs) << endl << endl;
|
||||
}
|
||||
Reference in New Issue
Block a user