当前位置: 首页 > 编程日记 > 正文

线性代数-矩阵-【5】矩阵化简 C和C++实现

点击这里可以跳转至

【1】矩阵汇总:http://www.cnblogs.com/HongYi-Liang/p/7287369.html

【2】矩阵生成:http://www.cnblogs.com/HongYi-Liang/p/7275278.html

【3】矩阵加减:http://www.cnblogs.com/HongYi-Liang/p/7287403.html

【4】矩阵点乘:http://www.cnblogs.com/HongYi-Liang/p/7287324.html

【5】矩阵化简:现在的位置

(待续)

...


C++语言:

高斯消元法:

继续使用这个矩阵

当我们使用高斯消元(无回代)化简这个矩阵,是这样算的:

上述过程归纳为:

  1. 找到第一行行的主元(第一行第一个数:1)
  2. 消除第而三行的的第一个数(r2-2*r1;r3-4*r1)
  3. 找到第二行的主元(第二行第二个数:-2)
  4. 消除第三行的第二个数(r3-3/2*r2)

可以发现实际上是1和2两个步骤的循环,所以写成循环的形式

  • 从第一行开始到最后一行
  1. 找主元:找出第i的主元(第i行第i个数)
  2. 消元:消除下面所有行的第i个数(下面每一行减去x倍的第一行来消除第i列)

到目前为止,基本达到消元的目的了,但是有一些小小的瑕疵

我们可能碰到一个这样矩阵,有一行全是0,例如这个:

那么我们在步骤1中搜索到主元为0的话,0的任意倍数都是0,会导致第2步无法进行。所以我们需要添加换行的操作,计算方法为:

所以我们把代码逻辑修改成这样:

  • 从第一行开始到最后一行
  1. 找主元:找出第i的主元(第i行第i个数),若主元为0,把第i行向下换行,直到找到有主元的行。若找不到主元,就开始找下一个
  2. 消元:消除下面所有行的第i个数(下面每一行减去x倍的第一行来消除第i列)

下面就是高斯消元的主程序:

template <typename T>
bool Matrix<T>::GaussianElimination()
{Matrix<T> outputMatrix = *this;/*Gaussian elmiation*/for(int k=0;k<outputMatrix.m_iRows;k++){/*if all the pivot have been found*/if(k>=m_iColumns){break;}/*exchange rows downward to find the row's pivot*/for(int i=k+1;i<outputMatrix.m_iRows;i++){/*pivot is non-zero*/if(outputMatrix.m_vecMatrix[k][k] != 0){//T temp = outputMatrix.m_vecMatrix[0][0];break;}else{            if(i < outputMatrix.m_iRows){outputMatrix.exchangeRows(k,i);}}}/*if there is no pivot in this row*/if(outputMatrix.m_vecMatrix[k][k] == 0){break;}/*elimination:The rows below pivot row subtract times of pivot row*/for(int i=k+1;i<outputMatrix.m_iRows;i++){double RowsfirstData = outputMatrix.m_vecMatrix[i][k]/outputMatrix.m_vecMatrix[k][k];//Save the first data of next(k+1) rows if(RowsfirstData != 0) {outputMatrix.m_vecMatrix[i][k]=0;for(int j=k+1;j<outputMatrix.m_iColumns;j++){outputMatrix.m_vecMatrix[i][j] -= RowsfirstData*outputMatrix.m_vecMatrix[k][j] ;}}}}*this = outputMatrix;return true;
}

高斯-若尔当法

若尔当在高斯消元的基础上加上了回代过程,把矩阵化简成行最简式。我们在高斯消元的基础上加上和回代,方法跟高斯消元相反,用上面的行减下面的行,这里就不详细描述(展开查看代码)

rref()//化简矩阵成行最简

template <typename T>
bool Matrix<T>::rref()
{Matrix<T> outputMatrix = *this;int rank=0;//the rank of the matrix, how many columns's pivot will it has(-1)/*Gaussian elmiation*/for(int k=0;k<outputMatrix.m_iRows;k++){/*if all the pivot elem have been found*/if(k>=m_iColumns){break;}/*exchange rows downward to find the pivot row*/for(int i=k+1;i<outputMatrix.m_iRows;i++){/*pivot is non-zero*/if(outputMatrix.m_vecMatrix[k][k] != 0){//T temp = outputMatrix.m_vecMatrix[0][0];rank++;break;}else{            if(i < outputMatrix.m_iRows){outputMatrix.exchangeRows(k,i);}}}/*if there is no pivot in this row*/if(outputMatrix.m_vecMatrix[k][k] == 0){break;}/*elimination:The rows below pivot row subtract times of pivot row*/for(int i=k+1;i<outputMatrix.m_iRows;i++){double RowsfirstData = outputMatrix.m_vecMatrix[i][k]/outputMatrix.m_vecMatrix[k][k];//Save the first data of next(k+1) rows if(RowsfirstData != 0) {outputMatrix.m_vecMatrix[i][k]=0;for(int j=k+1;j<outputMatrix.m_iColumns;j++){outputMatrix.m_vecMatrix[i][j] -= RowsfirstData*outputMatrix.m_vecMatrix[k][j] ;}}}}/*normalizing:set all pivots to 1*/for(int i=0;i<outputMatrix.m_iRows;i++){for(int j=0;j<outputMatrix.m_iColumns;j++){if(outputMatrix.m_vecMatrix[i][j] !=0 )//pivot has been foound
            {double pivot = outputMatrix.m_vecMatrix[i][j];//get pivotfor(int k=i;k<outputMatrix.m_iColumns;k++){outputMatrix.m_vecMatrix[i][k] /=pivot;}break;}}}/*Back substitution*/for(int i = rank;i>=1;i--){/*find a first non-zero elem (It is pivot)*/for(int j=0;j<outputMatrix.m_iColumns;j++){double times=0;if(outputMatrix.m_vecMatrix[i][j] !=0)//pivot found
            {for(int l=i-1;l>=0;l--){times = outputMatrix.m_vecMatrix[l][j]/outputMatrix.m_vecMatrix[i][j]; for(int k=j;k<outputMatrix.m_iColumns;k++)//tims of this row subtract by each columns in upon row 
                    {outputMatrix.m_vecMatrix[l][k] -= times*outputMatrix.m_vecMatrix[i][k];}}break;}}}*this = outputMatrix;return true;
}
View Code

rrefmovie()//化简矩阵成行最简,并打印过程

template <typename T>
bool Matrix<T>::rrefmovie()
{Matrix<T> outputMatrix = *this;int rank=0;//the rank of the matrix, how many columns's pivot will it has(-1)/*Gauss elmiation*/cout<<"Gauss elimination:"<<endl;outputMatrix.printfAll();for(int k=0;k<outputMatrix.m_iRows;k++){/*If all the pivot elem have been found*/if(k>=m_iColumns){break;}/*Exchange rows downward to find the pivot row*/for(int i=k+1;i<outputMatrix.m_iRows;i++){/*Pivot is non-zero*/if(outputMatrix.m_vecMatrix[k][k] != 0){rank++;break;}else{            if(i < outputMatrix.m_iRows){outputMatrix.exchangeRows(k,i);}}if(k!=i){cout<<"row"<<k+1<<" exchange row"<<i+1<<endl;//Debug
                outputMatrix.printfAll();}}/*If there is no pivot in this row*/if(outputMatrix.m_vecMatrix[k][k] == 0){break;}/*Elimination:The rows below pivot row subtract times of pivot row*/for(int i=k+1;i<outputMatrix.m_iRows;i++){double RowsfirstData = outputMatrix.m_vecMatrix[i][k]/outputMatrix.m_vecMatrix[k][k];//Save the first data of next(k+1) rows if(RowsfirstData != 0) {outputMatrix.m_vecMatrix[i][k]=0;for(int j=k+1;j<outputMatrix.m_iColumns;j++){outputMatrix.m_vecMatrix[i][j] -= RowsfirstData*outputMatrix.m_vecMatrix[k][j] ;}}cout<<"row"<<i+1<<" - "<<RowsfirstData<<"*"<<"row"<<k+1<<endl;//Debug
            outputMatrix.printfAll();}}/*Normalizing:set all rows pivot to 1*/for(int i=0;i<outputMatrix.m_iRows;i++){for(int j=0;j<outputMatrix.m_iColumns;j++){if(outputMatrix.m_vecMatrix[i][j] !=0 )//pivot has been foound
            {double pivot = outputMatrix.m_vecMatrix[i][j];//get pivotfor(int k=i;k<outputMatrix.m_iColumns;k++){outputMatrix.m_vecMatrix[i][k] /=pivot;}cout<<"row"<<i+1<<" / "<<pivot<<endl;//DebugoutputMatrix.printfAll();//Debugbreak;}}}/*Back substitution*/cout<<"Back substitution:"<<endl;for(int i = rank;i>=1;i--){/*find a first non-zero elem (It is pivot)*/for(int j=0;j<outputMatrix.m_iColumns;j++){double times=0;if(outputMatrix.m_vecMatrix[i][j] !=0)//pivot found
            {for(int l=i-1;l>=0;l--){times = outputMatrix.m_vecMatrix[l][j]/outputMatrix.m_vecMatrix[i][j]; for(int k=j;k<outputMatrix.m_iColumns;k++)//tims of this row subtract by each columns in upon row 
                    {outputMatrix.m_vecMatrix[l][k] -= times*outputMatrix.m_vecMatrix[i][k];}cout<<"row"<<l+1<<" - "<<times<<"*"<<"row"<<i+1<<endl;outputMatrix.printfAll();}break;}}}*this = outputMatrix;return true;
}
View Code

使用我们开始的矩阵测试:

    Matrix<double> matrix(3,3);matrix.setSpecifiedElem(0,0,1);matrix.setSpecifiedElem(0,1,2);matrix.setSpecifiedElem(0,2,3);matrix.setSpecifiedElem(1,0,2);matrix.setSpecifiedElem(1,1,2);matrix.setSpecifiedElem(1,2,2);matrix.setSpecifiedElem(2,0,4);matrix.setSpecifiedElem(2,1,5);matrix.setSpecifiedElem(2,2,6);matrix.printfAll();matrix.rrefmovie();matrix.printfAll();system("pause");

结果:

转载于:https://www.cnblogs.com/HongYi-Liang/p/7464850.html

相关文章:

哈佛管理论丛:谁背上了令人讨厌的猴子

先说说我的读后感想&#xff1a; 在团队管理中&#xff0c;应该尽量明晰的界定每一位团队成员在当前的任务中充当的角色和应该负责的职责。 实际的执行方法就是&#xff1a;约定好给猴子喂食的时间&#xff0c;并且确定在喂食时间到来时&#xff0c;猴子应该长成什么样子。 所以…

json_encode 中文不乱码

echo json_encode("中文", JSON_UNESCAPED_UNICODE);//"中文" 转载于:https://www.cnblogs.com/zxqblogrecord/p/10300244.html

Android-room的学习

目录 关于ROOM 1.Room有3个主要的组件 2.Room 不同组件之间的关系如图所示 3.导入ROOM&#xff08;使用 Room 需要添加依赖&#xff09; 4.&#xff08;实现数据库操作的步骤&#xff09;以下代码段包含具有一个实体和一个 DAO 的示例数据库配置 实例demo 1.Student.java …

JDK5中的控制台输入

Scanner类是JDK5新添加的一个类&#xff0c;主要作用是处理输入流、文件和文本内容等 。这个类在java.util包里面&#xff0c;实现了Iterator接口&#xff0c;而且io处理采用了jdk1.4才发布的nio。由于这个类实现了Iterator接口&#xff0c;如果全部是string的话&#xff0c;就…

[BZOJ3779]重组病毒(LCT+DFS序线段树)

同[BZOJ4817]树点涂色&#xff0c;只是多了换根操作&#xff0c;分类讨论下即可。 1 #include<cstdio>2 #include<algorithm>3 #define lc ch[x][0]4 #define rc ch[x][1]5 #define ls (x<<1)6 #define rs (ls|1)7 #define lson ls,L,mid8 #define rson rs,m…

UVA - 1594 Ducci Sequence

/*做这题时的心路历程其实挺有趣的一开始看到说Ducci序列最终要么全0&#xff0c;要么循环&#xff0c;我在想&#xff1a;要怎么判断循环呢&#xff1f;是不是还得记录下循环节什么的&#xff1f;是该用数组记录循环节吗&#xff1f;还是想要让我们利用STL来记录&#xff1f;后…

RTF密码破解

有一个RTF文件带密码&#xff0c;用文本编辑器察看&#xff0c;有类似“password”字样。为了编辑它&#xff0c;有两个方法&#xff1a; 1、用word2000打开该文件&#xff0c;Tools--〉Unprotect Document&#xff0c;执行后&#xff0c;文件就可以正常编辑了。如果有多个文件…

Android 数据存储-内外部存储测试

案例分析&#xff1a;FilePersistenceTest 在EditText中输入文本内容&#xff0c;退出应用程序或者 单击“保存”按钮时 保存EditText中的数据到名 为“data”的文件中。 打开Device File Explorer&#xff0c;该文件应该存于 /data/data/cn.edu.hunnu.filepersistencetest/…

微软以后要是也开源也免费,java还竞争过.NET吗?

上次参加招聘会&#xff0c;看得到好多大公司都要求精通java&#xff0c;可惜上大学大一就学了.NET,而java到大三才开&#xff0c;并且草草地只讲了些基本知识。有时我就在想难道学当初选择.NET真的错了吗&#xff1f;java确实比.NET存在很多优势。开源、跨平台、免费、开发工具…

Android Studio开发环境及第一个项目

1. 在你的电脑上搭建Android平台开发环境。 2. 新建项目&#xff0c;实现以下基本内容&#xff1a; (1) 修改默认的APP的名称和图标&#xff08;任意的&#xff0c;非默认的&#xff09;。 (2) 显示个人信息&#xff0c;包括&#xff1a;照片、专业、姓名、学号等基本信息。…

去除inline-block元素间距

转载于:https://www.cnblogs.com/keepitreal/p/10301199.html

C#ListView控件添加Checkbox复选框并获取选中的数目,检查checkbox是否勾选

[转载]原地址&#xff1a;http://blog.csdn.net/lucky51222/article/details/41892429 具体方法 1、添加复选框 并且如下设置 listView1.CheckBoxes true; 2、选中listview并获取选中的数目&#xff1a; 具体代码 private void listView1_ItemChecked(object sender, ItemChec…

weblogic学习笔记(1)

weblogic安装、配置和启动 1、weblogic安装转载于:https://blog.51cto.com/pengchenga/66424

react 从使用 看定义

如果你创建了一个类似元素做出反应Twitter的下面&#xff0c;你会的组件定义Twitter的样子&#xff1f; <Twitter usernametylermcginnis33>{(user) > user null? <Loading />: <Badge info{user} />} </Twitter> import React, { Component, Pro…

Android 活动与活动间数据传递

实验内容 综合运用基本组件完成一个注册与登录的应用程序设计。要求基于基础控件&#xff0c;综合使用Intent实现Android的Activity之间信息交换。系统包含启动页、注册页、登录页3个页面&#xff0c;具体要求如下&#xff1a; 1.注册页面和功能的实现。 –界面要求包含用户…

Selenium-js弹窗浮层

学习过js的小伙伴会发现&#xff0c;我们在一些实例中用到了alert()方法、prompt()方法、prompt()方法&#xff0c;他们都是在屏幕上弹出一个对话框&#xff0c;并且在上面显示括号内的内容&#xff0c;使用这种方法使得页面的交互性更精彩&#xff0c;实际上我们经常会在进行网…

JAVA基础(JAVA 执行环境) 第一天

JAVA程序有3中执行环境。 &#xff08;1&#xff09;能够单独运行的程序&#xff0c;称为Java Application(Java应用程序)。 &#xff08;2&#xff09;在Internet浏览器中运行的程序&#xff0c;称为 Java Applet&#xff08;JAVA小用用程序&#xff09;。Applet是一个在WEB浏…

ERP图形目录

这些天正在研究ERP&#xff0c;老师要求我们自己制作一个ERP出来。找了不少资料&#xff0c;就这个图形目录比较有学习价值。这个图形目录是PDF文件&#xff0c;包括销售管理、采购管理、库存管理、制作标准管理、计划管理、车间管理、JIT生产管理、质量管理、财务管理、人力资…

JSP学习笔记(五):日期处理、页面重定向、点击量统计、自动刷新和发送邮件...

一、JSP 日期处理&#xff1a; 使用JSP最重要的优势之一&#xff0c;就是可以使用所有Java API。本节讲述Java中的Date类&#xff0c;它在java.util包下&#xff0c;封装了当前日期和时间。 Date类有两个构造函数。第一个构造函数使用当前日期和时间来初始化对象&#xff1a;D…

完善登录注册页面

实验内容 综合运用基本组件完成一个注册与登录的应用程序设计。要求基于基础控件&#xff0c;综合使用Intent实现Android的Activity之间信息交换。系统包含启动页、注册页、登录页3个页面&#xff0c;具体要求如下&#xff1a; 在第2周上机作业的基础上&#xff0c;完善登录注…

EF 批量 添加 修改 删除

1批量添加 db.T_Investigator.AddRange(list) 2批量删除 db.T_Investigator.RemoveRange(list) 3批量修改 for 循环修改。 注意&#xff1a; 先查询出来&#xff0c;最后savechange&#xff08;&#xff09;&#xff0c;写在一个事务中&#xff0c;一次请求一个上下文。…

在IE7中无效的解决办法

通过ShowModalDialog 打开页面,在POSTBACK时,打开新的页面&#xff0c; 在IE6下没问题,只有在IE7下,会重新打开一新页面&#xff0c; 其实只要把<base target"_self"/> 放到 <head>下即可。 <head> <base target"_self"/> …

简单的纹理管理器

简单的纹理管理器 罗朝辉 (http://www.cnblogs.com/kesalin/)本文遵循“署名-非商业用途-保持一致”创作公用协议游戏中的资源一般都是由资源管理器来处理的&#xff0c;资源管理器负责载入&#xff0c;释放&#xff0c;以及根据资源ID返回相关资源供游戏程序使用。下面改写sph…

记住密码以及Android 列表的操作

1.综合使用RecycleView&#xff0c;CardView&#xff0c;Adapter实现一个宝宝相册&#xff0c;并将其加入到实验一形成的应用中&#xff0c;使得&#xff1a;用户成功登录后转到宝宝相册所在的主界面。还要求实现&#xff1a;用户单击对应的列表子项的不同部位时给出不同的Toas…

python-----利用filecmp删除重复文件

以下代码素材自取&#xff1a;链接&#xff1a;https://pan.baidu.com/s/1fL17RjKyGjpvpeeUFONCaQ 提取码&#xff1a;zgiw # coding:utf-8 import os import filecmp# 将指定目录下的所有文件的路径存储到all_files变量中 def get_all_files(path, dirs):all_files []for d …

如何设置REUSE_ALV_GRID_DISPLAY'的单个单元格的是否可以输入

代码如下&#xff1a;具体说明参见红色说明(本例子是从订单明细提取两个字段的数据到内表) REPORT ZALV_EDIT.TYPE-POOLS: SLIS.*- FieldcatalogDATA: IT_FIELDCAT TYPE LVC_T_FCAT.DATA: X_FIELDCAT TYPE LVC_S_FCAT.DATA: X_LAYOUT TYPE LVC_S_LAYO. "第1步&#xff1a;…

记一次生产的bug

第一个在代码中使用 new SimpleDateFormat("EEEE")来判断周几。在本地测试过程中通过日志打印出来的周几 比如周日对应的是中文汉字“星期日”&#xff0c;然后使用判断 if("星期日".equals(weekDay)){ } (其中weekDay是要使用的日期)。在本地测试通过后…

企业ERP制度的“执行力”

一直都很想说这个话题。可能很多人不是太理解这个标题&#xff0c;企业ERP制度是指完成了ERP系统实施的企业&#xff0c;为了维持ERP系统的持续运行而建立的ERP运行制度。执行力就不用多说了&#xff0c;就是ERP运行制度到底执行了多少&#xff0c;怎么执行的问题。许多管理软件…

python学习点滴记录-Day10-线程

多线程 协程 io模型 并发编程需要掌握的点&#xff1a; 1 生产者消费者模型2 进程池线程池3 回调函数4 GIL全局解释器锁 线程 理论部分 &#xff08;摘自egon老师博客&#xff09; 一、定义&#xff1a; 在传统操作系统中&#xff0c;每个进程有一个地址空间&#xff0c;而且默…

适配设备的简易新闻浏览器

同时兼容手机和平板。 进入应用后先显示新闻列表&#xff0c;当在手机上使用时&#xff0c;使用单页模式&#xff0c;单击列表项会打开新的页面。 当在平板上使用时&#xff0c;使用双页模式&#xff0c;单击左侧列表项时直接更新右侧新闻内容页。 MainActivity.java pack…