QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    6 D2 t, N& b4 {( p
  2. syms x;( `7 _+ S& N& p1 a5 g
  3. y=(x^2-1)^3+1;
    ; Z$ g) I( O' W  ?
  4. y1=diff(y,x);                       %y对x求一阶导) v7 G  L0 Z$ F% U8 J
  5. y2=diff(y,x,2);                     %y对x求二阶导
    ; r0 }8 d( ~! a0 P6 N* Y
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分5 m9 O) N) P8 `\" B6 h$ `' q
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图3 _( }* K5 F: Q6 ~# {) B$ D
  8. subplot(3,1,2);
    & Z$ Y\" y* N) C) S/ M
  9. ezplot(y1,[-1.5,1.5]);  B9 H& R, ^8 i% T0 D( k1 X
  10. subplot(3,1,3);/ `8 k\" q* a$ V% B6 T0 E& A
  11. ezplot(y2,[-1.5,1.5]);# }1 o8 h4 H' B5 w
  12. %通过导数为0的点求最值
    - i4 |9 H' F2 b( \: {
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点( E5 i8 n+ O6 F0 O
  14. y0=subs(y,x,x0);                    %把x0带入y中的x6 r/ \; `7 {# u$ @1 t
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值
      D3 I: l7 W( v5 @
  16. xmin1=x0(n);
    + W0 ~+ l+ V' M) N
  17. %通过fminbnd求函数最值
    % Q2 m* o& H) h) a# a\" s. ]9 p% T
  18. f=inline('(x^2-1)^3+1','x');0 f' x: n4 A( d; m6 r- ~\" c
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点    / F2 ]4 p; R5 \
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:* Z$ {4 R! b2 j, |$ a+ x4 l

+ f/ y- N# N; T. f# Q5 _1.clear all: 清除当前工作区的所有变量。
% H" E  B5 W( I' b, V: ?% m; v4 J2.syms x;: 声明符号变量 x。" L5 H" V4 P, q. \2 s0 x$ ^
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。0 z8 N* C& B$ F$ z, E
4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
/ `' ?& P$ c( ]# k0 b) g8 L: P5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。
' B1 u1 e( u  E) v6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。
" ]8 x/ B% W  I6 N" a( Q' Z3 E5 e7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。
. U+ h1 g' S( s( Q) }8.subplot(3,1,2);: 激活第 2 部分。( Y3 W8 e9 t" F) \6 d/ |8 F
9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。
  z3 s; C8 m: [10.subplot(3,1,3);: 激活第 3 部分。
- s, P& z$ D4 i& Q: l- i/ E11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
  m& c0 ^; G" \' \9 u% O. |& H12.通过导数为 0 的点求最值:
  S$ t+ ]+ Q9 q6 }8 Y* |1 F$ G7 B- w4 p! b7 l
13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。4 A; q" o- A" @. b
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。: p, x5 H. k) d! |
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。% G" k8 w  z3 `2 x* n) f( i
16.xmin1=x0(n);: 得到对应的 x 值。
! s# ~" Y2 p$ L# g( K" \" ~( q- u! P. B17.通过 fminbnd 求函数最值:- h- `/ D4 c! ~# h9 x! b

2 z) @" I8 p7 ?& g% p18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。' B  Z7 h, q7 K! v1 Y* C
19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。
' |5 E! w, J+ X' K1 \. m8 _# x5 Z7 H20.ymin2=f(xmin2);: 得到对应的最小值。1 f( E1 \9 x8 h5 N8 K/ w

8 y/ L7 S8 [" C! G- ~这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。$ I. n/ o- p$ n
  F7 S$ m: `* z
, c/ K5 C5 K9 A* _2 x- j

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-4-11 02:56 , Processed in 0.514167 second(s), 54 queries .

回顶部