如何用matlab求隐式函数的导数

隐函数求导的例子

假设有一个圆 \(x^2+y^2=5\) , 要求在某个点上的切线的斜率.

我们可以把式\(x^2+y^2=5\)中的每一项对\(x\)求导, 可以得到:

\[\begin{equation} \frac{d(x^2)}{dx} + \frac{d(y^2)}{dy}\frac{dy}{dx} = \frac{d(5)}{dx} \tag{1} \end{equation}
\]
\[\begin{equation} 2x+2y\frac{dy}{dx} = 0 \tag{2} \end{equation}
\]

再将 \(\frac{dy}{dx}\) 看成一个变量, 可以对式\((2)\)求解得到: $ \frac{dy}{dx}= - \frac{x}{y}$ , 这就一阶导, 也是圆上每一个点上切线的斜率.

对式\((2)\)再次求导:

\[\begin{equation} \frac{d}{dx}(2x) + \frac{d}{dx}(2y \frac{dy}{dx} ) = 0 \tag{3} \end{equation}
\]

求\(\frac{d}{dx}(2y \frac{dy}{dx} )\) 这一项要用乘法法则, 注意 \((\frac{dx}{dy})^2\) 和 \(\frac{d^2y}{dx^2}\) 是不同的.

\[\begin{equation} 2 + 2 \times ( \frac{dx}{dy} )^2 + \frac{d^2y}{dx^2} = 0 \tag{4} \end{equation}
\]

将$ \frac{dy}{dx}= - \frac{x}{y}$ 代入式\((4)\) , 将 \(\frac{d^2y}{dx^2}\) 看做变量可以求解得到:

\[\frac{d^2y}{dx^2} = - \frac{y^2+x^2}{y^3}
\]

这个就是二阶导.

如何用matlab求隐式函数的一阶导数

方法1: 用二元隐函数存在的定理

具体来说, 二元函数的求导代码是这样写的:

  1. 把等号右边的式子全移到左边
  2. 分别对式子求 x 和 y 的偏导
syms x y;
f = @(x,y) ( x^2+y^2-4 ); dx = diff(f(x,y),x);
dy = diff(f(x,y),y); ans = - dy/dx

方法2: 用solve硬解

如果你不知道公式, 还可以用solve函数强解隐函数导数, 具体做法如下:

  1. 把y写成y(x)让matlab把其当做与x相关的导数
  2. 直接对式x^2+y(x)^2=5求导可得到这样的结果: 2*x + 2*y(x)*diff(y(x), x) = 0
  3. 用变量dydx来代替原有的diff(y(x), x)
  4. 用solve函数解dydx
syms x;
g = str2sym('x^2+y(x)^2=5'); dgdx = diff(g,x) dgdx1 = str2sym('2*x + 2*y(x)*dydx = 0') solve(dgdx1,str2sym('dydx'))

如何用matlab求隐式函数的二阶导数

方法1: 链式法则

syms x y;

f = @(x,y) ( x^2 + y^2 - 5 );

dfx = diff(f,x);
dfy = diff(f,y); % 一阶隐式导
-dfx/dfy f1 = @(x,y) (-x/y); dydx = -x/y; % 二阶隐式导
d2ydx2 = diff(dydx,x)+diff(dydx,y)*dydx

方法2: 用solve硬解

如果不知道公式也一样可以用solve函数硬解, 不过要稍麻烦一点.

syms x y(x);
s1 = str2sym('x^2+y^2=5'); m1 = diff(s1,x) syms dydx;
s2 = subs(m1,diff(y),dydx)
s3 = solve(s2,dydx) % 再求导后用一阶导替换diff(y)
s4 = diff(s3,x)
ans = subs(s4,diff(y),s3)

http://www.codebonobo.tech/post/b0003_隐函数求导/

如何用matlab求隐式函数的导数的更多相关文章

  1. 2018-02-17 中文代码示例[译]Scala中创建隐式函数

    前言: 学习Scala时, 顺便翻译一下自己有兴趣的文章. 代码中所有命名都中文化了(不是翻译). 比如原文用的是甜甜圈的例子. 原文: Scala Tutorial - Learn How To C ...

  2. c语言中的隐式函数声明(转)

    本文转自:http://www.jb51.net/article/78212.htm 在c语言里面开来还是要学习c++的编程习惯,使用函数之前一定要声明.不然,即使编译能通过,运行时也可能会出一些莫名 ...

  3. 万恶之源:C语言中的隐式函数声明

    1 什么是C语言的隐式函数声明 在C语言中,函数在调用前不一定非要声明.如果没有声明,那么编译器会自己主动依照一种隐式声明的规则,为调用函数的C代码产生汇编代码.以下是一个样例: int main(i ...

  4. C语言的“隐式函数声明”违背了 “前置声明” 原则

    这个问题来源于小组交流群里的一个问题: 最终问题落脚在 : 一个函数在main中调用了,必须在main之前定义或者声明吗? 我在自己的Centos上做了实验,结果是函数不需要,但是结构体(变量也要)需 ...

  5. Matlab:显(隐)式Euler和Richardson外推法变步长求解刚性问题

    一.显示Euler 函数文件:Euler.m function f=Euler(h,Y) f(1,1)=Y(1)+h*(0.01-(1+(Y(1)+1000)*(Y(1)+1))*(0.01+Y(1) ...

  6. 关于gcc内置函数和c隐式函数声明的认识以及一些推测

    最近在看APUE,不愧是经典,看一点就收获一点.但是感觉有些东西还是没说清楚,需要自己动手验证一下,结果发现需要用gcc,就了解一下. 有时候,你在代码里面引用了一个函数但是没有包含相关的头文件,这个 ...

  7. Spark记录-Scala程序例子(函数/List/match/option/泛型/隐式转换)

    object func { def main(args:Array[String]):Unit={ //函数赋值给变量时, 必须在函数后面加上空格和下划线. def sayHello(name: St ...

  8. Scala学习二十一——隐式转换和隐式参数

    一.本章要点 隐式转换用于类型之间的转换 必须引入隐式转换,并确保它们可以以单个标识符的形式出现在当前作用域 隐式参数列表会要求指定类型的对象.它们可以从当前作用域中以单个标识符定义的隐式对象的获取, ...

  9. matlab求曲线长度

    曲线段在上的弧长为采用积分所求弧长s=∫√(1+y'²)dxmatlab求出各点的导数,然后按照上式积分 clear>> x=1:0.1:10;>> y=rand(1,leng ...

  10. Scala 隐式(implicit)详解

    文章正文 通过隐式转换,程序员可以在编写Scala程序时故意漏掉一些信息,让编译器去尝试在编译期间自动推导出这些信息来,这种特性可以极大的减少代码量,忽略那些冗长,过于细节的代码. 1.Spark 中 ...

随机推荐

  1. aliyun全站DCDN刷新--Django

    1.编写原因: 由于登录到阿里云DCDN,需要登录加打开各种页面,导致推送一次感觉非常麻烦,所以编写(网上以有很多可以借鉴) 2.基础环境 # 所需模块 pip install aliyun-pyth ...

  2. LabView十六进制与字符串之间的转换

    一.准备工具 Labview开发软件 字符串与十六进制的转换工具(做测试使用) 在线转换工具:IEE754浮点数16进制转换 本地工具如下图所示: 二.LabView字符串转换为十六进制 在数值中选择 ...

  3. 修改element,vant,mint等ui框架的样式

    vant和mint移动端常见,引入单独的css文件,在main.js中引入下即可,直接在对应的vue文件的css通过控制台查看中修改也行,再不济加!important element: 1.vue框架 ...

  4. gprMax项目代码分解:gprMax.py

    目录 1. 引言 2. 代码分解 (1) 导入模块 (2)main()函数 (3)run_main()函数 (4)run_std_sim()函数 (5)run_benchmark_sim()函数 (6 ...

  5. elasticsearch02-Request Body深入搜索

    目录 02. Request Body深入搜索 1.1 term查询 1.1.1 term 与 terms 1.1.2 range 范围查询 1.1.3 Constant Score 1.2 全文查询 ...

  6. css样式相关的惊艳的属性

    CSS gap 简写属性用于设置行与列之间的间隙(网格间距). 规范的早期版本将该属性命名为 grid-gap,且为了保持与旧网站的兼容性,浏览器仍然会接受 grid-gap 作为 gap 的别名. ...

  7. 重做贪吃蛇 万向移动型 蛇的移动和吃食部分C# wpf版

    之前写了一个贪吃蛇,代码实在太乱了,上一个是用polyline做的,这次这个是用一个个的elipse来渲染蛇的身体,其中一个圆点,就是一个elipse了.蛇的移动是通过定时器来实现的,方向键 A D控 ...

  8. Android 12(S) MultiMedia Learning(十)ACodec & OMX

    这一节的学习分为三块内容,omx hidl service用法.OMX架构.ACodec中的buffer分配. 1.omx hidl service system可以借助vndbinder来访问ven ...

  9. Hangfire 使用笔记 任务可以分离到别的项目中,无需重复部署Hangfire,通过API方式通信。

    "巨人们"的地址 Hangfire Mysql: https://github.com/arnoldasgudas/Hangfire.MySqlStorage 在获取set表数据的 ...

  10. 【终极指南】使用Python可视化分析文本情感倾向

    本文分享自华为云社区<Python理解文本情感倾向的终极指南>,作者: 柠檬味拥抱. 情感分析是一种通过自然语言处理技术来识别.提取和量化文本中的情感倾向的方法.Python在这一领域有着 ...