plotting a beat frequency
조회 수: 26 (최근 30일)
이전 댓글 표시
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.
댓글 수: 0
채택된 답변
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
추가 답변 (0개)
참고 항목
카테고리
Help Center 및 File Exchange에서 Signal Processing Toolbox에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!