Introduction
Maple 17 offers new signal processing tools for analyzing and manipulating data in the frequency and time domains. It can be used for diverse applications such as creating a speech spectrogram, removing noise from polluted signals, and identifying the periodicity of data.
This package includes tools for:
- Cosine, fast Fourier and wavelet transforms
- Bartlett, Blackman, Kaiser, Hann, and Hanning windows
- Signal generation
- Cross-correlation, autocorrelation, data statistics, and upsampling/downsampling
- FIR, IIR, and Butterworth filters
> |
![with(SignalProcessing[Engine])](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_2.gif) |
Application: Imaging a Speech Spectrogram
Import Wave File and Manipulate Data into Overlapping Slices
> |
data:image/s3,"s3://crabby-images/95e9d/95e9d9c18f096394db07dde7e8c2b39595aefa50" alt="" |
> |
data:image/s3,"s3://crabby-images/f4462/f4462d9772040e7c5d4a2e17e5bddfb592f5073f" alt="filename := cat(kernelopts(datadir), kernelopts(dirsep),"
data:image/s3,"s3://crabby-images/86492/8649213bdff3c0f10077e660a031167862d82ead" alt="filename := cat(kernelopts(datadir), kernelopts(dirsep)," |
> |
data:image/s3,"s3://crabby-images/5b67e/5b67ece656094f1b5f29ec28bdf6d8d846a8a2ba" alt="data := AudioTools:-Read(filename)" |
> |
data:image/s3,"s3://crabby-images/d1d42/d1d42b60ab108e28a46d1f69fae10be1761ac802" alt="" data:image/s3,"s3://crabby-images/f3a5f/f3a5feabd40850dc89b02ad32c4ce0d4574d9a13" alt="" |
> |
data:image/s3,"s3://crabby-images/ad66e/ad66e9b6b100303c4f902c2719ac60661c5099b2" alt="len := evalf(`/`(`*`(numelems(data)), `*`(samplingRate)))" |
Slice the data into segments with 256 samples. Each slice has a 50% overlap with the previous slice (that is, each slice starts at the half-way point of the previous slice).
> |
data:image/s3,"s3://crabby-images/58fdc/58fdcd7df039531fbec4fe838273d340fdeabc82" alt="samps := 256; -1" |
> |
data:image/s3,"s3://crabby-images/14bd8/14bd853f7267c3e1861e00edb3d7d2d0382850e3" alt="nTimes := `+`(floor(`+`(`/`(`*`(2, `*`(numelems(data))), `*`(samps)))), `-`(1))" |
> |
![sample := Matrix(samps, nTimes, proc (i, j) options operator, arrow; data[`+`(i, `*`(`/`(1, 2), `*`(`+`(j, `-`(1)), `*`(samps))))] end proc, datatype = float[8]); 1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_25.gif) |
Calculate the Spectrogram Data
Filter the data, slice by slice.
> |
![a := `<|>`(`<,>`(seq(HannWindow(sample[() .. (), i]), i = 1 .. nTimes))); -1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_27.gif) |
Calculate FFT of time segment consecutively.
> |
![FFTa := `<|>`(`<,>`(seq(FFT(a[i, () .. ()]), i = 1 .. nTimes))); -1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_28.gif) |
Calculate Power Spectrum of each slice consecutively.
> |
data:image/s3,"s3://crabby-images/cdb50/cdb506eff4ba13e342b77f8733098a761c53e76e" alt="spectra := `<|>`(`<,>`(seq(`~`[sqrt" .. ()])), i = 1 .. nTimes))); -1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_29.gif) |
Convert spectrum into decibels.
> |
data:image/s3,"s3://crabby-images/27d8d/27d8df49634a451f8d45dbbe2371d66a517a2df9" alt="dB := proc (x) options operator, arrow; `+`(`*`(20, `*`(log10(x)))) end proc; -1" |
> |
data:image/s3,"s3://crabby-images/fc67a/fc67ad773ef3997f21d20019d76be125e8b59665" alt="spectra := map(dB, spectra); -1" |
Strip out the repeated data.
> |
data:image/s3,"s3://crabby-images/f3908/f39081b873b1efe9e86a33baeb0b8482e62fcc74" alt="sim := LinearAlgebra:-SubMatrix(Re(spectra), 1 .. nTimes, 1 .. `+`(`*`(`/`(1, 2), `*`(samps)), 1)); -1" |
> |
data:image/s3,"s3://crabby-images/2233c/2233cf42568f793e093f1ec7690ec6de8d48ea5e" alt="nFreqs := LinearAlgebra:-ColumnDimension(sim)" |
The frequencies go from 0 to half the sampling rate. Hence the frequencies are in steps of (in Hz):
> |
data:image/s3,"s3://crabby-images/7a44a/7a44a6f6773749d1a04bb9259f0937fe6dca9d55" alt="`*`(samplingRate, `*`(`/`(`+`(`*`(2., `*`(nFreqs))))))" |
Scale the spectra so that the values are between 0 and 255.
> |
data:image/s3,"s3://crabby-images/5b0f5/5b0f5108834bb884f1cb1e4afef0304e2d5661d2" alt="minSim := min(sim)" |
> |
data:image/s3,"s3://crabby-images/183a9/183a9ea34fa5efa8dc4329e52b512f1842117ee9" alt="maxSim := max(sim)" |
> |
data:image/s3,"s3://crabby-images/bad44/bad446679ab107561e83138e948161f5e3be0322" alt="scale := proc (i) options operator, arrow; `/`(`*`(`+`(`*`(255, `*`(i)), `-`(`*`(255, `*`(minSim))))), `*`(`+`(maxSim, `-`(minSim)))) end proc; -1" |
Consecutive rows represent slices in time, while columns contain the spectra at each time.
> |
data:image/s3,"s3://crabby-images/18988/1898801eb80768610a9bb674bb3ce1ffbbb38a1f" alt="simScaled := `~`[scale"; 1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_42.gif) |
Plot the Spectrogram and Waveform
> |
![commonPlotOpts1 := labelfont = [Helvetica], labeldirections = [horizontal, vertical]; -1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_44.gif) |
> |
![p2 := listplot([seq([`/`(`*`(i), `*`(samplingRate)), data[i]], i = 1 .. numelems(data))], thickness = 0, gridlines, axes = boxed, labels = [](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_48.gif)
![p2 := listplot([seq([`/`(`*`(i), `*`(samplingRate)), data[i]], i = 1 .. numelems(data))], thickness = 0, gridlines, axes = boxed, labels = [](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_49.gif) |
> |
![display(Array(`<|>`(`<,>`(p1, p2))), aligncolumns = [1])](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_50.gif) |
Application: Filtering Audio
Import Speech Sample
> |
data:image/s3,"s3://crabby-images/03124/03124f627d0a40eb602db56c55349c1e9b6adad5" alt="filename2 := cat(kernelopts(datadir), kernelopts(dirsep),"
data:image/s3,"s3://crabby-images/1856e/1856e7751f05b2731f3fc5da9cb221b9ef8bba22" alt="filename2 := cat(kernelopts(datadir), kernelopts(dirsep)," |
> |
data:image/s3,"s3://crabby-images/e02e2/e02e28f9f8ede5fbb6b3a4b0c37fac049641aa43" alt="originalSpeech := AudioTools:-Read(filename2)" |
Plot Waveform and Power Spectrum
> |
![commonPlotOpts2 := titlefont = [Helvetica, 12], labelfont = [Helvetica], labeldirections = [horizontal, vertical], axis = [gridlines = [color =](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_58.gif)
![commonPlotOpts2 := titlefont = [Helvetica, 12], labelfont = [Helvetica], labeldirections = [horizontal, vertical], axis = [gridlines = [color =](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_59.gif) |
> |
![samplingRate := attributes(originalSpeech)[1]](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_60.gif) |
> |
data:image/s3,"s3://crabby-images/d8489/d84898f22b4439b9f5a5994a931dd6f9423deab0" alt="duration := evalf(AudioTools:-Duration(originalSpeech))" |
> |
data:image/s3,"s3://crabby-images/0b1c8/0b1c8514268d5bef076e9b2ee937e0e369803596" alt="plots:-display(p1)" |
> |
![fq := FFT(originalSpeech[1 .. `^`(2, 15)]); -1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_71.gif) |
> |
data:image/s3,"s3://crabby-images/c3c5d/c3c5d86b7b0271606a4a148644f123f4c45522af" alt="psq := PowerSpectrum(fq); -1" |
> |
data:image/s3,"s3://crabby-images/d5847/d584737a2d4eeb63cfb2e27d373201181ca12361" alt="plots:-display(ps1)" |
Apply IIR Butterworth or Chebyshev Filter
Apply Filter
> |
data:image/s3,"s3://crabby-images/5a3d2/5a3d27bd3afe8be84248b7f20244de42c0345ff6" alt="fc := 800; -1" |
> |
data:image/s3,"s3://crabby-images/fd5c6/fd5c62403fd539b4fc36874feeb521112e0b2fa0" alt="taps := GenerateButterworthTaps(9, `/`(`*`(fc), `*`(samplingRate)), 'filtertype' = 'lowpass', normalise = true)"
data:image/s3,"s3://crabby-images/72cb5/72cb5e7c63c40051d48881d6e097b899af756708" alt="taps := GenerateButterworthTaps(9, `/`(`*`(fc), `*`(samplingRate)), 'filtertype' = 'lowpass', normalise = true)" |
> |
data:image/s3,"s3://crabby-images/1110c/1110c0d9ee300ea67c854db8be7666dabd92ab44" alt="filteredSpeech := InfiniteImpulseResponseFilter(originalSpeech, taps); -1" |
View Before and After Power Spectrum and Waveform
> |
![FFTfilteredSpeech := FFT(filteredSpeech[1 .. `^`(2, 15)]); -1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_84.gif) |
> |
data:image/s3,"s3://crabby-images/f14b7/f14b742cd554585a1b9b964226234178725b1fc4" alt="PSfilteredSpeech := PowerSpectrum(FFTfilteredSpeech); -1" |
> |
data:image/s3,"s3://crabby-images/df79c/df79cd229194de8394c83089d29f8af003bf2653" alt="plots:-display(Array(`<,>`(`<|>`(ps1, ps2))))" |
> |
![plots:-display(Array(`<,>`(`<|>`(p1, p2))), view = [0 .. duration, -1 .. 1])](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_96.gif) |
Apply FIR Filter
Apply Filter
> |
data:image/s3,"s3://crabby-images/675b6/675b6fd1a9205de96e7504c4c66dab43c50e2897" alt="flow := 200; -1" |
> |
data:image/s3,"s3://crabby-images/d328f/d328fdecaba800bef076132a2fa0c20d0f23a24e" alt="fhigh := 700; -1" |
> |
data:image/s3,"s3://crabby-images/ead80/ead8001f87ec5db6dcb6d3bb538b889eff8bccff" alt=""
data:image/s3,"s3://crabby-images/525e7/525e7abc33cecadc4f344736404cca45a2b97ece" alt="" |
> |
data:image/s3,"s3://crabby-images/9c328/9c3288b2713cc463db39c7e223d7b2178f9e9d7b" alt="filteredSpeech := FiniteImpulseResponseFilter(originalSpeech, taps); -1" |
View Before and After Power Spectrum and Waveform
> |
![FFTfilteredSpeech := FFT(filteredSpeech[1 .. `^`(2, 15)]); -1](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_104.gif) |
> |
data:image/s3,"s3://crabby-images/38b58/38b58afd3493ade779b5d25e56c5b53e38b2ee19" alt="PSfilteredSpeech := PowerSpectrum(FFTfilteredSpeech); -1" |
> |
data:image/s3,"s3://crabby-images/56e69/56e69ee2ddee739c5a2736a21a431352150c5c6d" alt="plots:-display(Array(`<,>`(`<|>`(ps1, ps2))))" |
> |
![plots:-display(Array(`<,>`(`<|>`(p1, p2))), view = [0 .. duration, -1 .. 1])](/products/maple/new_features/images17/SignalProcessing/SignalProcessing_116.gif) |