需求:利用matlab求解二元函数 y=f(x1,x2)
=(339-0.01*x1-0.003*x2)*x1 +(399-0.004*x1-0.01*x2)*x2-(400000+195*x1+225*x2) 的最大值
步骤:1、syms x1 x2;
2、y=(339-0.01*x1-0.003*x2)*x1+(399-0.004*x1-0.01*x2)*x2-(400000+195*x1+225*x2) 得 y = - 195*x1 - 225*x2 - x1*(x1/100 + (3*x2)/1000 - 339) - x2*(x1/250 + x2/100 - 399) - 400000
3、y=simple(y) 得 y = - x1^2/100 - (7*x1*x2)/1000 + 144*x1 - x2^2/100 + 174*x2 - 400000
4、求偏导 dydx1=diff(y,x1) 得 dydx1 = 144 - (7*x2)/1000 - x1/50 dydx2=diff(y,x2) 得 dydx2 = 174 - x2/50 - (7*x1)/1000
5、令偏导等于0,解方程 S=solve(dydx1,dydx2) 得 S = x1:[1x1 sym] x2:[1x1 sym]
6、显示结果 S.x1 得 ans = 554000/117 S.x2 得 ans = 824000/117
7、把得到的结果代入原f(x1,x2),求最大y值:
y=subs(y,x1,554000/117); y=subs(y,x2,824000/117) 得 y = 5.5364e+005
当然,该最大值是不是真正的最大值,还需要进一步结合实际情况验证(通过画出图形,观察二阶导数的符号等).比如,syms x1 x2; y=(339-0.01*x1-0.003*x2)*x1+(399-0.004*x1-0.01*x2)*x2-(400000+195*x1+225*x2);然后使用 ezsurf(y,[0 10000],[0 10000]);就可以得到三维的图形如下图所示:
可以看到,在感兴趣区间内,函数是有最大值的,即上面求出的y = 5.5364e+005,在x1=554000/117,x2=824000/117处取得.
matlab中,两个自变量的函数怎么求最大值(急!1)
matlab中,两个自变量的函数怎么求最大值(急!1)
请举例说明
请举例说明
其他人气:760 ℃时间:2019-08-21 07:50:36
优质解答
我来回答
类似推荐
猜你喜欢
- 1正方形abcd中ae=bf=cg=dh判断四边形efgh是什么特殊的四边形
- 2已知斜三棱柱ABC—A1B1C1中,AB=AC=a,∠BAC=90°,顶点A1在底面ABC上的射影M为BC的中点,且点M到侧面AA1B
- 3怎样用英语表示“年龄”
- 4现在,他正在公园里玩.英语怎么说?
- 5矿泉水一瓶1500毫升,山泉水一桶18升,一桶山泉水相当于多少瓶左图中的矿泉水?
- 6求函数y=2x3-3x2-12x+5在[0,3]上的最大值与最小值.
- 7射线OA上点了B、C、E三点,问有几条射线
- 8孔雀东南飞字的解释
- 9在平面直角坐标系中p关于x轴对称p1(2a+b-a+1)和关于y轴对称p2(4-b,b+2) p坐标为
- 10已知偶函数y=f(x)在点P(1,m)处的切线方程是y=2x-1,f′(x)是函数f(x)的导数,则f(-1)+f′(1)=( ) A.0 B.1 C.2 D.3