QQ登录

只需要一步,快速开始

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

matlab求最值与求导

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 18:08 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
  1. clear all
    5 q& B6 @' d& c* {
  2. syms x;' {* W1 g  b) |. G) @
  3. y=(x^2-1)^3+1;7 d4 V+ |( \- z4 W. M) \. f
  4. y1=diff(y,x);                       %y对x求一阶导; X- ?$ S) N& d% W* D9 E( _
  5. y2=diff(y,x,2);                     %y对x求二阶导
    + a) I9 \( k# [& B* u1 W$ C4 B
  6. subplot(3,1,1);                     %把图形窗口分成3×1部分,并激活第1部分8 w: E* c& r2 T7 S
  7. ezplot(y,[-1.5,1.5]);               %对符号函数在[-1.5,1.5]上绘图
    , C1 e  h' l5 c  q; h
  8. subplot(3,1,2);
    # |% l! O8 d2 U6 |$ W* r8 B
  9. ezplot(y1,[-1.5,1.5]);4 J\" \; N6 g( d* E5 V
  10. subplot(3,1,3);
    , C6 Z! w# }% J6 ?0 a( h9 g% T
  11. ezplot(y2,[-1.5,1.5]);5 O5 W4 \\" k. d5 K( Z% p
  12. %通过导数为0的点求最值
    , d( h% F, u* ~) T; L; v5 l
  13. x0=solve('6*(x^2-1)^2*x=0','x');    %求解一阶导数(从workspace中得到)为0的点
    - z3 L- Y0 c8 W9 g/ X( O8 _2 i
  14. y0=subs(y,x,x0);                    %把x0带入y中的x
    # N8 a- z6 H0 V
  15. [ymin1,n]=min(eval(y0));            %求y0的最小值
      X1 k# k) w$ q4 ?4 e
  16. xmin1=x0(n);
    + J$ N: E7 C1 ~5 }& V) {
  17. %通过fminbnd求函数最值
    4 E6 v$ u, s0 o* t
  18. f=inline('(x^2-1)^3+1','x');- J! D- h! {! d: M
  19. xmin2=fminbnd(f,-1.5,1.5);          %在[-1.5,1.5]上求f函数的最小值点   
    1 Z/ e) O2 k3 v& Q# m& Z2 G
  20. ymin2=f(xmin2);
复制代码
这段Matlab代码主要执行以下任务:
; {  `/ g* o; Y9 \4 N4 i$ }4 x7 j$ @+ L4 k
1.clear all: 清除当前工作区的所有变量。' t. A( Q. V$ t7 @
2.syms x;: 声明符号变量 x。
  ^/ e- f7 Z1 N& J4 t! N3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。) C) }% }; U! S7 P( C
4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
/ z6 G# C; a# V5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。4 a$ P# A7 g$ c7 T3 m, a" C
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。
$ l; w0 b. a7 R$ R5 U, i: z$ N7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。* E/ n# t0 f6 H1 m, Y! L# H
8.subplot(3,1,2);: 激活第 2 部分。
# B  w1 t; T3 |1 S% t8 @: p9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。3 \5 C3 _8 T5 S& ~
10.subplot(3,1,3);: 激活第 3 部分。' o, Z8 `5 o2 {, a9 s' o3 k  ^
11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
6 p  |. w% H# h- }' s12.通过导数为 0 的点求最值:1 J! G2 b9 @& f0 ~. e6 @' b

6 X  }$ m" [+ O" e! O- `7 F13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。! k6 i! F4 ]1 S& R- Y: m1 l2 q
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。
5 t( g  q! _8 C8 @- D6 h0 N# a15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。
, i& [, V: f4 h# W, }0 d16.xmin1=x0(n);: 得到对应的 x 值。  R* B2 p1 @7 K0 A
17.通过 fminbnd 求函数最值:4 U+ n8 V7 H( [' F, |; P- m
- O, G4 L; s3 S- h5 s; m
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。
6 ~& B8 w' u5 R19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。
0 w, H; w( V: ^6 m! i9 s0 x, |; }20.ymin2=f(xmin2);: 得到对应的最小值。
) d0 T" \4 p- z: f% b1 K
, k0 q, H, S2 k- o( A4 s' Z这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。
) S9 f# G( l' L) k  S) h) @% S. T  x6 B

' f  ^8 Q2 n- 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-11 04:07 , Processed in 0.334099 second(s), 55 queries .

回顶部