在有限长度数位滤波器的设计中,最小平均平方误差(英文:least mean-square error)是所设计的滤波器响应与理想滤波器响应在欲探讨的频段中的最小误差。由于所设计的数位滤波器的长度不是无限长,所以在设计上和完美的滤波器会存在误差。是讯号工程师会关心设计的滤波器的响应重点。此平均误差利用统计学的方均值来计算求得。 本条目存在以下问题,请协助改善本条目或在讨论页针对议题发表看法。 此条目可能需要清理,以符合维基百科质量标准。 (2023年6月15日) 此条目需要精通或熟悉数字信号处理的编者参与及协助编辑。 (2023年6月15日) 定义 M S E ≜ 1 f s ∫ − f s / 2 f s / 2 | R ( f ) − H d ( f ) | 2 d f {\displaystyle MSE\triangleq {\frac {1}{f_{s}}}\int \limits _{-f_{s}/2}^{f_{s}/2}|R(f)-H_{d}(f)|^{2}df} 其中 R ( f ) {\displaystyle R(f)} 为设计滤波器响应,有k+1项: R ( F ) = ∑ n = 0 k s [ n ] c o s ( 2 π n F ) {\displaystyle R(F)=\sum _{n=0}^{k}s[n]cos(2\pi nF)} , F {\displaystyle F} 表示频率变数对取样频率 f s {\displaystyle f_{s}} 的正归化参数: F = f f s {\displaystyle F={\frac {f}{f_{s}}}} ,是离散化的频率(normalized frequency)。此为离散时间傅立叶转换表示法 其中 H d ( f ) = ∑ n h [ n ] e − j 2 π f f s = H d ( f ) = ∑ n h [ n ] e − j 2 π n F {\displaystyle H_{d}(f)=\sum _{n}h[n]e^{-j2\pi f \over f_{s}}=H_{d}(f)=\sum _{n}h[n]e^{-j2\pi nF}} 是理想滤波器的离散时间傅立叶转换表示法。 注意此算式中对频谱的积分上下界,采取正负取样频率的一半即可。[1]因为响应函式已经被取样,会让信号频谱具有周期性,其周期就是取样频率为 f s {\displaystyle f_{s}} 。所以探讨MSE时,积分范围采取 − f s 2 {\displaystyle -{\frac {f_{s}}{2}}} 到 f s 2 {\displaystyle {\frac {f_{s}}{2}}} 即可,节省运算量。 另外,此种将函数平方再对变数积分取平均的算法,类似对变数取 L 2 {\displaystyle L_{2}} 范数。即是对向量做二维的标量化平均的处理,和另一个设计滤波器做法Mini-max相比,做最佳化较容易,因为这是实函数平方微分后再积分的线性运算 Remove ads有限脉冲响应滤波器的设计应用 运用定义,将 F {\displaystyle F} 取代 f {\displaystyle f} 做变数变换: F = f f s {\displaystyle F={\frac {f}{f_{s}}}} , d F = 1 f s d f {\displaystyle dF={\frac {1}{f_{s}}}df} M S E = ∫ − 1 / 2 1 / 2 | R ( F ) − H d ( F ) | 2 d F = ∫ − 1 / 2 1 / 2 | ∑ n = 1 k s [ n ] c o s ( 2 π n F ) − H d ( F ) | 2 d F {\displaystyle {\begin{aligned}MSE&=\int _{-1/2}^{1/2}|R(F)-H_{d}(F)|^{2}dF\\&=\int _{-1/2}^{1/2}|\sum _{n=1}^{k}s[n]cos(2\pi nF)-H_{d}(F)|^{2}dF\\\end{aligned}}} 因为绝对值内函数是以时刻变数构成的实函数,所以可将绝对值平方直接写成两个实函数部分相乘。 M S E = ∫ − 1 / 2 1 / 2 ( ∑ v = 0 k s [ v ] c o s ( 2 π v F ) − H d ( F ) ) ( ∑ τ = 0 k s [ τ ] c o s ( 2 π τ F ) − H d ( F ) ) d F {\displaystyle MSE=\int _{-1/2}^{1/2}\left(\sum _{v=0}^{k}s[v]cos(2\pi vF)-H_{d}(F)\right)\left(\sum _{\tau =0}^{k}s[\tau ]cos(2\pi \tau F)-H_{d}(F)\right)dF} 将MSN对s{n]做偏微分, ∂ M S E ∂ s [ n ] = ∫ − 1 / 2 1 / 2 c o s ( 2 π n F ) ( ∑ τ = 0 k s [ τ ] c o s ( 2 π τ F ) − H d ( F ) ) d F + ∫ − 1 / 2 1 / 2 ( ∑ v = 0 k s [ v ] c o s ( 2 π v F ) − H d ( F ) ) d F {\displaystyle {\begin{aligned}{\frac {\partial MSE}{\partial s[n]}}&=\int _{-1/2}^{1/2}cos(2\pi nF){\Bigl (}\sum _{\tau =0}^{k}s[\tau ]cos(2\pi \tau F)-H_{d}(F){\Bigr )}dF\\&+\int _{-1/2}^{1/2}{\Bigl (}\sum _{v=0}^{k}s[v]cos(2\pi vF)-H_{d}(F){\Bigr )}dF\\\end{aligned}}} 将上式第一个等号后面的两个 Σ {\displaystyle \Sigma } 项合并,因为引数起始值和最末项值相同。 ∂ M S E ∂ s [ n ] = 2 ∑ τ = 0 k s [ τ ] ∫ − 1 / 2 1 / 2 c o s ( 2 π τ F ) c o s ( 2 π n F ) d F − 2 ∫ − 1 / 2 1 / 2 H d ( F ) c o s ( 2 π n F ) d F , ∀ n = 0 , 1 , 2 , . . . k {\displaystyle {\begin{aligned}{\frac {\partial MSE}{\partial s[n]}}&=2\sum _{\tau =0}^{k}s[\tau ]\int _{-1/2}^{1/2}cos(2\pi \tau F)cos(2\pi nF)dF\\&-2\int _{-1/2}^{1/2}H_{d}(F)cos(2\pi nF)dF,\forall n=0,1,2,...k\\\end{aligned}}} 上式等号右边的两项中,都各有将余弦函数从-1/2积分到1/2,又因为有两个自变数系数不同的余弦函数相乘,整个计算结果要分开讨论。 Remove ads R ( F ) {\displaystyle R(F)} 与 H d ( F ) {\displaystyle H_{d}(F)} 项次 R ( F ) {\displaystyle R(F)} 与 H d ( F ) {\displaystyle H_{d}(F)} 的项次 n {\displaystyle n} 与 τ {\displaystyle \tau } 相异或相同,因为函数的正交性,会有不同的积分效果。此可由三角函数的积化合差验证出来。 ∫ − 1 / 2 1 / 2 c o s ( 2 π τ F ) c o s ( 2 π n F ) d F = { 0 , n ≠ τ 1 / 2 , n = τ , n ≠ 0 1 , n = τ , n = 0 {\displaystyle \int _{-1/2}^{1/2}cos(2\pi \tau F)cos(2\pi nF)dF={\begin{cases}0,&n\neq \tau \\1/2,&n=\tau ,n\neq 0\\1,&n=\tau ,n=0\end{cases}}} 故可得: ∂ M S E ∂ s [ 0 ] = 2 s [ 0 ] × 1 − 2 ∫ − 1 / 2 1 / 2 H d ( F ) × 1 d F = 0 , ∀ n = 0 ∂ M S E ∂ s [ n ] = s [ n ] − 2 ∫ − 1 / 2 1 / 2 c o s ( 2 π n F ) H d ( F ) d F = 0 , ∀ n ≠ 0 {\displaystyle {\begin{aligned}{\frac {\partial MSE}{\partial s[0]}}&=2s[0]\times 1-2\int _{-1/2}^{1/2}H_{d}(F)\times 1dF=0,\forall n=0\\{\frac {\partial MSE}{\partial s[n]}}&=s[n]-2\int _{-1/2}^{1/2}cos(2\pi nF)H_{d}(F)dF=0,\forall n\neq 0\\\end{aligned}}} MSE 是设计上滤波器响应函数和理想函数之间的误差,吾人会希望这个误差越小越好,即是设计的响应要和理想的响应,在所有时刻n上的趋势一样。 故使: ∂ M S E ∂ s [ n ] = 0 {\displaystyle {\partial MSE \over \partial s[n]}=0} for all n. 可得: s [ 0 ] = ∫ − 1 / 2 1 / 2 H d ( F ) d F s [ n ] = 2 ∫ − 1 / 2 1 / 2 c o s ( 2 π n F ) H d ( F ) d F {\displaystyle {\begin{aligned}s[0]=\int _{-1/2}^{1/2}H_{d}(F)dF\\s[n]=2\int _{-1/2}^{1/2}cos(2\pi nF)H_{d}(F)dF\\\end{aligned}}} 观察上式,若我们要得到滤波器的最小方均误差,则要将理想滤波器频域响应对余弦函数做多项式内积。 最后将 s [ n ] {\displaystyle s[n]} 的值带入 h [ k ] {\displaystyle h[k]} : { h [ k ] = s [ 0 ] h [ k + n ] = s [ n ] / 2 , h [ k − n ] = s [ n ] / 2 , for n = 1 , 2 , 3 , . . . , k h [ n ] = 0 , for n < 0 and n ≥ N . {\displaystyle {\begin{cases}h[k]=s[0]\\h[k+n]=s[n]/2,h[k-n]=s[n]/2,&{\text{for }}n=1,2,3,...,k\\h[n]=0,{\text{ for }}n<0{\text{ and }}n\geq N.\end{cases}}} h [ n ] {\displaystyle h[n]} 即为欲设计的滤波器脉冲响应式。 Remove ads结合权重函数 在数位滤波器设计中,可以利用权重函数 W ( F ) {\displaystyle W(F)} 去设计定频段更接近理想值。则MSE则表示为: M S E = ∫ − 1 / 2 1 / 2 W ( F ) | R ( F ) − H d ( F ) | 2 d F = ∫ − 1 / 2 1 / 2 W ( F ) ( ∑ − 1 / 2 1 / 2 s [ τ ] ) c o s ( 2 π τ F ) − H d ( F ) ) d F {\displaystyle MSE=\int _{-1/2}^{1/2}W(F)|R(F)-H_{d}(F)|^{2}dF=\int _{-1/2}^{1/2}W(F){\Bigl (}\sum _{-1/2}^{1/2}s[\tau ])cos(2\pi \tau F)-H_{d}(F){\Bigr )}dF} MSE对s[n]的微分值为零可改写为: ∂ M S E ∂ s [ n ] = 2 ∫ − 1 / 2 1 / 2 W ( F ) c o s ( 2 π n F ) ( ∑ t a u k s [ τ ] c o s ( 2 π τ F ) − H d ( F ) ) d F {\displaystyle {\frac {\partial MSE}{\partial s[n]}}=2\int _{-1/2}^{1/2}W(F)cos(2\pi nF){\biggl (}\sum _{tau}^{k}s[\tau ]cos(2\pi \tau F)-H_{d}(F){\biggr )}dF} = ∑ τ = 0 k s [ τ ] ∫ − 1 / 2 1 / 2 W ( F ) c o s ( 2 π n F ) c o s ( 2 π τ F ) d F − ∫ − 1 / 2 1 / 2 W ( F ) H d ( F ) c o s ( 2 π n F ) d f = 0 , n ∈ [ 0 , k ] {\displaystyle =\sum _{\tau =0}^{k}s[\tau ]\int _{-1/2}^{1/2}W(F)cos(2\pi nF)cos(2\pi \tau F)dF-\int _{-1/2}^{1/2}W(F)H_{d}(F)cos(2\pi nF)df=0,n\in [0,k]} ⇒ ∑ τ = 0 k s [ τ ] ∫ − 1 / 2 1 / 2 W ( F ) c o s ( 2 π n F ) c o s ( 2 π τ F ) d F = ∫ − 1 / 2 1 / 2 W ( F ) H d ( F ) c o s ( 2 π n F ) d F {\displaystyle \Rightarrow \sum _{\tau =0}^{k}s[\tau ]\int _{-1/2}^{1/2}W(F)cos(2\pi nF)cos(2\pi \tau F)dF=\int _{-1/2}^{1/2}W(F)H_{d}(F)cos(2\pi nF)dF} 可再将上式写成矩阵式: [ A [ 0 , 0 ] A [ 0 , 1 ] A [ 0 , 2 ] . . . A [ 0 , k ] A [ 1 , 0 ] A [ 1 , 1 ] A [ 1 , 2 ] . . . A [ 1 , k ] ⋮ ⋮ ⋮ ⋱ ⋮ A [ k , 0 ] A [ k , 1 ] A [ k , 2 ] ⋯ A [ k , k ] ] [ s [ 0 ] s [ 1 ] ⋮ s [ k ] ] = [ B [ 0 ] B [ 1 ] ⋮ B [ k ] ] {\displaystyle {\begin{bmatrix}A[0,0]&A[0,1]&A[0,2]&...&A[0,k]\\A[1,0]&A[1,1]&A[1,2]&...&A[1,k]\\\vdots &\vdots &\vdots &\ddots &\vdots \\A[k,0]&A[k,1]&A[k,2]&\cdots &A[k,k]\end{bmatrix}}{\begin{bmatrix}s[0]\\s[1]\\\vdots \\s[k]\end{bmatrix}}={\begin{bmatrix}B[0]\\B[1]\\\vdots \\B[k]\end{bmatrix}}} A矩阵每一行表示不同 τ {\displaystyle \tau } 代表的数值,每一列代表不同n代表的数值;s向量与B向量每一列表示不同n代表的数值。 其中: A [ n , τ ] = ∫ − 1 / 2 1 / 2 W ( F ) c o s ( 2 π n F ) c o s ( 2 π τ F ) d F , B [ n ] = ∫ − 1 / 2 1 / 2 W ( F ) H d ( F ) c o s ( 2 π n F ) d F {\displaystyle A[n,\tau ]=\int _{-1/2}^{1/2}W(F)cos(2\pi nF)cos(2\pi \tau F)dF,B[n]=\int _{-1/2}^{1/2}W(F)H_{d}(F)cos(2\pi nF)dF} 经由此举阵式可解出带有权重函数设计的 s [ n ] {\displaystyle s[n]} 。 最后将 s [ n ] {\displaystyle s[n]} 带入 h [ k ] {\displaystyle h[k]} : { h [ k ] = s [ 0 ] h [ k + n ] = s [ n ] / 2 , h [ k − n ] = s [ n ] / 2 , for n = 1 , 2 , 3 , . . . , k h [ n ] = 0 , for n < 0 and n ≥ N . {\displaystyle {\begin{cases}h[k]=s[0]\\h[k+n]=s[n]/2,h[k-n]=s[n]/2,&{\text{for }}n=1,2,3,...,k\\h[n]=0,{\text{ for }}n<0{\text{ and }}n\geq N.\end{cases}}} h [ k ] {\displaystyle h[k]} 即是欲设计的滤波器响应。 Remove ads参考文献Loading content...Loading related searches...Wikiwand - on Seamless Wikipedia browsing. On steroids.Remove ads