QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1176

主题

4

听众

2884

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    ' T& |0 D; V9 V
  2. syms x;5 m6 ?; @% x' j# E2 J2 z8 o
  3. y=(x^2-1)^3+1;
    $ ?- s1 O. F* M) }6 z, c( D8 G6 G
  4. y1=diff(y,x);                       %y对x求一阶导
    - e5 x' j1 y2 n: u$ c5 T) d- f
  5. y2=diff(y,x,2);                     %y对x求二阶导
    . o( J% n# i$ w  t2 g
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分
    8 m3 [& ]- ^. [) I! u( F) s
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图* O; u. @% h. a5 n
  8. subplot(3,1,2);
    4 V' }+ R2 z5 z6 Y; H
  9. ezplot(y1,[-1.5,1.5]);
    $ z! E( h5 w+ f* j9 f- i
  10. subplot(3,1,3);$ L% L1 z- }4 J! ~
  11. ezplot(y2,[-1.5,1.5]);
    $ b6 e: l0 m, o6 B2 v- {/ k* n1 S
  12. %通过导数为0的点求最值/ t, M, t3 U\" R% S9 L2 _; y
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点
    4 U9 w+ f& B( K% a! j; m% M
  14. y0=subs(y,x,x0);                    %把x0带入y中的x* W' D/ D8 Y# B4 F
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值
    . H; v; y/ o$ s# T+ `; B, \' v
  16. xmin1=x0(n);
    / a0 `\" n$ ~4 E3 V2 M# @* R
  17. %通过fminbnd求函数最值
    3 H. Q+ a$ P9 a\" f
  18. f=inline('(x^2-1)^3+1','x');
    \" G/ V' e8 j% j( n
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点    7 p: i. p- v  d9 U. i6 X
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:2 j  l' `9 O6 t' C3 P

1 I, g% i9 c' i1.clear all: 清除当前工作区的所有变量。9 Q3 z3 u2 X9 s$ T( q
2.syms x;: 声明符号变量 x。
0 N- o# |% a/ J9 @3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。" s- e+ l! K) K# z3 }
4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。4 C4 q- l& s1 g* q
5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。% B$ a' U: W) y  y( A
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。
+ u; ]) q8 N* a3 L2 L/ I7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。5 X  T0 i4 a) O9 s. a/ _
8.subplot(3,1,2);: 激活第 2 部分。7 f" V+ o5 y, D+ ~- m
9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。9 C( Z" m% t/ j8 g- v
10.subplot(3,1,3);: 激活第 3 部分。
, T: d3 M8 O8 \/ @$ }' Y; u11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。" d8 |: Z9 k! v( y7 R
12.通过导数为 0 的点求最值:
6 w- w, q" c7 X0 y
, i! W, L# N1 i9 T; m/ F13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。
; F# t$ m% d& E6 N: D3 W14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。: _0 A9 y: @: A0 W
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。2 B& V: p! s* C1 ?$ H( R0 E/ N% Y
16.xmin1=x0(n);: 得到对应的 x 值。4 l6 O: v  g) p7 w2 C
17.通过 fminbnd 求函数最值:" E. \8 V/ P0 o9 e, O% j
) d  m* ?7 w7 c4 A4 S
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。# e6 D6 A2 t0 W8 y2 k
19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。, f" W4 K7 i0 ]9 ^8 g' b
20.ymin2=f(xmin2);: 得到对应的最小值。$ B) g, H6 \6 N3 S0 |/ \9 G2 X# I5 G3 @

( V& @# Q2 |& i2 f- A/ ?7 c/ x+ c这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。3 C& O% g4 G+ f1 `3 ]+ q! s

3 t. _6 O) J$ P' g' J# l0 K, }0 S" Q6 r( ]; f7 z$ a& o

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-9-21 07:51 , Processed in 1.339508 second(s), 55 queries .

回顶部