Matlab中文教程共63页
2024版matlab教程(全)资料ppt课件

进行通信系统的建模、仿真和分析。
谢谢聆听
B
C
变量与赋值
在MATLAB中,变量不需要事先声明,可以 直接赋值。变量名以字母开头,可以包含字 母、数字和下划线。
常用函数
MATLAB提供了丰富的内置函数,如sin、 cos、tan等三角函数,以及abs、sqrt等数 学函数。用户可以通过help命令查看函数的
D
使用方法。
02 矩阵运算与数组操作
错误处理
阐述try-catch错误处理机制的语法、 执行流程及应用实例。
04
函数定义与调用
函数概述
阐述函数的概念、作用及分类,包括内置函数和 自定义函数。
函数调用
深入剖析函数的调用方法,包括直接调用、间接 调用及参数传递等技巧。
ABCD
函数定义
详细讲解自定义函数的定义方法,包括函数名、 输入参数、输出参数及函数体等要素。
拟合方法
利用已知数据点构造近似函数,如最小二乘法、多项 式拟合、非线性拟合等。
插值与拟合的比较
插值函数经过所有数据点,而拟合函数则追求整体上 的近似。
数值积分与微分
01
数值积分方法
利用数值技术计算定积分的近似 值,如矩形法、梯形法、辛普森 法等。
02
数值微分方法
通过数值技术求解函数的导数或 微分,如差分法、中心差分法、 五点差分法等。
02
01
矩阵运算
加法与减法
对应元素相加或相减,要求矩阵 大小相同
乘法
使用`*`或`mtimes`函数进行矩阵 乘法,要求内维数相同
点乘与点除
使用`.*`、`./`进行对应元素相乘或 相除,要求矩阵大小相同
特征值与特征向量
matlab教程ppt(完整版)

展示部分与整体的关系,通过扇形面积或角度表 示占比。
三维图形
01
02
03
04
三维散点图
在三维空间中展示两个变量之 间的关系,通过点的位置展示
数据。
三维曲面图
通过曲面表示两个或多个变量 之间的关系,可以展示数据的
分布和趋势。
三维等高线图
表示三维空间中数据的分布和 变化,通过等高线的形状和密
集程度展示数据。
处理运行过程中出现的错误和 异常情况。
通过优化算法和代码结构,提 高程序的运行效率。
对代码进行重新组织,使其更 易于阅读和维护。
03
MATLAB可视化
绘图基础
散点图
描述两个变量之间的关系,通过点的分布展示数 据。
条形图
比较不同类别的数据大小,通过条形的长度或高 度进行比较。
折线图
展示时间序列数据或多个变量之间的关系,通过 线条的走势呈现数据变化。
控制系统仿真
使用MATLAB进行控制系统仿真 ,模拟系统动态性能。
控制系统优化
对控制系统进行优化设计,如权 重优化、多目标优化等。
THANK YOU
感谢聆听
对图像进行几何变换,如缩放、旋转、平移 等操作。
动画制作
帧动画
通过一系列静态图像的连续播放,形 成动态效果。
路径动画
让对象沿指定路径移动,形成动态效 果。
变形动画
让对象从一个形状逐渐变形为另一个 形状,形成动态效果。
交互式动画
允许用户通过交互操作控制动画的播 放、暂停、回放等操作。
04
MATLAB在科学计算中的应用
对函数进行数值积分和微分, 用于解决定积分和微分方程问 题。
数值优化
matlab教程ppt(完整版)

矩阵的数学运算
总结词
详细描述
总结词
详细描述
掌握矩阵的数学运算,如求逆 、求行列式、求特征值等。
在MATLAB中,可以使用inv() 函数来求矩阵的逆,使用det() 函数来求矩阵的行列式,使用 eig()函数来求矩阵的特征值。 例如,A的逆可以表示为 inv(A),A的行列式可以表示 为det(A),A的特征值可以表 示为eig(A)。
• 总结词:了解特征值和特征向量的概念及其在矩阵分析中的作用。 • 详细描述:特征值和特征向量是矩阵分析中的重要概念。特征值是满足Ax=λx的标量λ和向量x,特征向量是与特征值对
应的非零向量。特征值和特征向量在许多实际问题中都有应用,如振动分析、控制系统等。
04
MATLAB图像处理
图像的读取与显示
变量定义
使用赋值语句定义变量,例如 `x = 5`。
矩阵操作
学习如何创建、访问和操作矩 阵,例如使用方括号 `[]`。
函数编写
学习如何创建自定义函数来执 行特定任务。
02
MATLAB编程
变量与数据类型
01
02
03
变量命名规则
MATLAB中的变量名以字 母开头,可以包含字母、 数字和下划线,但不应与 MATLAB保留字冲突。
了解矩阵的数学运算在实际问 题中的应用。
矩阵的数学运算在许多实际问 题中都有应用,如线性方程组 的求解、矩阵的分解、信号处 理等。通过掌握这些运算,可 以更好地理解和解决这些问题 。
矩阵的分解与特征值
• 总结词:了解矩阵的分解方法,如LU分解、QR分解等。
• 详细描述:在MATLAB中,可以使用lu()函数进行LU分解,使用qr()函数进行QR分解。这些分解方法可以将一个复杂的 矩阵分解为几个简单的部分,便于计算和分析。
matlab教程ppt(完整版)

数据处理
应用MATLAB的信号处理和统计 分析函数库,进行数据预处理、
特征提取和模型训练。
机器学习与深度学习
机器学习
介绍MATLAB中的各种机器学习算法,如线性回归、决策 树、支持向量机等,以及如何应用它们进行分类、回归和 聚类。
深度学习
介绍深度学习框架和网络结构,如卷积神经网络(CNN) 、循环神经网络(RNN)等,以及如何使用MATLBiblioteka B进行 训练和部署。感谢观看
THANKS
符号微积分
进行符号微分和积分运算,如极限、导数和 积分。
符号方程求解
使用solve函数求解符号方程。
符号矩阵运算
进行符号矩阵的乘法、转置等运算。
05
MATLAB应用实例
数据分析与可视化
数据分析
使用MATLAB进行数据导入、清 洗、处理和分析,包括描述性统
计、可视化、假设检验等。
可视化
利用MATLAB的图形和可视化工 具,如散点图、柱状图、3D图等
数值求和与求积
演示如何对数值进行求和与求积 操作。
数值计算函数
介绍常用数值计算函数,如sin、 cos、tan等。
方程求解
演示如何求解线性方程和非线性方 程。
03
MATLAB编程基础
控制流
01
02
03
04
顺序结构
按照代码的先后顺序执行,是 最基本的程序结构。
选择结构
通过if语句实现,根据条件判 断执行不同的代码块。
数据分析
数值计算
MATLAB提供了强大的数据分析工具,支 持多种统计分析方法,可以帮助用户进行 数据挖掘和预测分析。
MATLAB可以进行高效的数值计算,支持 多种数值计算方法,包括线性代数、微积 分、微分方程等。
matlab教程ppt(完整版)

可以使用`'`运算符对矩阵进行 转置。
矩阵高级运算
01
逆矩阵
可以使用`inv`函数求矩阵的逆矩阵 。
行列式
可以使用`det`函数求矩阵的行列式 。
03
02
特征值和特征向量
可以使用`eig`函数求矩阵的特征值 和特征向量。
秩
可以使用`rank`函数求矩阵的秩。
04
04
matlab绘图功能
绘图基本命令
控制设计
MATLAB提供了控制系统设计和分析 工具箱,可以方便地进行控制系统的 建模、分析和优化。
03
信号处理
MATLAB提供了丰富的信号处理工具 箱,可以进行信号的时域和频域分析 、滤波器设计等操作。
05
04
图像处理
MATLAB提供了图像处理工具箱,可 以进行图像的增强、分割、特征提取 等操作。
02
matlab程序调试技巧分享
01
调试模式
MATLAB提供了调试模式,可以 逐行执行代码,查看变量值,设 置断点等。
日志输出
02
03
错误处理
通过使用fprintf函数,可以在程 序运行过程中输出日志信息,帮 助定位问题。
MATLAB中的错误处理机制可以 帮助我们捕获和处理运行时错误 。
matlab程序优化方法探讨
显示结果
命令执行后,结果将在命令窗口中显示。
保存结果
可以使用`save`命令将结果保存到文件中。
matlab变量定义与赋值
定义变量
使用`varname = value`格式定义变 量,其中`varname`是变量名, `value`是变量的值。
赋值操作
使用`=`运算符将值赋给变量。例如 ,`a = 10`将值10赋给变量a。
matlab教程ppt(完整版)

控制流语句
使用条件语句(如if-else)和 循环语句(如for)来控制程序 流程。
变量定义
使用赋值语句定义变量,例如 `a = 5`。
矩阵运算
使用矩阵进行数学运算,如加 法、减法、乘法和除法等。
函数编写
创建自定义函数来执行特定任 务。
02
MATLAB编程语言基础
变量与数据类型
变量命名规则
数据类型转换
编辑器是一个文本编辑器 ,用于编写和编辑 MATLAB脚本和函数。
工具箱窗口提供了一系列 用于特定任务的工具和功 能,如数据可视化、信号 处理等。
工作空间窗口显示当前工 作区中的变量,可以查看 和修改变量的值。
MATLAB基本操作
数据类型
MATLAB支持多种数据类型, 如数值型、字符型和逻辑型等 。
04
MATLAB数值计算
数值计算基础
01
02
03
数值类型
介绍MATLAB中的数值类 型,包括双精度、单精度 、复数等。
变量赋值
讲解如何给变量赋值,包 括标量、向量和矩阵。
运算符
介绍基本的算术运算符、 关系运算符和逻辑运算符 及其优先级。
数值计算函数
数学函数
列举常用的数学函数,如 三角函数、指数函数、对 数函数等。
矩阵的函数运算
总结词:MATLAB提供了许多内置函 数,可以对矩阵进行各种复杂的运算
。
详细描述
矩阵求逆:使用 `inv` 函数求矩阵的 逆。
特征值和特征向量:使用 `eig` 函数 计算矩阵的特征值和特征向量。
行列式值:使用 `det` 函数计算矩阵 的行列式值。
矩阵分解:使用 `factor` 和 `expm` 等函数对矩阵进行分解和计算指数。
matlab教程ppt(完整版)

汇报人:可编辑
2023-12-24
目录
• MATLAB基础 • MATLAB编程 • MATLAB矩阵运算 • MATLAB数值计算 • MATLAB可视化 • MATLAB应用实例
01
CATALOGUE
MATLAB基础
MATLAB简介
MATLAB定义
MATLAB应用领域
菜单栏
包括文件、编辑、查看、主页 、应用程序等菜单项。
命令窗口
用于输入MATLAB命令并显示 结果。
MATLAB主界面
包括命令窗口、当前目录窗口 、工作空间窗口、历史命令窗 口等。
工具栏
包括常用工具栏和自定义工具 栏。
工作空间窗口
显示当前工作区中的变量。
MATLAB基本操作
变量定义
使用变量名和赋值符号(=)定义变 量。
详细描述
直接输入:在 MATLAB中,可以直 接通过输入矩阵的元 素来创建矩阵。例如 ,`A = [1, 2, 3; 4, 5, 6; 7, 8, 9]`。
使用函数创建: MATLAB提供了多种 函数来创建特殊类型 的矩阵,如`eye(n)`创 建n阶单位矩阵, `diag(v)`创建由向量v 的元素构成的对角矩 阵。
使用bar函数绘制柱状图 ,可以自定义柱子的宽
度、颜色和标签。
使用pie函数绘制饼图, 可以自定义饼块的比例
和颜色。
三维绘图
01
02
03
04
三维线图
使用plot3函数绘制三维线图 ,可以展示三维空间中的数据
点。
三维曲面图
使用surf函数绘制三维曲面图 ,可以展示三维空间中的曲面
。
三维等高线图
matlab教程ppt(完整版)

矩阵减法:两个相同大小 的矩阵可以进行减法运算 ,例如D=A-B。
矩阵的分解与特征值
详细描述
矩阵分解:将一个复杂的矩阵分 解为几个简单的、易于处理的矩 阵,例如LU分解、QR分解等。
特征值:矩阵的特征值是该矩阵 的一个重要的数值属性,可以用 于分析矩阵的性质和特征。
矩阵运算
介绍矩阵的创建、索引、算术 运算和逻辑运算等操作。
控制流
介绍if语句、for循环和while 循环等控制流结构的使用方法 。
02
MATLAB编程
变量与数据类型
01
02
03
变量命名规则
MATLAB中的变量名以字 母开头,可以包含字母、 数字和下划线,但不能包 含空格。
数据类型
MATLAB支持多种数据类 型,如数值型、字符型、 逻辑型和单元数组等。
matlab教程PPT(完整版)
汇报人:可编辑 2023-12-26
目 录
• MATLAB基础 • MATLAB编程 • MATLAB矩阵运算 • MATLAB图像处理 • MATLAB数值分析 • MATLAB应用实例
01
MATLAB基础
MATLAB简介
MATLAB定义
MATLAB应用领域
MATLAB是一种用于算法开发、数据 可视化、数据分析和数值计算的编程 语言和环境。
函数编写
01
02
03
04
函数定义
使用`function`关键字定义函 数,指定输入输出参数。
函数体
在函数定义中编写实现特定功 能的代码。
函数调用
通过函数名和输入参数调用自 定义函数。
MATLAB中文手册

Matlab中文手册目录 (1)第1章MATLAB 6.5环境 (11)1.1 MATLAB简介 (11)1.1.1 MATLAB工具箱 (11)1.1.2 MATLAB功能和特点 (12)1.2 MATLAB 6.5环境设置 (13)1.2.1 菜单栏 (13)1.2.2 工具栏 (18)1.2.3 通用操作界面窗口 (18)1.3 MATLAB 6.5帮助 (32)1.4 MATLAB 6.5其他管理 (35)1.4.1 MATLAB用户文件格式 (35)1.4.2设置搜索路径 (36)1.4.3文件管理命令 (37)1.4.4 退出MATLAB (39)1.5 一个实例 (39)第2章MATLAB数值计算 (43)2.1 变量和数据 (43)2.1.1数据类型 (43)2.1.2数据 (43)2.1.3变量 (46)2.2 矩阵和数组 (47)2.2.1矩阵输入 (47)2.2.2矩阵元素和操作 (54)2.2.3字符串 (65)2.2.4矩阵和数组运算 (72)2.2.5多维数组 (92)2.3稀疏矩阵 (98)2.3.1稀疏矩阵的建立 (98)2.3.2稀疏矩阵的存储空间 (103)2.3.3稀疏矩阵的运算 (105)2.4多项式 (105)2.4.1多项式的求值、求根和部分分式展开 (105)2.4.2多项式的乘除法和微积分 (109)2.4.3多项式拟合和插值 (112)2.5元胞数组和结构数组 (115)2.5.1元胞数组 (116)2.5.2结构数组 (121)2.6数据分析 (127)2.6.1数据统计和相关分析 (127)2.6.2差分和积分 (129)2.6.3卷积和快速傅里叶变换 (134)2.6.4向量函数 (137)第3章MATLAB符号计算 (138)3.1 符号表达式的建立 (138)3.1.1 创建符号常量 (138)3.1.2 创建符号变量和表达式 (141)3.1.3 符号矩阵 (143)3.2符号表达式的代数运算 (145)3.2.1符号表达式的代数运算 (146)3.2.2 符号数值任意精度控制和运算 (149)3.2.3 符号对象与数值对象的转换 (152)3.3符号表达式的操作和转换 (154)3.3.1符号表达式中自由变量的确定 (154)3.3.2符号表达式的化简 (156)3.3.3符号表达式的替换 (161)3.3.4求反函数和复合函数 (164)3.3.5 符号表达式的转换 (166)3.4 符号极限、微积分和级数求和 (169)3.4.1符号极限 (169)3.4.2符号微分 (171)3.4.3符号积分 (174)3.4.4符号级数 (176)3.5 符号积分变换 (178)3.5.1傅里叶(Fourier)变换及其反变换 (178)3.5.2拉普拉斯(Laplace)变换及其反变换 (180)3.5.3 Z变换及其反变换 (181)3.6符号方程的求解 (183)3.6.1代数方程 (183)3.6.2符号常微分方程 (185)3.7符号函数的可视化 (186)3.7.1符号函数的绘图命令 (186)3.7.2图形化的符号函数计算器 (189)3.8 Maple函数的使用 (189)3.8.1访问Maple函数 (190)3.8.2 获得Maple的帮助 (191)第4章MATLAB计算的可视化和GUI设计 (192)4.1二维曲线的绘制 (192)4.1.1基本绘图命令plot (192)4.1.2绘制曲线的一般步骤 (198)4.1.3多个图形绘制的方法 (199)4.1.4曲线的线型、颜色和数据点形 (202)4.1.5设置坐标轴和文字标注 (204)4.1.6交互式图形命令 (210)4.2 MATLAB的三维图形绘制 (211)4.2.1绘制三维线图命令plot3 (211)4.2.2绘制三维网线图和曲面图 (212)4.2.3立体图形与图轴的控制 (217)4.2.4色彩的控制 (220)4.3 MATLAB的特殊图形绘制 (225)4.3.1条形图 (225)4.3.2面积图和实心图 (227)4.3.3直方图 (228)4.3.4饼图 (230)4.3.5离散数据图 (231)4.3.6对数坐标和极坐标图 (232)4.3.7等高线图 (234)4.3.8复向量图 (235)4.4图形窗口的功能 (236)4.5对话框 (238)4.6句柄图形 (242)4.6.1句柄图形体系 (242)4.6.2图形对象的操作 (242)4.6.3图形对象属性的获取和设置 (248)4.7图形用户界面(GUI)设计 (251)4.7.1可视化的界面环境 (252)4.7.2菜单 (253)4.7.5回调函数 (258)4.7.6 GUI应用举例 (258)4.8动画 (261)4.8.1以电影方式产生动画 (261)4.8.2以对象方式产生动画 (262)第5章MATLAB程序设计 (264)5.1脚本文件和函数文件 (264)5.1.1 M文本编辑器 (265)5.1.2 M文件的基本格式 (265)5.1.3 M脚本文件 (266)5.1.4 M函数文件 (268)5.2程序流程控制 (269)5.2.1 for ... end循环结构.. (269)5.2.2 while ... end循环结构. (271)5.2.3 If...else...end条件转移结构 (272)5.2.4 switch...case开关结构.. (273)5.2.5 try... catch... end试探结构 .. (275)5.2.6流程控制语句 (276)5.3函数调用和参数传递 (280)5.3.1子函数和私有函数 (280)5.3.2局部变量和全局变量 (281)5.3.4程序举例 (287)5.4 M文件性能的优化和加速 (289)5.4.1 P码文件 (289)5.4.2 M文件性能优化 (290)5.4.3 JIT和加速器 (292)5.5内联函数 (295)5.6利用函数句柄执行函数 (298)5.6.1函数句柄的创建 (298)5.6.2用feval命令执行函数 (299)5.7利用泛函命令进行数值分析 (301)5.7.1求极小值 (302)5.7.2求过零点 (304)5.7.3数值积分 (305)5.7.4微分方程的数值解 (306)第6章线性控制系统分析与设计 (309)6.1线性系统的描述 (309)6.1.1状态空间描述法 (309)6.1.2传递函数描述法 (311)6.1.3零极点描述法 (312)6.1.4离散系统的数学描述 (313)6.2线性系统模型之间的转换 (317)6.2.1连续系统模型之间的转换 (317)6.2.2连续系统与离散系统之间的转换 (325)6.2.3模型对象的属性 (330)6.3结构框图的模型表示 (334)6.4线性系统的时域分析 (348)6.4.1零输入响应分析 (348)6.4.2脉冲响应分析 (350)6.4.3阶跃响应分析 (351)6.4.4任意输入的响应 (353)6.4.5系统的结构参数 (356)6.5线性系统的频域分析 (358)6.5.1频域特性 (358)6.5.2连续系统频域特性 (359)6.5.3幅值裕度和相角裕度 (366)6.5.4离散系统频域分析 (367)6.6线性系统的根轨迹分析 (367)6.6.1绘制根轨迹 (367)6.6.2根轨迹的其它工具 (370)6.7线性系统的状态空间设计 (373)6.7.1极点配置法 (373)6.7.2最优二次型设计 (374)第7章Simulink仿真环境 (376)7.1演示一个Simulink的简单程序 (376)7.2 Simulink的文件操作和模型窗口 (379)7.2.1 Simulink的文件操作 (379)7.2.2 Simulink的模型窗口 (380)7.3 模型的创建 (382)7.3.1模块的操作 (382)7.3.2信号线的操作 (385)7.3.3给模型添加文本注释 (387)7.4 Simulink的基本模块 (387)7.4.1基本模块 (387)7.4.2常用模块的参数和属性设置 (390)7.5复杂系统的仿真与分析 (395)7.5.1仿真的设置 (395)7.5.2连续系统仿真 (397)7.5.3离散系统仿真 (400)7.5.4仿真结构参数化 (402)7.6子系统与封装 (403)7.6.1建立子系统 (403)7.6.2条件执行子系统 (405)7.6.3子系统的封装 (407)7.7用MATLAB命令创建和运行Simulink模型 (413)7.7.1用MATLAB命令创建Simulink模型 (413)7.7.2用MATLAB命令运行Simulink模块 (417)7.8以Simulink为基础的模块工具箱简介 (418)第8章MATLAB高级应用 (419)8.1 MATLAB应用接口 (419)8.1.1 MEX文件 (419)8.1.2 使用MATLAB编译器生成MEX和EXE文件 (424)8.2 低级文件的输入输出 (426)8.2.1打开和关闭文件 (426)8.2.2读写格式化文件 (428)8.2.3读写二进制数据 (433)8.2.4文件定位 (435)8.3 图形文件的转储 (437)8.4 Notebook (438)8.4.1 Notebook的安装 (438)8.4.2 Notebook的启动 (438)8.4.3 Notebook的使用 (441)8.4.4 Notebook中MATLAB的使用 (445)第1章MATLAB 6.5环境1.1MATLAB简介●MATLAB(Matrix Laborator)是MathWorks公司开发科学与工程计算软件;●广泛应用于自动控制、数学运算、信号分析、计算机技术、图像信号处理、财务分析、航天工业、汽车工业、生物医学工程、语音处理和雷达工程等行业;●国内外高校和研究部门科学研究的重要工具;●MATLIB 已成为数学计算工具方面事实上的标准,MATLIB 6.5是最新版本。
MATLAB教程课件

到九十年代,在国际上 30 几个数学类科技应用软件中, Matlab 在数值计算方面独占鳌头。
3
Matlab 简介
目前,Matlab 已成为世界顶尖的数学应用软件,以其强大 的工程计算、算法研究、工程绘图、应用程序开发、数据分 析和动态仿真等功能,在航空航天、机械制造和工程建筑等 领域发挥着越来越重要的作用。就影响而言,至今仍然没有 一个别的计算软件可与 Matlab 匹敌。 Matlab 的发行
7
Matlab 的特点与功能
Matlab 丰富的工具箱(toolbox)
根据专门领域中的特殊需要而设计的各种可选工具箱
Symbolic Math Signal process Control System
PDE
Image Process System Identification
Optimization Statistics
5
Matlab 的特点与功能
Matlab 是一个交互式软件系统
输入一条命令,立即就可以得出该命令的结果
Matlab 具有很强的数值计算功能
Matlab 以矩阵作为数据操作的基本单位, 但无需预先指定矩阵维数(动态定维)
按照 IEEE 的数值计算标准进行计算 提供十分丰富的数值计算函数,方便计算,提高效率 Matlab 命令与数学中的符号、公式非常接近,
format loose
自由格式
format + / format bank / format rat / format hex (详情查看联机帮助)
25
变量的存储
存储当前工作空间中的变量
matlab中文手册()

Matlab中文手册第1章MA TLAB6.5环境 (6)1.1MA TLAB简介 (6)1.1.1MATLAB工具箱 (6)1.1.2MATLAB功能和特点 (6)1.2MA TLAB6.5环境设置 (7)1.2.1菜单栏 (7)1.2.2工具栏 (10)1.2.3通用操作界面窗口 (10)1.3MA TLAB6.5帮助 (19)1.4MA TLAB6.5其他管理 (20)1.4.1MATLAB用户文件格式 (20)21 (22)1.4.4退出MATLAB (23)1.5一个实例 (23)第2章MA TLAB数值计算 (26)2.1变量和数据 (26)2626272.2矩阵和数组 (28)28313741522.3稀疏矩阵 (55)2.3.1稀疏矩阵的建立 (55)2.3.2稀疏矩阵的存储空间 (58)2.3.3稀疏矩阵的运算 (59)2.4多项式 (59) (59) (61) (63)2.5元胞数组和结构数组 (65) (65) (68)2.6数据分析 (71) (71) (72) (74) (76)第3章MA TLAB符号计算 (77)3.1符号表达式的建立 (77)3.1.1创建符号常量 (77)3.1.2创建符号变量和表达式 (78)3.1.3符号矩阵 (80)3.2符号表达式的代数运算 (81) (81)3.2.2符号数值任意精度控制和运算 (83)3.2.3符号对象与数值对象的转换 (84)3.3符号表达式的操作和转换 (85) (85) (86) (89) (90)3.3.5符号表达式的转换 (92)3.4符号极限、微积分和级数求和 (93)3.4.1符号极限 (93)3.4.2符号微分 (94)3.4.3符号积分 (96)3.4.4符号级数 (97)3.5符号积分变换 (98)3.5.1傅里叶(Fourier)变换及其反变换 (98)3.5.2拉普拉斯(Laplace)变换及其反变换 (99)3.5.3Z变换及其反变换 (100)3.6符号方程的求解 (101) (101) (102)3.7符号函数的可视化 (103) (103) (105)3.8Maple函数的使用 (105) (105)3.8.2获得Maple的帮助 (106)第4章MA TLAB计算的可视化和GUI设计 (107)4.1二维曲线的绘制 (107)4.1.1基本绘图命令plot (107) (111) (112) (114) (115) (118)4.2MA TLAB的三维图形绘制 (119)4.2.1绘制三维线图命令plot3 (119)4.2.2绘制三维网线图和曲面图 (120) (123) (125)4.3MA TLAB的特殊图形绘制 (128) (128) (129) (130) (131) (132) (132) (133) (134)4.4图形窗口的功能 (135)4.5对话框 (136)4.6句柄图形 (138) (138) (139) (142)4.7图形用户界面(GUI)设计 (144)4.7.1可视化的界面环境 (144)4.7.2菜单 (146)4.7.3控件 (147) (149)4.7.6GUI应用举例 (149)4.8动画 (151)4.8.1以电影方式产生动画 (151) (152)第5章MA TLAB程序设计 (153)5.1脚本文件和函数文件 (153)5.1.1M文本编辑器 (153)5.1.2M文件的基本格式 (154)5.1.3M脚本文件 (155)5.1.4M函数文件 (156)5.2程序流程控制 (157)5.2.1for...end循环结构. (157)5.2.2while...end循环结构 .. (158)5.2.3If...else...end条件转移结构 . (158)5.2.4switch...case开关结构.. (159)5.2.5try...catch...end试探结构.. (160)5.2.6流程控制语句 (161)5.3函数调用和参数传递 (163) (163) (164)5.3.3函数的参数 (165) (168)5.4M文件性能的优化和加速 (170)5.4.1P码文件 (170)5.4.2M文件性能优化 (170)5.4.3JIT和加速器 (171)5.5内联函数 (174)5.6利用函数句柄执行函数 (175) (175) (176)5.7利用泛函命令进行数值分析 (177)5.7.1求极小值 (178)5.7.2求过零点 (179)5.7.3数值积分 (180) (180)第6章线性控制系统分析与设计 (182)6.1线性系统的描述 (182) (182) (183) (184) (184)6.2线性系统模型之间的转换 (187) (187) (190) (193)6.3结构框图的模型表示 (195)6.4线性系统的时域分析 (203) (203) (204) (205) (206) (208)6.5线性系统的频域分析 (209) (209) (210) (214) (214)6.6线性系统的根轨迹分析 (215) (215) (216)6.7线性系统的状态空间设计 (219) (219) (220)第7章Simulink仿真环境 (221)7.1演示一个Simulink的简单程序 (221)7.2Simulink的文件操作和模型窗口 (223)7.2.1Simulink的文件操作 (223)7.2.2Simulink的模型窗口 (223)7.3模型的创建 (225) (225) (227) (228)7.4Simulink的基本模块 (228) (228) (230)7.5复杂系统的仿真与分析 (233)7.5.1仿真的设置 (233) (234) (237) (239)7.6子系统与封装 (239) (239) (241) (242)7.7用MA TLAB命令创建和运行Simulink模型 (246) (246) (248)7.8以Simulink为基础的模块工具箱简介 (249)第8章MA TLAB高级应用 (250)8.1MA TLAB应用接口 (250)8.1.1MEX文件 (250)8.1.2使用MATLAB编译器生成MEX和EXE文件 (253)8.2低级文件的输入输出 (255) (255) (256) (258) (259)8.3图形文件的转储 (261)8.4Notebook (261)8.4.1Notebook的安装 (261)8.4.2Notebook的启动 (261)8.4.3Notebook的使用 (263)8.4.4Notebook中MA TLAB的使用 (266)第1章MATLAB6.5环境1.1M ATLAB简介●MATLAB(MatrixLaborator)是MathWorks公司开发科学与工程计算软件;●广泛应用于自动控制、数学运算、信号分析、计算机技术、图像信号处理、财务分析、航天工业、汽车工业、生物医学工程、语音处理和雷达工程等行业;●国内外高校和研究部门科学研究的重要工具;●MATLIB已成为数学计算工具方面事实上的标准,MATLIB6.5是最新版本。
(完整版)Matlab入门教程

(完整版)Matlab⼊门教程第1章MATLAB操作基础1.1 MATLAB概述1.1.2 MATLAB的主要功能1.数值计算MATLAB以矩阵作为数据操作的基本单位,还提供了⼗分丰富的数值计算函数。
2.绘图功能可以绘制⼆维、三维图形,还可以绘制特殊图形(与统计有关的图,例如:区域图、直⽅图、饼图、柱状图等)。
3.编程语⾔MATLAB具有程序结构控制、函数调⽤、数据结构、输⼊输出、⾯向对象等程序语⾔特征,⽽且简单易学、编程效率⾼。
4.MATLAB⼯具箱MATLAB包含两部分内容:基本部分和各种可选的⼯具箱。
MATLAB⼯具箱分为两⼤类:功能性⼯具箱和学科性⼯具箱。
1.1.3MATLAB语⾔的特点语⾔简洁紧凑,使⽤⽅便灵活,易学易⽤。
例如:A=[1 2 3;4 5 6;7 8 9]⼀条语句实现了对3x3矩阵的输⼊。
语句功能强⼤,⼀条语句相当于其它语⾔的⼀个⼦程序,例如fft。
语句简单,内涵丰富。
同⼀个函数有不同的输⼊变量和输出变量,分别代表不同的含义。
Matlab既具有结构化的控制语句(if、for、while)⼜⽀持⾯向对象的程序设计。
⽅便的绘图功能。
包含功能强劲的⼯具箱。
易于扩展。
1.1.4 初识MATLAB例1-1 绘制正弦曲线和余弦曲线。
x=[0:0.5:360]*pi/180;plot(x,sin(x),x,cos(x));例1-2 求⽅程3x4+7x3+9x2-23=0的全部根。
p=[3,7,9,0,-23]; %建⽴多项式系数向量x=roots(p) %求根例1-3 求积分quad('x.*log(1+x)',0,1)例1-4 求解线性⽅程组。
a=[2,-3,1;8,3,2;45,1,-9];b=[4;2;17];x=inv(a)*b1.2 MATLAB的运⾏环境与安装1.2.1 MATLAB的运⾏环境硬件环境:(1) CPU(2) 内存(3) 硬盘(4) CD-ROM驱动器和⿏标软件环境:(1) Windows 98/NT/2000 或Windows XP(2) 其他软件根据需要选⽤1.2.2 MATLAB的安装运⾏系统的安装程序setup.exe,可以按照安装提⽰依次操作。
Matlab入门教程(很齐全)PPT课件

MATLAB成为工程和科学计算的标准工具,广泛应用于数学建模、算法开发、数据分析等领域。
1980年代初期
matlab发展史
matlab特点
MATLAB提供了交互式命令行窗口和编辑器,方便用户进行程序设计和调试。
交互式编程环境
MATLAB具有高效的数值计算和矩阵运算功能,适用于处理大规模数据和进行复杂数学运算。
强大的数值计算能力
MATLAB内置了丰富的绘图函数库,可以方便地将数据可视化,有助于分析和解决问题。
图形可视化
MATLAB提供了各种工具箱,如信号处理、图像处理、机器学习、控制系统等,可以扩展其应用领域。
丰富的工具箱
科学研究
MATLAB被广泛应用于物理学、化学、生物学、地球科学等领域的科研工作。
工程应用
要点一
要点二
GUIDE特点:GUIDE提供了一组交互式的界面控件,可以轻松地创建GUI界面,并支持M文件和C/C代码生成,使得用户可以轻松地扩展GUI功能。
GUIDE使用方法:使用GUIDE前需要先打开MATLAB,然后在命令窗口输入“guide”命令,即可打开GUIDE主界面。
要点三
GUI界面布局应该清晰、简洁、易于操作,使得用户能够快速完成操作。
界面布局
界面设计要素
选择合适的GUI控件,如按钮、文本框、菜单等,能够增强界面的交互性和可视化效果。
控件选择
色彩搭配应该和谐、自然,使得GUI界面更加美观易用。
色彩搭配
字体应该清晰易读,适应GUI界面的整体风格,使得用户能够轻松获取信息。
字体选择
06
matlab数据分析
导入数据
支持多种数据格式,如Excel、CSV等,方便用户快速导入数据
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
MatLab简介MATLAB是什么?典型的使用包括:数学和计算算术发展模型,模拟,和原型数据分析,开发,和可视化科学和工程图学应用发展包括图形用户界面设计MATLAB表示矩阵实验室。
MATLAB系统MATLAB系统由5主要的部分构成:1. MATLAB语言。
这是高阶的矩阵/数组语言,带控制流动陈述,函数,数据结构,输入/输出,而且面向目标的编程特点。
Ops 操作符和特殊字符。
Lang 程序设计语言作。
strfun 字符串。
iofun 输入/输出。
timefun 时期和标有日期。
datatypes数据类型和结构。
2. MATLAB工作环境。
这是你作为MATLAB用户或程序编制员的一套工具和设施。
3. 制图这是MATLAB制图系统。
它为2维上,而且三维的数据可视化,图象处理,动画片制作和表示图形包括高阶的指令在内。
它也为包括低阶的指令在内,允许你建造完整的图形用户界面(GUIs),MATLAB应用。
制图法功能在MATLAB工具箱中被组织成5文件夹:graph2d 2-的维数上的图表。
graph3d 三维的图表。
specgraph 专业化图表。
graphics 制图法。
uitools 图形用户界面工具。
4. MATLAB的数学的函数库。
数学和分析的功能在MATLAB工具箱中被组织成8文件夹。
elmat 初步矩阵,和矩阵操作。
elfun 初步的数学函数。
specfun 专门的数学函数。
matfun 矩阵函数-用数字表示的线性的代数。
datafun 数据分析和傅立叶变换。
polyfun 插入物,并且多项式。
funfun 功能函数。
sparfun 稀少矩阵。
5. MATLAB应用程序接口(API)。
这是允许你写C、Fortran语言与MATLAB 交互。
关于 SimulinkSimulink ? MATLAB为做非线性的动态的系统的模拟实验的交互式的系统。
它是允许你通过把方框图拉到屏幕,灵活地窜改它制作系统的模型的用图表示的鼠标驱动的程序。
实时工作室?允许你产生来自你的图表块的C代码,使之能用于各种实时系统。
关于工具箱工具箱是为了解答特别种类的问题扩展MATLAB环境的MATLAB函数的综合的(M-文件)收集MatLab工作环境命令窗口若输入A = [1 2 3; 4 5 6; 7 8 10]按下回车键后显示如下A =1 2 34 5 67 8 10清除命令窗口clc这并不清除工作间,只是清除了显示,仍可按上箭头看到以前发出的命令数据格式命令x = [4/3 1.2345e–6]format short1.3333 0.0000format short e1.3333e+000 1.2345e–006format short g1.3333 1.2345e–006format long1.33333333333333 0.00000123450000format long e1.333333333333333e+000 1.234500000000000e–006format long g1.33333333333333 1.2345e–006format bank1.33 0.00format +++format rat4/3 1/810045format hex3ff5555555555555 3eb4b6231abfd271若最大的元素大于1000或小于0.001,则显示short或long格式时时会加上一个比例还有两个格式:format compactformat loose禁止结果的显示在命令后加上分号,则屏幕上不会立即显示出结果,这在运算大的数据量时十分有用,如下命令产生100*100的幻方:A = magic(100);长命令行如想另起一行输入命令,在末尾加上"..."即可,如:s = 1 – 1/2 + 1/3 – 1/4 + 1/5 – 1/6 + 1/7 ... – 1/8 + 1/9 – 1/10 + 1/11 – 1/12;MatLab工作间你可用who或whos来察看当前工作间中有哪些变量,如: whosName Size Bytes ClassA 4x4 128 double arrayD 3x5 120 double arrayM 10x1 40 cell arrayS 1x3 628 struct arrayh 1x11 22 char arrayn 1x1 8 double arrays 1x5 10 char arrayv 1x14 28 char arrayGrand total is 93 elements using 984 bytes若要从工作间中删除所有的变量,用clear保存、重载工作间你可以将工作间保存为一个二进制的M文件,以后还可以恢复回来:save june10也可只保存工作间中的部分变量值save june10 x y z重载时只需输入load june10文件名保存在字符串中这样可以像调用函数一样调用工作间save(’myfile’,’VAR1’,’VAR2’)A = ’myfile’;load(A)与下面的命令相同save myfile VAR1 VAR2load myfile下面的命令把1至10的平方值分别存放在data1至data10中:file = ’data’;for i = 1:10 j = i.^2;save([file int2str(i)],’j’);end查找路径当你输入“yourpig"时发生了什么呢?1:察看是否是变量;2:察看是否是内建函数;3:察看当前目录下是否有文件:yourpig.m;4:察看查找目录下是否有文件:yourpig.m;对于查找路径中的文件,what显示当前目录下的文件,加上路径后可显示输入的路径下所有的MatLab文件.如:what matlab/elfun以下二命令分别显示、编辑m文件type rankedit rank图像窗口下面的命令产生一个与命令窗口隔离的图形窗口,figureplot函数则会在新的窗口中绘制图形,如t = 0:pi/100:2*pi;y = sin(t);plot(t,y)则有如下图形:寻求帮助下面的函数在寻求帮助时十分有用:help 列出你所寻求帮助的函数的功能描述;lookfor 列出所有函数的功能描述中含有你所输入的内容的函数的简介如:help inverse显示inverse.m not found.但如输入lookfor inverse则显示INVHILB Inverse Hilbert matrixACOSH Inverse hyperbolic cosineERFINV Inverse of the error functionINV Matrix inversePINV PseudoinverseIFFT Inverse discrete Fourier transformIFFT2 Two–dimensional inverse discrete Fourier transform ICCEPS Inverse complex cepstrumIDCT Inverse discrete cosine transform数据分析和统计面向列的数据集这年头似乎十分风行”面向”这个词,这儿故也套用,其英文为"Column-Oriented Data Sets",可理解为MatLab按列的存储方式来分析数据,下面是一个例子:Time Location 1 Location 2 Location 301h00 11 11 902h00 7 13 1103h00 14 17 2004h00 11 13 905h00 43 51 6906h00 38 46 76 07h00 61 132 186 08h00 75 135 180 09h00 38 88 115 10h00 28 36 55 11h00 12 12 14 12h00 18 27 30 13h00 18 19 29 14h00 17 15 18 15h00 19 36 48 16h00 32 47 10 17h00 42 65 92 18h00 57 66 151 19h00 44 55 90 20h00 114 145 257 21h00 35 58 68 22h00 11 12 15 23h00 13 9 15 24h00 10 9 7 以上数据被保存在一个称为count.dat的文件中.7 13 1114 17 2011 13 943 51 6938 46 7661 132 186 75 135 180 38 88 115 28 36 5512 12 1418 27 3018 19 2917 15 1819 36 4832 47 1042 65 9257 66 151 44 55 90 114 145 257 35 58 6811 12 1510 9 7下面,我们调入此文件,并看看文件的一些参数load count.dat[n,p] = size(count)n =24p =3创建一个时间轴后,我们可以把图画出来:t = 1:n;set(0,'defaultaxeslinestyleorder’,’-|--|-.’)set(0,'defaultaxescolororder’,[0 0 0])plot(t,count), legend('Location 1','Location 2','Location 3',0) xlabel('Time'), ylabel('Vehicle Count'), grid on足以证明,以上是对3个对象的24次观测.基本数据分析函数(一定注意是面向列的)继续用上面的数据,其每列最大值.均值.及偏差分别为:mx = max(count)mu = mean(count)sigma = std(count)mx =114 145 257mu =32.0000 46.5417 65.5833 sigma =25.3703 41.4057 68.0281重载函数,还可以定位出最大.最小值的位置[mx,indx] = min(count)mx =7 9 7indx =2 23 24试试看,你能看懂下面的命令是干什么的吗?[n,p] = size(count)e = ones(n,1)x = count – e*mu点这看看答案!下面这句命令则找出了整个矩阵的最小值:min(count(:))ans =7协方差及相关系数下面,我们来看看第一列的方差:cov(count(:,1))ans =643.6522cov()函数作用于矩阵,则会计算其协方差矩阵. corrcoef()用于计算相关系数,如:corrcoef(count)ans =1.0000 0.9331 0.95990.9331 1.0000 0.95530.9599 0.9553 1.0000数据的预处理未知数据NaN(Not a Number--不是一个数)被定义为未经定义的算式的结果,如 0/0.在处理数据中,NaN常用来表示未知数据或未能获得的数据.所有与NaN有关的运算其结果都是NaN.a = magic(3);a(2,2) = NaNa =8 1 63 NaN 74 9 2sum(a)ans =15 NaN 15在做统计时,常需要将NaN转化为可计算的数字或去掉,以下是几种方法: 注:判断一个值是否为NaN,只能用 isnan(),而不可用 x==NaN;用此法可以从数据中去掉不相关的数据,看看下面的命令是干什么用的:mu = mean(count);sigma = std(count);[n,p] = size(count)outliers = abs(count —mu(ones(n, 1),:)) > 3*sigma(ones(n, 1),:); nout = sum(outliers)nout =1 0 0count(any(outliers'),:) = [];点这看看答案回归与曲线拟合我们经常需要把观测到的数据表达为函数,假如有如下的对时间的观测:t = [0 .3 .8 1.1 1.6 2.3]’;y = [0.5 0.82 1.14 1.25 1.35 1.40]’;plot(t,y,’o’),grid on多项式回归由图可以看出应该可以用多项式来表达:y=a0+a1*t+a2*t^2系数a0,a1,a2可以由最小平方拟合来确定,这一步可由反除号"\"来完成解下面的三元方程组可得:X = [ones(size(t)) t t.^2]X =1.0000 0 01.0000 0.3000 0.09001.0000 0.8000 0.64001.0000 1.1000 1.21001.0000 1.60002.56001.00002.3000 5.2900a = X\ya =0.5318 0.9191 –0.2387a即为待求的系数,画图比较可得T = (0:0.1:2.5)’;Y = [ones(size(T)) T T.^2]*a;plot(T,Y,'–',t,y,'o',), grid on结果令人失望,但我们可以增加阶数来提高精确度,但更明智的选择是用别的方法.线性参数回归形如:y=a0+a1*exp(-t)+a2*t*exp(-t)计算方法同上:X = [ones(size(t)) exp(– t) t.*exp(– t)];a = X\ya =1.3974 – 0.8988 0.4097T = (0:0.1:2.5)';Y = [ones(size(T)) exp(– T) T.exp(– T)]*a;plot(T,Y,'–',t,y,'o'), grid on看起来是不是好多了!例子研究:曲线拟合下面我们以美国人口普查的数据来研究一下有关曲线拟合的问题(MatLab是别人的,教学文档是别人的,例子也是别人的,我只是一个翻译而已...)load census这样我们得到了两个变量,cdate是1790至1990年的时间列向量(10年一次),pop是相应人口数列向量.上一小节所讲的多项式拟合可以用函数polyfit()来完成,数字指明了阶数p = polyfit(cdate,pop,4)Warning: Matrix is close to singular or badly scaled.Results may be inaccurate. RCOND = 5.429790e–20p =1.0e+05 *0.0000 –0.0000 0.0000 –0.0126 6.0020产生警告的原因是计算中的cdata值太大,在计算中的Vandermonde行列式使变换产生了问题,解决的方法之一是使数据标准化.预处理:标准化数据数据的标准化是对数据进行缩放,以使以后的计算能更加精确,一种方法是使之成为0均值:sdate = (cdate – mean(cdate))./std(cdate)现在再进行曲线拟合就没事了!p = polyfit(sdate,pop,4)p =0.7047 0.9210 23.4706 73.8598 62.2285pop4 = polyval(p,sdate);plot(cdate,pop4,'–',cdate,pop,'+'), grid on在上面的数据标准化中,也可以有别的算法,如令1790年的人口数为0.余量分析p1 = polyfit(sdate,pop,1);pop1 = polyval(p1,sdate);plot(cdate,pop1,'–',cdate,pop,'+')figure, plot(cdate,res1,'+')p = polyfit(sdate,pop,2);pop2 = polyval(p,sdate);plot(cdate,pop2,'–',cdate,pop,'+')figure, plot(cdate,res2,’+’)p = polyfit(sdate,pop,4);pop4 = polyval(p,sdate);plot(cdate,pop4,'–',cdate,pop,'+')figure, plot(cdate,res4,'+')可以看出,多项式拟合即使提高了阶次也无法达到令人满意的结果指数拟合从人口增长图可以发现人数的增长基本是呈指数增加的,因此我们可以用年份的对数来进行拟合,这儿,年数是标准化后的!logp1 = polyfit(sdate,log10(pop),1);logpred1 = 10.^polyval(logp1,sdate);semilogy(cdate,logpred1,'–',cdate,pop,'+');grid onlogres2 = log10(pop) –polyval(logp2,sdate);plot(cdate,logres2,'+')上面的图不令人满意,下面,我们用二阶的对数分析:logp2 = polyfit(sdate,log10(pop),2);logpred2 = 10.^polyval(logp2,sdate);semilogy(cdate,logpred2,'–',cdate,pop,'+');grid onr = pop – 10.^(polyval(logp2,sdate));plot(cdate,r,'+')这种余量分析比多项式拟合的余量分析图案要随机的多(没有很强的规律性),可以预见,随着人数的增加,余粮所反映的不确定度也在增加,但总的说来,这种拟合方式要强好多!误差边界误差边界常用来反映你所用的拟合方式是否适用于数据,为得到误差边界,只需在polyfit()中传递第二个参数,并将其送入polyval().下面是一个二阶多项式拟合模型,年份已被标准化,下面的代码用了2σ,对应于95%的可置信度:[p2,S2] = polyfit(sdate,pop,2);[pop2,del2] = polyval(p2,sdate,S2);plot(cdate,pop,'+',cdate,pop2,'g–',cdate,pop2+2*del2,'r:',...cdate,pop2–2*del2,'r:'),grid on差分方程和滤波MatLab中的差分和滤波基本都是对向量而言的,向量则是存储取样信号或序列的.函数y = filter(b, a, x)将用a,b描述的滤波器处理向量x,然后将其存储在向量y中,filter()函数可看为是一差分方程a1y(n)=b1*x(1)+b2*x(2)+...-a2*y(2)-...如有以下差分方程:y(n)=1/4*x(n)+1/4*x(n-1)+1/4*x(n-2)+1/4*x(n-3),则a = 1;b = [1/4 1/4 1/4 1/4];我们载入数据,取其第一列,并计算有:load count.datx = count(:,1);y = filter(b,a,x);t = 1:length(x);plot(t,x,'–.',t,y,'–'),grid onlegend('Original Data','Smoothed Data',2)实现所表示的就是滤波后的数据,它代表了4小时的平均车流量MatLab的信号处理工具箱中提供了很多用来滤波的函数,可用来处理实际问题!快速傅立叶变换(FFT)傅立叶变换能把信号按正弦展开成不同的频率值,对于取样信号,用的是离散傅立叶变换.FFT是离散傅立叶变换的一种高速算法,在信号和图像处理中有极大的用处!fft离散傅立叶变换fft2二维离散傅立叶变换fftn n维离散傅立叶变换ifft离散傅立叶反变换ifft2二维离散傅立叶反变换ifftn n维离散傅立叶反变换abs幅度angle相角unwrap相位按弧度展开,大于π的变换为2π的补角fftshift把零队列移至功率谱中央cplxpair把数据排成复数对nextpow2下两个更高的功率向量x的FFT可以这样求:x = [4 3 7 –9 1 0 0 0]’y = fft(x)y =6.000011.4853 –2.7574i–2.0000 –12.0000i–5.4853 +11.2426i18.0000–5.4853 –11.2426i–2.0000 +12.0000i11.4853 +2.7574ix虽然是实数,但y是复数,其中,第一个是因为它是常数相加的结果,第五个则对应于奈奎斯特频率,后三个数是由于负频率的影响,它们是前面三个数的共轭值!下面,让我们来验证一下太阳黑子活动周期是11年!Wolfer数记录了300年太阳黑子的数量及大小:load sunspot.datyear = sunspot(:,1);wolfer = sunspot(:,2);plot(year,wolfer)title(’Sunspot Data’)现在来看看其FFT:Y = fft(wolfer);Y的幅度是功率谱,画出功率谱和频率的对应关系就得出了周期图,去掉第一点,因为他只是所有数据的和,画图有:N = length(Y);Y(1) = [];power = abs(Y(1:N/2)).^2;nyquist = 1/2;freq = (1:N/2)/(N/2)*nyquist;plot(freq,power),grid onxlabel(’cycles/year’)title(’Periodogram’)上面的图看起来不大方便,下面我们画出频谱-周期图period = 1./freq;plot(period,power),axis([0 40 0 2e7]),grid onylabel(’Power’)xlabel(’Period(Years/Cycle)’)为了得出精确一点的解,如下:[mp index] = max(power);period(index)ans =11.0769变换后的幅度和相位abs()和angle()是用来计算幅度和相位的先创建一信号,再进行分析,unwarp()把相位大于π的变换为2π的补角: t = 0:1/99:1;x = sin(2*pi*15*t) + sin(2*pi*40*t);y = fft(x);m = abs(y);p = unwrap(angle(y));f = (0:length(y)–1)'*99/length(y);subplot(2,1,1), plot(f,m),ylabel('Abs. Magnitude'), grid onsubplot(2,1,2), plot(f,p*180/pi)ylabel('Phase [Degrees]'), grid onxlabel('Frequency [Hertz]')可以发现幅度曲线关于奈奎斯特频率对称,只有0-50Hz的信息是有用的! FFT的长度与速度可以为FFT加上第二个参数,告诉MatLab这是n点FFT.如y = fft(x,n),若x长度大于n,软件自动补0,否则截取x.若:1. n为2的幂,软件将执行基2快速傅立叶算法,这时的运算速度是最快的2. n为合数,软件将n分解为素数来算,计算量与n的值有关.n为1013将比1000点的速度慢的多!3. n为素数,软件执行DFT的公式,此时最慢矩阵和线性代数MatLab中的矩阵MatLab中有好多函数可以产生不同的矩阵,下面就让我们产生两个3*3的矩阵,这一章中,我们的学习就靠她们了!!!A = pascal(3)A =1 1 11 2 31 3 6B = magic(3)B =8 1 63 5 74 9 2还有一个3*2的随机矩阵:C = fix(10*rand(3,2))C =9 42 86 7看看列矩阵,行矩阵,以及常数的表达:u = [3; 1; 4]v = [2 0 —1]s = 7产生的矩阵是:u =314v =2 0 —1 s =7加减法X = A + BX =9 2 74 7 105 12 8Y = X –AY =8 1 63 5 74 9 2若二矩阵维数不统一,则会出错!X = A + CError using ==> +Matrix dimensions must agree.向量的乘积与转置x = v*ux =2X = u*vX =6 0 —32 0 —18 0 —4X = B'X =8 3 41 5 96 7 2如x与y均是列向量,则x*y无解,但下二表达式却可以:x'*yy'*x称内积或点积.下面的语句产生单位矩阵eye(m,n)若用eye(n)则产生n*n的方阵解线性方程情况一:x = A\ux =10—125又如:X = A\BX =19 –3 —1—17 4 136 0 —6情况二;y是不同时刻t时的观测值: t = [0 .3 .8 1.1 1.6 2.3]';y = [.82 .72 .63 .60 .55 .50]';若函数形式是:y(t)=c1+c2*exp(t); 构造矩阵:E = [ones(size(t)) exp(–t)]E =1.0000 1.00001.0000 0.74081.0000 0.44931.0000 0.33291.0000 0.20191.0000 0.1003则可求得系数c1及c2c = E\yc =0.4760 0.3413表明:y(t)=0.4760+0.3413*exp(t) 画图如下:T = (0:0.1:2.5)';Y = [ones(size(T)) exp(–T)]*c; plot(T,Y,'–',t,y,'o')转置与行列式若A是方阵,且是非奇异的,则:d = det(A)X = inv(A)d =1X =3 —3 1—3 5 —21 —2 1若c不是方阵,则用pinv:X = pinv(C)X =0.1159 —0.0729 0.0171—0.0534 0.1152 0.0418那么我们可以发现,下面3个命令具有同样的功效(A是m*n的矩阵,m>n):x = A\bx = pinv(A)*bx = inv(A’*A)*A’*bLU.RQ.及Cholesky分解MatLab求解线性方程建立在以下三个分解之上:Cholesky分解Guass(高斯)分解正交分解Cholesky分解A=p*p'让我们临时把A变一变:A = pascal(6)A =1 1 1 1 1 11 2 3 4 5 61 3 6 10 15 211 4 10 20 35 561 5 15 35 70 1261 6 21 56 126 252A是二项式系数,每一项是其左方与上方系数之和,求其Cholesky分解系数有:R = chol(A)R =1 1 1 1 1 10 1 2 3 4 50 0 1 3 6 100 0 0 1 4 100 0 0 0 1 50 0 0 0 0 1R认识二项式系数.这样对于线性方程便可化简:A*x = bR'*R*x = bx = R\(R'\b)复杂度由O(n^3)变为O(n^2);LU分解A = L U其中,L时下三角阵,U是上三角阵,如: [L,U] = lu(B)L =1.0000 0 00.3750 0.5441 1.00000.5000 1.0000 0U =8.0000 1.0000 6.00000 8.5000 —1.00000 0 5.2941同样:A*x = b可以解为x = U\(L\b)QR分解正交阵有如下性质:Q'Q = I正交阵的好处在于,她保持了原阵的长度,角度,并且在计算的过程中不会扩大误差.RQ分解如下:A = Q R或 A P = Q R其中,Q是正交阵,R是上三角阵.矩阵的幂与指数若A是方阵,p是正数,则X = A^2X =3 6 106 14 2510 25 46若A是方阵,且是非奇异的,则X=A^(-P)将inv(A) P次方,如:Y = B^(–3)Y =0.0053 —0.0068 0.0018—0.0034 0.0001 0.0036—0.0016 0.0070 —0.0051分数词幂将由A的特征值决定.若是对矩阵的每个元素进行幂,用.^,如X = A.^2A =1 1 11 4 91 9 36sqrtm(A)计算A^(1/2),但要更精确,而sqrt(A)则计算A.^(1/2),是一个元素一个元素的算.dx/dt=Ax,可以表示为x(t)=exp(tA)*x(0);下面来看看如何计算:--expm(A)A =0 —6 —16 2 —16—5 20 —10x0 =111计算如下:X = [];for t = 0:.01:1X = [X expm(t*A)*x0];end作图有:plot3(X(1,:),X(2,:),X(3,:),'–o')特征值Av=λv若L是特阵值矩阵,则特征向量是V: AV=VL;如下:A =0 —6 —16 2 —16—5 20 —10lambda = eig(A)lambda =—3.0710—2.4645+17.6008i—2.4645-17.6008i由exp(λt)可以看出exp(At)(见上小节)若用二参数调用函数eig(),则返回特征向量及特征值矩阵: [V,D] = eig(A)V =—0.8326 —0.1203+ 0.2123i —0.1203– 0.2123i —0.3553 0.4691+ 0.4901i 0.4691– 0.4901i—0.4248 0.6249– 0.2997i 0.6249+ 0.2997iD =—3.0710 0 00 —2.4645+17.6008i 00 0 —2.4645—17.6008i对于下面的矩阵:A =6 12 19—9 —20 —334 9 15V =0.4741 0.4082 —0.4082—0.8127 —0.8165 0.81650.3386 0.4082 —0.4082D =—1.0000 0 00 1.0000 00 0 1.0000可以看出,有二特征值是一样的,其特征向量仅差一个符号,在Symbolic Math Toolbox中提供了Jordan标准型的函数,如下:[X,J] = jordan(A)X =—1.7500 1.5000 2.75003.0000 —3.0000 —3.0000—1.2500 1.5000 1.2500J =—1 0 00 1 10 0 1常微分方程常微分方程(Odinary Differential Equations---ODE)类别函数描述解常微分方程ode45 ode23 ode113 ode15s ode23s ode23t ode23tb常微分方程选项odeset odeset常微分方程输出选项odeplot odephas2 odephas3 odeprint如何表述问题多项式与插值多项式多项式的表达MatLab中用按降幂排列的多项式系数组成的行向量表示多项式,如: p(x)=x^3-2x-5被表示为:p = [1 0 –2 –5];多项式的根r = roots(p)r =2.0946–1.0473 + 1.1359i–1.0473 – 1.1359i根被储存为列向量.若要由方程的根构造多项式,则p2 = poly(r)p2 =1 8.8818e-16 –2 –5多项式估计可以用多项式估计出多项式在某一点的值:polyval(p,5)ans =110同样也可以估计矩阵多项式的值p(X) = X^3 – 2X – 5I,X = [2 4 5; –1 0 3; 7 1 5];Y = polyvalm(p,X)Y =377 179 439111 81 136490 253 639卷积多项式相乘是一个卷积的过程,conv()a = [1 2 3];b = [4 5 6];c = conv(a,b)c =4 13 28 27 18多项式相除是其逆过程,用deconv(): [q,r] = deconv(c,a)q =4 5 6r =0 0 0 0 0多项式曲线逼近polyfit(x,y,n)能用多项式逼近由x,y向量提供的数据,n是其阶数,如: x = [1 2 3 4 5];y = [5.5 43.1 128 290.7 498.4];p = polyfit(x,y,3)p =–0.1917 31.5821 –60.3262 35.3400将图画出x2 = 1:.1:5;y2 = polyval(p,x2);plot(x,y,’o’,x2,y2)grid on分式多项式分解residue()可将分式多项式分解如下:对于下式分解为:b = [–4 8];a = [1 6 8];[r,p,k] = residue(b,a)r =–12 8p =–4 –2k =[]重载此函数可以完成分式多项式相加:[b2,a2] = residue(r,p,k)b2 =–4 8a2 =1 6 8插值插值是在已知的数据列中,估计别点的函数值.一维插值一维插值在MatLab中有两种方法:@ 多项式插值@ 建立在FFT上的插值。