matlab基本语法

基本语法

变量命名规则

  • 区分大小写
  • 长度不超过63位
  • 字母开头,可以有字母、下划线和数字组成,但不能使用标点
  • 应该简洁明了

命令行窗口

>>>clc 清楚命令窗口

>>> claer all 清理工作区内容

注释

%% 注释符

数据类型

1.数字

1+1

2*2

1/1

10-7

2.字符串

matlab 复制代码
s = 'a'
abs(s)  %%Ascll码
char(65) %% 65代表 'a'
num2str(65)%% 代表65

str = 'I Love MATLAB'
length(str) %%计算字符串长度

3.矩阵

matlab 复制代码
A = [1 2 3;4 5 2;3 2 7;4 6 8] %% 3*3矩阵
B = A' %% 矩阵转置
C = A(:) %% 把A矩阵拉长(竖着拉长)
D = inv(A) %% 矩阵的求逆【矩阵必须是方阵】
A * D

E = zeros(10,5,3) %% 生成三维 10*5的0矩阵
E(:,:,1) = rand(10,5)
E(:,:,2) = randi(5,10,5) 
E(:,:,1) = randn(10,5)

1.rand生成均匀分布的伪随机数。分布在(0~1)之间

主要语法:rand(m,n)生成m行n列的均匀分布的伪随机数

rand(m,n,'double')生成指定精度的均匀分布的伪随机数,参数可以 是'single'

rand(RandStream,m,n)利用RandStram(类似于随机种子)生成伪随机数

2.randn 生成标准正态分布的伪随机数(均值为0,方差为1)

主要语法:与rand一样

3.randi 生成均匀分布的伪随机数

主要语法:randi(iMax)在开区间(0,iMax)生成均匀分布的伪随机整数

​ randi(iMax,m,n)在开区间(0,iMax)生成mXn型随机矩阵

​ r = randi([iMin,iMax],m,n)在开区间(iMin,iMax)生成mXn型随机矩阵

4.元胞数组

定义

matlab 复制代码
A = cell(1,6) %%
A{2} = eye(3) %% 生成3*3对角线为1单位矩阵
A{5} = magic(5)%% 生成n阶的幻方矩阵
B = A{5}

5.结构体

matlab 复制代码
books = struct('name',{{'Machine','Data Mining'}},'price,[30,40]')

MATLAB矩阵操作

矩阵定义与构造

matlab 复制代码
A = [1 2 3 5 8 5 4 6]
B = 1:3:9 %%[1,9]步长为3
C = repmat(B,3,1) %% 让B重复三行一列(横着重复3次 竖着重复1次)
D = ones(2,4)%% 生成2*4全1的矩阵

矩阵运算

matlab 复制代码
A = [1 2 3 4;5 6 7 8]
B = [1 1 2 2;2 2 1 1]
C = A + B
D = A - B
E = A * B'
F = A. *B %% 对应项相乘
G = A / B %%相当于A乘以B的逆
H = A./B %% 对应项相除

矩阵下标

注意:下标从1开始

matlab 复制代码
A = magic(5);
B = A(2,3)
C = A(:,4)
D = A(:,4)
[m,n] = find(A > 20)

循环结构

for

结构

for 循环变量 = 初值 : 步长 :终值

​ [执行语句]

end

for 循环变量 = 初值 : 终值 (步长 1)

​ [执行语句]

end

matlab 复制代码
%% 求和1^2 + 2^2 + 3^3 + 4^2 + 5^2
sum = 0
for n = 1 : 5
    sum = sum + n^2;
end
sum

while

while 条件表达式

​ [执行语句]

end

matlab 复制代码
s = 0;
n = 1;
while n<=10
    s = s+n;
    n = n+1;
end
s;

分支结构

if ... else结构

if 条件表达式

​ [语句体]

end

if...else...end

if 表达式

​ [语句体1]

​ else

​ [语句体2]

end

switch ... case ... end结构

switch 表达式(数值或字符串)

​ case 数值或字符串

  				语句体;

​ ...

​ otherwise

​ 语句体n;

end

二维平面画图

matlab 复制代码
%% 画图
x = 0:0.01:2*pi;%% 步长0.01
y = sin(x);
    %%figure 建立幕布
figure
plot(x,y); %%绘制当前x,y图
title('y = sin(x)');
xlabel('x');
ylabel('sin(x)');

%%画图
xlim([0 2*pi]) %% 规定区间
x = 0:0.01:20;
y1 = 200*exp(-0.05*x).*sin(x);
y2 = 0.08*exp(-0.5*x).*sin(10*x);
figure
[AX,H1,H2] = plotyy(x,y1,x,y2,'plot');%%共用一个坐标系
set(get(AX(1),'Ylabel'),'String','Slow Decay');
set(get(AX(2),'Ylabel'),'String','Fast Decay');
xlabel('Time (\musec)');
title('Multiple Decay Rates');
set(H1,'LineStyle','--');
set(H2,'LineStyle',':');
相关推荐
FPGA_Linuxer33 分钟前
xilinx hbm ip运用
网络·网络协议·tcp/ip
i嗑盐の小F38 分钟前
【 ACM独立出版,见刊后1个月检索!!!】第二届通信网络与机器学习国际学术会议(CNML 2024,10月25-27)
网络·图像处理·人工智能·深度学习·算法·机器学习·计算机视觉
金灰1 小时前
wx小程序渗透思路
网络·windows·安全·小程序·notepad++
mit6.8241 小时前
[Linux#49][UDP] 2w字详解 | socketaddr | 常用API | 实操:实现简易Udp传输
linux·网络·c++·笔记·后端
南叔先生1 小时前
Linux 性能优化 copy
网络·数据库·php
Chase-Hart1 小时前
【每日一题】LeetCode 7.整数反转(数学)
java·数据结构·算法·leetcode·eclipse
四角小裤儿儿2 小时前
Java数据结构(十一)——归并排序、计数排序
java·数据结构·排序算法
不悔哥2 小时前
openwrt wsdd模块介绍
linux·c语言·网络·tcp/ip·智能路由器
SUGERBOOM2 小时前
华为eNSP使用详解
网络·华为
朱皮皮呀2 小时前
排序算法-归并排序
数据结构·算法·排序算法·归并排序