QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1171

主题

4

听众

2781

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    0 n7 l% X- n: B\" z
  2. syms x;( O) Y( t9 B8 G! o6 @9 d0 H: Q+ K
  3. y=(x^2-1)^3+1;\" h1 b5 U6 ^, O# A+ x
  4. y1=diff(y,x);                       %y对x求一阶导, B# m, ], c% ?8 ^$ g\" V) N
  5. y2=diff(y,x,2);                     %y对x求二阶导
    & K\" L$ S8 W! R- ]& j
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分
    5 \6 l- ?\" B/ b, N' ~7 T
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图9 z5 E1 o: w1 s. r\" h; o
  8. subplot(3,1,2);4 e7 t# J) a6 r: t& P2 n
  9. ezplot(y1,[-1.5,1.5]);
    5 A0 B2 E! ^$ r5 H! e6 p
  10. subplot(3,1,3);
    9 L$ k\" g/ Q3 Z, q: P) b7 y
  11. ezplot(y2,[-1.5,1.5]);
    ' i' {% Y& W$ ~9 k! g( T
  12. %通过导数为0的点求最值& {7 `  y\" b; y2 ]! d, B& `
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点
    ( i+ E/ |  _) B% G# r6 D
  14. y0=subs(y,x,x0);                    %把x0带入y中的x
    4 v) @. L) _; a; b/ d: W' z
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值' D& {* X. C$ U' w7 F* d- B$ N4 K
  16. xmin1=x0(n);, h+ A. ~3 t0 ^% S4 g
  17. %通过fminbnd求函数最值# ~; b, x% J! x; ^
  18. f=inline('(x^2-1)^3+1','x');! F$ l% L, ~* E; q% }' Z
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点   
    . S  [\" P+ _/ {8 d* {
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:4 Z# R. F, ?, l7 U/ Q
9 b# R3 _& r6 i' T
1.clear all: 清除当前工作区的所有变量。
: N+ U; w5 `) g) p" u2.syms x;: 声明符号变量 x。
# a$ u' `# ~% n2 H3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。
1 e& R# d/ N0 m4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
0 \6 f, q: _5 c  a5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。5 ~# I) l2 Y9 T7 c
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。
- S1 g: W* ]+ f8 h0 @7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。0 Q1 e3 r% D: s# h) }, p* [' w
8.subplot(3,1,2);: 激活第 2 部分。
* F% `2 f) k3 g, r8 g2 B, ~9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。; u. P* T7 }/ I: N3 M; s
10.subplot(3,1,3);: 激活第 3 部分。
  Y' l/ `0 @5 k4 Y11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。; Q; k( ~9 b/ ]* l) U
12.通过导数为 0 的点求最值:. P" j6 x9 Q' f8 c! Z$ C/ j

+ d$ P3 W& v; a6 k& E3 P7 y13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。& H" w) R  A8 Y$ p5 U- R# Q# N
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。( \+ k1 n. H+ ^9 D8 {; U
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。  C# a( n* c: e/ g: T" V7 j
16.xmin1=x0(n);: 得到对应的 x 值。( T  J% o  Z) @) \
17.通过 fminbnd 求函数最值:
3 Q3 a" n% d. ]7 s! ~* K5 T
- f  k9 v+ N5 U8 Q7 R' d: i18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。
7 X4 X: n! _/ O% _4 u19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。
$ {- I. M3 a5 C( k9 p20.ymin2=f(xmin2);: 得到对应的最小值。
5 Z. D( J+ e5 u( Y
+ C4 m3 q$ i8 g3 x0 s这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。
# U$ ~* [$ z3 o6 w" p- c
% F- P# n* H  l4 f! _0 G
# Q9 p4 K- ^8 l

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-6-26 11:49 , Processed in 4.212175 second(s), 55 queries .

回顶部