《DSP using MATLAB》Problem 8.15

Posted ky027wh-sx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了《DSP using MATLAB》Problem 8.15相关的知识,希望对你有一定的参考价值。

技术图片

      代码:

%% ------------------------------------------------------------------------
%%            Output Info about this m-file
fprintf(‘\\n***********************************************************\\n‘);
fprintf(‘        <DSP using MATLAB> Problem 8.15 \\n\\n‘);

banner();
%% ------------------------------------------------------------------------

Wp = 8*pi; Ws = 40*pi; Rp = 0.5; As = 45;
Fp = Wp/(2*pi);
Fs = Ws/(2*pi);

Ripple = 10 ^ (-Rp/20)
Attn = 10 ^ (-As/20)

% Analog filter design, DIRECT form:
[b, a] = afd(‘cheby1‘, Fp, Fs, Rp, As);
%[b, a] = afd_chb1(Wp, Ws, Rp, As);

% Calculation of second-order sections:
[C, B, A] = sdir2cas(b, a);

% Calculation of Frequency Response:
[db, mag, pha, ww] = freqs_m(b, a, 45*pi);

% Calculation of Impulse Response:
[ha, x, t] = impulse(b, a);


%% -------------------------------------------------
%%                    Plot
%% -------------------------------------------------  

figure(‘NumberTitle‘, ‘off‘, ‘Name‘, ‘Problem 8.15 Lowpass Analog Chebyshev-1‘)
set(gcf,‘Color‘,‘white‘); 
M = 1.0;                          % Omega max

subplot(2,2,1); plot(ww/pi, mag);  grid on; axis([-45, 45, 0, 1.2]);
xlabel(‘ Analog frequency in \\pi*1k units‘); ylabel(‘|H|‘); title(‘Magnitude in Absolute‘);
set(gca, ‘XTickMode‘, ‘manual‘, ‘XTick‘, [-45, -40, -8, 0, 8, 40, 45]);
set(gca, ‘YTickMode‘, ‘manual‘, ‘YTick‘, [0, 0.005, 0.94, 1]);

subplot(2,2,2); plot(ww/pi, db);  grid on; %axis([0, M, -50, 10]);
xlabel(‘Analog frequency in \\pi*1k units‘); ylabel(‘Decibels‘); title(‘Magnitude in dB ‘);
set(gca, ‘XTickMode‘, ‘manual‘, ‘XTick‘, [-45, -40, -8, 0, 8, 40, 45]);
set(gca, ‘YTickMode‘, ‘manual‘, ‘YTick‘, [-70, -45, -1, 0]);
set(gca,‘YTickLabelMode‘,‘manual‘,‘YTickLabel‘,[‘70‘;‘45‘;‘ 1‘;‘ 0‘]);

subplot(2,2,3); plot(ww/pi, pha/pi);  grid on; axis([-45, 45, -1.2, 1.2]);
xlabel(‘Analog frequency in \\pi*1k nuits‘); ylabel(‘radians‘); title(‘Phase Response‘);
set(gca, ‘XTickMode‘, ‘manual‘, ‘XTick‘, [-45, -40, -8, 0, 8, 40, 45]);
set(gca, ‘YTickMode‘, ‘manual‘, ‘YTick‘, [-1:0.5:1]);


subplot(2,2,4); plot(t, ha); grid on; %axis([0, 30, -0.05, 0.25]); 
xlabel(‘time in seconds‘); ylabel(‘ha(t)‘); title(‘Impulse Response‘);

  运行结果:

       通带、阻带绝对指标

技术图片

        模拟chebyshev-1型低通,系统函数直接形式

技术图片

        模拟低通,幅度谱、相位谱和脉冲响应

技术图片

      幅度谱通带部分放大后

技术图片

 

以上是关于《DSP using MATLAB》Problem 8.15的主要内容,如果未能解决你的问题,请参考以下文章

《DSP using MATLAB》Problem 5.7

《DSP using MATLAB》Problem 6.7

《DSP using MATLAB》Problem 6.8

《DSP using MATLAB》Problem 3.12

《DSP using MATLAB》Problem 4.17

《DSP using MATLAB》Problem 3.5