QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |正序浏览
|招呼Ta 关注Ta
  1. clear all  x# `  U7 e& @+ ~0 E7 Z- J
  2. syms x;
    & M+ f/ e  g. x% ]' A
  3. y=(x^2-1)^3+1;- R% {/ T$ Q. a! D1 t: |4 N
  4. y1=diff(y,x);                       %y对x求一阶导8 Y. A, \) K/ N# ^
  5. y2=diff(y,x,2);                     %y对x求二阶导0 G2 k3 Q* G: C% a
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分: e5 d0 p4 |' r( q0 p/ Z7 |
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图
    & y# f& g. f1 H0 y7 K! b; L
  8. subplot(3,1,2);
    ' [# q- i! g1 W6 P. M/ i
  9. ezplot(y1,[-1.5,1.5]);/ P' S( `5 U/ ~# R2 l4 O
  10. subplot(3,1,3);6 ^) e  |2 Q\" O- u
  11. ezplot(y2,[-1.5,1.5]);
    0 `0 [  z( h# e; {# s, x/ w
  12. %通过导数为0的点求最值, t8 `& i  e# M0 z
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点: Y6 |9 a' n! y% l  M
  14. y0=subs(y,x,x0);                    %把x0带入y中的x* R& X+ C' b# F1 v& W7 _
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值$ \. m6 J; u+ y- \2 _7 S
  16. xmin1=x0(n);; _2 d, f! Y: Y1 C- f/ n
  17. %通过fminbnd求函数最值/ N7 q5 i+ K' K  P, v# S0 v, d+ n
  18. f=inline('(x^2-1)^3+1','x');
    : h& a. r6 v. m% H2 u* s. g
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点    3 e. W+ x9 G! \$ E9 }
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:) M& Y  ^* Z. g2 `8 t' c

7 c7 _+ d6 y7 ]! F1.clear all: 清除当前工作区的所有变量。
5 B5 @: X6 ]2 B" H0 R) S+ P7 P2.syms x;: 声明符号变量 x。/ L# Z% j5 J& U* |
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。- l3 H' b4 f# u: ?! m1 v
4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
  _6 ~" @) k( b* p( S" o8 b# v5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。& Q' }# {( @$ n( m7 e
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。
6 |# s( k( J6 ~+ U' \( f9 Z7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。/ C7 p7 t7 V# ~2 |1 ^; l# Y- J
8.subplot(3,1,2);: 激活第 2 部分。
3 c; g4 a+ g" p* L8 }' H9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。
0 X0 J  Z) L& q* u6 J! T10.subplot(3,1,3);: 激活第 3 部分。% G3 c. D/ ]% k2 D) M
11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
7 e, |1 K3 X! n7 \12.通过导数为 0 的点求最值:, t0 P$ T* L9 U

( x; {7 o0 Q# q* x) N, ?13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。+ ^- S7 E' P! X( n
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。$ u' F0 b! r; C8 _/ V. z- `
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。7 @$ O2 s% `9 J- g; s* N
16.xmin1=x0(n);: 得到对应的 x 值。. T$ ^, X4 _9 w) }% a
17.通过 fminbnd 求函数最值:7 U9 m/ \/ w: N0 p

: H! _& K) M& S; @18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。. v  [4 e/ t5 g) T
19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。# e  D$ F$ Q2 x7 y0 m
20.ymin2=f(xmin2);: 得到对应的最小值。. ~7 W$ B! T. c9 }

* S. p  [, F2 Y( d这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。3 K+ A9 C2 `5 E

3 u/ g, a- t! }! R- R: S" h$ @# U& @. K: C, 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, 2026-6-13 01:30 , Processed in 0.438889 second(s), 55 queries .

回顶部