Solving a nonlinear equation with numerical integration

조회 수: 12 (최근 30일)
Michael Bond
Michael Bond 2017년 11월 30일
댓글: Michael Bond 2017년 12월 1일
Hello everybody,
I am pretty new in Matlab and struggling at the moment. I want to calculate two unknown parameters (x1 and x2) from two equations with integrals inside.
The Values P1, P2, S1, S2, C1, C2 are known and have the datatype double.
B(lambda) and e(lambda) are datasets (x,y) stored in arrays that describe the filter curves (also double).
Many thanks for your help.

답변 (1개)

Torsten
Torsten 2017년 11월 30일
편집: Torsten 2017년 11월 30일
First method:
1. Fit functions B1(lambda), B2(lambda), e1(lambda) and e2(lambda) to your data in the different ranges (500 to 550 and 600 to 650).
2. Call fsolve as
fun = @(x)[P1-S1*integral(@(lambda)B1(lambda).*e1(lambda).*(1-exp(-x(1)./lambda.^1.39)).*c1./(lambda.^5.*(exp(c2./(lambda*x(2)))-1)),500,550),P2-S2*integral(@(lambda)B2(lambda).*e2(lambda).*(1-exp(-x(1)./lambda.^1.39)).*c1./(lambda.^5.*(exp(c2./(lambda*x(2)))-1)),600,650)];
x0 = [1, 1];
xsol = fsolve(fun,x0)
Second method:
function main
S1 = ...;
S2 = ...;
P1 = ...;
P2 = ...;
l = ...;
e = ...;
B = ...;
x0 = [1, 1];
xsol = fsolve(@(x)fun(x,S1,S2,P1,P2,l,e,B),x0);
function res = fun(x,S1,S2,P1,P2,l,e,B)
interpe = @(lambda)interp1(l,e,lambda);
interpB = @(lambda)interp1(l,B,lambda);
funI = @(lambda)interpe(lambda).*interpB(lambda).*(1-exp(-x(1)./lambda.^1.39)).*c1./(lambda.^5.*(exp(c2./(lambda*x(2)))-1));
res = [P1-S1*integral(funI,500,550),P2-S2*integral(funI,600,650)];
Best wishes
Torsten.
  댓글 수: 10
Torsten
Torsten 2017년 12월 1일
편집: Torsten 2017년 12월 1일
Remove the two "end" statements in your code.
Remove the semicolon after
function res = fun(x,S1,S2,P1,P2,l,e,B1,B2);
Best wishes
Torsten.
Michael Bond
Michael Bond 2017년 12월 1일
I've did it, it says "All functions in a script must be closed with an 'end'."

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Creating and Concatenating Matrices에 대해 자세히 알아보기

제품

Community Treasure Hunt

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

Start Hunting!

Translated by