24小时热门版块排行榜    

查看: 1429  |  回复: 10

yuyi2009

铜虫 (小有名气)

[求助] matlab程序问题求解答

function[c,err,yc]=bisect(f,a,b,delta)
% Input  - f is the function input as a string 'f'
%        - a and b are the left and right endpoints
%        - delta is the tolerance
% Output - c is the zero
%        - yc = f(c)
%        - err is the error estimate for c
ya = feval(f,a);
yb = feval(f,b);
if ya * yb > 0, end
max1 = 1+ round((log(b-a)-log(delta))/log(2));
for k =1:max1
    c =(a+b)/2;
    yc = feval(f,c);
    if yc==0;
        a=c;
        b=c;
    elseif yb * yc > 0
        b=c;
        yb=yc;
    else
        a=c;
        ya=yc;
    end
    if b - a < delta, break, end
end
c=(a+b)/2;
err=abs(b-a);
yc=feval(f,c);     % 求函数在c处的函数值

for T=200:10:300
   K = exp(-9.3932+3204.71/T+0.835931*log(T)...
       +2.35267*10^-3*T-1.8736*10^-6*T^2+5.1606*10^-10*T^3)
   f=inline('(4*K-1)*x^2-8*K*x+4*K');
   bisect(f,0,1,10^-5)
end
主程序调用函数出错
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhg19

金虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
LZ详细描述一下问题。。。
2楼2013-11-24 17:21:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuyi2009

铜虫 (小有名气)

引用回帖:
2楼: Originally posted by zhg19 at 2013-11-24 17:21:08
LZ详细描述一下问题。。。

给了一个与温度相关的平衡方程,求200-300每隔10的平衡常数,以及平衡转化率。。。要求用二分法求解~
3楼2013-11-24 17:46:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhg19

金虫 (小有名气)

引用回帖:
3楼: Originally posted by yuyi2009 at 2013-11-24 17:46:06
给了一个与温度相关的平衡方程,求200-300每隔10的平衡常数,以及平衡转化率。。。要求用二分法求解~...

主要是程序出现的问题是什么呢
4楼2013-11-24 22:09:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuyi2009

铜虫 (小有名气)

引用回帖:
4楼: Originally posted by zhg19 at 2013-11-24 22:09:26
主要是程序出现的问题是什么呢...

main

K =

   26.5468

Error using inline/feval (line 23)
Not enough inputs to inline function.

Error in bisect (line 8)
ya = feval(f,a);

Error in main (line 5)
   bisect(f,0,1,10^-5)
5楼2013-11-24 22:21:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuyi2009

铜虫 (小有名气)

引用回帖:
4楼: Originally posted by zhg19 at 2013-11-24 22:09:26
主要是程序出现的问题是什么呢...

就是我声明的函数有K,被认为是变量,所以就少参数了。。。但是前面的K是可以求出来的~这个就不知道怎么弄了,它为什么不代进去啊~
6楼2013-11-24 22:22:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Bruce_lee

铜虫 (著名写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
yuyi2009: 金币+50, ★★★★★最佳答案, 再次感谢 2013-11-24 23:47:56
function problem_solve
%--------------------------------------------
disp('----------------分割线-----------------');
%--------------------------------------------
function[c,err,yc]=bisect(f,a,b,delta)
% Input  - f is the function input as a string 'f'
%        - a and b are the left and right endpoints
%        - delta is the tolerance
% Output - c is the zero
%        - yc = f(c)
%        - err is the error estimate for c
ya = feval(f,a);
yb = feval(f,b);
if ya * yb > 0, end
max1 = 1+ round((log(b-a)-log(delta))/log(2));
for k =1:max1
    c =(a+b)/2;
    yc = feval(f,c);
    if yc==0;
        a=c;
        b=c;
    elseif yb * yc > 0
        b=c;
        yb=yc;
    else
        a=c;
        ya=yc;
    end
    if b - a < delta, break, end
end
c=(a+b)/2;
err=abs(b-a);
yc=feval(f,c);     % 求函数在c处的函数值
end
%---------------------------------------------
function f=subfun(x,K)
f=(4*K-1).*x.^2-8*K.*x+4*K;
end
%---------------------------------------------
for T=200:10:300
   K = exp(-9.3932+3204.71/T+0.835931*log(T)...
       +2.35267*10^-3*T-1.8736*10^-6*T^2+5.1606*10^-10*T^3)
   [c,err,yc]=bisect(@(x)subfun(x,K),0,1,10^-5)
   disp('----------------分割线-----------------');
end
end


楼主,希望能帮助到你。
努力就有收获!
7楼2013-11-24 23:37:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Bruce_lee

铜虫 (著名写手)

【答案】应助回帖


xzhdty: 金币+1, 谢谢参与 2013-11-25 06:46:02
将这个代码保存为m文件,直接在命令窗口输入problem_solve即可。
努力就有收获!
8楼2013-11-24 23:41:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yuyi2009

铜虫 (小有名气)

引用回帖:
7楼: Originally posted by Bruce_lee at 2013-11-24 23:37:40
function problem_solve
%--------------------------------------------
disp('----------------分割线-----------------');
%--------------------------------------------
function=bisect(f,a,b,delta)
% ...

多谢~能顺便解释下为什么嘛~
9楼2013-11-24 23:47:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Bruce_lee

铜虫 (著名写手)

像这样有传递参数的情况,一般都是将需要求解的函数定义为“function f=函数名(x,k)”的形式,这里k为传递参数。用inlne()函数,给出的是函数的符号形式,有时就会出错。
努力就有收获!
10楼2013-11-25 15:34:54
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 yuyi2009 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考博] 东华理工大学化材专业26届硕士博士申请 +6 zlingli 2026-03-13 6/300 2026-03-15 20:00 by ryzcf
[考研] 080500,材料学硕302分求调剂学校 +4 初识可乐 2026-03-14 5/250 2026-03-14 21:08 by peike
[考研] 复试调剂 +4 z1z2z3879 2026-03-14 5/250 2026-03-14 16:30 by JourneyLucky
[考研] 一志愿哈工大材料324分求调剂 +5 闫旭东 2026-03-14 5/250 2026-03-14 14:53 by 木瓜膏
[考研] 211本,11408一志愿中科院277分,曾在中科院自动化所实习 +3 Losir 2026-03-12 3/150 2026-03-14 12:11 by 热情沙漠
[考研] 求调剂 +3 清风问长安 2026-03-09 3/150 2026-03-14 02:15 by JourneyLucky
[考研] 333求调剂 +3 球球古力 2026-03-09 3/150 2026-03-14 01:57 by JourneyLucky
[考研] 环境调剂 +6 晓看天暮看云 2026-03-09 6/300 2026-03-14 01:16 by JourneyLucky
[考研] 327求调剂 +4 Ffff03 2026-03-10 4/200 2026-03-14 00:17 by JourneyLucky
[考研] 材料工程,326分,求调剂 +6 KRSLSR 2026-03-10 6/300 2026-03-13 23:47 by JourneyLucky
[考研] 0703,333分求调剂 一志愿郑州大学-物理化学 +3 李魔女斗篷 2026-03-11 3/150 2026-03-13 22:24 by JourneyLucky
[考研] [0860]321分求调剂,ab区皆可 +4 宝贵热 2026-03-13 4/200 2026-03-13 22:01 by 星空星月
[考研] 求调剂 +5 一定有学上- 2026-03-12 5/250 2026-03-13 18:31 by ms629
[考研] 一志愿211化学学硕310分求调剂 +8 努力奋斗112 2026-03-12 9/450 2026-03-13 15:41 by JourneyLucky
[考研] 26考研求调剂 +5 丶宏Sir 2026-03-13 5/250 2026-03-13 13:05 by JourneyLucky
[考研] 321求调剂(食品/专硕) +3 xc321 2026-03-12 6/300 2026-03-13 08:45 by xc321
[考博] 26读博 +4 Rui135246 2026-03-12 10/500 2026-03-13 07:15 by gaobiao
[基金申请] 提交后的基金本子,已让学校撤回了,可否换口子提交 +3 dut_pfx 2026-03-10 3/150 2026-03-11 08:38 by kudofaye
[考研] 收调剂 +7 调剂的考研学生 2026-03-10 7/350 2026-03-10 17:57 by 麦茶汤圆
信息提示
请填处理意见