逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值

逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值1、简单介绍         一个方阵A如果满足,则A可逆,且

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、计算思路

              一个方阵 A 如果满足逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值,则A可逆, 且

                                                 逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值   

              由上面公式可以知道,我们只需求出 A 的伴随阵及A对应的行列式的值即可求出方阵A的

       逆矩阵。下面将分别实现这两个部分。

二、具体实现

       1、计算矩阵A对应的行列式的值

                     引入一个定理: 行列式的值等于它的任一行(列)的各元素与其对应的代数余子式

        乘积之和

                上面定理中提到了代数余子式,其实这个概念很简单。在n阶行列式中位于 (i,  j) 的元素逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值

         代数余子式就是将该元素所在的第i行和第j列划掉后,留下来的n-1阶行列式叫做逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值的余子式,

                 记作逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值。记

    逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值

             逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值叫做元逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值的代数余子式。

                       根据上面这些我们就可以写出 计算矩阵对应的行列式的值的算法了。                                                                         

private static double getValueOfDeterminant(double[][] data) { if(data.length == 1) { return data[0][0]; } if(data.length == 2) { return data[0][0] * data[1][1] - data[0][1] * data[1][0]; } double valueOfDeterminant = 0; double[] elementsMultiplyItsCofactor = new double[data[0].length]; for(int j=0; j<data[0].length; j++) { double cofactorValue = getValueOfDeterminant(getCofactor(data, 0, j)); if(j % 2 == 0) { elementsMultiplyItsCofactor[j] = data[0][j] * cofactorValue; } else { elementsMultiplyItsCofactor[j] = -1 * data[0][j] * cofactorValue; } valueOfDeterminant += elementsMultiplyItsCofactor[j]; } return valueOfDeterminant; }

                       函数 getValueOfDeterminant 中用到了一个函数 getCofactor , 这个函数很简单,就是    

         用来获取矩阵中矩阵A中(i, j)元逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值的余子式的。              

                         

      2、计算获取矩阵A的伴随阵并求逆矩阵

                 伴随阵的定义: 行列式|A|的各个元素的代数余子式逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值 所构成的如下矩阵

                                                             逆矩阵的伴随阵的求法_伴随矩阵与原矩阵的特征值

                 分别计算矩阵A中每个元素的代数余子式,并除以|A|,即可获得矩阵A的逆矩阵.

                 主要代码如下:                     

public static double[][] getMatrixInversion(double[][] data) { //the matrix has no inverse matrix if(data.length != data[0].length) { return new double[][]{}; } //Get value of determinant for the matrix double valueOfDeterminant = getValueOfDeterminant(data);   if(valueOfDeterminant == 0) { //The matrix doesn't have inversion matrix return new double[][]{}; } //Get inversion of the matrix inputed double[][] inversion = new double[data.length][data[0].length]; for(int i=0; i<inversion.length; i++) { for(int j=0; j<inversion[0].length; j++) { double num = getValueOfDeterminant(getCofactor(data, i, j)); if( (i + j) % 2 == 0 ) { inversion[j][i] = num / valueOfDeterminant; } else { inversion[j][i] = -1 * num / valueOfDeterminant; } } } return inversion; }                               

                通过伴随阵来求逆矩阵效率不太高,接下来将会尝试用LU分解法来求解逆矩阵。

 

        3. 后记      

                     后面的文章里讲到了 LU分解求线性方程组 Ax=b。很明显,只要将这里的 矩阵 b 替换成

         与A同型的单位矩阵E,则该线性方程组的解x就是 矩阵A的逆矩阵了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/171659.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 中标麒麟安装deb命令_麒麟源码

    中标麒麟安装deb命令_麒麟源码**中标麒麟NeoKylin-SDK里都有哪些库文件**下边是中标麒麟1-8和14的安装包内容。希望对中标麒麟开发的同学能有些帮助。[root@bogonNeoKylin-SDK]#shinstall.shPleaseselectwhichgroupyouwanttoinstall:1)C-development5)gnome-soft…

    2022年8月10日
    94
  • Java集合详解(超详细)

    Java集合详解(超详细)这里写目录标题一、集合框架的概述二、Collection接口(一)常用方法(二)Iterator迭代器接口(三)JDK5.0新特性–增强for循环:(foreach循环)三、Collection子接口:List接口一、集合框架的概述集合与数组存储数据概述:集合、数组都是对多个数据进行存储操作的结构,简称Java容器。说明:此时的存储,主要指的是内存层面的存储,不涉及到持久化的存储(.txt,.jpg,.avi,数据库中)数组存储的特点:一旦初始化以后,其长度就确定了。数组一旦

    2022年5月25日
    33
  • python和pycharm以及anaconda的安装顺序_简述信息消息信号三者的区别与联系

    python和pycharm以及anaconda的安装顺序_简述信息消息信号三者的区别与联系1、致欢迎词我将详细讲述在学Python初期的各种手忙脚乱的问题的解决,通过这些步骤的操作,让你的注意力集中在Python的语法上以及后面利用Python所解决的项目问题上。而我自己作为小白,很不幸的没有错过任何的坑,都跳了进去,所以在这里写下经验贴,一方面希望能给后来的学者能够高效的避开这些坑,另一方面也算是自己的总结与警告。2、内容大纲2.1安装顺序能够使用Python的安装…

    2022年8月26日
    6
  • java中static关键字的作用_Java:Java中static关键字作用

    java中static关键字的作用_Java:Java中static关键字作用static关键字最基本的用法是:1、被static修饰的变量属于类变量,可以通过类名.变量名直接引用,而不需要new出一个类来2、被static修饰的方法属于类方法,可以通过类名.方法名直接引用,而不需要new出一个类来3、被static修饰的变量、被static修饰的方法统一属于类的静态资源,是类实例之间共享的。@JDK把不同的静态资源放在了不同的类中为什么不把所有静态资源放在一个类里面呢?…

    2022年7月8日
    18
  • 冲刺阶段 – PMP易错概念(持续更新中)

    冲刺阶段 – PMP易错概念(持续更新中)文章目录1.基础概念2.整合管理3.范围管理4.进度管理5.成本管理6.质量管理7.资源管理8.沟通管理9.风险管理10.采购管理11.相关方管理1.基础概念1.“管理层在项目管理方面缺乏经验”不是项目失败的原因。管理层可以不懂项目管理,但项目经理必须要非常精通项目管理,这里还有一个假设就是组织拥有非常充分的组织过程资产,即便经验不足,也可以去学习和借鉴组织过程资产。2.子项目的划分,根据项目的复杂性来划分,以便更好的去管理与控制项目,子项目会细化工作,故增加工

    2022年5月19日
    42
  • 市场上十块钱买一个随身WiFi使用技术手段,插卡流量不限速不限量?

    市场上十块钱买一个随身WiFi使用技术手段,插卡流量不限速不限量?前几天在逛某论坛,发现有人在薅随身WiFi,而随身WiFi竟然是安卓系统,能进系统界面。跟风买了一个来折腾。

    2022年6月7日
    72

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号