QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2170|回复: 0
打印 上一主题 下一主题

matlab求最值与求导

[复制链接]
字体大小: 正常 放大

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    * t# L7 Y: G* y& J
  2. syms x;
    4 }- o7 i0 |2 I8 \\" p\" t9 D, A  x
  3. y=(x^2-1)^3+1;
    * [. M. v5 m0 v# b/ y1 R
  4. y1=diff(y,x);                       %y对x求一阶导7 `# i9 z# v+ Z
  5. y2=diff(y,x,2);                     %y对x求二阶导. z8 e\" M7 O# l* U
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分
    4 ^% u! m  o\" W- k1 M
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图
    5 c0 a% X9 _6 a% \$ B\" F
  8. subplot(3,1,2);
    4 K/ e3 X' e$ F* k% g
  9. ezplot(y1,[-1.5,1.5]);
    \" f* w% c9 h8 @4 R7 x) W  L
  10. subplot(3,1,3);
    & h+ C# v. Y; T# \# S+ o
  11. ezplot(y2,[-1.5,1.5]);# J+ B0 w8 {6 E9 d3 H2 G7 U
  12. %通过导数为0的点求最值
    & D- K! ~* I! S9 o
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点. m0 O* Z% i  N# O
  14. y0=subs(y,x,x0);                    %把x0带入y中的x8 L, O: v9 `, b, a6 x( Q
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值: u8 ^% T1 z: w) ]1 F
  16. xmin1=x0(n);; C7 W2 E) k4 G+ D& ?7 g  E* e
  17. %通过fminbnd求函数最值
    ; p4 U7 B, G# A- t5 R* a
  18. f=inline('(x^2-1)^3+1','x');
    \" E1 p& p( y: \3 D6 K  ?0 d
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点   
    9 }  z! c% T1 B, D: ~8 `9 c6 B
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:+ b+ r) N: t4 P  V) b
7 w; E/ t- d$ p& z+ F( ?# T
1.clear all: 清除当前工作区的所有变量。7 ?. y( l/ N& w  h
2.syms x;: 声明符号变量 x。8 o0 r- H" |0 g, `  n( q/ Y( h
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。
$ }, S- @( z! M" Y. E9 ~' d( J9 T4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
7 y! a6 d, ~8 h( q0 {5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。
0 `5 x: P6 e' m! B6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。& P3 n. n* u' y# h# T9 j
7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。
3 c$ U4 N& R2 E$ R4 b8.subplot(3,1,2);: 激活第 2 部分。
3 K$ ^# Z/ ]) f" P: Q9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。
  h$ J- {( O. K9 v& ^10.subplot(3,1,3);: 激活第 3 部分。
2 V% ^+ V/ n. w) L) w8 R. K11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
9 F0 ~6 H3 m" v8 @; [12.通过导数为 0 的点求最值:) j7 L2 a. Z, d: W

- B1 K: U9 H. _3 T! |) P% Q13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。  y* A6 M, V, R6 I8 y
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。( P2 M4 W$ A$ r+ C. K( g6 I, W3 d
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。; B2 t: ]5 ~# t( y
16.xmin1=x0(n);: 得到对应的 x 值。1 v4 C$ h0 L# v
17.通过 fminbnd 求函数最值:, H2 N% L4 q* Y- N" f7 i8 {
; L# `  X5 k# V! E* F
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。
4 C- f" y& m% ?+ j0 S' C3 f' [( ?19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。4 i7 r: B9 I+ R
20.ymin2=f(xmin2);: 得到对应的最小值。/ k( P$ |7 z6 {
2 \0 F' [1 _" K* z
这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。1 K" M) k2 T  {. L1 T- _; O0 h
, _" @+ n- J8 i. C6 t$ }

% \: U2 C$ E0 j7 ?, t9 e

qiudao.m

725 Bytes, 下载次数: 0, 下载积分: 体力 -2 点

售价: 2 点体力  [记录]  [购买]

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-14 11:46 , Processed in 0.435500 second(s), 55 queries .

回顶部