File:Frequency response of 3-term boxcar filter.svg

原始檔案(SVG 檔案,表面大小:416 × 400 像素,檔案大小:20 KB)


摘要

描述
English: Frequency response (discrete time Fourier transform) of a 3-tap boxcar filter. To produce these plots, samples of the DTFT are obtained by computing the DFT of the zero-filled impulse response. Alternatively, one can directly sample the closed form of the DTFT:   and plot the magnitude and angle of the samples. (See File:MA2Amp_C.svg)
Note: At the two frequencies where the magnitude goes to zero, there are phase discontinuities of π radians. They are not artifacts of phase wrapping. Rather, they indicate a sign inversion... multiplication by -1. Since that is equivalent to an amplitude modification, it does not affect the filter's property of phase linearity. An illustration of that can be viewed at File:Amplitude & phase vs frequency for 3-term boxcar filter.svg.
日期
來源 自己的作品
作者 original: Bob K
vector version: Krishnavedala
授權許可
(重用此檔案)
我,本作品的著作權持有者,決定用以下授權條款發佈本作品:
Creative Commons CC-Zero 此檔案在創用CC CC0 1.0 通用公有領域貢獻宣告之下分發。
在此宣告之下分發本作品者,已依據各國著作權法,在全世界放棄其對本作品所擁有的著作權及所有相關相似的法律權利,從而將本作品貢獻至公有領域。您可以複製、修改、分發和演示該作品,用於任何商業用途,所有這些都不需要請求授權。

其他版本 本檔案衍生自: Frequency response of 3-term boxcar filter.gif
SVG開發
InfoField
 
SVG檔案的原始碼通過W3C驗證
Python source
InfoField
click to expand

This script is a translation of the original Octave script into Python, for the purpose of generating an SVG file to replace the GIF version.

import scipy
from scipy import signal
import numpy as np
from matplotlib import pyplot as plt
plt.rcParams['svg.fonttype'] = 'none'

N = 256
h = np.array([1., 1., 1.]) / 3
H = scipy.fftpack.shift(scipy.fft(h, N), np.pi)
w = np.linspace(-N/2, N/2-1, num=N) * 2 * np.pi / N

fig = plt.figure(figsize=[5,5])
plt.subplot(211)
plt.plot(w, np.abs(H), 'blue')
plt.grid(True)
plt.ylabel('Magnitude')
plt.xlim([-np.pi,np.pi])
plt.xticks([-np.pi, -2*np.pi/3,0,2*np.pi/3,np.pi], [])
plt.subplot(212)
plt.plot(w, np.angle(H), 'blue')
plt.grid(True)
plt.ylabel('Phase (radians)')
plt.xlabel('$\\longleftarrow$ Frequency ($\\omega$) (radians/sample) $\\longrightarrow$')
plt.xticks([-np.pi, -2*np.pi/3,0,2*np.pi/3,np.pi], ['-$\pi$','-2$\pi$/3','0','2$\pi$/3','$\pi$'])
plt.xlim([-np.pi,np.pi])
plt.yticks([-np.pi, -2,-1,0,1,2,np.pi], ['-$\pi$','-2','-1','0','1','2','$\pi$'])
plt.ylim([-np.pi,np.pi])
plt.subplots_adjust(hspace=0.1)
plt.savefig('Frequency response of 3-term boxcar filter.svg', bbox_inches='tight', transparent=True)
Octave/gnuplot source
InfoField
click to expand
This script was derived from the original in order to address some GNUplot bugs: a missing title and two missing axis labels.  And to add an Octave print function, which creates an SVG file.  Alternatively, the gnuplot screen image has an export function that produces an SVG file, but the π characters aren't as professional-looking.  I think the resultant quality produced by this script is now better than the file produced by the Python script.
graphics_toolkit gnuplot
clear all; close all; clc
  
hfig = figure("position",[100 100 509 509]);

x1 = .12;               % left margin for name of Y-variable
x2 = .02;               % right margin
y1 = .10;               % bottom margin for ticks
y2 = .08;               % top margin for title
dy = .08;               % vertical space between rows

width = 1-x1-x2;
height= (1-y1-y2-dy)/2; % space allocated for each of 2 rows

x_origin = x1;
y_origin = 1;           % start at top of graph area
%=======================================================
  N= 256;
  h = [1 1 1]/3;              % impulse response
  H = fftshift(fft(h,N));     % samples of DTFT
  abscissa = (-N/2:N/2-1)*2*pi/N;  % normalized frequency
%=======================================================
  y_origin = y_origin -y2 -height;        % position of top row
  subplot("position",[x_origin y_origin width height])
  plot(abscissa, abs(H), "linewidth",2);
  xlim([-pi pi])
  ylim([0 1.2])
  set(gca, "XTick", [-pi -2*pi/3 0 2*pi/3 pi])
  set(gca, "YTick", [0 .2 .4 .6 .8 1])
  grid("on")

  ylabel("Magnitude")
% set(gca, "ticklabelinterpreter", "tex")	% tex is the default
  set(gca, "XTickLabel", ['-\pi'; '-2\pi/3'; '0'; '2\pi/3'; '\pi';])
  set(gca, "YTickLabel", ['0'; '.2'; '.4'; '.6'; '.8'; '1';])
  title("Frequency response of 3-term boxcar filter", "fontsize", 12)
%=======================================================
  y_origin = y_origin -dy -height;
  subplot("position",[x_origin y_origin width height])
  plot(abscissa, angle(H), "linewidth",2);
  xlim([-pi pi])
  ylim([-pi pi])
  set(gca, "XTick", [-pi -2*pi/3 0 2*pi/3 pi])
  set(gca, "YTick", [-pi -2 -1 0 1 2 pi])
  grid("on")

  xlabel('\leftarrow Frequency (\omega) (radians/sample) \rightarrow')
  ylabel("Phase (radians)")
% set(gca, "ticklabelinterpreter", "tex")	% tex is the default
  set(gca, "XTickLabel", ['-\pi'; '-2\pi/3'; '0'; '2\pi/3'; '\pi';])
  set(gca, "YTickLabel", ['-\pi'; '-2'; '-1'; '0'; '1'; '2'; '\pi';])

% The print function results in nicer-looking "pi" symbols
% than the export function on the GNUPlot figure toolbar.
print(hfig,"-dsvg", "-S509,509","-color", ...
'C:\Users\BobK\Frequency response of 3-term boxcar filter.svg')

說明

添加單行說明來描述出檔案所代表的內容

在此檔案描寫的項目

描繪內容

沒有維基數據項目的某些值

作者姓名字串 繁體中文 (已轉換拼寫):​Bob K
維基媒體使用者名稱 繁體中文 (已轉換拼寫):​Bob K

著作權狀態 繁體中文 (已轉換拼寫)

檔案來源 Chinese (Taiwan) (已轉換拼寫)

上傳者的原創作品 繁體中文 (已轉換拼寫)

多媒體型式 繁體中文 (已轉換拼寫)

image/svg+xml

檔案歷史

點選日期/時間以檢視該時間的檔案版本。

日期/時間縮⁠圖尺寸用戶備⁠註
目前2020年10月1日 (四) 13:07於 2020年10月1日 (四) 13:07 版本的縮圖416 × 400(20 KB)KrishnavedalaText-to-graph aspect ratio renders poorly in thumbnails with text unreadable.
2019年7月3日 (三) 01:36於 2019年7月3日 (三) 01:36 版本的縮圖512 × 512(37 KB)Bob KIncrease graph "linewidth" to 2.
2019年7月2日 (二) 22:11於 2019年7月2日 (二) 22:11 版本的縮圖512 × 512(37 KB)Bob KEnlarge image. Add title. Improve rendering of "pi" symbols.
2017年8月22日 (二) 15:35於 2017年8月22日 (二) 15:35 版本的縮圖416 × 400(20 KB)KrishnavedalaUser created page with UploadWizard

下列頁面有用到此檔案:

全域檔案使用狀況

以下其他 wiki 使用了這個檔案:

詮釋資料