本文整理匯總了Python中scipy.ndimage.filters.convolve1d方法的典型用法代碼示例。如果您正苦於以下問題:Python filters.convolve1d方法的具體用法?Python filters.convolve1d怎麽用?Python filters.convolve1d使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類scipy.ndimage.filters
的用法示例。
在下文中一共展示了filters.convolve1d方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: smooth1d
# 需要導入模塊: from scipy.ndimage import filters [as 別名]
# 或者: from scipy.ndimage.filters import convolve1d [as 別名]
def smooth1d(array, window_size=None, kernel='gaussian'):
"""Apply a centered window smoothing to a 1D array.
Parameters
----------
array : ndarray
the array to apply the smoothing to
window_size : int
the size of the smoothing window
kernel : str
the type of smoothing (`gaussian`, `mean`)
Returns
-------
the smoothed array (same dim as input)
"""
# some defaults
if window_size is None:
if len(array) >= 9:
window_size = 9
elif len(array) >= 7:
window_size = 7
elif len(array) >= 5:
window_size = 5
elif len(array) >= 3:
window_size = 3
if window_size % 2 == 0:
raise ValueError('Window should be an odd number.')
if isinstance(kernel, str):
if kernel == 'gaussian':
kernel = gaussian(window_size, 1)
elif kernel == 'mean':
kernel = np.ones(window_size)
else:
raise NotImplementedError('Kernel: ' + kernel)
kernel = kernel / np.asarray(kernel).sum()
return filters.convolve1d(array, kernel, mode='mirror')
示例2: temporal_feature_smoothing
# 需要導入模塊: from scipy.ndimage import filters [as 別名]
# 或者: from scipy.ndimage.filters import convolve1d [as 別名]
def temporal_feature_smoothing(video_features, kernel):
#simple 1d convolution assuming that input is time x words x descriptors
return convolve1d(video_features, weights = kernel, axis = 0)
示例3: convolve
# 需要導入模塊: from scipy.ndimage import filters [as 別名]
# 或者: from scipy.ndimage.filters import convolve1d [as 別名]
def convolve(sequence, rule, **kwds):
"""Wrapper around scipy.ndimage.convolve1d that allows complex input."""
dtype = np.result_type(float, np.ravel(sequence)[0])
seq = np.asarray(sequence, dtype=dtype)
if np.iscomplexobj(seq):
return (convolve1d(seq.real, rule, **kwds) + 1j * convolve1d(seq.imag, rule, **kwds))
return convolve1d(seq, rule, **kwds)
示例4: h__foragingData
# 需要導入模塊: from scipy.ndimage import filters [as 別名]
# 或者: from scipy.ndimage.filters import convolve1d [as 別名]
def h__foragingData(self, fps, nose_bend_angle_d, min_win_size):
"""
Compute the foraging amplitude and angular speed.
Parameters
----------
fps :
nose_bend_angle_d : [n_frames x 1]
min_win_size : (scalar)
Returns
---------------------------------------
amplitudes : [1 x n_frames]
speeds : [1 x n_frames]
Notes
---------------------------------------
Formerly [amps,speeds] = h__foragingData(nose_bend_angle_d,
min_win_size, fps)
"""
if min_win_size > 0:
# Clean up the signal with a gaussian filter.
gauss_filter = utils.gausswin(2 * min_win_size + 1) / min_win_size
nose_bend_angle_d = filters.convolve1d(nose_bend_angle_d,
gauss_filter,
cval=0,
mode='constant')
# Remove partial data frames ...
nose_bend_angle_d[:min_win_size] = np.NaN
nose_bend_angle_d[-min_win_size:] = np.NaN
# Calculate amplitudes
amplitudes = self.h__getAmplitudes(nose_bend_angle_d)
assert(np.shape(nose_bend_angle_d) == np.shape(amplitudes))
# Calculate angular speed
# Compute the speed centered between the back and front foraging movements.
#
# TODO: fix the below comments to conform to 0-based indexing
# I believe I've fixed the code already. - @MichaelCurrie
# 1 2 3
# d1 d2 d1 = 2 - 1, d2 = 3 - 2
# x assign to x, avg of d1 and d2
#???? - why multiply and not divide by fps????
d_data = np.diff(nose_bend_angle_d) * fps
speeds = np.empty(amplitudes.size) * np.NaN
# This will leave the first and last frame's speed as NaN:
speeds[1:-1] = (d_data[:-1] + d_data[1:]) / 2
# Propagate NaN for speeds to amplitudes
amplitudes[np.isnan(speeds)] = np.NaN
return amplitudes, speeds