Logarithmic amplitude scaling of a signal

7 次查看(过去 30 天)
I need to logarithmically scale the amplitude a sinesweep signal from at the starting frequency to at the lastest frequency (it should be 12 dB per octave).
Is this code wrong? Why if I plot the exponential shape and the scaled signal the profiles does not overlap?
duration_sweep = 2; % Seconds
% Sine sweep frequency range
f_start = 100;
f_end = 10000;
%--------------------------------------------
% Settings sweeptone
duration_final_silence_sweep = 0.1; % Secondi
total_duration_sweep = duration_sweep + duration_final_silence_sweep ;
sweep = sweeptone(duration_sweep,duration_final_silence_sweep,Fs,"SweepFrequencyRange",[f_start f_end]);
% Time axis
t_input = (0:numel(sweep)-1);
% Scaling factor
amp = logspace(log10(0.1*10^-3), log10(10), length(sweep));
% amplitude scaling
out = sweep.*amp';
% Plot
figure(1)
plot (out, 'LineWidth', 1.5)
hold on
plot(t_input, amp)
grid minor
  3 个评论
Jeffrey Clark
Jeffrey Clark 2023-2-13
@Lorenzo Lellini, you are also using the length of sweep four your amp but sweep includes the silence duration as indicated in sweeptone documentation.
Lorenzo Lellini
Lorenzo Lellini 2023-2-13
ok, thank you! I forgot to specify Fs but I had already considered it...
How can I perform the procuct between amp and the sweeptone in a correct way since I must specify a silence duration in the sweep and vectors must have the same length?

请先登录,再进行评论。

采纳的回答

Jeffrey Clark
Jeffrey Clark 2023-2-14
@Lorenzo Lellini, note that your curve is assuming a full scale sweep of +/- 1 whereas sweeptone produces +/- 0.5 so you need to plot 0.5*amp. And as in my comments above, you need to exclude fix(duration_final_silence_sweep*Fs) bins from the end of sweep.

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Octave 的更多信息

产品


版本

R2022b

Community Treasure Hunt

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

Start Hunting!

Translated by