- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
- clear all
: }% ]2 b% U$ N5 E: N. W; ?& [ - syms x;9 l- P- B/ ?. H& ^0 L1 \
- y=(x^2-1)^3+1;9 O% e; f& r* G; n( ~/ v0 W; X
- y1=diff(y,x); %y对x求一阶导
( ^: y0 U+ s# {\" o0 ^, w - y2=diff(y,x,2); %y对x求二阶导; y/ Q- K& c- }8 I; x. ? [& g5 S! P
- subplot(3,1,1); %把图形窗口分成3×1部分,并激活第1部分
# p4 f5 l0 ]3 d+ |' M, q4 C A - ezplot(y,[-1.5,1.5]); %对符号函数在[-1.5,1.5]上绘图\" _5 c' ~1 t4 r
- subplot(3,1,2);) X1 S) e# {, D; Y9 X\" ?
- ezplot(y1,[-1.5,1.5]);& `6 B5 C. e9 p\" t* t6 p
- subplot(3,1,3);8 a e% _\" P: s1 e8 h
- ezplot(y2,[-1.5,1.5]);: j8 r2 k* p6 \
- %通过导数为0的点求最值* V& ~1 z( K* d8 I5 e) j
- x0=solve('6*(x^2-1)^2*x=0','x'); %求解一阶导数(从workspace中得到)为0的点3 ~ b, Z$ ]% i1 Y
- y0=subs(y,x,x0); %把x0带入y中的x
4 n: E\" f9 a* f\" r+ X L% c - [ymin1,n]=min(eval(y0)); %求y0的最小值) c% |\" n\" Y: D5 I+ v
- xmin1=x0(n);
6 A9 f# I4 N) S\" }; ] - %通过fminbnd求函数最值
1 P( T! u- t! v! c, T - f=inline('(x^2-1)^3+1','x');
- u. @; y8 ^0 W1 Q, T* o2 o7 G - xmin2=fminbnd(f,-1.5,1.5); %在[-1.5,1.5]上求f函数的最小值点
. G+ [/ L7 @4 Z* M* @ G - ymin2=f(xmin2);
复制代码 这段Matlab代码主要执行以下任务:+ }* r3 C4 z* R; {* a S) Z
3 I Z$ t, K0 f. Q4 o! D
1.clear all: 清除当前工作区的所有变量。: I, n, O7 e* O C6 a6 @
2.syms x;: 声明符号变量 x。
/ B. I1 n+ J6 N: ~( j5 H6 [; S3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。7 _+ j( k; u3 q3 f% B
4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。- i$ x" _# P6 G
5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。' b. m' z# o' Y$ h
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。, A# H3 k3 ?" \! l
7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。
' t4 M6 ~$ l5 d! v6 h8.subplot(3,1,2);: 激活第 2 部分。
; U0 O, b$ ~9 q3 v& A/ X9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。7 b; _9 W7 X/ t1 O$ u0 F9 Z
10.subplot(3,1,3);: 激活第 3 部分。, ]/ d' F) h) ?6 V0 w. O* Q
11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
9 G8 E( M$ F1 g12.通过导数为 0 的点求最值:( n5 P' Z. B8 I& l$ E$ i
$ r0 {* O- y! q. a& J R13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。" S4 T/ V( j* e5 N0 E% g8 n
14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。* y7 ]' R4 F- Y O
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。8 o$ |) U* {: l# F7 r
16.xmin1=x0(n);: 得到对应的 x 值。
7 s+ @0 b2 g% N5 T8 \5 I17.通过 fminbnd 求函数最值:
! b( q/ V. J/ P1 y3 K& E9 u4 ^$ ]; \; h0 T* y
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。: T+ p! x' x% c, {! q8 F; B
19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。
3 d: X4 N& C, f" K20.ymin2=f(xmin2);: 得到对应的最小值。9 F8 ?% |# N; d% p+ Q' C4 k
' Q6 ]* f/ V6 G/ [这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。
' l6 r! X. y" x" E: j
( s7 f, D6 T2 t3 y& E/ F0 S6 W* W9 K" R; U
|
-
-
qiudao.m
725 Bytes, 下载次数: 0, 下载积分: 体力 -2 点
售价: 2 点体力 [记录]
[购买]
zan
|