how to add harmonics to a sine wave ?

51 ビュー (過去 30 日間)
yuvi
yuvi 2011 年 5 月 17 日
コメント済み: Pham Duy Phuoc 2015 年 10 月 27 日
hi to all
i want to add to a sine wave (220volt and 50hz ) harmonics and to see them in a spectrum ( 50hz , 150hz ,250hz ....)
any suggestions ?
thanks
  1 件のコメント
Pham Duy Phuoc
Pham Duy Phuoc 2015 年 10 月 27 日
function y = harmonic(x,k)
% assumes that x is a column vector
assert(size(x,1) > 0);
assert(size(x,2) == 1);
% Interpolate by k and add k-th harmonic:
y = interp(x,k) + repmat(x,k,1);
end

サインインしてコメントする。

採用された回答

Arturo Moncada-Torres
Arturo Moncada-Torres 2011 年 5 月 17 日
Mmm, actually is very easy. Just add them to the original signal:
% Sampling
fs = 1000; % Sampling rate [Hz]
Ts = 1/fs; % Sampling period [s]
fNy = fs / 2; % Nyquist frequency [Hz]
duration = 10; % Duration [s]
t = 0 : Ts : duration-Ts; % Time vector
noSamples = length(t); % Number of samples
% Original signal
x = 220.*sin(2 .* pi .* 50 .* t);
% Harmonics
x1 = 100.*sin(2 .* pi .* 100 .* t);
x2 = 100.*sin(2 .* pi .* 200 .* t);
x3 = 100.*sin(2 .* pi .* 300 .* t);
% Contaminated signal
xn = x + x1 + x2 + x3;
% Frequency analysis
f = 0 : fs/noSamples : fs - fs/noSamples; % Frequency vector
% FFT
x_fft = abs(fft(x));
xn_fft = abs(fft(xn));
% Plot
figure(1);
subplot(2,2,1);
plot(t, x);
subplot(2,2,2);
plot(t, xn);
subplot(2,2,3);
plot(f,x_fft);
xlim([0 fNy]);
subplot(2,2,4);
plot(f,xn_fft);
xlim([0 fNy]);
Just some quick code. I tested it and it works.
Hope it helps ;-) . Keep coding!
  2 件のコメント
Arturo Moncada-Torres
Arturo Moncada-Torres 2011 年 5 月 17 日
Notice how the harmonics have an amplitude of 100 in order to be visualized in the spectrum plot. Otherwise, the original signal's magnitude (220) would be too big compared to the harmonics one.
yuvi
yuvi 2011 年 5 月 17 日
THANKS A LOT !

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeSpectral Measurements についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by