Matlab矩阵大全

Matlab矩阵大全目录1.矩阵下标引用2.矩阵合并3、矩阵运算(加、减、乘、除、点乘、点除等)4.Matlab平台提供了大量的常用的运算函数5.生成对角矩阵的基本用法6、生成三对角线上元素相同的矩阵7.m行n列的元素都为0的矩阵

大家好,又见面了,我是你们的朋友全栈君。

最近的项目需要一些矩阵的语法,现汇总如下(后续有时间的话,会继续补充):


                         目录

1.矩阵下标引用

2.矩阵合并

3、矩阵运算(加、减、乘、除、点乘、点除等)

4.Matlab平台提供了大量的常用的运算函数

5.生成对角矩阵的基本用法 

6、生成三对角线上元素相同的矩阵

7.m行n列的元素都为0的矩阵



1.矩阵下标引用

表达式(Matlab程序)   函数功能
A(1) 将二维矩阵A重组为一维数组,返回数组中第一个元素
A(: , j) 返回二维矩阵A中第 j 列 列向量
A( i , :) 返回二维矩阵A中第 i 行 行向量
A(: , j : k) 返回二维矩阵A中第 j 列第 k列 列向量组成的子矩阵
A( i : k , :) 返回二维矩阵A中第 i 行第 k行 行向量组成的子矩阵
A( i : k , j : m)

返回二维矩阵A中第 i 行第 k 行 行向量

第 j 列第 m 列 列向量的交集组成的子矩阵

A(:) 将二维矩阵A中得每列合并成一个列向量
A( j : k) 返回一个行向量,其元素为A(:)中的第 j 个元素到第 k 个元素
A([ j1 j2…]) 返回一个行向量,其元素为A(:)中的第 j1,j2…个元素
A(: , [ j1 j2 …]) 返回矩阵A的第 j1 列、第 j2 列等的列向量
A([ i1 i2 …] : ,) 返回矩阵A的第 i1 行、第 i2 行等的行向量
A([ i1 i2 …] , [ j1 j2 …]) 返回矩阵A的第 j1列、第 j2 列等和矩阵A的第 i1 行、第 i2 行等的元素

下面将常用的几个举例说明:

例如:

A=[1   2 3   4  5;
   12 12 14 56 657;
   23 46 34 67 56 ];

(1)将二维矩阵A转化成一维矩阵(列向量):Matlab 默认将其转化成列向量,需要行向量转置即可

 Matlab程序:  

A(:)  %将二维矩阵其转化成列向量

(2)读取矩阵取前N行或N列的方法

         Matlab程序:

A(1:2,:)  %读取矩阵A前2行
A(:,1:3)  %读取矩阵A前3列

(3)求矩阵中每行或每列的最大值和最小值

         ① 找矩阵A每列的最大值

[max_A,index]=max(A,[],1);

其中,max_A是最大的数值,index是最大的数值所处的位置

        ② 找矩阵A每行的最大值

[max_A,index]=max(A,[],2);
其中,max_A是最大的数值,index是最大的数值所处的位置

       同理可求出每行,每列的最小值。

       ③ 找矩阵A每列的最小值

[min_A,index]=min(A,[],1);
其中,min_A是最小的数值,index是最小的数值所处的位置

      ④ 找矩阵A每行的最小值

[min_A,index]=min(A,[],2);
其中,min_A是最小的数值,index是最小的数值所处的位置

2.矩阵合并

已知矩阵:

A=[1   2  3  4  5;
   12 12 14 56 657;
   23 46 34 67 56];
B=[1 1 1 1 1;
   2 2 2 2 2;
   3 3 3 3 3];

(1)矩阵A,B左右合并

horzcat(A,B); %矩阵A,B左右合并

Matlab矩阵大全

(2)矩阵A,B上下合并

vertcat(A,B); %矩阵A,B上下合并

Matlab矩阵大全

3、矩阵运算(加、减、乘、除、点乘、点除等)

(1)A+B; 表示矩阵A和矩阵B相加(各个元素对应相加);
(2)A-B; 表示矩阵A和矩阵B相减(各个元素对应相减);
(3)A*B; 表示矩阵A和矩阵B相乘;
(4)A.*B; 表示矩阵A和矩阵B对应元素相乘(点乘);
(5)A/B; 表示矩阵A与矩阵B相除法;
(6)A./B; 表示矩阵A和矩阵B对应元素相除(点除);
(7)A^B; 表示矩阵A的B次幂;
(8)A.^B; 表示矩阵A的每个元素的B次幂。

4.Matlab平台提供了大量的常用的运算函数

  函数  运算法则
exp(x) 求以e为底数的x次幂
log(x) 求以e为底数对x值取对数
Log10(x) 求以10为底数x值取对数
sqrt(x) 求x的平方根
sin(x) 正弦函数
cos(x) 余弦函数
tan(x) 正切函数
asin(x) 反正弦函数
acos(x) 反余弦函数
atan(x) 反正切函数
mode(a,b) a与b相除取余数
min(a,b) 返回a, b中较小的数值
max(a,b) 返回a, b中较大的数值
mean(x) 求x的列平均数(列平均)
median(x) 求x的列中位数(列中位数)
sum(x) x中各个列之间的元素求和
rank(x) X矩阵的秩

5.生成对角矩阵的基本用法 

(1)diag(a) 
使用diag(a)命令生成对角矩阵,a为某个向量,如下所示: 

A=diag([1 2 3])

Matlab矩阵大全

(2)diag(a,i) 
使用diag(a,i)命令生成,a为某个向量,i为a向量相对主对角线偏移的列数向上为正,向下为负)。当i=0时,可以直接写成diag(a)。具体情况如下: 

A=diag([1 2 3],1)

Matlab矩阵大全

A=diag([1 2 3],-1)

Matlab矩阵大全

6、生成三对角线上元素相同的矩阵

(1)生成全为1的向量如下:

  • a(1:3,1)=1 

Matlab矩阵大全

  • a=repmat([1],3,1) 

Matlab矩阵大全

注意:a=repmat(A,m,n)是用A矩阵铺成m*n块且每一块都是A的矩阵,如下:

  • >> A=[1,2;3,4];
    >> a=repmat(A,2,3)

Matlab矩阵大全

  • ones(3,1) 

Matlab矩阵大全

(2)生成对角线上元素相同的矩阵 

A=diag(repmat([1],1,5))+diag(repmat([2],1,4),1)+diag(repmat([3],1,4),-1)

Matlab矩阵大全

7.m行n列的元素都为0的矩阵

A=zeros(3,2)

Matlab矩阵大全


后续继续补充。。。。

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

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

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


相关推荐

  • 阿里技术专家详解 Dubbo 实践,演进及未来规划

    阿里技术专家详解 Dubbo 实践,演进及未来规划

    2021年6月28日
    94
  • 我的学习历程

    我的学习历程@[TOC]不负青春,加油干!自我介绍及共勉大家好!我是一名准大三学生,进入编程的大门已经2年的时间,从大一的css与html再到大二的java,javaweb,数据结构与算法(想哭的有没有),mysql,javascript,vue.js,javaee。我从一个啥也不会的小白转变成一个啥都想尝试的大白其中有艰难(调试bug弄了一晚上)有失落(参加蓝桥杯没拿奖)有幸福(用程序给女朋友写了个生日祝福软件)有迷茫(不知道前面的路该怎么选择)。刚进入这个圈子是因为觉得弄计算机的人特别酷,觉得黑客是这个世

    2022年10月5日
    0
  • java中voliate的讲解

    java中voliate的讲解Java并发编程:volatile关键字解析  volatile这个关键字可能很多朋友都听说过,或许也都用过。在Java5之前,它是一个备受争议的关键字,因为在程序中使用它往往会导致出人意料的结果。在Java5之后,volatile关键字才得以重获生机。  volatile关键字虽然从字面上理解起来比较简单,但是要用好不是一件容易的事情。由于volatile关键字是与Java

    2022年6月11日
    135
  • Linux环境PHP5.6升级7.1.8

    Linux环境PHP5.6升级7.1.8

    2021年11月4日
    55
  • 常见的图像增强方法有_图像中值滤波的算法实现

    常见的图像增强方法有_图像中值滤波的算法实现1.对比度拉升采用了线性函数对图像的灰度值进行变换2.Gamma校正采用了非线性函数(指数函数)对图像的灰度值进行变换这两种方式的实质是对感兴趣的图像区域进行展宽,对不感兴趣的背景区域进行

    2022年8月3日
    3
  • Python写的我的世界源码+现成

    文章目录不想阅读代码者跳过正派活于话少今天第一次讲Python不要问我为什么之前不讲,就不讲~(假装自己学过python但是不讲)瞧,标题是什么,敢多说吗(我也不敢多说啊)效果图:源码(903行)from__future__importdivisionimportsysimportmathimportrandomimporttimefromcollectionsimportdequefrompygletimportimagefrompyglet.g

    2022年4月14日
    160

发表回复

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

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