Damping and frequency from simulation data

28 Ansichten (letzte 30 Tage)
MM
MM am 31 Mär. 2020
Kommentiert: MD Riaz Pervez am 28 Apr. 2023
I have some simulation data, for example y in the attachment. I can manually calculate the damping and frequency with logarithmic decrement, but can I do this automated? I can't seem to figure out how.
And/or can I fit a nonlinear function through my datapoints? I tried polyfit but that doesn't work with time series.
  2 Kommentare
Ameer Hamza
Ameer Hamza am 2 Apr. 2020
How do you manually calculate the damping and frequency? Is there a mathematical formula? What type of nonlinear fit do you want to fit your data?
MM
MM am 3 Apr. 2020
I calculated it like they did here:
With damping:
And frequency:
What type of nonlinear fit? I don't know, any that will work. I was hoping a fit would maybe let me help to calculate the frequency and daming ratio

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Ameer Hamza
Ameer Hamza am 3 Apr. 2020
The following code automatically estimate the parameters from the signal.
load('PositionY_example.mat');
[val, locs] = findpeaks(y.Data);
peak_times = y.Time(locs);
t0 = t(locs(1));
tn = t(locs(2:end));
omega = mean((1:numel(tn))'./(tn-t0));
xt0 = val(1);
xtn = val(2:end);
delta = mean(log(xtn./xt0)./(1:numel(xtn))');
zeta = delta/sqrt(4*pi^2+delta^2);
As you already know the value of ω, δ, and ζ of your signal, you can calculate the nonlinear fit for your data using this equation.
  2 Kommentare
Maitham Alabbad
Maitham Alabbad am 8 Dez. 2021
What is variable t represent ?
t0 = t(locs(1));
tn = t(locs(2:end));
MD Riaz Pervez
MD Riaz Pervez am 28 Apr. 2023
t represent time. Here use t=Time therefore change that to make a single

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Linear Model Identification finden Sie in Help Center und File Exchange

Produkte


Version

R2018b

Community Treasure Hunt

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

Start Hunting!

Translated by