-
Notifications
You must be signed in to change notification settings - Fork 689
Signal Processing Cheat Sheet
needs import breeze.signal._
Note: many of these functions have extensive optional parameters in breeze.
See the ScalaDoc for a description of each parameter.
| Operation | Breeze | Numpy | Matlab |
| ---- | ---- | ---- | ---- | ---- | ---- |
| Convolve | convolve[Input, KernelType, Output]
| |
|
| Correlate | correlate[Input, KernelType, Output]
| |
|
these Breeze functions will use fft convolution by default for floating point DenseMatrixes and DenseVectors. For Int and Long DV/DMs, you can specify fft convolution by specifying the optional argument optMethod = OptMethod.FFT
| Operation | Breeze | Numpy | Matlab |
| ---- | ---- | ---- | ---- | ---- | ---- |
| 1D Fourier transform | fourierTr( denseVector )
| fft( a )
| fft( a )
|
| 1D Inverse Fourier transform | iFourierTr( denseVector )
| ifft( a )
| ifft( a )
|
| 2D Fourier Transform | fourierTr( denseMatrix )
| fft2( a )
| fft2( a )
|
| 2D Inverse Fourier Transform | iFourierTr( denseMatrix )
| ifft2( a )
| ifft2( a )
|
| Operation | Breeze | Numpy | Matlab |
| ---- | ---- | ---- | ---- | ---- | ---- |
| Fourier frequencies | fourierFreq( n, dt = (timestep) )
or fourierFreq( n, fs = (sample freq) )
| fftfreq(n, dt)
| --- |
| Fourier shift | fourierShift( denseVector )
| fftshift( a )
| fftshift( a )
|
| (inverse) | iFourierShift( denseVector )
| ifftshift( a )
| ifftshift( a )
|
| Operation | Breeze | Numpy | Matlab |
| ---- | ---- | ---- | ---- | ---- | ---- |
| Filter | filter( denseVector, denseVector )
| |
|
| Bandpass Filter | filterBP( denseVector, (omega0, omega1), taps = 512 )
| |
|
| Bandstop Filter | filterBS( denseVector, (omega0, omega1), taps = 512 )
| |
|
| Lowpass Filter | filterLP( denseVector, omega, taps = 512 )
| |
|
| Highpass Filter | filterHP( denseVector, omega, taps = 512 )
| |
|
| Median Filter | filterMedian( denseVector, windowLength )
| |
|
Breeze is a numerical processing library for Scala. http://www.scalanlp.org