code review!
下述两种方法是等价的
这个示例演示了使用Eigen库中的SelfAdjointEigenSolver
类来计算一个3x3矩阵的特征值和特征向量。它首先创建一个对称矩阵 matrix_33
,然后通过计算其转置与自身的乘积来准备进行特征值和特征向量计算。
分析:
Eigen::Matrix3d
表示一个3x3的矩阵,matrix_33
是我们创建的对称矩阵。SelfAdjointEigenSolver
是特征值和特征向量求解器的类型,这里使用 SelfAdjointEigenSolver
类来处理对称矩阵。eigen_solver
是我们创建的特征值和特征向量求解器的实例,它在被构造时会计算给定矩阵的特征值和特征向量。eigen_solver.eigenvalues()
用于获取计算得到的特征值,它返回一个向量,表示矩阵的特征值。eigen_solver.eigenvectors()
用于获取计算得到的特征向量,它返回一个矩阵,其中每一列是一个特征向量。确保你已经将Eigen库的头文件路径和库链接路径适配到你的项目配置中,然后编译并运行上述代码。你将会看到特征值和特征向量的输出。这个示例演示了如何使用Eigen库来进行矩阵的特征值和特征向量计算。
代码
#include
#include
int main() {
// 创建一个系数矩阵A和一个常数向量b
Eigen::MatrixXd A(3, 3);
A << 2, -1, 0,
-1, 2, -1,
0, -1, 2;
Eigen::VectorXd b(3);
b << 1, 2, 3;
// 解线性方程组 Ax = b
Eigen::VectorXd x = A.fullPivLu().solve(b);
std::cout << "Coefficient Matrix A:\n" << A << "\n";
std::cout << "Constant Vector b:\n" << b << "\n";
std::cout << "Solution Vector x:\n" << x << "\n";
return 0;
}
代码
#include
#include
int main() {
// 创建一个系数矩阵A和一个常数向量b
Eigen::MatrixXd A(3, 3);
A << 2, -1, 0,
-1, 2, -1,
0, -1, 2;
Eigen::VectorXd b(3);
b << 1, 2, 3;
// 进行QR分解
Eigen::ColPivHouseholderQR<Eigen::MatrixXd> qr(A);
// 解线性方程组 Ax = b
Eigen::VectorXd x = qr.solve(b);
std::cout << "Coefficient Matrix A:\n" << A << "\n";
std::cout << "Constant Vector b:\n" << b << "\n";
std::cout << "Solution Vector x:\n" << x << "\n";
return 0;
}
在C++中,你可以使用Eigen库进行Cholesky分解来解决线性方程组。Cholesky分解是一种用于对称正定矩阵的分解方法,可以有效地解决线性方程组。以下是一个使用Eigen库进行Cholesky分解解线性方程组的示例代码:
在这个示例中,我们首先创建一个系数矩阵 A
和一个常数向量 b
,代表线性方程组 Ax = b
。然后使用LLT
类进行Cholesky分解,如果分解成功(正定矩阵才能成功分解),就调用solve(b)
方法来解线性方程组并计算得到解向量 x
。
请注意,Cholesky分解适用于对称正定矩阵。在使用之前,你应该确保矩阵 A
是对称正定的。如果矩阵不满足这些条件,Cholesky分解将会失败。
确保你已经将Eigen库的头文件路径和库链接路径适配到你的项目配置中,然后编译并运行上述代码。你将会看到系数矩阵、常数向量和解向量的输出。这个示例演示了如何使用Eigen库进行Cholesky分解来解决线性方程组。
代码
#include
#include
int main() {
// 创建一个系数矩阵A和一个常数向量b
Eigen::MatrixXd A(3, 3);
A << 4, 2, 2,
2, 5, 1,
2, 1, 6;
Eigen::VectorXd b(3);
b << 4, 6, 7;
// 进行Cholesky分解
Eigen::LLT<Eigen::MatrixXd> lltOfA(A);
if (lltOfA.info() == Eigen::Success) {
// 解线性方程组 Ax = b
Eigen::VectorXd x = lltOfA.solve(b);
std::cout << "Coefficient Matrix A:\n" << A << "\n";
std::cout << "Constant Vector b:\n" << b << "\n";
std::cout << "Solution Vector x:\n" << x << "\n";
} else {
std::cout << "Cholesky decomposition failed!" << std::endl;
}
return 0;
}
代码
#include
#include
int main() {
using namespace Eigen;
// 创建一个旋转向量,绕 Z 轴旋转 45 度
AngleAxisd rotation_vector(M_PI / 4, Vector3d(0, 0, 1));
// 将旋转向量转换为旋转矩阵
Matrix3d rotation_matrix = rotation_vector.toRotationMatrix();
// 输出旋转向量
std::cout << "Rotation Vector: " << rotation_vector.angle() << " around "
<< rotation_vector.axis().transpose() << "\n";
// 输出旋转矩阵
std::cout << "Rotation Matrix:\n" << rotation_matrix << "\n";
return 0;
}
代码
#include
#include
int main() {
using namespace Eigen;
// 创建一个旋转矩阵,绕 Z 轴旋转 45 度
Matrix3d rotation_matrix;
rotation_matrix << 0.707107, -0.707107, 0,
0.707107, 0.707107, 0,
0, 0, 1;
// 从旋转矩阵中获取旋转向量
AngleAxisd rotation_vector(rotation_matrix);
// 输出旋转向量的角度和轴
std::cout << "Rotation Angle: " << rotation_vector.angle() << " radians\n";
std::cout << "Rotation Axis: " << rotation_vector.axis().transpose() << "\n";
return 0;
}
代码
#include
#include
#include
#include
#include
using namespace std;
using namespace Eigen;
int main(int argc, char** argv) {
// 创建两个旋转四元数 q1 和 q2,表示两个刚体的旋转
Quaterniond q1(0.35, 0.2, 0.3, 0.1), q2(-0.5, 0.4, -0.1, 0.2);
// 归一化旋转四元数,确保表示合法的旋转
q1.normalize();
q2.normalize();
// 创建两个平移向量 t1 和 t2,表示两个刚体的平移
Vector3d t1(0.3, 0.1, 0.1), t2(-0.1, 0.5, 0.3);
// 创建一个点 p1,表示在初始坐标系中的一个点
Vector3d p1(0.5, 0, 0.2);
// 创建两个欧氏变换矩阵 T1w 和 T2w,表示初始坐标系到两个刚体的变换
Isometry3d T1w(q1), T2w(q2);
// 将平移向量 t1 和 t2 分别添加到变换矩阵 T1w 和 T2w 中
T1w.pretranslate(t1);
T2w.pretranslate(t2);
// 计算新的坐标 p2,在第二个刚体的坐标系中的坐标
Vector3d p2 = T2w * T1w.inverse() * p1;
// 输出变换后的坐标 p2
cout << "Transformed Point p2: " << p2.transpose() << endl;
return 0;
}
代码
// 逐元素操作Vectorized operations on each element independently
// Eigen // Matlab //注释
R = P.cwiseProduct(Q); // R = P .* Q //逐元素乘法
R = P.array() * s.array(); // R = P .* s //逐元素乘法(s为标量)
R = P.cwiseQuotient(Q); // R = P ./ Q //逐元素除法
R = P.array() / Q.array(); // R = P ./ Q //逐元素除法
R = P.array() + s.array(); // R = P + s //逐元素加法(s为标量)
R = P.array() - s.array(); // R = P - s //逐元素减法(s为标量)
R.array() += s; // R = R + s //逐元素加法(s为标量)
R.array() -= s; // R = R - s //逐元素减法(s为标量)
R.array() < Q.array(); // R < Q //逐元素比较运算
R.array() <= Q.array(); // R <= Q //逐元素比较运算
R.cwiseInverse(); // 1 ./ P //逐元素取倒数
R.array().inverse(); // 1 ./ P //逐元素取倒数
R.array().sin() // sin(P) //逐元素计算正弦函数
R.array().cos() // cos(P) //逐元素计算余弦函数
R.array().pow(s) // P .^ s //逐元素计算幂函数
R.array().square() // P .^ 2 //逐元素计算平方
R.array().cube() // P .^ 3 //逐元素计算立方
R.cwiseSqrt() // sqrt(P) //逐元素计算平方根
R.array().sqrt() // sqrt(P) //逐元素计算平方根
R.array().exp() // exp(P) //逐元素计算指数函数
R.array().log() // log(P) //逐元素计算对数函数
R.cwiseMax(P) // max(R, P) //逐元素计算R和P的最大值
R.array().max(P.array()) // max(R, P) //逐元素计算R和P的最大值
R.cwiseMin(P) // min(R, P) //逐元素计算R和P的最小值
R.array().min(P.array()) // min(R, P) //逐元素计算R和P的最小值
R.cwiseAbs(P) // abs(P) //逐元素计算R和P的绝对值
R.array().abs() // abs(P) //逐元素计算绝对值
R.cwiseAbs2() // abs(P.^2) //逐元素计算平方
R.array().abs2() // abs(P.^2) //逐元素计算平方
(R.array() < s).select(P,Q); // (R < s ? P : Q) //根据R的元素值是否小于s,选择P和Q的对应元素
R = (Q.array()==0).select(P,A) // R(Q==0) = P(Q==0) R(Q!=0) = P(Q!=0) //根据Q中元素等于零的位置选择P中元素
R = P.unaryExpr(ptr_fun(func)) // R = arrayfun(func, P) // 对P中的每个元素应用func函数
参考链接:一文学会Eigen库