Matlab 实用笔记(纯干货)

1. 普通


t1 : t2 : t3;
从t1到t3,间隔取t2

linspace(始,终,元素个数);

= [];
用 [] 赋值,删除元素

x = 12345;
s = num2str(x);
数字转字符串

ceil(x);
向上取整

floor(x);
向下取整

round(x);
四舍五入取整

rand(l,m,n);
生成l*m*n矩阵,矩阵元素为0-1之间的随机数

A’
矩阵A共轭转置
A.’
矩阵A转置
conj(A)
矩阵A共轭


2. 矩阵


length(A) = max(size(A));

A(end,:);
矩阵A最后一行

A(:,end-1);
矩阵A倒数第二列

eye(n);
生成n阶单位阵

prod(A);
矩阵A各列连乘

min(A);
取矩阵A各列最小值

[x,I] = min(A);
取矩阵A各列最小值及其下标

max(A,[],dim);
当dim为2时,返回矩阵A每行最大值

C = max(A,B);
返回A,B矩阵同位置较大值组成的矩阵(A,B须为同型矩阵)

C = max(A,n);
返回A的同型矩阵,各位置取A和n中较大的值(n为数字)

mean(A);
取每列平均值

mean(A,dim);
当dim为2时,取矩阵A每行平均值

median(A);
每列中位数

median(A,dim);
当dim为2时,取矩阵A每行中位数

all(A);
返回矩阵A每列所有元素相与后所得的行向量

any(A);
返回矩阵A每列所有元素相或之后所得的行向量

find(A > 5);
返回由矩阵A中所有大于5的元素的一维下标所组成的列向量

[x,y] = find(A > 5);
返回由矩阵A中所有大于5的元素的二维下标所组成的列向量

sort(A);
返回矩阵A每列升序排序的结果

sort(A, 2, ’descend’);
返回矩阵A每行降序排序的结果

flipud(A);
将矩阵A上下反向

fliplr(A);
将矩阵A左右反向

reshape(A,m,n);
将矩阵A的size变为m行n列。改变的宗旨是按照绝对下标。
绝对下标的排布永远是以列优先。


3. 多项式


interp1(x,y,x1,’method’);
一维插值,x,y为已知点的横纵坐标向量,x1为所求点的横坐标向量。’method’为插值方法,有’linear’, ’nearest’, ’spline’等

interp2(r,s,t,x,y,’method’);
二维插值,r,s为已知点横纵坐标矩阵,t为已知点的值,x,y为待求点坐标矩阵

[P,S] = polyfit(x,y,m);
多项式拟合,x,y为已知点坐标列表,m为拟合阶数;返回P为系数列表,S为采样点误差

y = polyval(P,x);
多项式求值,P为系数列表,x为自变量数值列表

P3 = conv(P1,P2);
多项式相乘

P_dev = polyder(P);
多项式求导

[P_dev,Q_dev] = polyder(P,Q);
多项式(P/Q)求导

x = roots(P);
求多项式零点


4. 输入输出


A = input(‘输入提示’);
用户输入矩阵赋值给变量A

s = input(‘输入提示’, ’s’);
用户输入字符串并赋给变量s

disp(x);
输出显示(不显示变量名)


5. 符号变量


syms a b c d;
定义符号变量

syms x;
f = 1/(2*x);
定义符号表达式

factor(f);
分解因式,f为符号表达式

simplify(f);
化简

limit(f,x,a);
求极限f(x->a),f为符号表达式,x,a为符号变量

diff(f,x,n);
对f求x的n阶导,f为符号表达式,x为符号变量,n为数字

int(f,x);
求f对x的不定积分,f为符号表达式,x为符号变量

int(f,x,x1,x2);
求f对x的定积分

syms x;
sovle(x^4+1 = x^2 +1);
解单变量方程

syms x y;
sovle(x*y+2 = y, y);
解关于y的方程

syms x y;
solve(x^2+y^2 = 1, x+y = 1);
方程联立求解

F = fourier(f,x);
求傅里叶变换,f为符号表达式,x为符号变量,f是关于x的函数,返回的是变换后的符号表达式

f = ifourier(F,x);
求傅里叶逆变换

F = laplace(f,x);
求拉普拉斯变换

f = ilaplace(F,x);
求拉普拉斯逆变换

symsum(a,x,x0,n);
级数求和;a为符号表达式,x为符号变量,x0,n为数字;a为关于x的表达式,x为自变量,x0为自变量初值,n为所求级数数量,无穷则为“inf”

taylor(f,x,x0,’order’,n);
将函数f(x)在x=x0处进行n阶泰勒展开,f为符号表达式,x为符号变量,x0,n为数字,’order’为固定字符串,表示阶数

f = poly2sym(P);
由多项式系数向量产生符号表达式


6. 图像操作


grid on
加网格线
grid off
去网格线

hold on
保持当前figure

plot(x,y,’CLM’);
设置,C为颜色,L为线型,M为数据点形状

plot(X,Y,'LineWidth',2,'Color',[.6 0 0])
设置线宽、颜色

axis([xmin,xmax,ymin,ymax]);
限定图像轴长

axis square;
将图像坐标范围限定为正方形

set(gca,’ytick’,[x1,x2,x3]);
gca表示指向当前句柄,’ytick’表示在坐标轴上显示设定的坐标值

subplot(m,n,i); plot(x,y);
一张图里有m行n列个子图,在第i个子图中plot

title(‘标题’);
给当前图像加标题

title(‘\fontsize{18} 标题’);
给当前图像加标题并设置标题字体大小
一般标题18号,x轴y轴16号,图例12号

xlable(‘x轴名称’);  ylable(‘y轴名称’);
给坐标轴命名

legend(‘图线1’, ‘图线2’, ‘图线3’);
加图例

text(x,y,’文字’);
在图像上x,y坐标处加文字

gtext(‘文字’);
在图像上加文字,位置由鼠标点击

repmat(A,m,n);
重复矩阵A,m行n列

plot3(x,y,z);
画三维曲线

mesh(x,y,z);
surf(x,y,z);
画三维曲面,x,y为二维矩阵,z为x,y的函数,也是二维矩阵。mesh只有格线,surf能填充颜色

meshc(x,y,z);
画等高线图

x = [-3:3]; y = [1:5]; [x,y] = meshgrid(x,y);
生成画曲面所需的自变量二维矩阵

polar(theta,r);
画极坐标图

Hf = figure;
建立一个图形窗口,返回它的句柄值

figure(Hf);
激活句柄Hf

Hf = gcf;
获取当前图像句柄(get current figure)

Ha = gca;
获取当前坐标系句柄(get current axis)

Hx = gco;
获取当前对象句柄(get current object)

saveas(Hf,’title.jpg’);
保存图像并指定图像后缀名

fill(X,Y,C);
为平面图像填充颜色;
X、Y、C均为行向量;
X包含了一个封闭图形(一小格)各顶点的横坐标;
Y包含了一个封闭图形(一小格)各顶点的纵坐标;
C包含三个元素,分别为R、G、B值,大小均在0~1之间;
每次只能填充一小格,需要用循环对整体进行填充;
使用fill之前记得把原图hold on住。

你可能感兴趣的:(Matlab 实用笔记(纯干货))