16、matlab求导、求偏导、求定积分、不定积分、数值积分和数值二重积分

server/2024/9/24 23:22:37/

1、matlab求导,diff()函数

1)一阶导数

语法:diff(f(x)):求一阶导数 //diff(f(x),n):求n阶导数(n为具体正整数)

以函数(cos(x)+sin(x)-x^2)的一阶导数为例

一阶导数代码:

yms x;%声明符号变量x
f(x)=cos(x)+sin(x)-x^2;%定义原式子
dy=diff(f(x))%求一阶导数dy =cos(x) - 2*x - sin(x)

2)n阶倒数

以函数(cos(x)+sin(x)-x^2)二三阶倒数为例

二三阶导数代码:

syms x;%声明符号变量x
f(x)=cos(x)+sin(x)-x^2;%定义原式子
dy1=diff(f(x),2)
% pretty(dy1)
dy2=diff(f(x),3)dy1 =- cos(x) - sin(x) - 2dy2 =sin(x) - cos(x)

2、matlab求偏导,diff()函数

语法:diff(f(x)):求一阶导数 //diff(f(x),n):求n阶导数(n为具体正整数)

以函数(f(x1,x2)=sin(x1)+exp(x2))求解x1和x2偏倒为例

1)一阶偏导

x1求偏导代码:

syms x1 x2;%声明符号变量x1\x2
f(x1,x2)=sin(x1)+exp(x2);%定义原函数
%求一阶偏导
dy1=diff(f(x1,x2),x1)dy1 =cos(x1)

x2求偏导代码:

syms x1 x2;%声明符号变量x1\x2
f(x1,x2)=sin(x1)+exp(x2);%定义原函数
dy2=diff(f(x1,x2),x2)dy2 =exp(x2)

2)n阶偏导

x1二阶偏导代码:

syms x1 x2;%声明符号变量x1\x2
f(x1,x2)=sin(x1)+exp(x2);%定义原函数
dy3=diff(f(x1,x2),x1,2)dy3 =-sin(x1)

 x2三阶偏导代码:

syms x1 x2;%声明符号变量x1\x2
f(x1,x2)=sin(x1)+exp(x2);%定义原函数
dy4=diff(f(x1,x2),x2,3)dy4 =exp(x2)

3、matlab求积分,int()函数

1)不定积分求解

语法:牛顿——莱布尼兹公式求解积分

代码:

syms x;%声明变量x
y1=x^2;%定义原式
fy1=int(y1,x)%不定积分fy1 =x^3/3

2)定积分求解 

代码:

syms x;%声明变量x
y1=x^2;%定义原式
% fy1=int(y1,x)%不定积分
fy2=int(y1,x,0,1)%定积分fy2 =1/3syms x;%声明变量x
y1=x^2;%定义原式
% fy1=int(y1,x)%不定积分
% fy2=int(y1,x,0,1)%定积分
fy3=int(y1,x,-inf,+inf)fy3 =Inf

 4、数值积分

1)梯形法计算积分 trapz()函数

语法:I=trapz(x,y) %适用于被积函数为离散数据

代码:

format long%显示格式设置
fy=@(x)sin(x)./x%@句柄的用法
x1=pi/6:pi/100:pi;
y1=fy(x1);
%绘图
bar(y1)
%定积分
s1=trapz(x1,y1)fy =包含以下值的 function_handle:@(x)sin(x)./xs1 =1.336217975152237

视图效果:

 2)基于变步长辛普森计算积分

语法:[I,n]=quad(‘fname’,a,b,Tol,trace)%I积分值/n积分函数调用次数

参数介绍fname:被积函数名 a,b积分界限 TOL精度 trace是否展现积分过程

基于变步长辛普森计算积分与梯形法计算积分对比代码:

fy=@(x)sin(x)./x%被积函数
s=quad(fy,pi/6,pi,0.00001,1)%变步长辛普森计算积分
x1=pi/6:pi/100:pi;
y1=fy(x1);
s1=trapz(x1,y1)%梯形法计算积分fy =包含以下值的 function_handle:@(x)sin(x)./x9     0.5235987756     7.10994777e-01     0.619018804711     1.2345935530     1.19600432e+00     0.626190692913     2.4305978762     7.10994777e-01     0.0910383671s =1.336247864730292s1 =1.336217975152237

 5、数值二重积分 dblquad()函数

语法:I=dblquad(f,a,b,c,d,tol,method),求f(x,y)在[a,b]、[c,d]区域上的二重积分

TOL精度 Method:计算一维积分(quad/quadl) 

代码:

 f=@(x,y)exp(x.^2).*sin(x.^2+y.^2)I1=dblquad(f,-2,2,-1,1)I2=dblquad(f,-2,2,-1,1,1e-9,'quadl')I3=dblquad(f,-2,2,-1,1,1e-9,'quad')%默认f =包含以下值的 function_handle:@(x,y)exp(x.^2).*sin(x.^2+y.^2)I1 =-9.400793312509709I2 =-9.400792842118586I3 =-9.400792842296315

 6、数值积分 integral()函数

语法:q = integral(fun,xmin,xmax,Name,Value)

代码:

fun = @(x) exp(-x.^2).*log(x).^2;
q = integral(fun,0,Inf)
q1 = integral(fun,0,Inf,'RelTol',1e-9)q =1.947522220295560q1 =1.947522180314255

 7、二重积分 integral2()函数

语法:q = integral2(fun,xmin,xmax,ymin,ymax,Name,Value)

代码:

fun = @(x,y) 1./( sqrt(x + y) .* (1 + x + y).^2 );
q1= integral2(fun,0,1,0,1)
q2= integral2(fun,0,1,0,1,'RelTol',1e-9)q1 =0.369530192486637q2 =0.369530180500556


http://www.ppmy.cn/server/48167.html

相关文章

JDBC是什么?它如何工作?

一、JDBC概述 JDBC(Java Database Connectivity)是Java语言与数据库之间进行交互的API。它允许Java程序通过SQL(结构化查询语言)来执行各种数据库操作,如查询、更新、删除等。JDBC是Java应用程序访问数据库的标准方式…

四十一、openlayers官网示例Flight Animation解析——在地图上绘制飞机航线、牵引线效果、动态动画

官网demo地址: Flight Animation 这篇介绍了如何实现飞机航线动画。 首先加载一张底图,定义一个样式。 const tileLayer new TileLayer({source: new StadiaMaps({layer: "outdoors",}),});const map new Map({layers: [tileLayer],target…

数据结构之ArrayList与顺序表(上)

找往期文章包括但不限于本期文章中不懂的知识点: 个人主页:我要学编程(ಥ_ಥ)-CSDN博客 所属专栏:数据结构(Java版) 顺序表的学习,点我 上面这篇博文是关于顺序表的基础知识,以及顺序表的实现。…

文心一言使用分享

文心一言使用分享 一、初识文心一言 文心一言(ERNIE Bot)是百度全新一代知识增强大语言模型,它不仅拥有强大的自然语言处理能力,还能与人进行流畅、自然的对话,提供准确、有用的信息。自从我开始使用文心一言以来&am…

CorelDRAW2024发布更新啦!设计师们的得力助手

在数字化的今天,视觉设计已经成为我们生活中不可或缺的一部分。从手机界面到广告海报,从网页布局到包装设计,每一个细节都离不开设计师们的专业与创意。然而,面对日益增长的设计需求和不断提升的审美标准,许多设计师开…

声明式事务原理,传播机制,事务失效情况二

不同类中的方法互相调用: 当不同类中的方法相互调用时,如果这些方法都被 Transactional 注解标记,并且被 Spring 代理管理,那么 Spring 的事务管理通常仍然会按照预期进行。然而,为了确保事务按照预期工作,…

【 0 基础 Docker 极速入门】镜像、容器、常用命令总结

Docker Images(镜像)生命周期 Docker 是一个用于创建、部署和运行应用容器的平台。为了更好地理解 Docker 的生命周期,以下是相关概念的介绍,并说明它们如何相互关联: Docker: Docker 是一个开源平台&#…

ubuntu18.04环境下,arduino ide在打开串口监视器时报错

ubuntu18.04环境下,arduino ide在打开串口监视器时报错 Exception in thread “AWT-EventQueue-0” java.lang.UnsatisfiedLinkError: /home/lzx/.jssc/linux/libjSSC-2.8_x86_64.so: /home/lzx/.jssc/linux/libjSSC-2.8_x86_64.so: file too short 这个错误表明 li…