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

做捐款网站先建设网站后付款

做捐款网站,先建设网站后付款,网站建设的完整流程包括,紧急紧急626969目录 1、矩阵的构造和初始化操作 2、矩阵的算术运算 3、矩阵的分解和求解 4、矩阵的变换 5、矩阵的访问和修改 6、矩阵遍历 7、线性方程组求解 8、其他操作 Eigen库是一个高级的C库#xff0c;用于线性代数#xff0c;矩阵和向量运算#xff0c;数值分析和相关的数学…目录 1、矩阵的构造和初始化操作 2、矩阵的算术运算 3、矩阵的分解和求解 4、矩阵的变换 5、矩阵的访问和修改 6、矩阵遍历 7、线性方程组求解 8、其他操作 Eigen库是一个高级的C库用于线性代数矩阵和向量运算数值分析和相关的数学运算。这个库提供了大量的矩阵操作功能。 1、矩阵的构造和初始化操作 Eigen::Matrix3f A; // 创建一个3x3的双精度浮点型矩阵A 1, 2, 3, 4, 5, 6, 7, 8, 9;cout3X3 float: \nAendl;Eigen::MatrixXf m Eigen::MatrixXf::Identity(3, 3); // 创建一个3x3的单位矩阵cout3X3 identity: \nmendl;Eigen::MatrixXf mf(3, 3); // 使用构造函数初始化默认初始化为0 Eigen::MatrixXi mi(3, 3); // 创建一个3x3的整型矩阵默认初始化为0cout3X3 mf: \nmfendl;cout3X3 mi: \nmiendl;Eigen::MatrixXf z Eigen::MatrixXf::Zero(3, 3); // 创建一个3x3的全0矩阵Eigen::MatrixXi n Eigen::MatrixXi::Ones(3, 3); // 创建一个3x3的全1矩阵cout3X3 Zero: \nzendl;cout3X3 Ones: \nnendl;Eigen::MatrixXf r Eigen::MatrixXf::Random(3, 3); // 创建一个3x3的随机矩阵cout3X3 random: \nrendl;float data[9] {1, 2, 3, 4, 5, 6, 7, 8, 9};Eigen::MapEigen::MatrixXf mp(data, 3, 3); // 将data数组映射为一个3x3的矩阵cout3X3 map mp: \nmpendl;Eigen::MatrixXf m_i(3, 3);m_i (Eigen::MatrixXf(3, 3)1, 2, 3, 4, 5, 6, 7, 8, 9).finished(); //对于动态大小的矩阵可以使用逗号初始化器但需要在初始化时指定大小coutinitializer m_i: \nm_iendl;Eigen::MatrixXf m_c m_i;coutcopy constructor m_c : \nm_cendl; 2、矩阵的算术运算 Eigen::MatrixXf m1 Eigen::MatrixXf::Identity(3, 3);Eigen::MatrixXf m2 Eigen::MatrixXf::Identity(3, 3);Eigen::Matrix3f sum m1 m2; // 矩阵加法 coutsum : \nsumendl;Eigen::MatrixXf diff m1 m2; // 矩阵减法 coutdiff : \ndiffendl;Eigen::MatrixXf scaled m1 * 2.0f; // 矩阵与标量的乘法 coutscaled : \nscaledendl;Eigen::MatrixXf product m1 * m2.transpose(); // 矩阵乘法coutproduct : \nproductendl;// 矩阵加法 Eigen::Matrix3f C A A;// 矩阵乘法 Eigen::Matrix3f D A * A.transpose();// 向量加法 Eigen::Vector4f e b b;// 点积内积 float dotProduct b.dot(b);// 转置 std::cout Transpose of A:\n A.transpose() std::endl;// 访问元素 std::cout Element (1, 1) of A: A(1, 1) std::endl;3、矩阵的分解和求解 Eigen::MatrixXf m1 Eigen::Matrix3f::Random();cout original matrix:\n m1 endl;// 对矩阵进行特征值分解Eigen::EigenSolverEigen::Matrix3f es(m1);cout eigenvalues:\n es.eigenvalues() endl; cout eigenvectors:\n es.eigenvectors() endl; // 假设我们有一个线性方程组 Ax bEigen::Vector3f b(1, 2, 3);cout vector b:\n b endl;// 使用列主元QR分解求解线性方程组Eigen::Vector3f x m1.colPivHouseholderQr().solve(b);cout Solution x:\n x endl; 4、矩阵的变换 Eigen::MatrixXf m1 Eigen::Matrix4f::Random();cout original matrix:\n m1 endl;// 获取矩阵的转置 Eigen::Matrix4f transposed m1.transpose();cout transposed:\n transposed endl; // 获取矩阵的对角线元素Eigen::Vector4f diagonal m1.diagonal();cout diagonal:\n diagonal endl; // 获取矩阵的逆注意需要先检查矩阵是否可逆if(m1.determinant() ! 0) // 使用行列式检查是否可逆{// 求逆矩阵Eigen::Matrix4f inv_m m1.inverse();cout inverse:\n inv_m endl; // 验证逆矩阵的正确性m * inv_m 应该接近单位矩阵Eigen::MatrixXf identity_check m1 * inv_m;cout identity check:\n identity_check endl; }else { cerr Matrix is singular and cannot be inverted. endl; } 5、矩阵的访问和修改 Eigen::MatrixXf m1 Eigen::Matrix4f::Random();cout original matrix:\n m1 endl;// 取出前3行和前3列的子矩阵Eigen::Matrix3f sub_matrix m1.block(0, 0, 3, 3);cout sub_matrix:\n sub_matrix endl;// 修改矩阵的元素 m1(1, 2) 10; // 将第2行第3列的元素设置为10// 访问矩阵的元素cout Element at (1, 2): m1(1, 2) endl;// 访问矩阵的第2行 Eigen::Vector4f row m1.row(1);cout row 2: row std::endl;// 访问矩阵的第2列 Eigen::Vector4f col m1.col(1);cout col 2: col std::endl;Eigen::MatrixXf m2 Eigen::Matrix3f::Random();cout original matrix:\n m2 endl;// 创建一个4x4的矩阵并初始化 Eigen::Matrix4f m4_4 Eigen::Matrix4f::Zero();// 将3x3矩阵赋值给4x4矩阵的前3行和前3列 m4_4.block(0, 0, 3, 3) m2;cout 4x4 matrix with 3x3 block assigned:\n m4_4 endl; //块操作 // 提取矩阵的第二列 Eigen::Vector3f column A.col(1);// 提取矩阵的前两行 Eigen::Matrix2f topRows A.topRows(2);6、矩阵遍历 3.1 使用迭代器遍历和打印#include iostream #include Eigen/Denseint main() {Eigen::MatrixXd mat(3, 4);mat 1, 2, 3, 4,5, 6, 7, 8,9, 0, 1, 2;// 遍历并打印矩阵的每一行for (int row 0; row mat.rows(); row) {for (Eigen::MatrixXd::RowIterator it mat.row(row).begin(); it ! mat.row(row).end(); it) {std::cout *it ;}std::cout \n;}Eigen::VectorXd vec(5);vec 3, 6, 9, 12, 15;// 遍历并打印向量的所有元素for (Eigen::VectorXd::Iterator it vec.begin(); it ! vec.end(); it) {std::cout *it ;}std::cout \n;return 0; }3.2 直接访问元素并打印 #include iostream #include Eigen/Denseint main() {Eigen::MatrixXd mat(3, 4);mat 1, 2, 3, 4,5, 6, 7, 8,9, 0, 1, 2;// 遍历并打印矩阵的每一行for (int row 0; row mat.rows(); row) {for (int col 0; col mat.cols(); col) {std::cout mat(row, col) ;}std::cout \n;}Eigen::VectorXd vec(5);vec 3, 6, 9, 12, 15;// 遍历并打印向量的所有元素for (int i 0; i vec.size(); i) {std::cout vec(i) ;}std::cout \n;return 0; } 7、线性方程组求解 // 假设A是已知的系数矩阵b是已知的右侧向量 Eigen::VectorXd x; Eigen::MatrixXd A(3, 3); Eigen::VectorXd b(3);// ... 初始化A和b ...// 使用LLT分解求解Axb Eigen::LLTEigen::MatrixXd llt(A); if (llt.info() Eigen::Success) {x llt.solve(b); } else {std::cerr LLT decomposition failed! std::endl; }// 输出解 std::cout Solution: x std::endl; 8、其他操作 Eigen::Matrix3f m1; // 创建一个3x3的双精度浮点型矩阵m1 1, 2, 3, 4, 5, 6, 7, 8, 9;// 计算矩阵的Frobenius范数float norm m1.norm();cout norm of the matrix: norm endl;Eigen::Matrix3f m2; // 创建一个3x3的双精度浮点型矩阵m2 1, 2, 3, 4, 5, 6, 7, 8, 9.0001f;// 检查两个矩阵是否近似相等这里使用1e-5作为精度阈值bool are_approx m1.isApprox(m2, 1e-5);cout are m1 and m2 approximately equal? (are_approx ? Yes : No) endl;
http://www.sczhlp.com/news/179985/

相关文章:

  • 外贸网站是什么意思大型门户网站的建设外包在本公司制作好还是
  • 每日反思(2025.10.09)
  • 软件工程学习日志2025.10.9
  • 供应链优化技术助力应对疫情挑战
  • 搜索关键词 - 呓语
  • 阅读《构建之法》产生的问题
  • 一级a做爰片免费的网站有吗百度联盟广告点击一次收益
  • 做介绍美食网站的菜单的wordpress简题
  • 武安市城乡建设局网站电商推广
  • 社区网站建设工作职责wordpress js代码放哪
  • 建设厅网站的秘钥怎么买连云港建设局电力网站
  • 企业网站源码进一品资源网网站怎么做文件下载
  • 抓好门户网站建设信用门户网站建设规范
  • 网页设计与网站建设课后习题答案wordpress related
  • 淘客手机端网站建设做家教网站赚钱么
  • 仿牌网站安全推广普通话的故事
  • 网站建设硬件需求视频推广计划
  • 建设环境竣工验收网站企业自建站
  • 校园网站建设必要性网站谁做的比较好看的
  • 手机商城网站建设拉新接单网
  • 网站排名seo培训久久建设集团有限公司
  • 中山网站建设文化效果嘉兴服饰网站建设
  • 平面设计可以做网站wordpress 获取用户名
  • 网站备案需要资料flash属于网页制作平台吗
  • 巴南市政建设网站成年男女做羞羞视频网站
  • discuz网站名称舟山网站设计
  • 环球资源网的优势珠海做网站优化
  • 长沙网站开发培训建设网站如何索要素材
  • 天津深圳网站开发定制小说一键生成动漫
  • 做一个网站可以卖东西嘛兰州道路建设情况网站