Fitting data to integral function
古いコメントを表示
Hi everybody. I'm trying to fit an essemble of data ("r" as x and "texp" as y) by a function defined by an integral:
FC*integral(@(x)exp(-a./x.*log(x)),1,texp)
, were both "FC" and "a" are the parameters to fit, while "texp" are the upper integration limits, which must be equal to the "y" parameters at each point.
Thank you so much !
2 件のコメント
Torsten
2018 年 6 月 4 日
So you have data (xi,yi) that should be representable by
(texp(i),FC*integral(@(x)exp(-a./x.*log(x)),1,texp(i)))
?
Walter Roberson
2018 年 6 月 4 日
What should the expression equal?? Is it
texp = FC*integral(@(x)exp(-a./x.*log(x)),1,texp)
?
Where is your independent variable?
回答 (2 件)
Sergio Quesada
2018 年 6 月 4 日
0 投票
1 件のコメント
Walter Roberson
2018 年 6 月 4 日
Where is your independent variable appearing in the model? Is texp(r) intended to convey "the texp that corresponds to r", or is texp somehow intended to be both a function to be applied to r on the left side, but a particular numeric value on the right hand side where it is acting as the upper bounds of the integral ?
Or is texp(r) intended to be multiplication, as in
texp(K) * r(K) == FC * integral(@(x)exp(-a./x.*log(x), 1, texp(K))
and thus
texp(K) == FC / r(K) * integral(@(x)exp(-a./x.*log(x), 1, texp(K))
Sergio Quesada
2018 年 6 月 4 日
編集済み: Sergio Quesada
2018 年 6 月 4 日
0 投票
12 件のコメント
Walter Roberson
2018 年 6 月 4 日
If texp is your independent variable, then where does your dependent variable r appear? Is it
r = FC*integral(@(x) -a./(x*log(x)),1,texp)
Torsten
2018 年 6 月 4 日
So you have experimental data (r(i),texp(i)) and function values calculated according to
fun(i) = FC*integral(@(x) exp(-a./(x*log(x))),1,texp(i))
What are the data from your experiment that fun(i) should equal after optimizing a and FC ?
And please don't always open new "Answers" when you should add a Comment.
Sergio Quesada
2018 年 6 月 4 日
編集済み: Walter Roberson
2018 年 6 月 4 日
Torsten
2018 年 6 月 4 日
I still don't understand, but I'm sure "lsqcurvefit" or "lsqnonlin" can solve your problem.
Best wishes
Torsten.
Walter Roberson
2018 年 6 月 4 日
Okay, but where does r come into this? Is r the same as fun?
Sergio Quesada
2018 年 6 月 4 日
Walter Roberson
2018 年 6 月 4 日
Is fun(i) the same as texp(i) ?
texp(i) = FC*integral(@(x) exp(-a./(x.*log(x))),1,r(i))
Sergio Quesada
2018 年 6 月 4 日
編集済み: Sergio Quesada
2018 年 6 月 4 日
Walter Roberson
2018 年 6 月 4 日
What are class(r), class(texp), class(x0) ?
Sergio Quesada
2018 年 6 月 4 日
Walter Roberson
2018 年 6 月 4 日
fun = @(FCa, r) arrayfun(@(R) FCa(1) * integral(@(x) exp(-FCa(2)./(x.*log(x))), 1, R), r);
FCa = lsqcurvefit(fun, x0, r, texp);
FC = FCa(1); a = FCa(2);
Sergio Quesada
2018 年 6 月 4 日
カテゴリ
ヘルプ センター および File Exchange で Descriptive Statistics についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!