当前位置: 首页 > news >正文

Eigen线性代数求解器(分解类)

1. 核心分解类概览

Eigen 提供多种矩阵分解方法,适用于不同矩阵类型(稠密/稀疏、正定/非正定等):

分解类适用矩阵类型分解形式典型应用场景
PartialPivLU方阵(可逆)A=PLUA=PLU通用线性方程组求解
FullPivLU任意矩阵A=P−1LUQ−1A=P−1LUQ−1高稳定性求解(计算成本高)
HouseholderQR任意矩阵(列满秩)A=QRA=QR最小二乘问题(快速但不稳定)
ColPivHouseholderQR任意矩阵A=QRA=QR(列主元)稳定的最小二乘解
FullPivHouseholderQR任意矩阵A=QRA=QR(完全主元)高稳定性(计算成本最高)
LLT正定矩阵A=LLTA=LLTCholesky 分解(快速)
LDLT半正定/正定矩阵A=LDLTA=LDLT带对角调整的 Cholesky

2. 通用方法与属性

所有分解类均继承自 Eigen::SolverBase,提供以下统一接口:

核心方法
方法参数说明返回值/功能示例
compute(const MatrixType& A)A: 待分解矩阵无(更新分解状态)lu.compute(A);
solve(const MatrixType& b)b: 右侧矩阵/向量解 Ax=bAx=bVectorXf x = lu.solve(b);
matrixLU()返回 LU 分解后的矩阵MatrixXd LU = lu.matrixLU();
info()返回计算状态(Success/NumericalIssueif (lu.info() != Success) { /* error */ }
属性
属性说明
rows()cols()返回分解矩阵的行数/列数
rank()返回矩阵的秩(仅 FullPiv* 类支持)

3. 各分解类详解

(1) PartialPivLU(部分主元 LU 分解)
  • 适用场景:通用方阵求解(推荐默认使用)。

  • 特有方法

    cpp

    PermutationMatrix P = lu.permutationP();  // 返回排列矩阵 P
    MatrixXd L = lu.matrixLU().triangularView<UnitLower>();  // 提取 L
    MatrixXd U = lu.matrixLU().triangularView<Upper>();      // 提取 U
(2) HouseholderQR 与 ColPivHouseholderQR
  • 区别:后者通过列主元提高稳定性,但稍慢。

  • 特有方法

    cpp

    MatrixXd Q = qr.householderQ();  // 获取 Q 矩阵(需显式计算)
    VectorXd hCoeffs = qr.hCoeffs(); // 返回 Householder 系数
    // 仅 ColPivHouseholderQR:
    PermutationMatrix P = qr.colsPermutation(); // 列排列矩阵
(3) LLT 与 LDLT(Cholesky 分解)
  • 要求:矩阵必须正定(LLT)或半正定(LDLT)。

  • 特有方法

    cpp

    MatrixXd L = llt.matrixL();  // 获取下三角矩阵 L(LLT)
    VectorXd D = ldlt.vectorD(); // 获取对角矩阵 D(LDLT)

4. 稀疏矩阵分解类

类名适用场景关键方法
SimplicialLLT稀疏正定矩阵analyzePattern()factorize()
SparseLU通用稀疏方阵solve() 支持多右手边
ConjugateGradient稀疏对称正定矩阵(迭代)setTolerance()compute()

5. 代码示例

稠密矩阵求解

cpp

#include <Eigen/Dense>
using namespace Eigen;Matrix3f A;
Vector3f b;
A << 1, 2, 3, 4, 5, 6, 7, 8, 10;
b << 3, 3, 4;// PartialPivLU 分解(推荐默认)
PartialPivLU<Matrix3f> lu(A);
Vector3f x = lu.solve(b);  // 解 Ax = b// Cholesky 分解(正定矩阵)
LLT<Matrix3f> llt(A.transpose() * A);  // A^T A 正定
Vector3f y = llt.solve(A.transpose() * b);  // 解正规方程
稀疏矩阵求解

cpp

#include <Eigen/Sparse>
SparseMatrix<double> mat(100, 100);
VectorXd b = VectorXd::Random(100);// SimplicialLLT 分解
SimplicialLLT<SparseMatrix<double>> solver;
solver.compute(mat);
VectorXd x = solver.solve(b);

6. 选择分解方法的准则

矩阵类型推荐分解类原因
通用稠密方阵PartialPivLU平衡速度与稳定性
最小二乘问题(非对称)ColPivHouseholderQR稳定性优于 HouseholderQR
正定稠密矩阵LLT最快(约 2 倍加速)
稀疏对称正定矩阵SimplicialLLT内存高效

注意事项

  1. 分解重用:若矩阵不变,可先调用 compute(A) 再多次 solve(b) 提高效率。

  2. 数值稳定性:对于病态矩阵,优先选择 FullPivLU 或 ColPivHouseholderQR

  3. 稀疏矩阵:分解前需调用 analyzePattern() 优化内存分配。

通过合理选择分解类,可以显著提升计算性能!更多细节见 Eigen 文档。

相关文章:

  • 代码随想录算法训练营Day31 | 56. 合并区间 738.单调递增的数字
  • 代码随想录算法训练营第二十七天(补)
  • ABAP Object Services
  • 通过gap看margin和padding在布局中的应用
  • 多个请求并行改造
  • 人工智能:入门阶段学习路径
  • 使用Xshell中自带的传输新建文件功能实现上传下载文件
  • PCL点云处理之基于FPFH特征的SAC-IA全局配准算法 (二百四十六)
  • gin框架学习笔记
  • C++篇——继承
  • 04_jQuery
  • 4-26记录(学习通排序测试)
  • TDengine 中的压缩设计
  • springboot入门-repository数据访问层JPA和mybatis
  • NtripShare 2025第一季度主要技术进展
  • Python循环结构深度解析与高效应用实践
  • 2.4goweb项目上传到csdn的git仓库
  • SinSR模型剪枝实验报告
  • 蓝桥杯赛场反思:技术与心态的双重修炼
  • 基于大模型对先天性幽门肥厚性狭窄预测及临床方案的研究报告
  • 西北大学党委副书记吕建荣调任西安财经大学党委书记
  • 本周看啥|在电影院里听民谣,听摇滚,燥起来吧
  • 美称中美贸易谈判仍在进行中,外交部:美方不要混淆视听
  • 专访|攸佳宁:手机只是矛盾导火索,重要的是看见孩子的内心
  • 神舟二十号3名航天员顺利进驻中国空间站
  • 陕西省烹饪餐饮行业领军人物黄建军逝世,终年53岁