Fit Multiple gaussian curve on data with flat tops

How to fit double gaussian curve for this data set which is flat at some domains?

2 Kommentare

Would you please give out all data in a file?
Umar
Umar am 3 Jul. 2024
Hi Alex,
Due to limited resources and being poor, this is the best I can do at the moment. Hope you understand my point.

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Umar
Umar am 3 Jul. 2024

0 Stimmen

Hi Amit,

You asked, How to fit double gaussian curve for this data set which is flat at some domains?

To answer your question, use the fit function along with a custom equation that represents the double Gaussian curve. I can provide a basic example to get you started:

I will generate example data with two Gaussian peaks and some noise.

>> % Generate example data x = linspace(0, 10, 100); y = 2*exp(-(x-3).^2) + 1.5*exp(-(x-7).^2) + 0.5*randn(size(x));

Use the fit function with the gauss2 model to fit the double Gaussian curve to the data.

% Fit a double Gaussian curve f = fit(x', y', 'gauss2');

Finally, plot the original data points along with the fitted curve for visualization.

% Plot the data and the fitted curve plot(x, y, 'o') hold on plot(f, x, y) legend('Data', 'Fitted Curve')

For more information on fit function, please refer to

https://www.mathworks.com/help/curvefit/fit.html

Hope this will help resolve your problem.

For a double-hump data with plateaux, you can try fitting it using two Exponential Power distribution functions. Let's take a look at how the function looks like:
x = -5:0.01:5;
a = 1;
b = 1/sqrt(2);
c = 1/sqrt(2);
d = 0;
e = 8; % exponent (in Gaussian, e = 2)
y = a*exp(-((x - (-c))/b).^e) + a*exp(-((x - c)/b).^e) + d;
plot(x, y, 'r.'), grid on, axis([-6 6, -0.2 1.2]), xlabel('x'), ylabel('y')
title('Double-hump with plateaux')

Kategorien

Mehr zu Get Started with Curve Fitting Toolbox finden Sie in Hilfe-Center und File Exchange

Produkte

Version

R2024a

Gefragt:

am 3 Jul. 2024

Beantwortet:

am 3 Jul. 2024

Community Treasure Hunt

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

Start Hunting!

Translated by