QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all( G- [8 o3 ^3 x( \
  2. syms x;3 G  L$ @. Y$ K/ f0 V* p3 _
  3. y=(x^2-1)^3+1;
    + ]3 K( j. F) R
  4. y1=diff(y,x);                       %y对x求一阶导
    , v5 C8 y4 V4 R9 [, i
  5. y2=diff(y,x,2);                     %y对x求二阶导
    $ G0 X+ p1 G4 k5 H6 y
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分
    . d: c. P. B& l/ U3 A
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图/ D  ~  ?! t( F$ s+ B- F2 p7 v& D' }
  8. subplot(3,1,2);
    ; S! M, X; m% `5 E
  9. ezplot(y1,[-1.5,1.5]);7 ~3 ~) h- S& U& P4 m6 }$ j
  10. subplot(3,1,3);
      h2 h& _' {+ F8 X: g3 |
  11. ezplot(y2,[-1.5,1.5]);
    6 `, v9 U; R& N& A
  12. %通过导数为0的点求最值! \* M4 |5 u. m; ]  I( [/ q. o
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点+ z0 b, S/ C7 Q
  14. y0=subs(y,x,x0);                    %把x0带入y中的x8 r9 X  g4 m5 q+ G0 w( I8 X
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值
    \" p0 P1 l, h# t
  16. xmin1=x0(n);
    1 f. I/ u0 @: t9 b
  17. %通过fminbnd求函数最值8 S4 N( ]: j' P8 r
  18. f=inline('(x^2-1)^3+1','x');7 ^. M& o2 h  G0 t) x- m
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点    ' k4 k8 L% j9 X7 F* f6 d
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:& {+ l5 C$ H- r% e6 t. t) G
3 V" I' X3 w3 P/ N  o8 `4 |
1.clear all: 清除当前工作区的所有变量。4 d  x! X% w3 k; b- e# D# r* P
2.syms x;: 声明符号变量 x。6 T3 u; V; N1 Y% B* g# Z
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。' ~. O! u" r, r/ y6 p% Q7 e
4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
+ o) r* D3 J( M2 q5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。. Z: Z0 l4 ?7 w
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。( p# s! L8 M, N. K4 T6 _$ m9 f- J
7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。
9 R) n, M) S. Z6 Y7 T1 \$ h' S& V8.subplot(3,1,2);: 激活第 2 部分。
# Q/ @! v) H+ u6 i/ I- v9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。
" G9 S- k9 O1 S; M) N10.subplot(3,1,3);: 激活第 3 部分。
5 r* [- ]8 M5 f11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
( R8 u' V+ ~0 G# ~$ q12.通过导数为 0 的点求最值:! l$ n6 h4 y7 `5 m; N' i. h

# Q; i$ l* o2 t) l+ J13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。
- W4 Q, M! q# o* \- n4 m# d14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。* j: G. h# X, {; N& f9 n3 @
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。* Z& m: h/ r5 @4 `3 Z! S
16.xmin1=x0(n);: 得到对应的 x 值。/ h8 Q$ H" w$ q$ B2 k& G6 F  h
17.通过 fminbnd 求函数最值:% k$ P# S5 ?+ J" v) `4 c
8 g, L  k+ v1 H8 Z4 L
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。9 B& T. ~+ o9 a5 t8 a' [6 y; v
19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。+ J" N3 v6 R0 c
20.ymin2=f(xmin2);: 得到对应的最小值。/ N  Z# f* |% q0 c' S

+ q, V2 q( C; m+ }1 U这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。
- X) I# e$ l# _) J) x, I! y: f* y9 E/ j) j+ z
5 U  ]* w' S3 X' E# ?- S  x. }

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-6-13 02:52 , Processed in 0.395989 second(s), 54 queries .

回顶部