필터 지우기
필터 지우기

plotting a beat frequency

조회 수: 26 (최근 30일)
justin stephens
justin stephens 2018년 2월 7일
댓글: Star Strider 2018년 2월 7일
well folks i am having an issue with plotting a beat frequency fc is the central freq, fdel is the freq deviation, F is the sampling rate, and dur is the duration. here is the code.
if true
% code
end
function x = beatfreq(fc,fdel,F,dur)
t = [0:F:dur]; % time index
x = cos(2*pi*(fc+fdel)*t)+ cos(2*pi*(fc-fdel)*t);
plot(t,x); % plot signal
axis([0 127 -20 20]);
title('Sinusoidal signal x(t)');
xlabel('Time t (sec)');
ylabel('Amplitude');
grid on;
sound(x);
end
the problem i am having is that there is no plot in the figure or no sound. so would one of you more knowledgeable folks steer me in the right direction? also please ignore the if true %code end, that is not part of the code.

채택된 답변

Star Strider
Star Strider 2018년 2월 7일
You need to tweak your function just a bit, changing sound to soundsc, and add the sampling frequency to it as the second argument. Note that ‘F’ is the sampling interval in the context of the way you have assigned ‘t’, not the sampling frequency.
Try this:
function x = beatfreq(fc,fdel,F,dur)
t = [0:F:dur]; % time index
x = cos(2*pi*(fc+fdel)*t)+ cos(2*pi*(fc-fdel)*t);
plot(t,x); % plot signal
axis([0 127 -20 20]);
title('Sinusoidal signal x(t)');
xlabel('Time t (sec)');
ylabel('Amplitude');
grid on;
soundsc(x, 1/F);
end
Call it as:
z = beatfreq(3000, 500, 0.001, 15);
to see and hear it work correctly.
  댓글 수: 6
justin stephens
justin stephens 2018년 2월 7일
its fine, i figured it out. i wasn't using F correctly. i finally have it working. thank you for the help thought!
Star Strider
Star Strider 2018년 2월 7일
As always, my pleasure!

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Signal Processing Toolbox에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by