How to calculate the integral of a function with a spline in it
Mostra commenti meno recenti
Hello Everybody,
So i have a function called FB, and it is the product of a couple of functions
nB = spline(Wavelength,B3);
emi = @(x) 1.989e-6*(10^9*x).^2-0.002;
FB = @(x,T) nB(x).*emi(x)./(x.^5.*(exp((h.*c)./(x.*k.*T))-1))
%integration:
RaBG(Counts) = integral(@(x)FB(x,T),400e-9,720e-9)
nB is a function i must adquire from data. When fitting it with a polinomial function i get a small error which i believe is making me get wrong results, though the code works. I'm trying to fit it with a spline but haven't been able to get the code to work. I also tryied calling FB as this, which didn't work:
FB = @(x,T) ppval(nB,x).*emi(x)./(x.^5.*(exp((h.*c)./(x.*k.*T))-1));
Can anyone please help me?
3 Commenti
Andrew Newell
il 21 Apr 2017
If your data are evenly spaced, you could skip the spline fit and integrate using one of the Newton-Cotes formulae.
Renan Kops
il 24 Apr 2017
John D'Errico
il 25 Apr 2017
I'd like to chime in here,but without knowing what wavelength, B3, and G3 are, it is impossible to give a useful answer.
Risposte (1)
Andrew Newell
il 24 Apr 2017
Modificato: Andrew Newell
il 24 Apr 2017
Interpolation is also reasonable. How exactly isn't the code working?
I don't see any values assigned to c, k or T. Are you doing that earlier? If so, it would make sense to define
FB = @(x) ppval(nB,x).*emi(x)./(x.^5.* (exp((h.*c)./(x.*k.*T))-1));
7 Commenti
Renan Kops
il 25 Apr 2017
Modificato: Renan Kops
il 25 Apr 2017
John D'Errico
il 25 Apr 2017
Andrew is correct hee. You just need to evaluate the spline correctly. spline does not return a function you can evaluate directly as NB(x). You need to use ppval as he did.
Note that using trapz will also increase the error.
Andrew Newell
il 25 Apr 2017
John, I'm not so sure that trapz will increase the error. Will an accurate integral of the spline be an accurate integral of the unknown function? Perhaps someone has analyzed this in the literature.
Renan Kops
il 25 Apr 2017
Andrew Newell
il 25 Apr 2017
Without the data, I can only guess. However, I notice that in the interval you're integrating over, you're dividing over the term
(x.^5.*(exp((h.*c)./(x.*k.*T))-1))
which is very small, so maybe you're dealing with numerical errors. Maybe you could rescale it so x is of order 1.
Renan Kops
il 25 Apr 2017
Andrew Newell
il 25 Apr 2017
I'm glad to know that the alternative methods are working!
Categorie
Scopri di più su Numerical Integration and Differentiation in Centro assistenza e File Exchange
Prodotti
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!