24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1461  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料专硕322 +7 哈哈哈吼吼吼哈 2026-04-05 7/350 2026-04-06 00:50 by fmesaito
[有机交流] 3-溴吡啶-4-甲醛合成 10+3 雪糕也能爆炸 2026-03-31 9/450 2026-04-06 00:24 by nBu锂
[考研] 一志愿苏州大学材料工程(085601)专硕有科研经历三项国奖两个实用型专利一项省级立项 +10 大火山小火山 2026-04-05 10/500 2026-04-05 19:58 by 小蜗牛小蜗牛
[考研] 一志愿9材料学硕297已过六级求调剂推荐 +11 adaie 2026-04-04 12/600 2026-04-05 19:04 by 蓝云思雨
[考研] 266分,一志愿电气工程,本科材料,求材料专业调剂 +8 哇呼哼呼哼 2026-04-02 9/450 2026-04-05 17:14 by lbsjt
[考研] 288求调剂 +7 没有答案_ 2026-04-05 7/350 2026-04-05 17:01 by yulian1987
[考研] 工科277分求调剂材料 +8 上了上了上哦 2026-04-05 9/450 2026-04-05 13:05 by wwytracy
[考研] 0832食品科学与工程学硕282调剂 +6 鱼在水中游a 2026-04-02 9/450 2026-04-05 11:45 by flysky1234
[考研] 一志愿西北农林畜牧专硕336分求调剂 +3 5ourr 2026-04-03 3/150 2026-04-05 10:40 by JOKER0401
[考研] 283求调剂 +10 A child 2026-04-04 10/500 2026-04-05 08:22 by qlm5820
[考研] 调剂 +11 JLLLLLLLLLL 2026-04-03 11/550 2026-04-04 22:21 by hemengdong
[考研] 283求调剂 +4 mcbbc 2026-04-03 5/250 2026-04-04 20:51 by imissbao
[考研] 348分环境工程·调剂 +10 吴彦祖24k 2026-04-03 11/550 2026-04-04 14:19 by 无际的草原
[考研] 268求调剂 +8 你好tg 2026-04-03 9/450 2026-04-04 05:08 by gswylq
[考研] 一志愿山东大学,085600,344 +7 魏子per 2026-04-02 8/400 2026-04-02 21:12 by 百灵童888
[考研] 一志愿北京科技材料科学与工程288分,求调剂 +14 是辰啊 2026-04-02 14/700 2026-04-02 21:10 by dongzh2009
[考研] 求调剂 +7 Aniyaio 2026-04-02 7/350 2026-04-02 16:42 by zzsw+
[考研] 08工科求调剂290分 +5 1314捧花 2026-04-02 8/400 2026-04-02 13:16 by 乔哒哒哒
[考研] 270调剂 +7 maxjxbsk 2026-04-02 7/350 2026-04-02 09:50 by yulian1987
[考研] 265求调剂 +11 yelck 2026-04-01 12/600 2026-04-01 19:12 by 549790059
信息提示
请填处理意见