Approximate experimental data from multiple cells
Show older comments
Hello. I have several cell arrays with probe data from .mat-file.
I need to find resonance frequencies and q-factors for each of the 1000 inputs, and then estimate (approximate) them. However, the code below provides only 1 value of fres instead of 1000, and no plot for (i, fres) is shown. (I attached a frequency-amplitude plot)
- FStart - cell array (1000*1)
- FEnd - cell array (1000*1)
- Amp - multiarray (1000*100)
for i = 1:1:1000
f1 = FStart(i):10:FEnd(i);
grid on
y1 = plot(f1,Amp(i,:));
[maxValue, maxIndex] = max(Amp(i,:)); %find maximum value of amplitude for each i
[Q_Value, Q_Index] = max(0.5*AmpA2(i,:)); %also tried 0.5*max() and /2
fres = f1(maxIndex); %by index of max amplitude value find resonance frequency
plot(i,fres) %plot resonance frequency for each i
hold on
end
NB: the last FStart value is less than the first FreqEnd value
Futhermore, I try to esteem the Q factor as: Max(frequency on level = 1/2*MaxAmplitude)-Min(frequency on level = 1/2*MaxAmplitude)
fmin = min(f1(Q_Index))
fmax = max(f1(Q_Index))
But it shows fmin = fmax
Could you please tell, what's the problem here?
3 Comments
KSSV
on 12 Jul 2017
YOu have not shown what is f2 ? And the question is based on f2.
Elaine Carroll
on 12 Jul 2017
Guillaume
on 12 Jul 2017
You say that FStart and Fend are cell arrays, yet your code has
f1 = FStart(i):10:FEnd(i);
which would cause an error if they were indeed cell arrays. Are they actually just plain matrices (in this case vectors)?
Answers (1)
But it shows fmin = fmax Well, of course. I don't understand what you're trying to do but you have:
[Q_Value, Q_Index] = max(0.5*AmpA2(i,:))
fmin = min(f1(Q_Index))
fmax = max(f1(Q_Index))
so AmpA2(i, :) is a column vector from which you're taking the maximum and its location Q_index. There is only ever one Q_Index value returned by max. Therefore f1(Q_Index) is a scalar value. The minimum and maximum of a single value is the same: that single value.
Also: see comment to the question, above, about the cell arrays.
1 Comment
Elaine Carroll
on 12 Jul 2017
Edited: Elaine Carroll
on 12 Jul 2017
Categories
Find more on Loops and Conditional Statements in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!