【编程语言】Matlab 学习记录
title: Matlab Learning Record
date: 2020-05-23 20:11:26
author: liudongdong1
img: https://gitee.com/github-25970295/blogImage/raw/master/img/voice-recognition-speech-detect-deep-260nw-694633963.webp
reprintPolicy: cc_by
cover: false
categories: 语言框架
tags:
- Matlab
MATLAB是一种语法简单用途广泛的编程语言,既可以用于编写脚本,函数,也可以用于面向对象的程序开发或开发GUI界面。MATLAB被广泛应用于数值计算,图像处理,机器学习等领域。
- 高效的数值计算及符号计算功能,能使用户从繁杂的数学运算分析中解脱出来;
- 广阔的线性代数,统计,傅立叶分析,筛选,优化,数值积分,解常微分方程的数学函数库。
- 具有完备的图形处理功能,实现计算结果和编程的可视化;
- 友好的用户界面及接近数学表达式的自然化语言,使学者易于学习和掌握;
- 功能丰富的应用工具箱(如信号处理工具箱、通信工具箱等) ,为用户提供了大量方便实用的处理工具。
- MATLAB的编程接口给开发工具,提高代码质量和可维护性和性能的最大化。
- 它提供了基于MATLAB算法集成了C,Java,NET和Microsoft Excel等与外部应用程序和语言功能。
1. 变量与矩阵
MATLAB在变量声明是不需要指出变量的类型
。
clear; %清空内存
clc; %清空命令行
r1=1; %为一个变量赋值
z1=1+sqrt(3)*i; %赋值一个复数 sqrt()开方运算
z_real=real(z1); %复数的实部
z_img=imag(z1); %复数的虚部
z_abs=abs(z1); %复数的模
z_ang=angle(z1); %复数的幅角
z2=z1^2; %平方运算
MATLAB的数组索引从1开始,这点需要牢记
。
arr1=rand(1,5); %arr1=[0.1418,0.4217,0.9157,0.7922,0.9594]
arr2=zeros(1,5); %arr2=[0,0,0,0,0]
arr3=ones(1,5); %arr3=[1,1,1,1,1]
arr4=linspace(1,2,5); %arr4=[1,1.25,1.5,1.75,2]
arr4=linspace(2,2,5); %arr4=[2,2,2,2,2]
mat1=rand(3,3); %随机生成3*3矩阵
mat2=[1,2,3;4,5,6;7,8,9];
获取
一维数组的长度用length函数
;获取多维函数的维数大小用size
;
n = ndims(A) # 获取数组维度
numberOfElements = length(array) #即一维数组的长度或者多维数组中最大的维数行数或列数中的较大值
[m,n] = size(X) #获得矩阵的各个维数的大小
a=[1,2,3,4,5] #用逗号或空格间隔
a=[1 2 3 4 5]
x=初始值 :[步长]:终值
x=linspace(初始值 ,终值,个数n)
x=logspace(初始值 ,终值,个数n)#生成[10初值,10终值]之间等分的n个数 如果步长省略,默认步长为50
M = max(A)
C = max(A,B)
for i=1:1:r
plot([time(w(i,1)),timev2(w(i,2))],[phaseznormal(w(i,1)),phasev2(w(i,2))],'--','Color',[0.5 0.5 0.5], 'LineWidth',0.5);
hold on
end
2. 分支与循环
MATLAB常用的分支语句有__if-else__和__switch-case__
limit = 0.75;
A = rand(10,1)
if any(A > limit)
disp('There is at least one value above the limit.')
else
disp('All values are below the limit.')
end
MATLAB常用的循环有__while__循环和__for__循环
for v = 1.0:-0.2:0.0
disp(v)
end
for v = [1 5 8 17]
disp(v)
end
3. 函数及函数句柄
这里分别使用函数
和函数句柄
的方法来生成__Fibonacci__数列。
需要注意函数名和文件名要保持一致
,以下先使用函数
的方式:
function y = fibonacci (x)
if x == 1 || x==2
y = 1;
return % return可以不写
else
y = fibonacci(x-1) + fibonacci(x-2);
return
end
以下是使用函数句柄
的方式:
fibo=@(n) (((1+sqrt(5))/2)^n-((1-sqrt(5))/2)^n)/sqrt(5);
fn=zeros(1,100);
for i=1:1:100
fn(i)=fibo(i);
end
4. 数值微积分
使用dx=0.000001为步长的向前差分求sin(x)的导数
:
\]
figure ('name','diff demo1');
x=linspace(0,10,100);
y=sin(x);
dx=0.000001;dydx=[];
for i=1:100
dydx(i)=(sin(x(i)+dx)-y(i))/dx;
end
plot(x,y,'r',x,dydx,'b');
legend('sin(x)','cos(x)');
title('diff demo');
xlabel('x');ylabel('y')
使用MATLAB的差分工具diff
计算导数
h = 0.001; % step size
X = -pi:h:pi; % domain
f = sin(X); % range
Y = diff(f)/h; % first derivative
Z = diff(Y)/h; % second derivative
plot(X(:,1:length(Y)),Y,'r',X,f,'b', X(:,1:length(Z)),Z,'k')
使用矩形法计算\(\int_0^1x^2dx\):
\]
n=100000;a=0;b=1; %取步长为100000
x=a:1/n:b;
dx=(b-a)/n;x=x+dx/2;
s=x.^2; %采样
int=dx*sum(s);
调用MATLAB中的quad
函数使用__Simpson__法计算数值积分
:
func=@(x)x.^2;
int=quad(func,0,1)
5. 常微分方程(组)的数值解
使用__Euler__法计算常微分方程(误差较大,不推荐):
\]
\]
取时间步长为h,则
\]
function matlab_demo
func=@(x,y)x.^2+y.^2+3*x-2*y
[x,y]=euler(func,[0,1],1,0.01)
plot(x,y)
return
function [x,y]=euler(fun,xspan,y0,h)
x=xspan(1):h:xspan(2)
y(1)=y0;
for n=1:length(x)-1
y(n+1)=y(n)+h*feval(fun,x(n),y(n))
end
return
使用45阶__Runge-Kutta__算法ode45
计算常微分方程组:
\]
\]
\]
\]
function ode_demo
y0=[1,1];
tspan=0:0.01:5;
option = odeset('AbsTol',1e-4);
[t,x]=ode45(@dfunc,tspan,y0,option);
figure('name','ode45 demo');
plot(t,x(:,1),'r',t,x(:,2),'b');
return
function dx=dfunc(t,x)
dx=zeros(2,1);
dx(1)=2*x(1)-3*x(2); % x(1)=x
dx(2)=x(1)+2*x(2); % x(2)=y
return
6. 偏微分方程(组)的数值解
使用pdepe
进行微分方程(组)的求解,需要先将微分方程(组),以及边界和初值条件化为如下形式:
\]
\]
\]
举一个例子:
\]
\]
\]
\]
求解过程如下:
function pde_demo
x=0:0.05:1;
t=0:0.05:1;
m=0;
sol=pdepe(m,@pdefun,@pdeic,@pdebc,x,t);
figure('name','pde demo');
surf(x,t,sol(:,:,1));
title('pde demo');
xlabel('x');ylabel('t');zlabel('u');
return
function [c,f,s]=pdefun(x,t,u,du) %方程描述函数
c=1;
f=1*du;
s=-1*u;
return
function [pa,qa,pb,qb]=pdebc(xa,ua,xb,ub,t) %边界描述函数
pa=ua-1;
qa=0;
pb=ub;
qb=0;
return
function u0=pdeic(x) %初值描述函数
u0=(x-1)^2;
return
7. 文件读取
#通过python 文件进行存储为txt格式,然后通过matlab代码直接读取
np.savetxt("xy1.txt", yvals,fmt='%d',delimiter=',')
clear ;close all; clc
data=load('./kinect/314637_Guesture_segment.txt')
x_dtw=data(:,1)
y_dtw=data(:,2)
z_dtw=data(:,3)
time=data(:,4)
%转置操作 data=data.’
phase=4*pi*(x_dtw.^2+y_dtw.^2+z_dtw.^2)/0.33
phaseznormal=zscore(phase)
save kinect.txt -ascii phaseznormal
8. 快捷键
4.1. 注释
Ctrl+r
:选中要注释的多行文本,然后按Ctrl+r
就可以实现多行注释。
Ctrl+t
:选中已经注释了的多行文本,然后按Ctrl+t
就可以取消多行注释。
Resource
- matlab-tutorial: Matlab Tutorial using Jupyter Notebook
- Image Processing MATLAB Codes, Simulink, GUI, and Standalone Applications
- awesome-matlab-robotics: a list of awesome demos, tutorials, utilities and overall resources for the robotics community that use MATLAB and Simulink. 后期学习机器人可以好好学习使用
【编程语言】Matlab 学习记录的更多相关文章
- Matlab学习记录(函数)
Matlab中的内建函数 Matlab自定义函数 用function构造函数 用inline构造函数 用syms构造符号函数 多项式相关函数 polyvalx convx 向量和矩阵运算函数 向量运算 ...
- matlab学习记录
1.在命令框输入preferences,可以调整字体大小 2.产生正太分布函数 参考:https://blog.csdn.net/s334wuchunfangi/article/details/816 ...
- Matlab 进阶学习记录
最近在看 Faster RCNN的Matlab code,发现很多matlab技巧,在此记录: 1. conf_proposal = proposal_config('image_means', ...
- Python学习记录day6
title: Python学习记录day6 tags: python author: Chinge Yang date: 2016-12-03 --- Python学习记录day6 @(学习)[pyt ...
- Python学习记录day5
title: Python学习记录day5 tags: python author: Chinge Yang date: 2016-11-26 --- 1.多层装饰器 多层装饰器的原理是,装饰器装饰函 ...
- Matlab安装记录 - LED Control Activex控件安装
Matlab安装记录-LED Control Activex控件安装 2013-12-01 22:06:36 最近在研究Matlab GUI技术,准备用于制作上位机程序:在Matlab GUI的技术 ...
- Thrift学习记录
Thrift学习记录 Thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在C++,Java,Python,PHP,Ruby,Erlang, ...
- Python全栈工程师系列学习之学习记录
@ 目录 前言 Day 01 一.python的历史和种类 二.安装python解释器以及配置环境变量 三.变量.常量和注释 Day 02 Day 03 Day 04 Day 05 Day 06 一. ...
- git原理学习记录:从基本指令到背后原理,实现一个简单的git
一开始我还担心 git 的原理会不会很难懂,但在阅读了官方文档后我发现其实并不难懂,似乎可以动手实现一个简单的 git,于是就有了下面这篇学习记录. 本文的叙述思路参照了官方文档Book的原理介绍部分 ...
随机推荐
- XDFZOI 月赛 201905 Sliver
组题人自己组完过后,才发现自己还是太弱了... T1 简单模拟. 按照游戏规则直接模拟显然是不明智的,所以我们可以像石头剪刀布一样,将判断改变为检验. 同时,我们发现,一共只有48种牌,所以我们可以直 ...
- WIN10家庭版 访问WINXP 共享打印机
WIN10家庭版 1.安装对应的打印机驱动 2.打开WIN10计算机---在地址栏中输入:\\计算机XP名称,显示对应的共享资源,直接选择即可.如果无法访问则进行如下第三步 3.设置过程 开始 -设置 ...
- Java基础00-数组9
1. 数组定义格式 1.1 数组概述 1.2 什么是数组 1.3 数组定义格式 推荐使用第一种格式,因为第一种格式读法比较顺畅. 2. 数组初始化之动态初始化 2.1 数组初始化概述 2.2 数组初始 ...
- Java基础00-运算符4
1. 算术运算符 1.1 运算符和表达式 1.2 算数运算符 余数的计算取余数是指整数除法中被除数未被除尽部分,且余数的取值范围为0到除数之间(不包括除数)的整数 ,例如27除以6,商数为4,余数为3 ...
- Python+Requests+Re(正则)爬取某糗事百科图片(数据分析一)
1.博客目前在学习爬虫课程,使用正则表达式来爬取网页的图片信息 2.下面我们一起来回归下Python中的正则使用方式/方法 3.糗事百科图片爬取源码如下: import requestsimport ...
- NOIp 2020
游记 Day-1 我已经开始慌了. 不知道前路如何.不想回文化课.唯一一次机会,可是这几天却一直在颓,不颓就慌. 没心思写题,导致这几天看的题啥都不会.不知道考试当天又会出什么幺蛾子. 啊啊啊,烦. ...
- Servlet 单例多线程详解(六)
一.Servlet 单例多线程 Servlet如何处理多个请求访问?Servlet容器默认是采用单实例多线程的方式处理多个请求的:1.当web服务器启动的时候(或客户端发送请求到服务器时),Servl ...
- Allure测试框架 python
关于Allure Allure是一个report框架,可以基于一些测试框架生成测试报告,比较常用的一般是Junit/Testng框架: Allure 生成的报告样式简洁美观,同时又支持中文: Allu ...
- 在js中对属性的操作
一:访问属性 两种方法: ①:对象名.属性名 function test(sno,age,sex){ this.sno=sno, this.age=age, this.sex=s ...
- zabbix latest.php SQL注入漏洞(CVE-2016-10134)
Zabbix 2.2.14之前的版本和3.0.4之前的3.0版本 latest.php页面提取cookie中的zbx_sessionid的后16位 246c58ba963457ef http://19 ...