本文发布矩阵(Matrix)的一些初级算法。

一、矩阵的行列式(Determinant)

矩阵行列式是指矩阵的全部元素构成的行列式,设A=(a)是数域P上的一个n阶矩阵,则所有A=(a)中的元素组成的行列式称为矩阵A的行列式,记为|A|或det(A)。若A,B是数域P上的两个n阶矩阵,k是P中的任一个数,则|AB|=|A||B|,|kA|=kⁿ|A|,|A*|=|A|,其中A*是A的伴随矩阵;若A是可逆矩阵,则|A|=|A|。

/// <summary>
/// 计算 A[p,q] 位于 [,]temp 的块辅因子
/// </summary>
/// <param name="matrix"></param>
/// <param name="temp"></param>
/// <param name="p"></param>
/// <param name="q"></param>
/// <param name="n"></param>
private static void BlockCofactor(double[,] matrix, ref double[,] temp, int p, int q, int n)
{int i = 0;int j = 0;for (int row = 0; row < n; row++){for (int col = 0; col < n; col++){if (row != p && col != q){temp[i, j++] = matrix[row, col];if (j == (n - 1)){j = 0;i++;}}}}
}/// <summary>
/// 求矩阵行列式(递归算法)
/// </summary>
/// <param name="N"></param>
/// <param name="matrix"></param>
/// <param name="n"></param>
/// <returns></returns>
public static double Determinant(int N, double[,] matrix, int n)
{if (n == 1){return matrix[0, 0];}double D = 0.0;double[,] temp = new double[N, N];int sign = 1;for (int f = 0; f < n; f++){BlockCofactor(matrix, ref temp, 0, f, n);D += sign * matrix[0, f] * Determinant(N, temp, n - 1);sign = -sign;}return D;
}

二、矩阵的伴随矩阵(Adjoint Matrix)

一个方形矩阵的伴随矩阵是一个类似于逆矩阵的概念。如果二维矩阵可逆,那么它的逆矩阵和它的伴随矩阵之间只差一个系数,对多维矩阵也存在这个规律。然而,伴随矩阵对不可逆的矩阵也有定义,并且不需要用到除法。

/// <summary>
/// 伴随矩阵
/// </summary>
/// <param name="A"></param>
/// <param name="adj"></param>
public static void Adjoint(double[,] matrix, out double[,] adjoint)
{int N = matrix.GetLength(0);adjoint = new double[N, N];if (N == 1){adjoint[0, 0] = 1.0;return;}int sign = 1;double[,] temp = new double[N, N];for (int i = 0; i < N; i++){for (int j = 0; j < N; j++){BlockCofactor(matrix, ref temp, i, j, N);sign = ((i + j) % 2 == 0) ? 1 : -1;adjoint[j, i] = (sign) * (Determinant(N, temp, N - 1));}}
}

三、矩阵的逆矩阵(Inverse Matrix)

设A是一个n阶矩阵,若存在另一个n阶矩阵B,使得: AB=BA=E ,则称方阵A可逆,并称方阵B是A的逆矩阵。矩阵求逆,即求矩阵的逆矩阵。矩阵是线性代数的主要内容,很多实际问题用矩阵的思想去解既简单又快捷。逆矩阵又是矩阵理论的很重要的内容,逆矩阵的求法自然也就成为线性代数研究的主要内容之一。

/// <summary>
/// 矩阵求逆
/// </summary>
/// <param name="A"></param>
/// <param name="inverse"></param>
/// <returns></returns>
public static bool Inverse(double[,] matrix, out double[,] inverse)
{int N = matrix.GetLength(0);inverse = new double[N, N];double det = Determinant(N, matrix, N);if (det == 0){return false;}Adjoint(matrix, out double[,] adj);for (int i = 0; i < N; i++){for (int j = 0; j < N; j++){inverse[i, j] = adj[i, j] / (double)det;}}return true;
}

演算代码:

private void button1_Click(object sender, EventArgs e)
{double[,] A = { {5, -2, 2, 7},{1, 0, 0, 3},{-3, 1, 5, 0},{3, -1, -9, 4}};double d = Algorithm_Gallery.Determinant(4, A, 4);StringBuilder sb = new StringBuilder();sb.Append(Welcome());sb.AppendLine("1、<b>原始矩阵</b>(Source Matrix):<br>");sb.Append(Algorithm_Gallery.ToHtml(A));sb.AppendLine("行列式(Determinant)=" + d + "<br>");Algorithm_Gallery.Adjoint(A, out double[,] adj);sb.AppendLine("<br>2、<b>伴随矩阵</b>(Adjoint Matrix):<br>");sb.Append(Algorithm_Gallery.ToHtml(adj));Algorithm_Gallery.Inverse(A, out double[,] inv);sb.AppendLine("<br>3、<b>逆矩阵</b>(Inverse Matrix):<br>");sb.Append(Algorithm_Gallery.ToHtml(inv));sb.Append(Bye());webBrowser1.DocumentText = sb.ToString();
}

打印矩阵的代码:


public static string ToHtml(double[,] y)
{int m = y.GetLength(0);int n = y.GetLength(1);StringBuilder sb = new StringBuilder();sb.AppendLine("<style>");sb.AppendLine("td { padding:5px;text-align:right; }");sb.AppendLine("</style>");sb.AppendLine("<table width='100%' border=1 bordercolor='#999999' style='border-collapse:collapse;'>");for (int i = 0; i < m; i++){sb.AppendLine("<tr>");for (int j = 0; j < n; j++){sb.AppendLine("<td>" + String.Format("{0:F8}", y[i, j]) + "</td>");}sb.AppendLine("</tr>");}sb.AppendLine("</table>");return sb.ToString();
}

————————————————————————————————

POWER BY  TRUFFER.CN

C#,数值计算,矩阵的行列式(Determinant)、伴随矩阵(Adjoint)与逆矩阵(Inverse)的算法与源代码相关推荐

  1. c语言中用伴随矩阵求逆,C语言求矩阵的行列式、伴随矩阵、逆矩阵

    CSDN大神编写的求矩阵的行列式,intgetA(intarcs[N][N],intn),通过调用递归函数,按矩阵的第一行进行分解,虽然行列式的计算都学过,但是自己写起来还是得费一番功夫的,好在有MA ...

  2. C#,数值计算,矩阵的乔莱斯基分解(Cholesky decomposition)算法与源代码

    一.安德烈·路易斯·乔尔斯基 安德烈·路易斯·乔尔斯基出生于法国波尔多以北的查伦特斯海域的蒙古扬.他在波尔多参加了Lycée e,并于1892年11月14日获得学士学位的第一部分,于1893年7月24 ...

  3. 矩阵的基础知识回顾:矩阵乘法,矩阵的逆,伴随矩阵,矩阵的转置,行列式,相似矩阵,实对称矩阵

    Agenda 1. 矩阵matrix 1.1 矩阵运算matrix operations 1.1.1 矩阵乘法matrix multiplication 1.1.1.1 简化矩阵乘法(facilita ...

  4. armadillo matlab,Armadillo之计算矩阵的行列式(determinant)

    计算矩阵的行列式很简单,用det方法或是log_det方法 1 det(A) 如果A不是方阵的(square),将抛出std::logic_error异常 例: mat m = "3,2,4 ...

  5. 【线性代数(8)】矩阵行列式、伴随矩阵、逆矩阵

    逆矩阵 1 矩阵行列式 2 伴随矩阵 3 逆矩阵 3.1 逆矩阵概念 3.2 逆矩阵的性质 手动反爬虫: 原博地址 知识梳理不易,请尊重劳动成果,文章仅发布在CSDN网站上,在其他网站看到该博文均属于 ...

  6. 线性代数 --- 三种计算矩阵的行列式的方法之二 莱布尼兹展开法(个人笔记扫描版)

    三种计算矩阵的行列式的方法之二 莱布尼兹展开法 在我的个人的线性代数学习中,我分别记录计算矩阵行列式的三种方法,1,LU分解法,2,拉普拉斯展开法,这里我介绍一下第三种方法,莱布尼兹展开法.   行列 ...

  7. 线性代数矩阵行列式_非平方矩阵的行列式| 使用Python的线性代数

    线性代数矩阵行列式 Prerequisites: 先决条件: Defining a Matrix 定义矩阵 Determinant of a Matrix 矩阵的行列式 Note: Determina ...

  8. 线性代数——方阵的行列式、伴随矩阵、逆矩阵

    文章目录 方阵的行列式 性质 伴随矩阵 性质 逆矩阵 性质 Numpy中逆矩阵的函数 方阵的行列式 由n阶方阵A的元素所构成的行列式,称为方阵A的行列式,记作|A|. 性质 |AT| = |A| |λ ...

  9. 搞懂矩阵的转置,矩阵的逆和伴随矩阵(一)

    文章目录 矩阵和行列式的区别: 三种常见的矩阵计算 矩阵的转置 矩阵的逆 伴随矩阵 正交矩阵 矩阵的计算 1. 用伴随矩阵求矩阵的逆 2. 用初等变换来求矩阵的逆 矩阵和行列式的区别: 即使内部元素相 ...

  10. 3D图形:矩阵的行列式,矩阵的逆、正交矩阵、齐次矩阵

    前言 在前面我们说到关于矩阵的一些计算知识,相信大家已经觉得进入了水深火热之中了,那么为了让大家感到更加刺激的视觉体验和感官体验,这一篇博客,我将对矩阵的行列式,矩阵的逆,正交矩阵,齐次矩阵进行探讨研 ...

最新文章

  1. 10-GLBP Weighting //2.1.5(GNS3版本,后面都是如此注明)
  2. 为什么用lazy启动eclipse的时候,插件activator的start自动被调用
  3. boost::type_erasure模块实现了支持多个签名的 Boost.Function 扩展
  4. [导入]九个笑话能告诉你九个人生的道理
  5. android 常用注解,Android 开发小工具之:注解 Annotation
  6. spring思想分析
  7. 论文写作之WPS安装Mathtype插件编写数学公式
  8. Unity学习笔记--无限地图(地图拼接)
  9. php多合一安装包,DOXCX多合一小程序系统Sass平台源码分享
  10. 加多宝李二强:营销数字化闭环初体验,真的很爽
  11. 关于BD文件的一些操作
  12. Arduino - 摇杆模块
  13. 运载火箭飞行控制系统设计
  14. IC设计中节省静态功耗和动态功耗的方法
  15. 为什么很多人吐槽谭浩强的C语言程序设计,端碗吃饭放碗骂娘?
  16. 0922Android传感器实例指南针
  17. Gin框架使用Zap接收日志
  18. linux 识别u盘,移动硬盘,固定硬盘
  19. kubernetes监控-Heapster+InfluxDB+Grafana(十五)
  20. 计算机体系结构的一些总结

热门文章

  1. 7-5 华氏度转摄氏度(四舍五入) (5分) java pta
  2. 关于音频情感分类的随笔(4)
  3. 运放输入偏置电流方向_运放-输入偏置电流与输入失调电流
  4. 摆地摊赚钱方案全攻略
  5. 图灵接口 php,图灵机器人API接口
  6. 【外贸建站规则】外贸网站建站流程有哪些?需要注意什么? (上)
  7. python 正则re模块 group() groups()
  8. 实训项目:PHP双色球效果实现
  9. python里的def方法中->代表什么意思
  10. python中右对齐_python右对齐的实例方法