QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all0 _: I9 I& R& t6 Y  ]& R
  2. syms x;
    , V4 j1 N/ Y( W! e: ~& C
  3. y=(x^2-1)^3+1;
    8 g1 R+ @; S0 z+ j$ p# |% ]
  4. y1=diff(y,x);                       %y对x求一阶导8 p& I2 E! ~5 U; f; m$ O
  5. y2=diff(y,x,2);                     %y对x求二阶导
    9 K! }6 ^, I) m& l  f* U
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分& [, S4 `\" Z4 E: u3 r% _/ d
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图6 o3 a% a- i7 e( v7 P5 H( u) l
  8. subplot(3,1,2);
      {5 L3 z4 r' S' r: u( d7 T
  9. ezplot(y1,[-1.5,1.5]);/ e/ N, J8 y% F) \
  10. subplot(3,1,3);\" Z: S5 \5 g: d
  11. ezplot(y2,[-1.5,1.5]);4 a% g3 p4 P# M' o; f; ~6 R6 L
  12. %通过导数为0的点求最值7 u; R4 r+ {( D  R7 ~) A4 ]
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点3 M8 |$ \5 S6 y/ V0 x- D4 G
  14. y0=subs(y,x,x0);                    %把x0带入y中的x3 E0 d8 e7 a) s1 S' z
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值
    ) P8 d: @; |# e0 c$ d. d+ d8 R
  16. xmin1=x0(n);5 l1 P  ]  B: I4 X
  17. %通过fminbnd求函数最值. p' O5 L/ K8 p3 u: M% a6 q( {
  18. f=inline('(x^2-1)^3+1','x');
    7 A( Q: t. @4 ?! |\" i( O! h
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点   
    3 p5 Y7 t0 _* s
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:' C( D2 M8 }- a( a) z
: u7 d( X; |! X2 P5 m, T1 ~* v0 Y
1.clear all: 清除当前工作区的所有变量。% S0 {  D; u4 |
2.syms x;: 声明符号变量 x。$ s$ S. T% x' N  T( P& W! s! q  M- x
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。
  h% P! G2 g& c) d! e  [9 l4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。$ \+ q: }# ~) K. V# n& @
5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。3 m6 m1 H# d. t! g6 [: r0 J
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。" B( O5 [- V: T3 _; ]4 B) {* G
7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。6 E$ p- S, j4 D6 b* E+ u3 O0 B6 u
8.subplot(3,1,2);: 激活第 2 部分。
7 U( J) E9 J0 y, c+ d9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。
2 q( [" ?6 y& q8 t9 l1 R& i10.subplot(3,1,3);: 激活第 3 部分。( K  T! B7 H- n6 @% P: F- C
11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
( i  S$ S- y& _" \" u12.通过导数为 0 的点求最值:
" Y$ _' g8 }- d- ]- s
9 t  e9 C9 }6 G( ?$ x8 ~4 U3 B6 }13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。+ I/ ~" w, V# S( }2 I
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。4 q$ H8 ~8 m! G1 x+ S  [: p
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。
$ @/ i$ e+ t! _  e16.xmin1=x0(n);: 得到对应的 x 值。+ Y  J( W. S  i( y
17.通过 fminbnd 求函数最值:
& s3 h$ v7 ]! x) c9 m- \/ j1 i: O' v$ d7 w' Z' ~5 ^3 c' E
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。
  b0 J) i+ e: p: U) n/ m+ Z5 s19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。
3 V$ f9 q+ R2 e: q8 c( L20.ymin2=f(xmin2);: 得到对应的最小值。3 O8 [* V" \1 B5 B: _

5 ~( {2 Z3 B  m: p) t( _. `这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。$ [/ v* o- _# g; F3 b& G' ?; r
# s. H% Y$ l4 F) }0 l2 j

) _% u: t  {- ?9 [8 u4 E  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-12 17:48 , Processed in 0.433654 second(s), 55 queries .

回顶部