MATLAB常用语句总结7

MATLAB总结7:常见错误归纳

本篇专门用于记录一些应试技巧


文章目录

  • MATLAB总结7:常见错误归纳
  • 前言
  • 一、一些小定义和小技巧
  • 二、蒙塔卡罗求解方法
    • 1.函数的定义
    • 2.函数引用
    • 3.代码量较少的蒙塔卡罗
  • 三、函数引用与多变量
  • 四、矩阵引用
  • 五、非线性函数:fmincon的使用
  • 六、线性规划函数
    • 1.linprog
    • 2.fminbnd、fminsearch
  • 七、积分和微分
    • 1.quad积分
    • 2.积分int 微分diff
  • 八、lsqcurvefit
  • 九、矩阵求解
  • 十、polyfit 函数进行多项式拟合
  • 十一、ode23和ode45
  • 十二、fzero
  • 十三、meshgrid和surf
  • 十四、fsolve


前言

记忆力比较差,把学习过程中常用的语法记录于此,方便回忆时索引


一、一些小定义和小技巧

  1. rand的使用

rand 是用于生成在(0,1)上随机数的函数,而后面加入 rand(1,2),则意为一个一行两列的(0,1)矩阵,不可乱加。需要使用不同范围的随机数则使用 A*rand() 即可

    x=5*rand();y=5*rand();
  1. 符号
取余:mod(A,b)%A是要进行取余的数字,b是除数
不等于:~=
  1. find()的使用
    用r=find(A<=0.6),直接找到A中小于0.6的下标

  2. 分段函数的使用

y=(x<=8).* (2*x)+(x>8&&x<12).*(3*x)+(x>12).* (4*x);
  1. upper, lower的大小写转换
for i=1:length(v)if v(i)=='a'r(i)=upper(r(i));elseif v(i)=='h'r(i)='2';elseif v(i)=='v'r(i)='3';end
end

二、蒙塔卡罗求解方法

在这里插入图片描述

1.函数的定义

代码如下(示例):

function c=myobj(x)
c=10*x(1)^3+x(3)*(x(1)^2+x(2)^2);
function r=mycon(x)
r=[x(1)^2+x(2)^2-x(3)-10 ; x(1)^2+x(2)^2+x(3)-3];
function m=myrand
while 1m=[10*rand-5 ;10*rand-5 ;10*rand-5 ];if mycon(m)<=0return end
end

2.函数引用

代码如下(示例):

function [val,x]=myfun2
rand('seed',11);betterx=myrand;
betterval=myobj(betterx);for i=1:10000betterx=myrand;if myobj(betterx)>betterval;betterval=myobj(betterx);end
end
x=double(betterx);
val=double(betterval);

3.代码量较少的蒙塔卡罗

function [val,x]=myfun2
rand('seed',11);
val=0;
for i=1:100000s=-10*rand(1,3)+5;if s(1)^2+s(2)^2-s(3)-10<=0 && s(1)^2+s(2)^2+s(3)-3<=0if 10*s(1)^3+s(3)*(s(1)^2+s(2)^2)>valval=10*s(1)^3+s(3)*(s(1)^2+s(2)^2);x=s;endend
end

三、函数引用与多变量

要分清多元函数的变量要用循环引用

代码如下(示例):

function v=testmain
x=-2:0.1:2;
v=fun(x);function r=fun(x)
for i=1:length(x)if x(i)<-1r(i)=x(i)^2+2*x(i)+1;elseif x(i)>-1 && x(i)<=2r(i)=3*x(i);elser(i)=2*sqrt(x(i));end
end

四、矩阵引用

引用矩阵可以用行列索引,也可以单行单列(注意单行单列是逗号),而且引用矩阵必须是括号

代码如下(示例):

A(1,:)%引用第一行
A(:,2)%引用第二列
A(1,:)=A(1,:).^2;%给矩阵赋值要明白给谁赋值

五、非线性函数:fmincon的使用

  1. 使用时要注意哪里是只输入系数,哪里是方程
  2. 求最小值的是方程,其他的都只输出系数
  3. 同种变量用逗号隔开,不同种用分号
  4. 注意noncon的位置是使用@,引用里面有()
  5. lb ub里面是逗号
  6. 函数系数的对应关系

在这里插入图片描述

代码如下(示例):

function [min,val]=fun3
Fun=@(x) 2*(x(1)-1)^2+3*(x(2)-1)^2+0.2*x(1)*x(2)+(2*x(3)-2)^2
A=[3 2 6;4 5 2;2 9 7];
b=[50;40;100];
Lb=[0,0,0];
ub=[15,9,25];
[min,val]=fmincon(Fun,[0,0,0],A,b,[],[],Lb,ub,@noncon);
function [c,ceq]=noncon(x)
c=[-2*x(1)^-x(2)^2-x(3)^2+5,x(1)^2+x(2)^2+2*x(3)^2-200];
ceq=[0];

六、线性规划函数

1.linprog

求解常规线性规划
注意!!!f 函数调用是系数

代码如下(示例):
在这里插入图片描述

function [x,fval]=myfun19
f=[3,-4,2];
A=[1 -1 1;3 2 4;3 2 0];
b=[10;22;10];
Aeq=[];
beq=[];
lb=[0,0,0];
ub=[inf,inf,inf];
[x,fval] = linprog(f,A,b,Aeq,beq,lb,ub);

2.fminbnd、fminsearch

用于找到极小值,fminbnd找到区间内,fminsearch找到从某一点开始的极小值
fminbnd

[x,val] = fminbnd(fun, x1, x2)

% 定义要最小化的函数
fun = @(x) x^2 + 2*x + 1;% 在区间[-2, 2]内寻找最小值
[x,val] = fminbnd(fun, -2, 2);

fminsearch

% 定义要最小化的函数
fun = @(x) x(1)^2 + x(2)^2;% 指定初始点
x0 = [1, 1];% 在多维空间中寻找最小值
x = fminsearch(fun, x0);

七、积分和微分

1.quad积分

y=@(x) (3.*x+2)./(x.^3+2.*x+5);
r=quad(y,0,3);

2.积分int 微分diff

在这里插入图片描述
在这里插入图片描述

F=@(x,y) exp(2*x.^2+3*y.^2);
I=integral2(F,0.5,1,0,1);%取值范围

八、lsqcurvefit

  1. xdata,ydata储存数据,x(i)存放未知变量
  2. 调用时要把 fun(x,xdata) 全部带上
  3. 注意调用时,x和x1的意义是已经计算的系数和要代入计算的函数值,他们的位置和使用fun时的位置相对应!!!

代码如下(示例):

xdata=[10.03,20.04,30.23,40.37,50.16,60.4,70.3,80.66,90.69,100.16,110.94,121.18,130.66,141.23,150.88,160.24];
ydata=[50.44,82.95,133.07,202.76,286.39,381.34,467.36,540.54,591.7,624.28,647.62,660.77,668.06,672.83,675.36,676.82];
fun = @(x,xdata) x(1)./(1+((x(1)/x(2))-1).*exp(-x(3)*xdata));
x0 = [1,1,1];
x = lsqcurvefit(fun,x0,xdata,ydata);
x1=[150:0.5:190];
y=fun(x,x1);

九、矩阵求解

  1. 可以使用linsolve
  2. 也可以求逆
  3. 或者是符号“\”
    在这里插入图片描述

代码如下(示例):

a=[1 1 -1 2;-1 -2 1 -3;1 1 1 -3;2 1 -3 1];
e=[-3;1;-7;4];
x=inv(a)*e;
a=[1 1 -1 2;-1 -2 1 -3;1 1 1 -3;2 1 -3 1];
e=[-3;1;-7;4];
x=linsolve(a,e);
a=[1 1 -1 2;-1 -2 1 -3;1 1 1 -3;2 1 -3 1];
e=[-3;1;-7;4];
x=a\e;

十、polyfit 函数进行多项式拟合

  1. p = polyfit(x, y, n);
  2. x 是数据点的 x 值(自变量)向量,y 是数据点的 y 值(因变量)向量,n 是要拟合的多项式的次数。
  3. polyval(p,50); 用于计算特定位置的值

代码如下(示例):

% 示例数据点
t=[1,6,11,16,21,26,31,36];
x=[5.35,10.51,15.664,20.76,25.94,30.08,35.22,40.36];
p=polyfit(t,x,1);
val=polyval(p,50);
r=[p,val];

十一、ode23和ode45

  1. 使用myode时,注意输入要把x,y都带上,先是自变量,后是因变量
  2. y(1)可表示y,y(2)可表示一阶导数
  3. 输出 [t,y] 分别是对应时间点和对应时间的输出值

在这里插入图片描述

y1 = 0:0.01:1;%取值范围
y0 = 1;初值
[t,y] = ode23(@myode, y1, y0);function dydx=myode(x,y)dydx=(2/3)*x/y^2;
function r = myfunx1 = 0:0.1:100;%定义范围x0 = [2; 0]; %定义初始条件[t, x] = ode23(@myode, x1, x0);%这里的x是一个向量
endfunction dxdt = myode(t, x)dxdt = [20*(1-x(1)^2)*x(2) + 0.5*x(1); 0];%x(1)代表x,x(2)代表dx/dt
end

十二、fzero

x0 是初始猜测的根的值。

代码如下(示例):

x = fzero(fun, x0)
x = fzero(fun, x0, options)

十三、meshgrid和surf

  1. 注意z的输出
  2. [x,y]=meshgrid(x取值,y取值)
  3. surf绘制表面图

代码如下(示例):

function z=myfun24
[x,y]=meshgrid(-3:0.1:3,-3:0.1:3);
z=x.*y.*exp(sin(x.^2+y.^2));
surf(x,y,z);

十四、fsolve

  1. 记住两个公式:root2和fsolve的使用
  2. folsve(@root2,x0)
  3. f=root2(x) f(1)= f(2)=

代码如下(示例):

% 示例数据点
function r=myfun29
x0=[0,0];
r=fsolve(@root2,x0);function f=root2(x)
f(1)=x(1)^2-x(2)-1;
f(2)=(x(1)-2)^2+(x(2)-0.5)^2-1;

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二叉树的链式存储

目录 链式存储&#xff1a; 简介&#xff1a; 二叉树链式存储的模拟实现&#xff1a; 节点的定义&#xff1a; ​编辑 链式二叉树的创建&#xff1a; 前序构建&#xff1a; 中序构建&#xff1a; 后续构建&#xff1a; 链式二叉树的销毁&#xff1a; 链式二叉树求节点…

algorithm算法库学习之——不修改序列的操作

algorithm此头文件是算法库的一部分。本篇介绍不修改序列的操作函数。 不修改序列的操作 all_ofany_ofnone_of (C11)(C11)(C11) 检查谓词是否对范围中所有、任一或无元素为 true (函数模板) for_each 应用函数到范围中的元素 (函数模板) for_each_n (C17) 应用一个函数对象到序…

Raw Socket(一)实现TCP三次握手

实验环境&#xff1a; Windows物理机&#xff1a;192.168.1.4 WSL Ubuntu 20.04.6 LTS&#xff1a;172.19.32.196 Windows下的一个http服务器&#xff1a;HFS&#xff0c;大概长这个样子&#xff1a; 客户端就是Ubuntu&#xff0c;服务端就是这个…

【Spring AOP 源码解析前篇】什么是 AOP | 通知类型 | 切点表达式| AOP 如何使用

前言&#xff08;关于源码航行&#xff09; 在准备面试和学习的过程中&#xff0c;我阅读了还算多的源码&#xff0c;比如 JUC、Spring、MyBatis&#xff0c;收获了很多代码的设计思想&#xff0c;也对平时调用的 API 有了更深入的理解&#xff1b;但过多散乱的笔记给我的整理…

PCIe驱动开发(2)— 第一个简单驱动编写和测试

PCIe驱动开发&#xff08;2&#xff09;— 第一个简单驱动编写和测试 一、前言 教程参考&#xff1a;02_实战部分_PCIE设备测试 教程参考&#xff1a;03_PCIe设备驱动源码解析 二、驱动编写 新建hello_pcie.c文件 touch hello_pcie.c然后编写内容如下所示&#xff1a; #i…

数学系C++(六七)

目录 * &指针与地址 void指针 指针可以等于&#xff1a; const 指向常量的指针 const int *px 常指针 int * const px 指向常量的常指针const 类型标识符 * const 指针名 指针加减&#xff1a; 指针恒等式 函数指针【待续】 指针型函数&#xff1a; 指向函数的…

MuLan:模仿人类画家的多对象图像生成

在图像生成领域&#xff0c;处理包含多个对象及其空间关系、相对大小、重叠和属性绑定的复杂提示时&#xff0c;现有的文本到图像模型仍面临挑战&#xff1a;当文本提示中包含多个对象&#xff0c;并且这些对象之间存在特定的空间关系时&#xff0c;现有模型往往难以准确地捕捉…

土豆炒肉做法

菜单&#xff1a;土豆、葱、铁辣子、纯瘦肉、淀粉、生抽、酱油、刀、案板、十三香、盐巴、擦板 流程&#xff1a; 洗土豆&#xff0c;削皮&#xff0c;擦成条&#xff0c;用凉水过滤两遍淀粉&#xff0c;顺便放个燥里洗肉&#xff0c;切成条&#xff0c;按照生抽、酱油、淀粉、…

Maven依赖管理项目构建工具

目录 文章目录 目录一、Maven简介1、为什么学习Maven1.1、Maven是一个依赖管理工具1.2、Maven是一个构建工具1.3、结论2. Maven介绍3. Maven软件工作原理模型图(了解)二、Maven安装和配置1. Maven安装2. Maven环境配置3. Maven功能配置4. IDEA配置本地Maven软件三、基于IDEA创…

银行信用卡风险大数据分析与挖掘2024

银行信用卡风险大数据分析与挖掘 使用excel数据挖掘功能完成 一、信用卡客户信用等级影响因素分析与挖掘 基于客户信用记录表 1. 数据预处理 浏览数据 客户等级占比&#xff0c;其中优质客户占比较少&#xff0c;风险客户很多&#xff0c;分析影响客户信用等级的原因 年…

spring boot读取yml配置注意点记录

问题1&#xff1a;yml中配置的值加载到代码后值变了。 现场yml配置如下&#xff1a; type-maps:infos:data_register: 0ns_xzdy: 010000ns_zldy: 020000ns_yl: 030000ns_jzjz: 040000ns_ggglyggfwjz: 050000ns_syffyjz: 060000ns_gyjz: 070000ns_ccywljz: 080000ns_qtjz: 090…

ASRock Creator系列GPU:为AI推理及多GPU系统打造,采用16针电源接口的Radeon RX 7900系列显卡

ASRock 正在筹备推出专为人工智能推理和多GPU系统设计的AMD GPU——Creator系列显卡。这一系列显卡采用双槽位、吹风式设计&#xff0c;并配备16针电源连接器&#xff0c;首发产品包括基于Navi 31架构的AMD Radeon RX 7900XTX和RX 7900 XT型号。这些原属于WS系列的显卡最初在20…

C++初学者指南-5.标准库(第一部分)--迭代器

C初学者指南-5.标准库(第一部分)–迭代器 Iterators 文章目录 C初学者指南-5.标准库(第一部分)--迭代器 Iterators1.默认正向迭代器2.反向迭代器3.基于迭代器的循环4.示例&#xff1a;交换相邻的一对元素5.迭代器范围6.迭代器范围中的元素数量7. 总结&#xff1a;迭代器 指向某…

Sequelize 操作 MySQL 数据库

安装 npm install --save sequelize安装驱动程序&#xff1a; npm install --save mysql2连接到数据库 要连接到数据库,必须创建一个 Sequelize 实例. 这可以通过将连接参数分别传递到 Sequelize 构造函数或通过传递一个连接 URI 来完成&#xff1a; const {Sequelize} re…

【C++知识点总结全系列 (06)】:STL六大组件详细总结与分析- 配置器、容器、迭代器、适配器、算法和仿函数

STL六大组件目录 前言1、配置器(1)What(2)Why(3)HowA.调用new和delete实现内存分配与销毁B.STL Allocator (4)allocator类A.WhatB.HowC.allocator的算法 2、容器(1)What(2)Which&#xff08;有哪些容器&#xff09;(3)序列容器&#xff08;顺序容器&#xff09;A.WhichB.array&…

Vue+Xterm.js+WebSocket+JSch实现Web Shell终端

一、需求 在系统中使用Web Shell连接集群的登录节点 二、实现 前端使用Vue&#xff0c;WebSocket实现前后端通信&#xff0c;后端使用JSch ssh通讯包。 1. 前端核心代码 <template><div class"shell-container"><div id"shell"/>&l…

web缓存代理服务器

一、web缓存代理 web代理的工作机制 代理服务器是一个位于客户端和原始&#xff08;资源&#xff09;服务器之间的服务器&#xff0c;为了从原始服务器取得内容&#xff0c;客户端向代理服务器发送一个请求&#xff0c;并指定目标原始服务器&#xff0c;然后代理服务器向原始…

【NTN 卫星通信】Starlink基于终端用户的测量以及测试概述

1 概述 收集了一些starlink的资料&#xff0c;是基于终端侧部署在野外的一些测试以及测量结果。 2 低地球轨道卫星网络概述 低地球轨道卫星网络(lsn)被认为是即将到来的6G中真正实现全球覆盖的关键基础设施。本文介绍了我们对Starlink端到端网络特征的初步测量结果和观测结果&…

win11自动删除文件的问题,安全中心提示

win11自动删除文件的问题&#xff0c;解决方法&#xff1a; 1.点击任务栏上的开始图标&#xff0c;在显示的应用中&#xff0c;点击打开设置。 或者点击电脑右下角的开始也可以 2.点击设置。也可以按Wini打开设置窗口。 3.左侧点击隐私和安全性&#xff0c;右侧点击Windows安全…

尚品汇-(十四)

&#xff08;1&#xff09;提交git 商品后台管理到此已经完成&#xff0c;我们可以把项目提交到公共的环境&#xff0c;原来使用svn&#xff0c;现在使用git 首先在本地创建ssh key&#xff1b; 命令&#xff1a;ssh-keygen -t rsa -C "your_emailyouremail.com" I…