1. Trang chủ
  2. » Luận Văn - Báo Cáo

digital signal processing laboratory transfer function and digital

30 0 0
Tài liệu đã được kiểm tra trùng lặp

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Tiêu đề Transfer Function and Digital Filter Design
Trường học International University
Chuyên ngành Digital Signal Processing
Thể loại Laboratory
Thành phố Ho Chi Minh City
Định dạng
Số trang 30
Dung lượng 618,5 KB

Cấu trúc

  • 1.1 Fourier Transform (7)
  • 1.2 Transfer Function (8)
  • 1.3 Resonator Filter (10)
  • 1.4 Hamming Window (11)
  • 2.1 Problem 1 (13)
  • 2.2 Problem 2 (21)
  • 2.3 Problem 3 (27)
  • 3.1 Results of Problem 1 (29)
  • 3.2 Results of Problem 2 (29)
  • 3.3 Results of Problem 3 (29)

Nội dung

VIETNAM NATIONAL UNIVERSITY – HO CHI MINH CITY INTERNATIONAL UNIVERSITY SCHOOL OF COMPUTER SCIENCE AND ENGINNERING Digital Signal Processing LaboratoryTRANSFER FUNCTION AND DIGITAL FILTE

Fourier Transform

 The Fourier transform is a mathematical function that decomposes a time-dependent waveform into frequencies The transform's output is a complex-valued frequency function.

In simpler words, the Fourier transform can help find the frequencies of a function in the time domain [1]

 For doing the Fourier transform, we will use the following formula [2] :

 Applying the Fourier transform to the square wave reveals its hidden frequency components It shows a series of vertical lines on a frequency axis, representing the different frequencies present in the signal Here is what it may look like:

Figure 1: Example of Fourier transform (taken from” Why Fourier series and transform of a square wave are different? - Signal Processing Stack Exchange”)

 Fourier transform has numerous applications in real-life and here are some of them:

Transfer Function

 A transfer function is defined as the ratio of the output Laplace transform to the input Laplace transform, assuming that all initial conditions are zero [3] It consists of seven different types: a) Impulse response b) Difference equation c) I/O Difference Equation d) Frequency response e) Block diagram of realization f) Sample Processing Algorithm g) Frequency Response and Pole/zero Pattern

 We have the direct form to do the transfer function which is:

Here by taking the z-transform of both sides of the equation we get:

 Transfer function can have many applications in real-life Here are some of them:

Resonator Filter

 A resonator filter, also known as a resonant filter or a resonant circuit, is a form of electrical filter that filters or amplifies certain frequencies using the idea of resonance.

 Resonator filters can be implemented using various electronic components and circuit configurations The most common types of resonator filters are based on LC (inductor- capacitor) circuits or RLC (resistor-inductor-capacitor) circuits The resonant frequency of the filter can be adjusted by varying the values of the inductors, capacitors, or resistors in the circuit.

 Let's consider an example of a resonator filter with a resonant frequency of 1 kHz The

LC circuit consists of an inductor with an inductance of 100 mH and a capacitor with a capacitance of 10 nF By using these values, we can calculate the resonant frequency using the formula:

Resonant frequency (f) Substituting the values: f ≈ 1591 Hz

So, in this example, the resonant frequency of the filter would be approximately 1.591 kHz.

 Here are some applications of resonator filter:

Hamming Window

 The Hamming window is a mathematical function used in signal processing and other applications to taper the edges of a signal, most notably in Fourier analysis.

 The mathematical expression for the Hamming Window is given by:

(Eq.3) where: is the value of the window at sample n

N is the total number of samples

By multiplying each sample of the signal by the corresponding sample by this formula:

 Some of the applications of Hamming Window

Problem 1

Code: a = [1,0.7,0.6]; b = [1,-1.5,0.9]; x = zeros(1,100); x(1) = 1; h = filter(b,a,x); h = h' stem(h) xlabel('n') b)

Code: close all; a = [1, 0.7, 0.6]; b = [1, -1.5, 0.9]; x = zeros(1, 100); x(1) = 1; h = filter(b, a, x); h = h';

% Plot pole-zero plot figure; zplane(b, a);

% Plot frequency response q = fftshift(fft(h)); subplot(2, 1, 1); plot(linspace(-pi, pi, length(q)), abs(q)); grid on; grid minor; xlim([-pi, pi]); title('Magnitude of Frequency Response'); ylabel('|H(e^{j \Omega})|'); xlabel('\Omega'); subplot(2, 1, 2); plot(linspace(-pi, pi, length(q)), 180/pi*angle(q)); grid on; grid minor; xlim([-pi, pi]); title('Angle of Frequency Response'); ylabel('\angle H(e^{j \Omega})'); xlabel('\Omega');

Problem 2

%Define the signal x = 2*sin(2*pi*f1*t*Ts) + sin(2*pi*f2*t*Ts) + 1.5*sin(2*pi*f3*t*Ts);

%Calculate the 2048-point FFT fft_2048 = fft(x,L);

%Calculate the magnitude spectrum mag_spec = abs(fft_2048)/L;

%Define freq axis f = linspace(0, Fs/2, L/2+1); figure; plot(f, mag_spec(1:L/2+1)); xlabel('Freq (Hz)'); ylabel('Magnitude spectrum (mag_spec)'); title('Magnitude spectrum of the signal with omega = 50 Hz'); xlim([0,200]); %Set limitation to 200 Hz

%define the min difference in the component freq delta_min_freq = min(f2-f1, f3-f2);

%Using formula to calculate the minimum number of samples

L_min = fs/delta_min_freq; disp(['Minimum number of samples to achieve sufficient freq (measured in samples): ', num2str(L_min)]);

% Plot the signal figure; subplot(2, 1, 1); ylabel('Amplitude'); title('Generated Signal'); grid on;

% Plot the magnitude spectrum subplot(2, 1, 2); plot(f, mag_spec(1:L/2+1)); xlabel('Frequency (Hz)'); ylabel('Magnitude Spectrum'); title('Magnitude Spectrum of the Generated Signal'); xlim([0, 200]); % Set limitation to 200 Hz grid on;

Minimum number of samples to achieve sufficient freq (measured in samples): 3000000 c)

%Hamming window hamming_window = 0.54-0.46*cos((2*pi*t)/(L-1)); x_hamming = x.*hamming_window;

%Calculate the FFT of the Hamming window fft_hamming = fft(x_hamming, L);

%Calculate the magnitude spectrum mag_spec_hamming = abs(fft_hamming)/L;

%Define freq axis f = linspace(0, fs/2, L/2+1);

% Plot the signal figure; subplot(3, 1, 1); plot(t, x); xlabel('Time (s)'); ylabel('Amplitude'); title('Generated Signal'); grid on;

% Plot the magnitude spectrum subplot(3, 1, 2); plot(f, mag_spec(1:L/2+1)); xlabel('Frequency (Hz)'); ylabel('Magnitude Spectrum'); title('Magnitude Spectrum of the Generated Signal'); xlim([0, 200]); % Set limitation to 200 Hz grid on;

% Plot the Hamming-windowed signal subplot(3, 1, 3); plot(t, x_hamming); xlabel('Time (s)'); ylabel('Amplitude'); title('Hamming-Windowed Signal'); grid on; figure;

% Plot the magnitude spectrum of the Hamming-windowed signal plot(f, mag_spec_hamming(1:L/2+1)); xlabel('Frequency (Hz)'); ylabel('Magnitude Spectrum'); title('Magnitude Spectrum of Hamming-Windowed Signal');

Problem 3

N = 500; fs = 500; % Sampling rate t = (0:N-1)/fs; % Time vector x = ecg(N); % Generate cardiogram signal noise = 0.1 * randn(size(x)); % Generate random noise y = x + noise; % Define function y(t)

% 4.a w_cut_off = 15; % Cut off freq n = 10; % Filter order

% Design the FIR low-pass filter h = fir1(n, w_cut_off/(fs/2), 'low');

% Plot the original and filtered signals figure; plot(t, y, 'b'); hold on; plot(t, filtered_y, 'r'); xlabel('Time (s)'); ylabel('Signal amplitude'); legend('Original signal', 'Filtered signal'); title('Noisy cardiogram signal and filtered signal');

Results of Problem 3

[1]: Stanford University (n.d.) Fourier Transform - GRU Retrieved from https://gru.stanford.edu/doku.php/tutorials/fouriertransform.

Ngày đăng: 24/07/2024, 16:04

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN