matlab 常用函数(数学建模-复习)
常用函数
fscanf(fid, '%c', inf) -> 直接读取整个文件, 因为inf表示无穷
strtrim
char(num): 将num转为ASCII字符
strtok(content, delimiters)
regexprep(content, pattern, replacement): 正则表达式匹配并替换成指定的字符
lower: 小写字符
cumsum: 求紧邻累加和序列
eval: 将sym符号转换为数值
syms: 定义符号变量
dsolve: 求解常微分方程, 求出符合条件的一个函数
solve: 求解方程组, 可以偷懒了:-)
matlab中的''和""是不一样的, 建议以后使用"", 因为s = ["hello", "world"]和['hello', 'world']返回的结果是不一样
linprog -> 使用单纯形法计算出最小的最优解
参数1: 目标函数的系数列向量
参数2: 约束条件的系数矩阵
参数3: 约束条件的值
注意: 单纯形法使用求解最大的最优解的, 但是在MATLAB中只提供了linprog用来求最小最优解的, 所以在列出了单纯形法的形式之后, 在传入第一个参数的使用取反即可
使用示例:
z = [25; 30];
A = [20 30; 5 4];
b = [690; 120];
[x\_1, x\_2] = linprog(-z, A, b);
randperm --> 类似于python中的shuffle
isempty --> 判断向量或者矩阵的是否为空(里面没有任何内容)
参数1: vec 或者 matrix
返回值:
- 1: 表示为空
- 0: 表示不为空
exist --> 判断变量是否存在
直接上示例
- exist('example', 'var'): 判断example这个变量是否存在,注意第二个参数不是乱写的,'var'表示变量
注意:
- 在matlab中peaks函数就使用了这个函数,所有我们可以直接调用peaks,而不需要传递参数
image 与 imagesc 函数 --> 显示一个图片,但是会自动的缩放尺寸
参数1: 像素矩阵
返回值:
- Image 结构体
colormap 函数 --> 创建出一个figure,并且根据传入的参数来绘制对应的图片类型(rgb, grayscale)
参数1:
- 可以是gray, hot, jet中的其中一个,默认是jet
注意:
- 如果当前已经有了一个figure,则使用colormap会改变当前图片的维度(类型),一般是将RGB转为gray,使用colormap(gray)
axis image off --> 不显示坐标轴
meshgrid --> 返回网格矩阵
参数1: X
可选参数:
- Y
返回网格矩阵,下面通过例子,自己意会吧
x = [1 2 3];
y = [1 2 3];
[xx, yy] = meshgrid(x, y)
xx = 1 2 3
1 2 3
1 2 3 yy = 1 1 1
2 2 2
3 3 3 xx1 = meshgrid(x)
xx1 = 1 2 3
1 2 3
1 2 3
peaks 返回山顶数据X,Y,Z
- 使用: [X, Y, Z] = peaks;
contour 函数 --> 画等高线 --> 如果要画封闭的曲线的,要联想到等高线,使用matlab中的contour函数进行绘制
参数1: X
参数2: Y
参数3: Z
可选参数:
- number: 数字类型,表示显示的等高线的个数
- range: [a, b], 表示只画出Z的值在[a, b]之间的等高线
- 'ShowText', 'on': 在等高线上显示对应的Z的值,可以与range一起使用,帮助理解
使用:
- surf(X, Y, Z, [0, 1], 'ShowText', 'on');
type 指令 --> 列出函数的源码
surf 函数 --> 画出3D图
- 参数1: X
- 参数2: Y
- 参数3: Z
xlim 和 ylim --> 设置图像中的x和y的定义域和值域
参数1: start
参数2: end
额外:
- axes函数
numel 函数 --> 返回向量或者矩阵中所有元素的个数
- 参数1: matrix
- 返回值:
返回向量或者矩阵中所有元素的个数
logpace 函数 --> 返回行向量
参数1: a
参数2: b
参数3: n
返回值:
- 返回一个在[\(10^{a}\), \(10^{b}\)]之间有n个元素的行向量
linspace 函数 --> 返回行向量
参数1: a
参数2: b
参数3: n
返回值:
- 返回一个在[a, b]之间有n个元素的行向量
spline 函数 --> 返回一个非矩阵形式的三阶样条的函数
参数1: x
参数2: y
返回值:
- 返回一个非矩阵形式的三阶样条的函数
注意:
- 获取返回值之后, 紧接着调用ppval(p, x)函数计算出函数结果
ppval 函数 --> 计算出多项式的结果
参数1: p -> 非矩阵形式的函数
参数2: x向量的值
返回值:
- 返回结果
poly2sym 函数 -> 将系数多项式转为符号多项式
参数1: 一个系数多项式的向量
返回值:
- 一个符号多项式
conv 函数 -> 多项式乘法
参数1: 第一个多项式向量
参数2: 第二个多项式向量
返回值:
- 返回参数1和参数2进行多项式乘法之后得到的多项式的结果
max 函数 -> 计算出最大值
参数1: 需要计算的矩阵
参数2: 为[], 好像是一个表示位, 如果不写第二个参数则返回的就是一个向量, 但是如果写了[], 则还会返回一个最大值在原来的矩阵中对应的下标
参数3: 1表示查找列中最大值, 2表示查找行中最大值
返回值:
- 如果第二个参数为[], 返回两个向量
- 如果没有第二个参数, 返回的是一个向量
建议:
- 有时候忽略第二个参数会有问题, 尽量使用上第2个参数
min函数和max一样
reshape函数 -> 返回一个reshape后的矩阵
参数1: 需要reshape的矩阵
参数2: reshape成几行
参数3: reshape成几列, 如果为[]则会根据参数2自动计算出列数, 如果我们划分的行和列不合理就会报错
返回值
- 一个reshape后的矩阵
注意:
- reshape函数在划分的时候是按照列的方向划分出一行的
示例:
- 生成[2, 1, 4, 3...]向量
- reshape([2:2:100; 1:2:100], 1, [])
- 生成[2, 1, 4, 3...]向量
多项式拟合函数
polyfit 函数 -> 返回拟合的多项式 -> 类似于 [3, 2, 1] (注意: 多项式在matlab中是以数组的方式存储的, 其中x变量的阶数就是下标, 所以返回的多项式是将降幂的)
参数1: x为横坐标
参数2: y为纵坐标
参数3: n为拟合出来的多项式的最高阶数
- 例子: 拟合出来的是 y = 2n^2 + 3n + 1, 观察到幂数是从高到低排序的
- 则n就是2
返回值:
+ p: 各个阶数的系数, 返回的是一个行vector
polyval 函数
- 参数1: 多项式 -> [3, 2, 1] -> 3x^2 + 2x + 1
- 参数2: 输入的值, 可以为向量[1, 2, 3]也可以是矩阵
- 返回值:
- 将参数2代入参数1表示的多项式返回的结果
最大回撤率函数
maxdrawdown 函数
参数1: 向量(一维的)
返回值:
+ 最大回撤率 -> 就是风险率
读取文件
xlsread()
参数1: filename
参数2: sheet
参数3: xlRange
返回值:
+ 数据
xlswrite()
- 参数1: filename
- 参数2: a variable
- 参数3: sheet
- 参数4: xlRange
save():
- 示例:
- save(filename, a_variable, '-ascii'), 注意: 最好只保存一个变量这样在读取的时候方便
- 其中a_variable要使用引号包含起来
- 示例:
load():
- 示例:
- a = load(filename, 'acsii'), filename的数据要维度一样
- 示例:
textread(), 读入的精度好:
参数1: filename
参数2: format --> '%s %s %f %d'
参数3: number_of_lines_to_read
参数4: 'headerlines'
参数5: where_is_the_headerline, will begin to read the next line
返回值:
- 返回值的个数要与format中的%的格式数量对应
fprintf(), 写出的精度好
- 参数1: filename_fid
- 参数2: fmt, 以空格分开
文件读取三步骤
- fid = fopen(filename, 'r')
- var = fread(fid, '* char'), 读取所有的字符
- var = native2unicode(var), 转为unicode
- fclose(fid)
目录函数
dir()
- 参数1: 目录名
- 返回值
- 一个struct array结构体, 属性有name, folder, isdir, datef, bytes
fullfile()
参数1: 目录名, 不能以/结尾
参数2: 可以是文件或者目录
返回值: 返回添加了/的目录路径的字符串
显示图片
imread()
参数1: filename
参数2: fmt
返回值: 相应图片类型的维度, bmp为二维的, jpeg为三维的
imshow()
- 参数1: 矩阵
- 参数2: 矩阵中的值域(用来控制对比度)
读取视频
- videoFReader = vision.VideoReader('my.mp4'); % 保存了视频帧, 一堆又一堆的矩阵
- videoPlayer = vision.VideoPlayer(); % 用来显示一个帧
- while ~IsDone(videoFReader) % isDone函数用来判断是否到了end了
currentFrame = step(videoFReader); % 获取Reader中保存的一个帧, 栈会一步一步的走下去, 如果不需要将帧指针返回到初始位置, 则使用reset(videoFReader);
step(videoPlayer, currentFrame); % 播放一个帧
- end
- release(videoPlayer); % 释放videoPlayer, 为下一次play做准备
读取视频2(这是player的位置)
r = groot, % groot就是屏幕, r.ScreenSize返回的是[1, 1, 1400, 900]返回的是左下角和右上角
videoFReader = vision.VideoReader('my.mp4'); % 保存了视频帧, 一堆又一堆的矩阵
videoPlayer = vision.VideoPlayer('Position', [1, 1, 1400, 900]); % 用来显示一个帧
while ~IsDone(videoFReader) % isDone函数用来判断是否到了end了
currentFrame = step(videoFReader); % 获取Reader中保存的一个帧, 栈会一步一步的走下去, 如果不需要将帧指针返回到初始位置, 则使用reset(videoFReader);
step(videoPlayer, currentFrame); % 播放一个帧
end
release(videoPlayer); % 释放videoPlayer, 为下一次play做准备
---恢复内容结束---
### 常用函数
xlim 和 ylim --> 设置图像中的x和y的定义域和值域
参数1: start
参数2: end
额外:
- axes函数
numel 函数 --> 返回向量或者矩阵中所有元素的个数
- 参数1: matrix
- 返回值:
返回向量或者矩阵中所有元素的个数
logpace 函数 --> 返回行向量
参数1: a
参数2: b
参数3: n
返回值:
- 返回一个在[\(10^{a}\), \(10^{b}\)]之间有n个元素的行向量
linspace 函数 --> 返回行向量
参数1: a
参数2: b
参数3: n
返回值:
- 返回一个在[a, b]之间有n个元素的行向量
spline 函数 --> 返回一个非矩阵形式的三阶样条的函数
参数1: x
参数2: y
返回值:
- 返回一个非矩阵形式的三阶样条的函数
注意:
- 获取返回值之后, 紧接着调用ppval(p, x)函数计算出函数结果
ppval 函数 --> 计算出多项式的结果
参数1: p -> 非矩阵形式的函数
参数2: x向量的值
返回值:
- 返回结果
poly2sym 函数 -> 将系数多项式转为符号多项式
参数1: 一个系数多项式的向量
返回值:
- 一个符号多项式
conv 函数 -> 多项式乘法
参数1: 第一个多项式向量
参数2: 第二个多项式向量
返回值:
- 返回参数1和参数2进行多项式乘法之后得到的多项式的结果
max 函数 -> 计算出最大值
参数1: 需要计算的矩阵
参数2: 为[], 好像是一个表示位, 如果不写第二个参数则返回的就是一个向量, 但是如果写了[], 则还会返回一个最大值在原来的矩阵中对应的下标
参数3: 1表示查找列中最大值, 2表示查找行中最大值
返回值:
- 如果第二个参数为[], 返回两个向量
- 如果没有第二个参数, 返回的是一个向量
建议:
- 有时候忽略第二个参数会有问题, 尽量使用上第2个参数
min函数和max一样
reshape函数 -> 返回一个reshape后的矩阵
参数1: 需要reshape的矩阵
参数2: reshape成几行
参数3: reshape成几列, 如果为[]则会根据参数2自动计算出列数, 如果我们划分的行和列不合理就会报错
返回值
- 一个reshape后的矩阵
注意:
- reshape函数在划分的时候是按照列的方向划分出一行的
示例:
- 生成[2, 1, 4, 3...]向量
- reshape([2:2:100; 1:2:100], 1, [])
- 生成[2, 1, 4, 3...]向量
多项式拟合函数
polyfit 函数 -> 返回拟合的多项式 -> 类似于 [3, 2, 1] (注意: 多项式在matlab中是以数组的方式存储的, 其中x变量的阶数就是下标, 所以返回的多项式是将降幂的)
参数1: x为横坐标
参数2: y为纵坐标
参数3: n为拟合出来的多项式的最高阶数
- 例子: 拟合出来的是 y = 2n^2 + 3n + 1, 观察到幂数是从高到低排序的
- 则n就是2
返回值:
+ p: 各个阶数的系数, 返回的是一个行vector
polyval 函数
- 参数1: 多项式 -> [3, 2, 1] -> 3x^2 + 2x + 1
- 参数2: 输入的值, 可以为向量[1, 2, 3]也可以是矩阵
- 返回值:
- 将参数2代入参数1表示的多项式返回的结果
最大回撤率函数
maxdrawdown 函数
参数1: 向量(一维的)
返回值:
+ 最大回撤率 -> 就是风险率
读取文件
xlsread()
参数1: filename
参数2: sheet
参数3: xlRange
返回值:
+ 数据
xlswrite()
- 参数1: filename
- 参数2: a variable
- 参数3: sheet
- 参数4: xlRange
save():
- 示例:
- save(filename, a_variable, '-ascii'), 注意: 最好只保存一个变量这样在读取的时候方便
- 其中a_variable要使用引号包含起来
- 示例:
load():
- 示例:
- a = load(filename, 'acsii'), filename的数据要维度一样
- 示例:
textread(), 读入的精度好:
参数1: filename
参数2: format --> '%s %s %f %d'
参数3: number_of_lines_to_read
参数4: 'headerlines'
参数5: where_is_the_headerline, will begin to read the next line
返回值:
- 返回值的个数要与format中的%的格式数量对应
fprintf(), 写出的精度好
- 参数1: filename_fid
- 参数2: fmt, 以空格分开
文件读取三步骤
- fid = fopen(filename, 'r')
- var = fread(fid, '* char'), 读取所有的字符
- var = native2unicode(var), 转为unicode
- fclose(fid)
目录函数
dir()
- 参数1: 目录名
- 返回值
- 一个struct array结构体, 属性有name, folder, isdir, datef, bytes
fullfile()
参数1: 目录名, 不能以/结尾
参数2: 可以是文件或者目录
返回值: 返回添加了/的目录路径的字符串
显示图片
imread()
参数1: filename
参数2: fmt
返回值: 相应图片类型的维度, bmp为二维的, jpeg为三维的
imshow() --> 尽量原样输出原始图片
- 参数1: 矩阵
- 参数2: 矩阵中的值域(用来控制对比度)
读取视频
- videoFReader = vision.VideoReader('my.mp4'); % 保存了视频帧, 一堆又一堆的矩阵
- videoPlayer = vision.VideoPlayer(); % 用来显示一个帧
- while ~IsDone(videoFReader) % isDone函数用来判断是否到了end了
currentFrame = step(videoFReader); % 获取Reader中保存的一个帧, 栈会一步一步的走下去, 如果不需要将帧指针返回到初始位置, 则使用reset(videoFReader);
step(videoPlayer, currentFrame); % 播放一个帧
- end
- release(videoPlayer); % 释放videoPlayer, 为下一次play做准备
读取视频2(这是player的位置)
- r = groot, % groot就是屏幕, r.ScreenSize返回的是[1, 1, 1400, 900]返回的是左下角和右上角
- videoFReader = vision.VideoReader('my.mp4'); % 保存了视频帧, 一堆又一堆的矩阵
- videoPlayer = vision.VideoPlayer('Position', [1, 1, 1400, 900]); % 用来显示一个帧
- while ~IsDone(videoFReader) % isDone函数用来判断是否到了end了
currentFrame = step(videoFReader); % 获取Reader中保存的一个帧, 栈会一步一步的走下去, 如果不需要将帧指针返回到初始位置, 则使用reset(videoFReader);
step(videoPlayer, currentFrame); % 播放一个帧
- end
- release(videoPlayer); % 释放videoPlayer, 为下一次play做准备
matlab 常用函数(数学建模-复习)的更多相关文章
- matlab 常用函数
Matlab常用函数 Matlab的内部常数 eps 浮点相对精度 pi 圆周率 exp 自然对数的底数e i 或j 虚数单位 Inf或 inf 无穷大 Matlab概率密度函数 ...
- (转载)delphi 常用函数(数学)
delphi 常用函数(数学) Delphi中怎么将实数取整? floor 和 ceil 是 math unit 里的函数,使用前要先 Uses Math.trunc 和 round 是 system ...
- Delphi 常用函数(数学函数)round、trunc、ceil和floor
源:Delphi 常用函数(数学函数)round.trunc.ceil和floor Delphi 常用函数(数学) Delphi中怎么将实数取整? floor 和 ceil 是 math unit 里 ...
- php常用函数——数学函数
php常用函数——数学函数
- MATLAB常用函数, 常见问题
MATLAB常用函数 1.常用取整函数 round(x):四舍五入函数 floor(x) : 向下取整, 即 floor(1.2)=1, floor(1.8) = 1 ceil(x) : 向上取整, ...
- Matlab常用函数集锦
ndims(A)返回A的维数size(A)返回A各个维的最大元素个数length(A)返回max(size(A))[m,n]=size(A)如果A是二维数组,返回行数和列数nnz(A)返回A中非0元素 ...
- MATLAB常用函数
Matlab的内部常数 pi 圆周率 exp(1) 自然对数的底数e i 或j 虚数单位 Inf或 inf ...
- MySql常用函数数学函数、加密函数等(转—收藏)
MySql函数众多,这里只是列举了一部分常用的函数. 一.数学函数 ABS(x) // 返回x的绝对值 BI ...
- matlab 常用函数汇总
1. 特殊变量与常数 主题词 意义 主题词 意义 ans 计算结果的变量名 computer 确定运行的计算机 eps 浮点相对精度 Inf 无穷大 I 虚数单位 inputname 输入参数名 Na ...
随机推荐
- 发布倒计时!JDK11为我们带来哪些新特性?
今年7月底,JDK11已经进入了Rampdown Phase Two阶段,这标志着该版本所有特性已经被冻结,不会有新的JEP会加入版本中. 这一阶段将会修复P1–P2级BUG,之后,JDK11预定于今 ...
- C++ 替换字符串内某个字符或子串
1. 问题描述 string s="abc"; string tmp="1"; 2.解决方案 // tmp 必须为字符串 // 第一个 1 表示 s 中的位置 ...
- sql 查看表结构
sqlserver 查看表结构 exec sp_help @TableName --得到表信息.字段,索引.constraint. exec sp_pkeys @TableName --得到主键. e ...
- Angular14 Angular相关命令
1 创建相关 1.1 创建项目 ng new 项目名 -> 创建新项目 ng new 项目名 --skip-install -> 不进行模块安装 ng new 项目名 -si ng ...
- linux date用法
读者可以设定特定的格式,格式设定规则:一个加号后接数个标记,每个标记中都有%,其中可用的标记列表和说明如下: %n : 下一行 %t : 跳格 %H : 小时(00..23) %I : 小时(01. ...
- 数据库 连接(join)
转自http://www.cnblogs.com/caozengling/p/5318696.html 数据库中飞内连接,自然连接,外连接 数据库中的连接join氛围内连接,自然连接,外连接,外连接又 ...
- JavaScript学习系列7 -- JavaScript中的运算符
今天,我们来说一说JavaScript中的运算符,首先我们来讲一讲 一元运算符 JavaScript中的一元运算符有以下几种 1. delete delete 运算符主要用于删除对以前定义的对象属性或 ...
- 使用配置类而不使用XML文件(代替bean.xml)对spring进行配置
以下类是一个配置类,它的作用和bean.xml是一样的注解: @Configuration 作用: 用于指定当前类是一个spring配置类,当创建容器时会从该类上加载注解. 获取容器时需要使用Anno ...
- 读《JavaScript权威指南》笔记(二)
1.加号运算和比较运算符的区别 对于数字和字符串操作符来说,加号运算符和比较运算符的行为都有所不同,前者更偏爱字符串,如果它的其中一个操作数是字符串的话,则进行字符串连接操作.而比较运算符则更偏爱数字 ...
- 《权限系列shiro+cas》---封装公共验证模块
操作系统:Windows8.1 显卡:Nivida GTX965M 开发工具:Visual Studio 2017 Introduction 我们现在可以将任意属性传递给每个顶点的顶点着色器使用.但是 ...