24小时热门版块排行榜    

查看: 805  |  回复: 9

YunPengWang

新虫 (初入文坛)

[求助] 求助 已有2人参与

各位大神,怎么用matlab解这个方程(求S)

求助


发自小木虫Android客户端
回复此楼

» 猜你喜欢

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

月只蓝

主管区长 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
m文件如下:
简便起见,我用的穷举法(肯定还有其他效率更高的方法)
参数f_number表示在区间内计算的次数,取整数,数值越大,计算精度越高,以下代码中取为10 000。
CODE:
function YunPengWang
clear;clc
format long
f_number=1e4;
B=2;
a=0.5;
f=0.5584;
F=0.0585E9;
s_all=linspace(4.001498e6,4.0015e6,f_number);
n=length(s_all);
for i=1:n
    s=s_all(i);

y(i)=F*f- (1+B/f/s)*log(1+f*s)/(  quadgk( @(x) exp(-x*(a^2+1))./(1+f*s*exp(-a^2*x))        ,0,Inf    ))  ;
end
plot(s_all,y,'b-',[min(s_all) max(s_all)],[0 0],'r-');

[y_min index]=min(abs(y));
residual_errory=y_min
s_ans=s_all(index)

计算结果:
方程残差 residual_errory =5.464069545269013e-04


待求参数s的数值 s_ans = 4.001498796679668e+06

» 本帖已获得的红花(最新10朵)

MATLAB、MS小问题、普通问题请发帖求助!时间精力有限,恕不接受无偿私信求助。
2楼2016-12-12 20:38:18
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

YunPengWang

新虫 (初入文坛)

送红花一朵
引用回帖:
2楼: Originally posted by 月只蓝 at 2016-12-12 20:38:18
m文件如下:
简便起见,我用的穷举法(肯定还有其他效率更高的方法)
参数f_number表示在区间内计算的次数,取整数,数值越大,计算精度越高,以下代码中取为10 000。

function YunPengWang
clear;clc
forma ...

如果F是一个范围呢?就是已知F范围(0.585e9~5.834e9),然后画出F与S关系图,穷举法是否可行?谢谢大神!

发自小木虫Android客户端
3楼2016-12-12 21:43:23
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

tuburfransth

金虫 (正式写手)

引用回帖:
2楼: Originally posted by 月只蓝 at 2016-12-12 20:38:18
m文件如下:
简便起见,我用的穷举法(肯定还有其他效率更高的方法)
参数f_number表示在区间内计算的次数,取整数,数值越大,计算精度越高,以下代码中取为10 000。

function YunPengWang
clear;clc
forma ...

你好,看到了你的回答我想问一下你怎么知道s_all的取值范围是在4.001498e6,4.0015e6之间?s_all=linspace(4.001498e6,4.0015e6,f_number);

发自小木虫Android客户端
4楼2016-12-12 22:25:36
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

pdl9527

专家顾问 (小有名气)

引用回帖:
4楼: Originally posted by tuburfransth at 2016-12-12 22:25:36
你好,看到了你的回答我想问一下你怎么知道s_all的取值范围是在4.001498e6,4.0015e6之间?s_all=linspace(4.001498e6,4.0015e6,f_number);
...

首先应该是个较大的范围,然后根据画图的结果人为进行缩小。
5楼2016-12-13 06:49:26
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

pdl9527

专家顾问 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
引用回帖:
3楼: Originally posted by YunPengWang at 2016-12-12 21:43:23
如果F是一个范围呢?就是已知F范围(0.585e9~5.834e9),然后画出F与S关系图,穷举法是否可行?谢谢大神!
...

CODE:
function question_12
%2016-12-13
clear;clc
B=2;
a=0.5;
f=0.5584;
%在值域内取20个F的值来求s
FF=linspace(0.585e9,5.834e9,20);
y=@(F) @(s) F*f- (1+B/f/s)*log(1+f*s)/(quadgk( @(x) exp(-x*(a^2+1))./(1+f*s*exp(-a^2*x)),0,Inf));
[s,fval,exitflag]=arrayfun(@(F) fsolve(y(F),1e8),FF);
%F和s的关系图像
plot(FF,s,'bo--');
xlabel('F');
ylabel('s')
%最大误差
max(abs(fval))

» 本帖已获得的红花(最新10朵)

6楼2016-12-13 07:23:54
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

YunPengWang

新虫 (初入文坛)

送红花一朵
引用回帖:
6楼: Originally posted by pdl9527 at 2016-12-13 07:23:54
function question_12
%2016-12-13
clear;clc
B=2;
a=0.5;
f=0.5584;
%在值域内取20个F的值来求s
FF=linspace(0.585e9,5.834e9,20);
y=@(F) @(s) F*f- (1+B/f/s)*log(1+f*s)/(quadgk( @(x) exp(-x*(a ...

好的,我回去试试!谢谢

发自小木虫Android客户端
7楼2016-12-13 08:01:14
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

YunPengWang

新虫 (初入文坛)

引用回帖:
6楼: Originally posted by pdl9527 at 2016-12-13 07:23:54
function question_12
%2016-12-13
clear;clc
B=2;
a=0.5;
f=0.5584;
%在值域内取20个F的值来求s
FF=linspace(0.585e9,5.834e9,20);
y=@(F) @(s) F*f- (1+B/f/s)*log(1+f*s)/(quadgk( @(x) exp(-x*(a ...

你好,我还想问一下,为什么求完S的值,回带的时候结果会不一样呢?

发自小木虫Android客户端
8楼2016-12-14 20:07:19
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

pdl9527

专家顾问 (小有名气)

引用回帖:
8楼: Originally posted by YunPengWang at 2016-12-14 20:07:19
你好,我还想问一下,为什么求完S的值,回带的时候结果会不一样呢?
...

不知道你指哪里不一样,你将下列代码加到程序的最末,可以看到将s(1)带到原方程中求得的F的值是5.8500e+08,和条件中给的F范围(0.585e9~5.834e9)中的第一个值完全吻合,同样你可以将s(20)带入,求得的结果和最后一个F的值是吻合的,说明程序没有问题。
CODE:
yy=@(s) (1+B/f/s)*log(1+f*s)/(f*quadgk( @(x) exp(-x*(a^2+1))./(1+f*s*exp(-a^2*x)),0,Inf));
feval(yy,s(1))

» 本帖已获得的红花(最新10朵)

9楼2016-12-14 20:26:10
已阅   关注TA 给TA发消息 送TA红花 TA的回帖

YunPengWang

新虫 (初入文坛)

送红花一朵
引用回帖:
9楼: Originally posted by pdl9527 at 2016-12-14 20:26:10
不知道你指哪里不一样,你将下列代码加到程序的最末,可以看到将s(1)带到原方程中求得的F的值是5.8500e+08,和条件中给的F范围(0.585e9~5.834e9)中的第一个值完全吻合,同样你可以将s(20)带入,求得的结果和最后一 ...

错误找到了,谢谢大神!!!

发自小木虫Android客户端
10楼2016-12-14 21:53:26
已阅   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 YunPengWang 的主题更新
信息提示
请填处理意见