我试图在scipy.signal中添加所有窗口函数的文档,并且卡在Slepian(与DPSS相同?)和General Gaussian窗口中,这是我以前从未听说过的。
有两个变量是某种类型的形状参数,分别p
在广义高斯模型和width
Slepian模型中。(sig
似乎是sigma,是标准偏差。)
2个问题:
代替我进行逆向工程和猜测,没有人能解释这些变量的名称以及它们的作用吗?
您能解释一下这些窗口的用途或用途吗?
def general_gaussian(M, p, sig, sym=True):
"""Return a window with a generalized Gaussian shape.
The Gaussian shape is defined as ``exp(-0.5*(x/sig)**(2*p))``, the
half-power point is at ``(2*log(2)))**(1/(2*p)) * sig``.
"""
if M < 1:
return np.array([])
if M == 1:
return np.ones(1, 'd')
odd = M % 2
if not sym and not odd:
M = M + 1
n = np.arange(0, M) - (M - 1.0) / 2.0
w = np.exp(-0.5 * (n / sig) ** (2 * p))
if not sym and not odd:
w = w[:-1]
return w
def slepian(M, width, sym=True):
"""Return the M-point slepian window.
"""
if (M * width > 27.38):
raise ValueError("Cannot reliably obtain slepian sequences for"
" M*width > 27.38.")
if M < 1:
return np.array([])
if M == 1:
return np.ones(1, 'd')
odd = M % 2
if not sym and not odd:
M = M + 1
twoF = width / 2.0
alpha = (M - 1) / 2.0
m = np.arange(0, M) - alpha
n = m[:, np.newaxis]
k = m[np.newaxis, :]
AF = twoF * special.sinc(twoF * (n - k))
[lam, vec] = linalg.eig(AF)
ind = np.argmax(abs(lam), axis=-1)
w = np.abs(vec[:, ind])
w = w / max(w)
if not sym and not odd:
w = w[:-1]
return w
可能的匹配项:
nipy的dpss_windows函数使用NW
,“对应于2NW = BW * f0 = BW * N / dt但dt为1的标准化半带宽”
Matlab的dpss使用time_halfbandwidth
这是同一窗口吗?是time_halfbandwidth
一样的东西width
吗?
DPSS定义具有 “所需的主瓣截止频率,以弧度每秒为单位”。
广义正态分布具有β(等于两倍p
?),它被称为形状参数,β= 1的正态分布,β= 2的拉普拉斯分布。