Curve fitting using a equation that involves a integral that isnt possible to solve analytically?

1 次查看(过去 30 天)
Hello there,
I'm trying from 2 days to curve fit some data that I have using this equation
f = @(x) ((x.^4) .* exp(x)) ./((exp(x)-1).^2);
gama*x + 9*R*((x/a)^3)*quad(f,0,a/x);
Here x is independent variable and a is unknown, gama is known. I tried the following procedure with the most success.
function C=myquad(a,T)
C = zeros(size(T));
gama = 20 * 1e-3;
R = 8.314;
f = @(x) ((x.^4) .* exp(x)) ./((exp(x)-1).^2);
for n = 1:length(T)
C(n) = gama*T(n) + 9*R*((T(n)/a)^3)*quad(f,0,a/T(n));
end
>>fit(T_0,C_0,fittype('myquad(a,x)'));
It returned following error
??? NaN computed by model function, fitting cannot continue. Try using or tightening upper and lower bounds on coefficients.
Error in ==> fit at 443 errstr = handleerr( errid, errmsg, suppresserr );
No idea what to do. Please guide..

采纳的回答

Sean de Wolski
Sean de Wolski 2011-7-8
dbstop if error
then inspect the variables being fed into your function. A good place to start at least.
  1 个评论
simar
simar 2011-7-8
thanks a lot i spotted out ..
i found that when i change the integral limits from 0 to 0.1 or so .. it is able to calculate. But I'm not sure whether my method for fit is right or not. I'm not getting the correct curves.

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 MATLAB 的更多信息

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by