QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1171

主题

4

听众

2780

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    , |# Q# H* P# c7 b# I
  2. syms x;
    . _1 V! m2 v8 m% H; @
  3. y=(x^2-1)^3+1;0 a; x  p1 x) N+ {+ C: \: ?# A
  4. y1=diff(y,x);                       %y对x求一阶导4 y\" N+ }, j) _\" m$ q
  5. y2=diff(y,x,2);                     %y对x求二阶导; J; S  l( i' |% B4 T
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分; v6 S6 f, {0 i8 _3 m' N0 X4 u6 J
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图
    & D3 A\" P9 u7 m  W7 y\" h
  8. subplot(3,1,2);
    - i0 L+ b( l. k
  9. ezplot(y1,[-1.5,1.5]);  l9 @+ x: Y! N% |0 V; u
  10. subplot(3,1,3);
    ! j+ q: L& Z0 C
  11. ezplot(y2,[-1.5,1.5]);9 O; d7 A8 g8 Z1 Z\" U
  12. %通过导数为0的点求最值; B, Q' B+ e0 [1 m1 t9 {\" b
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点
    2 \! ?' s0 E2 x+ p( \; C3 _0 i: k0 {2 f3 k
  14. y0=subs(y,x,x0);                    %把x0带入y中的x; n' q/ W7 M, Q8 A
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值3 F4 [9 h; @' d3 S\" j' P( o3 F
  16. xmin1=x0(n);
    8 Q) h0 V: H& k+ {2 [) Z% I1 x
  17. %通过fminbnd求函数最值
    \" l# U8 [. T! ^5 }
  18. f=inline('(x^2-1)^3+1','x');
      H( a/ H$ ^5 d( i: F; b0 {
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点   
    # U5 V3 f1 |7 D- K; N
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:# ]% k8 x  M3 f

+ R$ e! c$ `! C% k" a! T* m# @2 j1.clear all: 清除当前工作区的所有变量。5 D/ h/ }& K+ s
2.syms x;: 声明符号变量 x。, U6 Q1 r2 |3 I! j' Z! _) X
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。
0 u: f* V1 ~) j8 E+ `4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
) c& b8 @; y! @% w$ D  D$ }5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。
0 |& A) ^8 P9 O8 `$ \4 M$ [6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。2 I; O& i  W# L
7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。
8 i8 \+ H/ _1 h/ F, l8.subplot(3,1,2);: 激活第 2 部分。, o5 r5 w; @1 U) p! _
9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。1 y/ ^2 l  h2 H! y, d# F" P
10.subplot(3,1,3);: 激活第 3 部分。, _0 n- i* F1 w& t2 M1 x
11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。: P) t3 Q( y/ |9 y
12.通过导数为 0 的点求最值:8 p/ M& i$ y- b& A

; o5 L& ^6 V; B% u: u13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。
; a& h9 w3 c: J! p  \" `: D14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。& o1 d) E, Q; z
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。! e/ s3 U' ]* f: Y1 V# m2 ?/ ^
16.xmin1=x0(n);: 得到对应的 x 值。
9 v. h. e  ?# @0 s9 W, z17.通过 fminbnd 求函数最值:
& F1 z  S+ X- L& H
9 p) c0 [5 Q( ~. Z7 _7 Z18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。
- l  w2 A8 Z4 _3 W19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。' |: x3 j3 |; X# `; s8 t7 r
20.ymin2=f(xmin2);: 得到对应的最小值。, J3 v5 }& T  m7 u
% }3 ~* G* y% R1 W6 e, T2 h! q
这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。0 w, t' Y) d' D2 T: |% z: N! K

; x' l* R/ C- ]( p) ^: ]# @' N: H

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-23 10:11 , Processed in 0.785982 second(s), 54 queries .

回顶部