MATLAB实例讲解求二元函数的极值
实例
程序 clc; clear all; close all; %计算二元函数的极值点 并进行判断 syms x y %定义二元变量 x y z = (6*x-x^2)*(4*y-y^2);%定义二元变量函数 f1 = simplify(diff(z,x));%求z对x的一阶偏导 f2 = simplify(diff(z,y));%求z对y的一阶偏导 %求f1 = 0 f2 = 0 % [x1,y1] = solve(y*(2*x - 6)*(y - 4)==0,x*(2*y - 4)*(x - 6)==0,x,y); %求二元函数的驻点(x1,y1) [x1,y1] = solve(f1==0,f2==0,x,y); %求二元函数的驻点(x1,y1) x1 = double(x1); %将sym个数转化为double数值格式 y1 = double(y1);%将sym个数转化为double数值格式 n = length(x1);%求长度 %输出驻点个数 fprintf("二元函数z=f(x,y)的驻点个数为n =%dr ",n); %输出驻点坐标 for i = 1:n fprintf("二元函数z=f(x,y)的第%d个驻点为(x,y)=(%f,%f)r ",i,x1(i),y1(i)); end %幅值A,B,C为空矩阵 A = []; B = []; C = []; for i = 1:n %sub函数用来替换求解函数的具体某点的值和double函数将sym个数转化为double数值格式 temp = double(subs(diff(z,x,2),[x y],[x1(i) y1(i)])); %计算A temp1 = double(subs(diff(f1,y,1),[x y],[x1(i) y1(i)]));%计算B temp2 = double(subs(diff(z,y,2),[x y],[x1(i) y1(i)]));%计算C A = [A;temp];%存储A的计算结果 B = [B;temp1];%存储B的计算结果 C = [C;temp2];%存储C的计算结果 end %根据AC-B^2结果判断 若(x,y)计算值大于0,则存在极值点,反之不存在若A>0,则为极小值点,A<0,则为极大值点 R = A.*C-B.^2; %判断 for i = 1:n if R(i)>0 if A(i)>0 %用subs函数计算极值点处的函数值,然后用double函数将sym格式化成数值格式 ymax = double(subs(z,[x y],[x1(i) y1(i)])); fprintf("二元函数z=f(x,y)的第%d个驻点(x,y)=(%f,%f)为极小值点,极小值为:%fr ",i,x1(i),y1(i),ymax); else ymin = double(subs(z,[x y],[x1(i) y1(i)])); fprintf("二元函数z=f(x,y)的第%d个驻点(x,y)=(%f,%f)为极大值点,极大值为:%fr ",i,x1(i),y1(i),ymin); end else fprintf("二元函数z=f(x,y)的第%d个驻点(x,y)=(%f,%f)不是极值点r ",i,x1(i),y1(i)); end end
结果 二元函数z=f(x,y)的驻点个数为n =5 二元函数z=f(x,y)的第1个驻点为(x,y)=(0.000000,0.000000) 二元函数z=f(x,y)的第2个驻点为(x,y)=(0.000000,4.000000) 二元函数z=f(x,y)的第3个驻点为(x,y)=(6.000000,0.000000) 二元函数z=f(x,y)的第4个驻点为(x,y)=(3.000000,2.000000) 二元函数z=f(x,y)的第5个驻点为(x,y)=(6.000000,4.000000) 二元函数z=f(x,y)的第1个驻点(x,y)=(0.000000,0.000000)不是极值点 二元函数z=f(x,y)的第2个驻点(x,y)=(0.000000,4.000000)不是极值点 二元函数z=f(x,y)的第3个驻点(x,y)=(6.000000,0.000000)不是极值点 二元函数z=f(x,y)的第4个驻点(x,y)=(3.000000,2.000000)为极大值点,极大值为:36.000000 二元函数z=f(x,y)的第5个驻点(x,y)=(6.000000,4.000000)不是极值点
1、diff函数
差分和近似导数语法 Y = diff(X) Y = diff(X,n) Y = diff(X,n,dim) 说明 示例 Y = diff(X) 计算沿大小不等于 1 的第一个数组维度的 X 相邻元素之间的差分: 如果 X 是长度为 m 的向量,则 Y = diff(X) 返回长度为 m-1 的向量。Y 的元素是 X 相邻元素之间的差分。 Y = [X(2)-X(1) X(3)-X(2) ... X(m)-X(m-1)] 如果 X 是不为空的非向量 p×m 矩阵,则 Y = diff(X) 返回大小为 (p-1)×m 的矩阵,其元素是 X 的行之间的差分。 Y = [X(2,:)-X(1,:); X(3,:)-X(2,:); ... X(p,:)-X(p-1,:)]
如果 X 是 0×0 的空矩阵,则 Y = diff(X) 返回 0×0 的空矩阵。X = [1 1 2 3 5 8 13 21]; Y = diff(X)Y = 1×7 0 1 1 2 3 5 8
请注意,Y 的元素比 X 少一个。
使用 diff 函数和语法 Y = diff(f)/h 求偏导数近似值,其中 f 是函数值在某些域 X 上计算的向量,h是一个相应的步长大小。
例如,sin(x) 相对于 x 的第一个导数为 cos(x),相对于 x 的第二个导数值为 -sin(x)。可以使用 diff 求这些导数的近似值。 h = 0.001; % step size X = -pi:h:pi; % domain f = sin(X); % range Y = diff(f)/h; % first derivative Z = diff(Y)/h; % second derivative plot(X(:,1:length(Y)),Y,"r",X,f,"b", X(:,1:length(Z)),Z,"k")
在此绘图中,蓝色线条对应原始函数 sin。红色线条对应计算出的第一个导数 cos,黑色线条对应计算出的第二个导数 -sin。 syms x; diff(sin(x^2)) ans = 2*x*cos(x^2)syms x t; diff(sin(x*t^2), t) ans = 2*t*x*cos(t^2*x)
给定函数f(x)=cosx/(x 3+7x+2)的一阶导数,并将每个点上的值与原函数的值通过matlab函数绘制出来. 一阶导数 syms x; f=cos(x)/(x^3+7*x+2); f1d=diff(f,x) pretty(f1d)
2、solve函数 简单来说,solve函数可以进行以下情况的求解: (1)等式:单/多变量+线性/非线性 ;(2)不等式 语法 S = solve(eqn,var)example S = solve(eqn,var,Name,Value)example Y = solve(eqns,vars) Y = solve(eqns,vars,Name,Value)example [y1,...,yN] = solve(eqns,vars)example [y1,...,yN] = solve(eqns,vars,Name,Value) [y1,...,yN,parameters,conditions] = solve(eqns,vars,"ReturnConditions",true)example Description 一些函数 vpa 设置数值的精度(有效数字位数、保留的小数点位数) subs 符号替换(用数字来替换符号变量) ezplot 简单地画出函数的图形/曲线(显函数fun(x)、隐函数fun2(x,y)=0) isAlways 一个判断函数(返回logical 1,表示true) pretty 漂亮地打印符号表达式(看起来是有分子分母的格式) 举例 1.%% 求解单变量方程 %-----例子1------ syms x eqn=sin(x)==1; solve(eqn,x) %-----例子2------ syms x eqn=sin(x)==1; [solx,params,conds]=solve(eqn,x,"ReturnConditions",true) %-----例子3--------------- %如果返回empty,则表明解不存在。如果返回empty+warning,则解可能存在,但是solve找不到 syms x solve(3*x+2,3*x+1,x)2.%% 求解多变量方程 %---例1----------------- %为了避免求解方程时对符号参数产生混乱,需要指明一个等式中需要求解的变量。 %如果不指明的话,solve函数就会通过symvar选择一个变量(认为该变量是要求解的变量)clc,clear syms a b c x sola=solve(a*x^2+b*x+c==0,a) %待求解的变量是a sol=solve(a*x^2+b*x+c==0) %待求解的变量是x
3、subs函数 matlab中subs()是符号计算函数,表示将符号表达式中的某些符号变量替换为指定的新的变量,常用调用方式为: subs(S,OLD,NEW) 表示将符号表达式S中的符号变量OLD替换为新的值NEW。 下面具体演示4种不同形式的OLD和NEW的调用效果: 首先在matlab命令窗口输入如下代码,定义三个符号变量和一个符号表达式S 1、将变量x替换为数值1:subs(S,x,1) 2、将变量x替换为变量z:subs(S,x,z) 3、同时将变量x和y分别替换为1和z:subs(S,{x,y},{1,z}) 4、将单变量替换为数组:subs(S,x,[1 2;3 4]) 首先是调用格式: R = subs(S) R = subs(S, new) R = subs(S, old, new) 其中S为符号表达式,默认的是变量x!
下面看几个例子,相信大家就是使用了!
例1: >> syms x; >> f=x^2; >> subs(f,2)ans = 4
例2:将表达式x^2+y^2中x取值为2 >> syms x y; >> f=x^2+y^2; >> subs(f,x,2)ans = y^2 + 4
例3: >> syms x y; >> f=x^2+y^2; >> subs(f,findsym(f),2)ans = y^2 + 4
其中findsym(f)为查找f中所有的符号变量
例4:同时对两个或多个变量取值求解 >> syms a b; subs(cos(a) + sin(b), {a, b}, {sym("alpha"), 2})ans = sin(2) + cos(alpha)
例5:带入数据的值也可以是数组形式 >> syms t a; >> subs(exp(a*t), "a", -magic(2))ans = [ 1/exp(t), 1/exp(3*t)] [ 1/exp(4*t), 1/exp(2*t)]
4、符号表达式化简函数 语法:命令(符号表达式) 1. pretty(f)将符号表达式f化简成语高等代数课本上显示符号表示类似; 2. collect(f)合并符号表达式的同类项; 3. hornet(f)将一般的符号表达式转换成嵌套形式的符号表达式; 4. factor(f)对符号表达式进行因式分解; 5. expand(f)对表达式进行展开; 6. simplify(f)对符号表达式进行化简,利用各种类型的恒等式,包括求和,求积分,三角函数以及Bessel函数等简化符号表达式. 7. simple(f)对符号表达式尝试各种不同的算法进行化简,以显示长度最短的符号表达式简化形式; 8. [r,how]=simple(f)返回的r为符号表达式进行化简后的形式,how为采用的简化方法
本文内容来源于网络,仅供参考学习,如内容、图片有任何版权问题,请联系处理,24小时内删除。
作 者 | 郭志龙
编 辑 | 郭志龙
校 对 | 郭志龙
如果你我一生都不会再见(原创)郝有花如果你我一生都不会再见从花开到花落从擦肩而过的那一秒起没有遇见只有思念的种子在风里游荡我想知道你会不会怨我怨我是一个冷清的人?把寂寞放在指尖弹奏尘封的过往,从此只是一个陌生相
年过五十,不管混得好不好,都别跟三种人联系了,真没必要人们都说五十岁知天命,一个人走过了五十载的岁月,必然沉淀了许多的人生经验,对生活也有了一定感悟。虽然年过半百,但往后的时光仍需经营。年过五十要知道,有些人不值得交往,不要在不值得的
二月二龙抬头,别忘了吃3道头菜,寓意一年开个好头导语二月二龙抬头,别忘了吃3道头菜,寓意一年开个好头。大家好我是傻姐美食,生活中唯有美食和美景不可辜负。元宵节过后还有一个重要的节日二月二,二月二龙抬头,龙不抬头我抬头,小时候不知
系红绳的胶州大白菜系着红丝带的胶白。王昭脉摄光明图片国家地理标志产品探秘大概是物以稀为贵吧。北京的白菜运往浙江,便用红头绳系住菜根,倒挂在水果店头,尊为胶菜。鲁迅先生在藤野先生一文中提到的胶菜,其实
羊肚菌为名贵食药用真菌一种状如羊肚,有蜂窠眼者珍馐羊肚菌是羊肚菌属真菌的统称,又称羊肚蘑蜂窝蘑羊肚菜阳省菌包谷菌谷谷哈木等,属子囊菌亚门盘菌纲盘菌目羊肚菌科羊肚菌属真菌。包括黑色羊肚菌黄色羊肚菌变红羊肚菌半开羊肚菌4个类群,我国栽
20元一瓶的牛栏山,年销过百亿,明明知道是酒精酒,为何都在买?年销能过百亿的白酒有哪些?茅台五粮液这些都不用说了,人家压根不愁销量,加上本身单价就高,轻轻松松过百亿。但是谁能想到,20元一瓶的牛栏山一年也能卖出上亿瓶,总营收也超过了百亿级别。
关于朝鲜平壤的45个冷知识,你都知道几个?平壤是朝鲜的首都,这里也是一座历史古城,旧称柳京意为柳树茂盛的地方,现在是朝鲜的政治经济文化中心,人口有325万1平壤有一条江叫大同江,江上有一个酷似羊角的岛屿叫做羊角岛,这里有全
冬季版舞剧长恨歌西安年又火了一把惊艳出圈的背后除了付出还是付出刚刚过去的西安年中,每天晚上,骊山脚下,骊宫焕彩寒冰倒挂沐雪起舞,光影和火焰特效照亮夜空,冬季版的冰火长恨歌踏雪而来,为观众带来精彩的唐风视觉盛宴。日前,记者走进长恨歌剧组,了解他
地理冷知识浙江绍兴嵊州在浙江绍兴,有一个历史悠久人文荟萃的小县城嵊州,秦汉时期这里就已建县,称剡,唐初设嵊州。嵊州母亲河剡溪穿城而过,剡溪之于会稽(绍兴),正如终南山之于长安。400多位唐代诗人留下了1
那些长期喝咖啡的人,现在都怎样了?随着咖啡文化的不断普及,越来越多的人开始喝咖啡,甚至成为他们日常生活中必不可少的一部分。然而,长期以来,咖啡一直被认为是一种不健康的饮品,特别是对于那些长期饮用咖啡的人。那么,那些
正式官宣!山西男篮两大强援加盟,杨学增征召夺冠班底北京时间2月20日,根据山西男篮的官方社交媒体透露,除了外界关注的西蒙斯正式回归到球队,还有上个赛季效力山东男篮的老牌后卫王汝恒,他将会以自由球员的身份加盟到山西男篮,这就意味着前