导航

Gonum矩阵加减乘除

Posted on 2022-04-27 19:26  蝈蝈俊  阅读(450)  评论(0编辑  收藏  举报

加减

加减需要同样尺寸才可以。

a := mat.NewDense(3, 3, []float64{
	1, 2, 3,
	4, 5, 6,
	7, 8, 9})
b := mat.NewDense(3, 3, []float64{
	8, 8, 8,
	8, 8, 8,
	8, 8, 8})
var c mat.Dense
c.Add(a, b)
fmt.Printf("%v\n\n", mat.Formatted(&c))

c.Sub(a, b)
fmt.Printf("%v\n\n", mat.Formatted(&c))

输出

⎡ 9  10  11⎤
⎢12  13  14⎥
⎣15  16  17⎦

⎡-7  -6  -5⎤
⎢-4  -3  -2⎥
⎣-1   0   1⎦

乘法

假设有矩阵\(\textbf{A}\)和矩阵\(\textbf{B}\), 那么 \(\textbf{A}\)能够与\(\textbf{B}\)相乘的前提是\(\textbf{A}\)的列数等于\(\textbf{B}\)行数。


图中\(\textbf{A}\)有3列,那么\(\textbf{B}\)就必须有3行两者才能相乘。至于\(\textbf{A}\)的行数和\(\textbf{B}\)的列数则不影响。

即:如果\(\textbf{A}\)为 \(m \times n\),那么 \(\textbf{B}\) 必须是 \(n \times p\) 的形式,\(\textbf{AB}\)的结果是一个 \(m \times p\) 矩阵。

参考: 矩阵乘法

例子:

a := mat.NewDense(2, 3, []float64{
	1, 2, 3,
	4, 5, 6})
b := mat.NewDense(3, 2, []float64{
	6, 8,
	6, 8,
	6, 8})
var c mat.Dense
c.Mul(a, b)
fmt.Printf("%v\n\n", mat.Formatted(&c))

结果

⎡ 36   48⎤
⎣ 90  120⎦

逆矩阵

逆矩阵

  • 矩阵一定要是"方形" (行和列数目相同)才能有逆矩阵。
  • 行列式不能是零 (不然便要除以零了)

除法

两个数相除,\(a \div b\)有意义须得\(b \neq 0\)。这个条件在矩阵的时候就是\(\textbf{A} \div \textbf{B}\)须得\(\textbf{B}\)可逆。

矩阵的除法不是直接放在分数线上计算的,而是要引入一个新的概念“逆矩阵”,例如矩阵\(\textbf{A}\)的逆矩阵为\(\textbf{A}^{-1}\),则有
\(\textbf{A}\textbf{A}^{-1} = 1\)

比如我们有这样一个问题要解决:

有一个几个家庭组团出去旅行,出发的时候是乘坐大巴,每位儿童3元,每个大人3.2元,一共花费了118.4元。
在回程时,他们选择乘坐火车,每名儿童3.5元,每名成人3.6元,总计135.20元。
那问题来了,这里边有多少个小孩和大人呢?

虽然这道题用线性方程组来解很简单,但这次我们尝试用矩阵思维来解答。

相关的计算代码:

a := mat.NewDense(1, 2, []float64{
	118.4, 135.2})
b := mat.NewDense(2, 2, []float64{
	3, 3.5,
	3.2, 3.6})

var c mat.Dense
c.Inverse(b) // 先求逆矩阵
fmt.Printf("%v\n\n", mat.Formatted(&c))

var d mat.Dense
d.Mul(a, &c) // 与逆矩阵相乘
fmt.Printf("%v\n\n", mat.Formatted(&d))

输出结果:

⎡  -9  8.75⎤
⎣   8  -7.5⎦

[15.999999999999773  22.000000000000114]

一共有16个孩子和22个大人。
参看 逆矩阵的最通俗解析

参考: