003 MATLAB基础计算

01 方程组的求解

多项式及其运算

多项式在MATLAB中以向量形式存储。
即n次多项式用一个长度为n+1的系数向量来表示,且按降幂,缺少的幂次对应的向量元素为0。 多项式的运算主要包括多项式的四则运算、求导、求值和求根运算

多项式的四则运算:

>> p1=[2 0 -6 1];
>> p2=[1 -1];

加减运算       p=polyadd(p1,p2)
                     p =      2     0    -5     0        ,适用于任意阶次间多项式相加
乘法运算       p=conv(p1,p2)
                     p =      2    -2    -6     7    -1        ,p=conv(p1,p2) 
除法运算       [p,r]=deconv(p1,p2)
                      p =      2     2    -4 r =      0     0     0    -3      
                ,[p,r]=deconv(p1,p2),其中k是商,r是余数。

多项式求导:

利用函数polyder来实现,语法格式:
 poly(p):返回多项式p的导数。  
poly(p1,p2):返回多项式p1*p2的导数。
[q,d]=poly(p1,p2):返回多项式p1/p2的导数,q是分子,d是分母。

多项式求值:

y=polyval(p,x):按数组运算规则计算多项式值。
y=polyvalm(p,X):按矩阵运算规则计算多项式值,且X只能是方阵

多项式求根:

>> p=[1 2 -5 0 4];
>> r=roots(p)

当多项式的根已知时,可以利用函数poly(r)来构建多项式的系数。
>> poly(r)
 ans =     1.0000    2.0000   -5.0000    0.0000    4.0000

02 线性方程组的求解:

可直接通过矩阵相除得到

>> A=[1 1 1;2 3 -1;-1 2 4];
>> B=[1;3;2];
>> x=A\B

03 非线性方程组的求根:

x=fzero(fun,x0)
建立函数文件方式:

%建立函数文件fun1.m。
function f=fun1(x)
f=x^2+2*x-exp(x)+5;
%以M函数文件的函数句柄输入方程

>> x=fzero(@fun1,1)                      
x =
    2.9929
以匿名函数方式输入方程方式:

%以匿名函数方式输入方程

>> x=fzero(@(x)x^2+2*x-exp(x)+5,1)        

x =     2.9929

%以字符串方式输入方程

>> x=fzero('x^2+2*x-exp(x)+5',1)            
x =     2.9929
以字符串方式输入方程:
>> x=fzero('x^2+2*x-exp(x)+5',1)            
x =     2.9929

非线性方程组求解:

x=fsolve(fun,x0)
求解时还可以在指令中加入options:
x=fsolve(fun,x0,options)
其中options通过调用optimset函数来设定最大优化代数、优化精度、中间结果的显示等等。
例如'Display'选项决定显示优化的中间结果的方式,其调用格式为:
options=optimset('Display','off'或'iter'或'final')
其中'off'表示不显示,'iter'表示每步都显示,'final'表示仅显示最终结果。

fun也可以以M函数文件的函数句柄、匿名函数或字符串方式输入

04 插值和拟合

由离散点数据来确定函数的方法

测量值是准确的,没有误差,一般用插值

测量值与真实值有误差,一般用曲线拟合

1 函数插值

作用:函数插值是根据给定的有限个样本点,产生另外的估计点以达到数据更为平滑的效果

一维插值函数的调用格式为:
yi=interp1(x,y,xi, 'method')

method是内插方法,可选择:
最近项插值'nearest'、线性插值'linear'、样条插值'spline'或立方插值'cubic',默认为线性插值。

其中的插值方式也可直接这么用:

s = spline(x,y,xq)

返回与查询点xq对应的插值向量s。s的值由x和y的三次样条插值确定。

>> x=0:10;y=sin(x)+cos(x);
>> xi=0:0.1:10;
>> y1=interp1(x,y,xi);
>> y2=interp1(x,y,xi,'nearest');
>> y3=interp1(x,y,xi,'spline');
>> y4=interp1(x,y,xi,'cubic');
plot(xi,y1,xi,y2,'-s',xi,y3,'-.',xi,y4,'-*')

  ‘nearest’为直角转折; ‘linear’是分段线性变化; 'spline'和 'cubic'形成的曲线很平滑

二维数据插值:
Z1=interp2(X,Y,Z,X1,Y1,'method')

其中X,Y是两个向量,分别描述两个参数的采样点,Z是与参数采样点对应的函数值,X1,Y1是两个向量或标量,描述欲插值的点。Z1是根据相应的插值方法得到的插值结果。 method的取值与一维插值函数相同

其中X1,Y1的取值范围不能超出X,Y的给定范围,否则,会给出“NaN”错误

>>x=0:2.5:10;
>>h=[0:30:60]';
>>T=[95,14,0,0,0;88,48,32,12,6;67,64,54,48,41];
>>xi=[0:0.5:10];
>>hi=[0:10:60]';
>>temps=interp2(x,h,T,xi,hi,'cubic');
>>mesh(xi,hi,temps)

 其中mesh是三维网格图绘制

2 曲线拟合 

作用:曲线拟合就是寻找一个函数(或曲线),使该函数(或曲线)在某种准则下与样本点数据最为接近,但并不要求拟合曲线通过全部已知的样本点

p=polyfit(x,y,n)

函数ployfit使用的准则是最小二乘准则:测得m个离散点,构造一个n(n<m)次多项式:p(x)=a1x^n+a2x^n-1+...+anx+an+1,使得在各个已知数据点处,(p(xi)-yi)^2之和达到最小。 

其中,x和y是已知样本点数据,n是拟合多项式的阶次,p为返回的拟合多项式的系数。

>> x=0:10;y=sin(x)+cos(x);
>> p1=polyfit(x,y,1),p2=polyfit(x,y,2),p3=polyfit(x,y,3),p4=polyfit(x,y,4);
>> x1=-1:0.1:11;
>> y1=polyval(p1,x1);
>> y2=polyval(p2,x1);
>> y3=polyval(p3,x1);
>> y4=polyval(p4,x1);
>>plot(x1,y1,'-*',x1,y2,'--',x1,y3,'-.',x1,y4)

05 常用于数据统计与分析的函数

1. 求矩阵最大元素和最小元素

(1)求最大值和最小值

y=max(X)
y=min(X)
  • 当X为向量时:

返回向量X的最大(小)值存入y,如果X中包含复数元素,则按模取最大(小)值

  • 当X为矩阵时:

返回一个行向量,返回每列的最大元素

[y,I]=max(X)
[y,I]=min(X)
  • 当X为向量时:

返回向量X的最大值(小)存入y,最大(小)值的序号存入I,如果X中包含复数元素,则按模取最大(小)值

  • 当X为矩阵时:

返回每列的最大元素和对应行号

max(A,[],dim)

dim取1时,该函数和max(A)完全相同;dim取2时,该函数返回一个列向量

 2. 求矩阵的平均值和中值

(1)求平均值和中值

mean(X)
  • 当X为向量时:

返回向量X的算术平均值。

  • 当X为矩阵时:

返回一个行向量,各列的平均值

mean(A,dim):当dim为1时,该函数等同于mean(A)。当dim为2时,各行的平均值
median(X)
  • 当X为向量时:

返回向量X的中值。(数据序列为偶数个,则取中间两项的平均值)

  • 当X为矩阵时:

返回一个行向量,各列的中值

median(A,dim):当dim为1时,该函数等同于median(A);当dim为2时,各行的中值

3. 矩阵元素求和与求积

 sum(X)
  • 当X为向量时:

返回向量X各元素的和

  • 当X为矩阵时:

返回一个行向量,各列之和

sum(A,dim):当dim为1时,该函数等同于sum(A);当dim为2时,返回一个列向量,各行之和
 prod(X)
  •  当X为向量时:

返回向量X各元素的乘积

  • 当X为矩阵时:

返回一个行向量,各列之积

prod(A,dim):当dim为1时,该函数等同于prod(A);当dim为2时,返回一个列向量,各行之积

 4.求标准方差

对于向量X:
std(X)
对于矩阵A: 
   Y=std(A,flag,dim)

其中当dim=1时,求各列元素的标准方差(返回行向量);
       当dim=2时,则求各行元素的标准方差(返回列向量)。

当flag=0时,按σ1所列公式计算标准差,
当flag=1时,按σ2所列公式计算标准差。
                省略时flag=0,dim=1

5.相关系数

 X,Y是向量:
 corrcoef(X,Y)
X是矩阵:
corrcoef(X)

返回从矩阵X形成的一个相关系数矩阵。它把矩阵X的每列作为一个变量,然后求它们的相关系数(各列两两之间,依次求相关系数)。

6.  排序 

对向量X:
sort(X)

函数返回一个对X中的元素按升序排列的新向量

 [Y,I]=sort(A,dim,mode)

其中若dim=1,则按列排;
       若dim=2,则按行排。

mode默认‘ascend’,若取‘descend’,则按降序。
Y是排序后的矩阵,而I记录Y中的元素在A中原来的位置。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/926979.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

金蝶云苍穹:个人上传授权文件

金蝶云苍穹开发者门户--下载文件地址。

解决windows下php8.x及以上版本,在Apache2.4中无法加载CURL扩展的问题

本文已首发于:秋码记录 若你也想搭建一个个人博客,可参考:国内 gitee.com Pages 下线了,致使众多站长纷纷改用 github、gitlab Pages 托管平台 在日新月异的信息化下,软件也在跟随着互联网的脚步,逐步推进…

数据库管理-第267期 23ai:Oracle Data Redaction演示(20241128)

数据库管理267期 2024-11-286 数据库管理-第267期 23ai:Oracle Data Redaction演示(20241128)1 示例表及数据2 创建编校策略2.1 名字全编校2.2 电话部分编校 3 DML演示3.1 场景13.2 场景2 总结 数据库管理-第267期 23ai:Oracle Da…

根据电池容量及功耗估算充电及放电时间

根据电池容量和功耗估算充电和放电时间的方法可以通过以下简单的公式进行: 1. 估算放电时间 放电时间是指电池在一定功耗下,能够持续供应电力的时间。可以使用以下公式: 解释: 电池容量:电池的容量一般以毫安时&…

【Maven】继承和聚合

5. Maven的继承和聚合 5.1 什么是继承 Maven 的依赖传递机制可以一定程度上简化 POM 的配置,但这仅限于存在依赖关系的项目或模块中。当一个项目的多个模块都依赖于相同 jar 包的相同版本,且这些模块之间不存在依赖关系,这就导致同一个依赖…

对抗攻击算法:FGSM和PGD

FGSM 传送门 FGSM 利用了梯度上升的思想,通过损失函数相对于输入图像的梯度来找到 最容易 迷惑网络的方向,并沿着这个方向对图像进行微小的扰动。 FGSM 的基本想法是,沿着这个梯度的符号方向对图像进行微调,以最大化损失函数。具…

Matlab mex- setup报错—错误使用 mex,未检测到支持的编译器...

错误日志: 在使用mex编译时报错提示:错误使用 mex,未检测到支持的编译器。您可以安装免费提供的 MinGW-w64 C/C 编译器;请参阅安装 MinGW-w64 编译器。有关更多选项,请访问https://www.mathworks.com/support/compile…

内网穿透步骤

步骤 第一次需要验证token window和linux的方法不同。 然后 启动 cpolar 服务: 在命令窗口中输入 cpolar.exe htttp 8080,启动内网穿透服务。确保命令窗口保持开启状态,以维持穿透效果。 cpolar.exe hhttp 8080 成功后 注意事项 命令窗口…

系统架构:MVVM

引言 MVVM 全称 Model-View-ViewModel,是在 MVP(Model-View-Presenter)架构模式基础上的进一步演进与优化。MVVM 与 MVP 的基本架构相似,但 MVVM 独特地引入了数据双向绑定机制。这一创新机制有效解决了 MVP 模式中 Model 与 Vie…

网络协议(TCP/IP模型)

目录 网络初识 网络协议 协议分层 协议拆分 分层 协议分层的优势 1.封装效果 2.解耦合 TCP/IP五层模型 协议之间配合工作(详解) 网络初识 网络核心概念: 局域网:若干电脑连接在一起,通过路由器进行组网。 …

网络安全之IP伪造

眼下非常多站点的涉及存在一些安全漏洞,黑客easy使用ip伪造、session劫持、xss攻击、session注入等手段危害站点安全。在纪录片《互联网之子》(建议搞IT的都要看下)中。亚伦斯沃茨(真实人物,神一般的存在)涉…

软件工程之静态建模

静态模型:有助于设计包、类名、属性和方法特征标记(但不是方法体)的定义,例如UML类图。 用例的关系: 扩展关系: 扩展关系允许一个用例(可选)扩展另一个用例(基用例&…

JS听到了爆燃的回响

Window对象 BOM(浏览器对象模型) BOM是浏览器对象模型 Window对象是一个全局对象,也可以说是JS中的顶级对象 像是document、alert()、console.log()都是window的属性 所有通过var定义在全局作用域的变量、函数都会变成window对象的属性和…

【Linux】死锁、读写锁、自旋锁

文章目录 1. 死锁1.1 概念1.2 死锁形成的四个必要条件1.3 避免死锁 2. 读者写者问题与读写锁2.1 读者写者问题2.2 读写锁的使用2.3 读写策略 3. 自旋锁3.1 概念3.2 原理3.3 自旋锁的使用3.4 优点与缺点 1. 死锁 1.1 概念 死锁是指在⼀组进程中的各个进程均占有不会释放的资源…

单片机学习笔记 15. 串口通信(理论)

更多单片机学习笔记:单片机学习笔记 1. 点亮一个LED灯单片机学习笔记 2. LED灯闪烁单片机学习笔记 3. LED灯流水灯单片机学习笔记 4. 蜂鸣器滴~滴~滴~单片机学习笔记 5. 数码管静态显示单片机学习笔记 6. 数码管动态显示单片机学习笔记 7. 独立键盘单片机学习笔记 8…

MyBatis异常体系中ErrorContext和ExceptionFactory原理分析

🎮 作者主页:点击 🎁 完整专栏和代码:点击 🏡 博客主页:点击 文章目录 exceptions包分包设计ExceptionFactory类介绍为什么使用工厂不是直接new呢?【统一的异常处理机制】【异常的封装与转化】【…

【Canvas与雷达】点鼠标可暂停金边蓝屏雷达显示屏

【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>点鼠标可暂停金边蓝屏雷达显示屏 Draft1</title><style typ…

Spark Optimization —— Reducing Shuffle

Spark Optimization : Reducing Shuffle “Shuffling is the only thing which Nature cannot undo.” — Arthur Eddington Shuffle Shuffle Shuffle I used to see people playing cards and using the word “Shuffle” even before I knew how to play it. Shuffling in c…

数据结构 (22)哈夫曼树及其应用

前言 哈夫曼树&#xff08;Huffman Tree&#xff09;&#xff0c;又称最优二叉树或最优树&#xff0c;是一种特殊的二叉树结构&#xff0c;其带权路径长度&#xff08;WPL&#xff09;最短。 一、哈夫曼树的基本概念 定义&#xff1a;给定N个权值作为N个叶子结点&#xff0c;构…

Android Studio安装TalkX AI编程助手

文章目录 TalkX简介编程场景 TalkX安装TalkX编程使用ai编程助手相关文章 TalkX简介 TalkX是一款将OpenAI的GPT 3.5/4模型集成到IDE的AI编程插件。它免费提供特定场景的AI编程指导&#xff0c;帮助开发人员提高工作效率约38%&#xff0c;甚至在解决编程问题的效率上提升超过2倍…