- 在线时间
- 480 小时
- 最后登录
- 2026-6-1
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7823 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2934
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1174
- 主题
- 1189
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
- clear all( G- [8 o3 ^3 x( \
- syms x;3 G L$ @. Y$ K/ f0 V* p3 _
- y=(x^2-1)^3+1;
+ ]3 K( j. F) R - y1=diff(y,x); %y对x求一阶导
, v5 C8 y4 V4 R9 [, i - y2=diff(y,x,2); %y对x求二阶导
$ G0 X+ p1 G4 k5 H6 y - subplot(3,1,1); %把图形窗口分成3×1部分,并激活第1部分
. d: c. P. B& l/ U3 A - ezplot(y,[-1.5,1.5]); %对符号函数在[-1.5,1.5]上绘图/ D ~ ?! t( F$ s+ B- F2 p7 v& D' }
- subplot(3,1,2);
; S! M, X; m% `5 E - ezplot(y1,[-1.5,1.5]);7 ~3 ~) h- S& U& P4 m6 }$ j
- subplot(3,1,3);
h2 h& _' {+ F8 X: g3 | - ezplot(y2,[-1.5,1.5]);
6 `, v9 U; R& N& A - %通过导数为0的点求最值! \* M4 |5 u. m; ] I( [/ q. o
- x0=solve('6*(x^2-1)^2*x=0','x'); %求解一阶导数(从workspace中得到)为0的点+ z0 b, S/ C7 Q
- y0=subs(y,x,x0); %把x0带入y中的x8 r9 X g4 m5 q+ G0 w( I8 X
- [ymin1,n]=min(eval(y0)); %求y0的最小值
\" p0 P1 l, h# t - xmin1=x0(n);
1 f. I/ u0 @: t9 b - %通过fminbnd求函数最值8 S4 N( ]: j' P8 r
- f=inline('(x^2-1)^3+1','x');7 ^. M& o2 h G0 t) x- m
- xmin2=fminbnd(f,-1.5,1.5); %在[-1.5,1.5]上求f函数的最小值点 ' k4 k8 L% j9 X7 F* f6 d
- ymin2=f(xmin2);
复制代码 这段Matlab代码主要执行以下任务:& {+ l5 C$ H- r% e6 t. t) G
3 V" I' X3 w3 P/ N o8 `4 |
1.clear all: 清除当前工作区的所有变量。4 d x! X% w3 k; b- e# D# r* P
2.syms x;: 声明符号变量 x。6 T3 u; V; N1 Y% B* g# Z
3.y=(x^2-1)^3+1;: 定义符号表达式 y,这个表达式是一个函数 (x^2-1)^3 + 1。' ~. O! u" r, r/ y6 p% Q7 e
4.y1=diff(y,x);: 对 y 关于 x 求一阶导数,结果存储在 y1 中。
+ o) r* D3 J( M2 q5.y2=diff(y,x,2);: 对 y 关于 x 求二阶导数,结果存储在 y2 中。. Z: Z0 l4 ?7 w
6.subplot(3,1,1);: 将图形窗口分成 3 行 1 列,并激活第 1 部分。( p# s! L8 M, N. K4 T6 _$ m9 f- J
7.ezplot(y,[-1.5,1.5]);: 绘制符号函数 y 在 x 范围 [-1.5, 1.5] 上的图像,显示在第一个子图中。
9 R) n, M) S. Z6 Y7 T1 \$ h' S& V8.subplot(3,1,2);: 激活第 2 部分。
# Q/ @! v) H+ u6 i/ I- v9.ezplot(y1,[-1.5,1.5]);: 绘制一阶导数 y1 在 x 范围 [-1.5, 1.5] 上的图像,显示在第二个子图中。
" G9 S- k9 O1 S; M) N10.subplot(3,1,3);: 激活第 3 部分。
5 r* [- ]8 M5 f11.ezplot(y2,[-1.5,1.5]);: 绘制二阶导数 y2 在 x 范围 [-1.5, 1.5] 上的图像,显示在第三个子图中。
( R8 u' V+ ~0 G# ~$ q12.通过导数为 0 的点求最值:! l$ n6 h4 y7 `5 m; N' i. h
# Q; i$ l* o2 t) l+ J13.x0=solve('6*(x^2-1)^2*x=0','x');: 解一阶导数为 0 的方程,得到导数为 0 的点的 x 值。
- W4 Q, M! q# o* \- n4 m# d14.y0=subs(y,x,x0);: 将这些 x 值代入原函数 y 中,得到对应的 y 值。* j: G. h# X, {; N& f9 n3 @
15.[ymin1,n]=min(eval(y0));: 找到 y0 中的最小值及其索引。* Z& m: h/ r5 @4 `3 Z! S
16.xmin1=x0(n);: 得到对应的 x 值。/ h8 Q$ H" w$ q$ B2 k& G6 F h
17.通过 fminbnd 求函数最值:% k$ P# S5 ?+ J" v) `4 c
8 g, L k+ v1 H8 Z4 L
18.f=inline('(x^2-1)^3+1','x');: 定义一个匿名函数 f,表示原函数。9 B& T. ~+ o9 a5 t8 a' [6 y; v
19.xmin2=fminbnd(f,-1.5,1.5);: 在指定范围 [-1.5, 1.5] 上使用 fminbnd 函数求函数 f 的最小值点。+ J" N3 v6 R0 c
20.ymin2=f(xmin2);: 得到对应的最小值。/ N Z# f* |% q0 c' S
+ q, V2 q( C; m+ }1 U这段代码的目的是分别绘制原函数、一阶导数、和二阶导数的图像,并通过求导数为 0 的点和 fminbnd 函数分别找到函数的最小值及其对应的 x 值。
- X) I# e$ l# _) J) x, I! y: f* y9 E/ j) j+ z
5 U ]* w' S3 X' E# ?- S x. }
|
-
-
qiudao.m
725 Bytes, 下载次数: 0, 下载积分: 体力 -2 点
售价: 2 点体力 [记录]
[购买]
zan
|