MATLAB矩阵生成

MATLAB矩阵生成MATLAB矩阵生成

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

1,

  A=zeros(m,n,p,...)或A=zeros([m,n,p,...]):m*n*p*...全零矩阵
  A=zeros(...,classname):classname表示数据类型

2,

A=ones(m,n,p,...)或A=ones([m,n,p,...]):生成m*n*p*...全1矩阵
 A=ones(...,classname):classname表示数据类型

3,

A=magic(N),N>2:生成一个N*N的魔方矩阵,
    每一行、每一列及对角线元素之和都相等,矩阵元素为1~N*N之间的整数

4,

A=eye(N):产生N*N单位矩阵
A=eye(m,n):产生m*n矩阵,对角线元素为1,其余为0

5,

rand()返回的矩阵元素服从0到1之间的均匀分布
rand(m,n,p,...)或rand([m,n,p,...]):生成m*n*p*... 0到1之间均匀分布的随机数
rand(...,‘double’)或rand(...,‘single’):产生的随机数类型为双精度或单精度浮点数
随机数需要种子,保存随机数的种子可以在下次运行程序时产生完全相同的数据,便于数据和功能的再现。
rand('seed',a):使用MATLAB v4随机数生成器
rand('state',a):使用MATLAB v5随机数生成器
rand('twister',a):使用MATLAB Mersenne Twister随机数生成器
rng(a):新版本MATLAB推荐使用形式,使用Mersenne Twister算法
rng(a,‘v4’)代替rand('seed',a),rng(a,‘v5uniform’)代替 rand('state',a)
rng(‘default’):将种子设为默认值

6,

randn():生成标准正态分布随机数,均值为0,方差为1,
         如果要产生均值为u、标准差为d的正态分布随机数,
         可以采用A=u+d*randn(m,n,p,...)。
randn()调用格式同rand()。

7,

linspace()函数产生线性等分向量。
线性等分向量是一个元素均匀增大或减小的向量。
相邻元素之间的差值相等,相当于等差数列。
linspace(a,b):产生1*100的向量,向量元素值从a均匀变化到b
linspace(a,b,N):产生1*N的向量,向量元素从a均匀变化到b
a:b或colon(a,b):产生从a到b,以1为步进值均匀增加的向量
a:step:b或colon(a,colon,b)产生从a到b以step为步进值均匀增加的向量

8,

logspace(a,b):产生1*50的向量,向量元素值从10^a均匀变化到10^b
logspace(a,b,N):产生1*N的向量,向量元素从10^a均匀变化到10^b

9,

P=randperm(N):返回向量[1,2,...,N]的一个随机排列,
           向量中的元素为1~N之间的整数,每个数字出现且仅出现一次
P=randperm(N,K):返回长度为K的向量,
           其中的元素取自1~N间的整数,元素无重复。K小于或等于N。
perms(A):产生一个向量的所有排列形式

10,

randi生成可重复的均匀分布随机整数。
R=randi(IMAX,N):返回一个N*N随机矩阵,
         矩阵中元素为1~IMAX之间的均匀分布随机整数,IMAX大于1
R=randi(IMAX,M,N)或R=randi(IMAX,[M,N]):返回M*N随机矩阵
R=randi([IMIN,IMAX],...):产生IMIN~IMAX之间的随机整数

11,

diag有两种用法:由对角线元素生成矩阵;由矩阵生成对角线元素
由向量生成矩阵:
X=diag(V,K):V是一个向量,K指定向量V在生成的矩阵中的位置。
             当K=0时返回一个以V为主对角线的方阵,
             当K>0时,V是矩阵主对角线上方的第K条对角线,
             当K<0时,V是矩阵主对角线下方的第|K|条对角线
X=diag(V):相当于diag(V,0)
由矩阵生成向量:
V=diag(X,K):X是一个矩阵,返回一个列向量V,V为矩阵X的第K条对角线。
             当K=0时返回主对角线,
             当K>0时返回矩阵主对角线上方第K条对角线,
             当K<0时返回矩阵主对角线下方第|K|条对角线
V=diag(X):返回矩阵的主对角线

12,

repmat:复制矩阵,形成更大的矩阵或数组
B=repmat(A,[m n])或B=repmat(A,m,n):矩阵A是待复制的矩阵,函数将A视为一个元素,
按照m*n的形式复制、拼接为新的矩阵B。size(B)=[size(A,1)*m,size(A,2)*n]
B=repmat(A,[m n p ...]):返回一个大的多维数组B,B包含m*n*p个矩阵,
   大小为[size(A,1)*m,size(A,2)*n,size(A,3)*p,...]

13,

reshape:改变矩阵的形状而保持元素不变
B=reshape(A,[m n p ...])或B=reshape(A,m,n,p,...):
    矩阵A为待变维的矩阵,元素个数必须和m*n*p*...相等。
    函数将A转变为[m,n,p,...]形状,元素顺序保持列优先
B=reshape(A,siz):按siz指定的形状对矩阵A进行变维
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

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


相关推荐

  • java8中 Collectors.groupingBy用法

    java8中 Collectors.groupingBy用法Collectors.groupingBy根据一个或多个属性对集合中的项目进行分组1、数据准备:publicProduct(Longid,Integernum,BigDecimalprice,Stringname,Stringcategory){this.id=id;this.num=num;this.price=price;this.name=name;this.category=category;}…

    2022年8月20日
    12
  • ros的安装教程_ros可以安装在什么系统

    ros的安装教程_ros可以安装在什么系统一、准备工作1. 一个装有Ubuntu14.04镜像文件的U盘启动盘2. 电脑安装EASYBCD、分区助手软件3. 保证电脑硬盘有一个分区有足够的空间安装ROS,和Ubuntu14.04二、制作启动盘1.首先我们先安装软碟通,完成安装后打开软碟通,文件-&gt;打开,打开我们的iso镜像 2.然后选择我们的U盘,然后点击启动-&gt;写入硬盘映像  3.写入方式有zip和hdd两种,一般我们选择h…

    2025年10月24日
    4
  • SpringBoot框架_若依框架怎么样

    SpringBoot框架_若依框架怎么样SpringBoot框架

    2022年8月20日
    8
  • SpringBoot❤SpringClould常用注解史诗级汇总[通俗易懂]

    SpringBoot❤SpringClould常用注解史诗级汇总[通俗易懂]什么是注解?什什么是注解Java注解是附加在代码中的⼀一些元信息,⽤用于⼀一些⼯工具在编译、运⾏行行时进⾏行行解析和使⽤用,起到说明、配置的功能注解本质上继承Annotation接⼝口,我们可以通过反射获取注解的相关信息,从⽽而做些逻辑操作springboot⾥里里⾯面⼤大量量使⽤用了了注解,@Controller、@RestController、@Service、@Autowire等一、SpringBoot注解1.1.@SpringBootApplication包含@Confi

    2022年7月20日
    12
  • jdk9新特性

    jdk9新特性jdk目录结构变化JDK=JRE+开发工具集(javac编译工具等)JRE=JVM+JavaSE标准类库jdk8的目录结构:jdk9目录结构:模块化先创建两个modul

    2022年7月4日
    24
  • vue实现管理系统_学生管理系统实验报告

    vue实现管理系统_学生管理系统实验报告Vue项目:学生管理系统增删改查一套免费获取

    2022年9月19日
    1

发表回复

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

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