Problem in Calling a function in the custom equation for curve fitting

1 view (last 30 days)
I have defined a custom function to use it in curve fitting toolbox. In my defined function, I need to call another function "kkrebook2" which is in the file exchange and its inputs are vectors. But for defining a custom function we have a for loop of our x value and everything is defined in that for loop which means the input for "kkrebook2" will be elements of vector of x. So, it doesn't work when I try to fit because it is getting elements instead of vectors. Does anyone has a suggestion how can I write my custom function such that I can use "kkrebook2" and also use it for curvefitting?
This is related part of my code for the defined custom function for curve fitting and the "kkrebook2" function.
Thank you in advance!
function p = SCR(nu,numGaussians,a,sigma)
for i = 1:length(nu)
for k = 1 : numGaussians
if k==1
b = Start;
else
b = Start+(24E6 * (k-1));
end
thisGaussian(i) = a.*exp(-((nu(i)-b).^2)/(2.*(sigma.^2)));
% Add into accumulator array:
gaussEqn1(i) = gaussEqn1(i) + thisGaussian(i);
d(i)= gaussEqn1(i);
end
Imag(i)=(-log(d(i))*c)./(nu(i));
Real(i)=kkrebook2(nu(i),Imag(i),0);
f(i)=(-r1+r2*exp(-(d(i)).*exp(-1i*Real(i)));
g(i)=(1-r1*r2*exp(-(d(i))).*exp(-1i*Real(i)));
p(i)= abs(f(i)./g(i));
end
end
  1 Comment
Bala Tripura Bodapati
Bala Tripura Bodapati on 26 May 2022
Hi Shaily,
It is my understanding that an error is being encountered while fitting data using the custom defined function. Could you attach the code snippet where you are using curve fitting , along with information regarding the inputs that are being passed to the custom function like the dimensions and value?

Sign in to comment.

Answers (1)

Bala Tripura Bodapati
Bala Tripura Bodapati on 24 May 2022
Hi Shaily,
It is my understanding that you would like to call the function "kkrebook2" from custom defined function and the input to the function according to your code is an element of a vector rather than a vector.
The following code will illustrate how to call the function "kkrebook2" from your custom function with vector as input argument,assuming that 'nu' input argument in your custom defined function is a single-dimensional aray:
function p = SCR(nu,numGaussians,a,sigma)
for i = 1:length(nu)
for k = 1 : numGaussians
if k==1
b = Start;
else
b = Start+(24E6 * (k-1));
end
thisGaussian(i) = a.*exp(-((nu(i)-b).^2)/(2.*(sigma.^2)));
% Add into accumulator array:
gaussEqn1(i) = gaussEqn1(i) + thisGaussian(i);
d(i)= gaussEqn1(i);
end
end
Imag=(-log(d)*c)./(nu();
Real=kkrebook2(nu,Imag,0);
f=(-r1+r2*exp(-d).*exp(-1i*Real));
g=(1-r1*r2*exp(-(d)).*exp(-1i*Real));
p= abs(f./g);
end
  3 Comments

Sign in to comment.

Products


Release

R2022a

Community Treasure Hunt

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

Start Hunting!