QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1175

主题

4

听众

2844

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all2 Z# A1 {\" J* w0 B
  2. syms x;
    3 n; W! J# V# \' W
  3. y=(x^2-1)^3+1;
    5 f* }5 G- L9 P! H2 [\" f
  4. y1=diff(y,x);                       %y对x求一阶导( h% L, V# c\" g  c  i; X
  5. y2=diff(y,x,2);                     %y对x求二阶导
    0 `9 g! m7 H! K
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分
    9 ~\" ^7 k0 q+ X% J! b/ }: ]+ L1 P
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图
    $ \# _! _# g& a0 |, r' Y& q
  8. subplot(3,1,2);) G9 j0 P/ A) I  l
  9. ezplot(y1,[-1.5,1.5]);
    1 m4 i/ |) [5 g% D7 X1 p* o: D6 q: o
  10. subplot(3,1,3);
    . V6 P' d* y9 R
  11. ezplot(y2,[-1.5,1.5]);3 e! g5 R8 B. ^* t+ D( [( Q$ T7 b' l
  12. %通过导数为0的点求最值% o9 C5 K8 T1 ?, x) i! y' |
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点. W* t. k7 h) q. M! z
  14. y0=subs(y,x,x0);                    %把x0带入y中的x! y: D# g. l9 n: D  E0 t
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值1 o, q* ?. `\" K/ d) X
  16. xmin1=x0(n);) R4 v' d# a1 f\" y
  17. %通过fminbnd求函数最值6 r# p+ o; F; L6 y
  18. f=inline('(x^2-1)^3+1','x');
    : W3 x+ D+ s& a* L* V3 ?  @  }& B
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点   
    3 h- K- S. z. O
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:
% n4 M3 g0 |. A- D+ X4 B, Y! P" N3 R/ P* ]0 z
1.clear all: 清除当前工作区的所有变量。
+ ?; @& Q- }7 {$ g2.syms x;: 声明符号变量 x。  w3 T6 N; R" u( h
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。
3 |/ x8 B* W8 q6 W5 d) V$ v( s+ j; t4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
& s3 Y) A6 O& V  y' l3 X5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。7 Q  h. Y! c, O9 _
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。
8 }( @. u2 @6 |4 g' d# Q7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。$ n+ V' N; ~4 v* F% t2 H/ o$ a7 d
8.subplot(3,1,2);: 激活第 2 部分。
' a5 U! W5 Y; H: ~5 P8 j9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。
+ _0 j0 h# `9 d$ N3 H) f10.subplot(3,1,3);: 激活第 3 部分。
# G- b1 O4 N" \' T4 Q2 u+ b: N11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
" B; N. J& k0 Q9 _12.通过导数为 0 的点求最值:  Y5 l8 F- Y. S" G1 P& e

/ a9 I) O9 K% b: m" i13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。$ R" c& d- y3 q. N! w' `
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。# Y/ t1 W6 K: T( v# K0 c
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。, |7 p( \1 `$ I8 F# V
16.xmin1=x0(n);: 得到对应的 x 值。
2 e/ v+ j& {6 t4 U5 o17.通过 fminbnd 求函数最值:
* z/ t3 o6 d. Q- o- C  Z* f2 Z7 D
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。
8 n& F- f! o; w9 r2 U+ Q' l19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。
& X- R. e4 z0 L0 j& |( J1 U& v20.ymin2=f(xmin2);: 得到对应的最小值。- m: V7 j, ~$ x, N

# P( K% t3 T. _- j这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。
* D% J, k* h% Y8 [- e
) g1 Y( f8 U  p3 d# i
1 X8 f# m' a3 |0 F/ |( 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, 2025-8-1 12:23 , Processed in 0.309835 second(s), 55 queries .

回顶部