matlab vdp函数,MATLAB第29讲

2024-03-21 21:20
文章标签 matlab 函数 29 vdp

本文主要是介绍matlab vdp函数,MATLAB第29讲,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

利用泛函命令进行数值分析

在MATLAB中,所有以函数为输入变量的命令,都称为泛函命令。

常见语法:

[输出变量列表]=函数名(h_fun,输入变量列表)

[输出变量列表]=函数名('funname',输入变量列表)

说明:h_fun是要被执行的M函数文件的句柄,或者是内联函数和字符串;'funname'是M函数文件名。

1.fminbnd函数

fminbnd函数用来计算单变量非线性函数的极小值。

[x,y]=fminbnd(h_fun,x1,x2,options)

[x,y]=fminbnd('funname',x1,x2,options)

说明:h_fun是函数句柄,'funname'是函数名,必须是单值非线性函数;options是用来控制算法的参数向量,默认值为0,可省略;x是fun函数在区间x1

【例5.22】  用fminbnd求解humps函数的极小值。

>>[x,y]=fminbnd(@humps,0.5,0.8)

%求在0.5~0.8之间的极小值

程序分析:humps函数是MATLAB提供的M文件,保存为humps.m文件;@humps表示humps函数的句柄,humps的函数最小值曲线如图所示,最小值为图中的圆点(0.6370,11.2528),误差小于10-4。

4fde10c25913ea169eaae09e2b3d095a.png

2.fminsearch函数

fminsearch函数用于求多变量无束缚非线性最小值,采用Nelder-Mead单纯形算法求解多变量函数的最小值。

x=fminsearch(h_fun,x0)

x=fminsearch('funname',x0)

说明:x0是最小值点的初始猜测值。

【例5.23】  求著名的Banana测试函数f(x,y)=100(y-x2)2+(1-x)2的最小值,它的理论最小值是x=1,y=1。该测试函数有一片浅谷,很多算法都难以逾越。

>>fn=inline('100*(x(2) -x(1)^2)^2+(1-x(1))^2','x')

%用inline产生内联函数,x和y用二元数组表示

Inline function:

fn(x)=100*(x(2) -x(1)^2)^2+(1-x(1))^2

>>y=fminsearch(fn,[0.5, -1])

%从(0.5,-1)为初始值开始搜索求最小值

1.0000  1.0000

fzero函数可以寻找一维函数的零点,即求f(x)=0的根。

x=fzero(h_fun,x0,tol,trace)

x=fzero('funname',x0,tol,trace)

说明:h_fun是待求零点的函数句柄;x0有2个作用:预定待搜索零点的大致位置和搜索起始点;tol用来控制结果的相对精度,默认值为eps;trace指定迭代信息是否在运算中显示,默认为0,表示不显示迭代信息。tol和trace都可以省略。

【例5.24】求解humps函数的过零点,humps函数的过零点用圆点表示,如图所示。

>>xzero=fzero(@humps,1)

%求在1附近的零点

>>xzero=fzero(@humps,[0.5,1.5])

%求在0.5~1.5范围内的零点

>>xzero=fzero(@humps,[0.5,1])

%求在0.5~1范围内的零点

???Errorusing==>fzero

The

function valuesat the

interval end points must differinsign.

633e5bdaa2150bc27283a54e7f281ec4.png

函数quad和quad8基于数学上的正方形概念计算函数的面积。这2个函数在所需的区间计算被积函数都应用递归调用的方法,quad8比quad更精确,速度更快。与trapz梯形比较这2个函数能够进行更高阶的近似。

s=quad(h_fun,x1,x2,tol,trace,p1,p2,…)

s=quad('funname',x1,x2,tol,trace,p1,p2,…)

s=quad8(h_fun,x1,x2,tol,trace,p1,p2,…)

s=quad8('funname',x1,x2,tol,trace,p1,p2,…)

【例5.25】  计算y=humps(x)曲线下面的面积。

>>x=0:0.01:1;

>>y=humps(x);

>>area=trapz(x,y)  %用梯形计算积分

>>area1=quad(@humps,0,1)  %用quad计算积分

>>area2=quad8(@humps,0,1)  %用quad8计算积分

MATLAB提供了ode23、ode45和ode113等多个函数求解微分方程的数值解。以下介绍低维方法、高维方法和变维方法解一阶常微方程组。

[t,y]=ode45(h_fun,tspan,y0,options,p1,p2…)

[t,y]=ode45('funname',tspan,y0,options,p1,p2…)

说明:h_fun是函数句柄,函数以dx为输出,以t,y为输入量;tspan=[起始值 终止值],表示积分的起始值和终止值;y0是初始状态列向量;options可以定义函数运行时的参数,可省略;p1,p2…是函数的输入参数,可省略。

一般来说,ode45求解算法最常用。ode23和ode45都运用了基本的龙格-库塔(Runge-Kutta)数值积分法的变形,ode23运用组合2/3阶龙格-库塔法,而ode45运用组合的4/5阶龙格-库塔法,ode45可取较多的时间步。

函数M文件vdpol.m:

%范德波尔方程

Function

y prime=vdpol(t,y)

yprime=[y(2);2*(1-y(1)^2)*y(2)-y(1)]

(3)给定当前时间及y1和y2的初始值,解微分方程。

>>tspan=[0,30];  %起始值0和终止值30

>>y0=[1;0];  %初始值

>>[t,y]=ode45(@vdpol,tspan,y0);

%解微分方程

>>y1=y(:,1);

>>y2=y(:,2);

>>figure(1)

>>plot(t,y1,':b',t,y2,'-r')

%画微分方程解

>>figure(2)

>>plot(y1,y2)  %画相平面图

这篇关于matlab vdp函数,MATLAB第29讲的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/833899

相关文章

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

kotlin的函数forEach示例详解

《kotlin的函数forEach示例详解》在Kotlin中,forEach是一个高阶函数,用于遍历集合中的每个元素并对其执行指定的操作,它的核心特点是简洁、函数式,适用于需要遍历集合且无需返回值的场... 目录一、基本用法1️⃣ 遍历集合2️⃣ 遍历数组3️⃣ 遍历 Map二、与 for 循环的区别三、高

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

MySQL中COALESCE函数示例详解

《MySQL中COALESCE函数示例详解》COALESCE是一个功能强大且常用的SQL函数,主要用来处理NULL值和实现灵活的值选择策略,能够使查询逻辑更清晰、简洁,:本文主要介绍MySQL中C... 目录语法示例1. 替换 NULL 值2. 用于字段默认值3. 多列优先级4. 结合聚合函数注意事项总结C

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

golang panic 函数用法示例详解

《golangpanic函数用法示例详解》在Go语言中,panic用于触发不可恢复的错误,终止函数执行并逐层向上触发defer,最终若未被recover捕获,程序会崩溃,recover用于在def... 目录1. panic 的作用2. 基本用法3. recover 的使用规则4. 错误处理建议5. 常见错