Signal processing
SignalAnalysis.circconv
— Functioncircconv(x)
circconv(x, y)
Computes the circular convolution of x
and y
. Both vectors must be the same length.
SignalAnalysis.compose
— Methodcompose(r, t, a; duration, fs)
Compose a signal from a reference signal and a list of arrival times and amplitudes.
Examples:
julia> x = cw(10kHz, 0.01, 44.1kHz)
julia> y1 = compose(x, [0.01, 0.03, 0.04], [1.0, 0.8, 0.6]; duration=0.05)
julia> y2 = compose(real(x), [10ms, 30ms, 40ms], [1.0, 0.8, 0.6]; duration=50ms)
SignalAnalysis.delay!
— Methoddelay!(x, v)
Delay signal x
by v
units. The delay may be specified in samples or in time units (e.g. 2.3𝓈). The function supports delays of fractional or negative number of samples. The length of the returned signal is the same as the original, with any part of the signal that is shifted beyond the original length discarded.
Examples:
julia> x = signal([1.0, 2.0, 3.0], 10.0)
julia> delay!(x, 1)
SampledSignal @ 10.0 Hz, 3-element Vector{Float64}:
0.0
1.0
2.0
julia> x = signal([1.0, 2.0, 3.0], 10.0)
julia> delay!(x, -1)
SampledSignal @ 10.0 Hz, 3-element Vector{Float64}:
1.0
2.0
0.0
julia> x = signal([1.0, 2.0, 3.0, 2.0, 1.0], 10.0)
julia> delay!(x, 1.2)
SampledSignal @ 10.0 Hz, 5-element Vector{Float64}:
-0.10771311593885118
0.8061269251734184
1.7488781412804602
2.9434587943152617
2.2755141401574472
julia> x = signal([1.0, 2.0, 3.0, 2.0, 1.0], 10.0)
julia> delay!(x, -0.11𝓈)
SampledSignal @ 10.0 Hz, 5-element Vector{Float64}:
2.136038062052266
2.98570052268015
1.870314441196549
0.9057002486847239
-0.06203155191384361
SignalAnalysis.demon
— Methoddemon(x; fs, downsample, method, cutoff)
Estimates DEMON spectrum. The output is highpass filtered with a cutoff
frequency and downsampled. Supported downsampling methods are :rms
(default), :mean
and :fir
.
SignalAnalysis.downconvert
— Functiondownconvert(s, sps, fc)
downconvert(s, sps, fc, pulseshape; fs)
Converts passband signal centered around carrier frequency fc
to baseband, and downsamples it by a factor of sps
. If the pulseshape
is specified to be nothing
, downsampling is performed without filtering.
SignalAnalysis.findsignal
— Functionfindsignal(r, s)
findsignal(r, s, n; prominence, coarse)
Finds up to n
copies of reference signal r
in signal s
. The reference signal r
should have a delta-like autocorrelation for this function to work well. If the keyword parameter coarse
is set to true
, approximate arrival times are computed based on a matched filter. If it is set to false
, an iterative optimization is performed to find more accruate arrival times.
Returns named tuple (time=t, amplitude=a)
where t
is a vector of arrival times and a
is a vector of complex amplitudes of the arrivals. The arrivals are sorted in ascending order of arrival times.
Examples:
julia> x = chirp(1000, 5000, 0.1, 40960; window=(tukey, 0.05))
julia> x4 = resample(x, 4)
julia> y4 = samerateas(x4, zeros(32768))
julia> y4[128:127+length(x4)] = real(x4) # time 0.000775𝓈, index 32.75
julia> y4[254:253+length(x4)] += -0.8 * real(x4) # time 0.001544𝓈, index 64.25
julia> y4[513:512+length(x4)] += 0.6 * real(x4) # time 0.003125𝓈, index 129.0
julia> y = resample(y4, 1//4)
julia> y .+= 0.1 * randn(length(y))
julia> findsignal(x, y, 3; coarse=true)
(time = Float32[0.000781, 0.001538, 0.003125], amplitude = ComplexF64[...])
julia> findsignal(x, y, 3)
(time = Float32[33, 64, 129], [0.000775, 0.001545, 0.003124], amplitude = ComplexF64[...])
SignalAnalysis.fir
— Functionfir(n, f1)
fir(n, f1, f2; fs, method)
Designs a n
-tap FIR filter with a passband from f1
to f2
using the specified method
. If frame rate fs
is not specified, f1
and f2
are given in normalized units (1.0 being Nyquist). If f1
is 0, the designed filter is a lowpass filter, and if f2
is nothing
then it is a highpass filter.
This method is a convenience wrapper around DSP.digitalfilter
.
Examples:
julia> lpf = fir(127, 0, 10kHz; fs=44.1kHz) # design a lowpass filter
127-element Array{Float64,1}:
⋮
julia> hpf = fir(127, 10kHz; fs=44.1kHz) # design a highpass filter
127-element Array{Float64,1}:
⋮
julia> bpf = fir(127, 1kHz, 5kHz; fs=44.1kHz) # design a bandpass filter
127-element Array{Float64,1}:
⋮
SignalAnalysis.gmseq
— Functiongmseq(m)
gmseq(m, θ)
Generates an generalized m-sequence of length 2^m-1
or tap specification m
.
Generalized m-sequences are related to m-sequences but have an additional parameter θ
. When θ = π/2
, generalized m-sequences become normal m-sequences. When θ < π/2
, generalized m-sequences contain a DC-component that leads to an exalted carrier after modulation. When θ
is atan(√(2^m-1))
, the m-sequence is considered to be period matched. Period matched m-sequences are complex sequences with perfect discrete periodic auto-correlation properties, i.e., all non-zero lag periodic auto-correlations are zero. The zero-lag autocorrelation is 2^m-1
, where m
is the shift register length.
This function currently supports shift register lengths between 2 and 30.
Examples:
julia> x = gmseq(3) # generate period matched m-sequence
7-element Array{Complex{Float64},1}:
0.3535533905932738 + 0.9354143466934853im
0.3535533905932738 + 0.9354143466934853im
0.3535533905932738 + 0.9354143466934853im
0.3535533905932738 - 0.9354143466934853im
0.3535533905932738 + 0.9354143466934853im
0.3535533905932738 - 0.9354143466934853im
0.3535533905932738 - 0.9354143466934853im
julia> x = gmseq(3, π/4) # generate m-sequence with exalted carrier
7-element Array{Complex{Float64},1}:
0.7071067811865476 + 0.7071067811865475im
0.7071067811865476 + 0.7071067811865475im
0.7071067811865476 + 0.7071067811865475im
0.7071067811865476 - 0.7071067811865475im
0.7071067811865476 + 0.7071067811865475im
0.7071067811865476 - 0.7071067811865475im
0.7071067811865476 - 0.7071067811865475im
SignalAnalysis.goertzel
— Methodgoertzel(x, f, n; fs)
Detects frequency f
in input signal using the Goertzel algorithm.
The detection metric returned by this function is the complex output of the Goertzel filter at the end of the input block. Typically, you would want to compare the magnitude of this output with a threshold to detect a frequency.
When a block size n
is specified, the Goertzel algorithm in applied to blocks of data from the original time series.
SignalAnalysis.istft
— Methodistft(, X; nfft, noverlap, window)
Compute the inverse short time Fourier transform (ISTFT) of one-sided STFT coefficients X
which is based on segments with nfft
samples with overlap of noverlap
samples. Refer to DSP.Periodograms.spectrogram
for description of the parameters.
For perfect reconstruction, the parameters nfft
, noverlap
and window
in stft
and istft
have to be the same, and the windowing must obey the constraint of "nonzero overlap add" (NOLA). Implementation based on Zhivomirov 2019 and istft
in scipy
.
Examples:
julia> x = randn(1024)
1024-element Array{Float64,1}:
-0.7903319156212055
-0.564789077302601
0.8621044972211616
0.9351928359709288
⋮
2.6158861993992533
1.2980813993011973
-0.010592954871694647
julia> X = stft(x, 64, 0)
33×31 Array{Complex{Float64},2}:
⋮
julia> x̂ = istft(Real, X; nfft=64, noverlap=0)
1024-element Array{Float64,1}:
-0.7903319156212054
-0.5647890773026012
0.8621044972211612
0.9351928359709288
⋮
2.6158861993992537
1.2980813993011973
-0.010592954871694371
SignalAnalysis.istft
— Methodistft(, X; nfft, noverlap, window)
Compute the inverse short time Fourier transform (ISTFT) of two-sided STFT coefficients X
which is based on segments with nfft
samples with overlap of noverlap
samples. Refer to DSP.Periodograms.spectrogram
for description of the parameters.
For perfect reconstruction, the parameters nfft
, noverlap
and window
in stft
and istft
have to be the same, and the windowing must obey the constraint of "nonzero overlap add" (NOLA). Implementation based on Zhivomirov 2019 and istft
in scipy
.
Examples:
julia> x = randn(Complex{Float64}, 1024)
1024-element Array{Complex{Float64},1}:
-0.5540372432417755 - 0.4286434695080883im
-0.4759024596520576 - 0.5609424987802376im
⋮
-0.26493959584225923 - 0.28333817822701457im
-0.5294529732365809 + 0.7345044619457456im
julia> X = stft(x, 64, 0)
64×16 Array{Complex{Float64},2}:
⋮
julia> x̂ = istft(Complex, X; nfft=64, noverlap=0)
1024-element Array{Complex{Float64},1}:
-0.5540372432417755 - 0.4286434695080884im
-0.47590245965205774 - 0.5609424987802374im
⋮
-0.2649395958422591 - 0.28333817822701474im
-0.5294529732365809 + 0.7345044619457455im
SignalAnalysis.mfilter
— Methodmfilter(r, s)
Matched filter looking for reference signal r
in signal s
.
SignalAnalysis.mseq
— Functionmseq(m)
mseq(m, θ)
Generates an m-sequence of length 2^m-1
or tap specification m
.
m-sequences are sequences of +1/-1
values with near-perfect discrete periodic auto-correlation properties. All non-zero lag periodic auto-correlations are -1. The zero-lag autocorrelation is 2^m-1
, where m
is the shift register length.
This function currently supports shift register lengths between 2 and 30.
Examples:
julia> x = mseq(3) # generate regular m-sequence
7-element Array{Float64,1}:
1.0
1.0
1.0
-1.0
1.0
-1.0
-1.0
julia> x = mseq((1,3)) # generate m-sequence with specification (1,3)
7-element Array{Float64,1}:
1.0
1.0
1.0
-1.0
1.0
-1.0
-1.0
SignalAnalysis.pll
— Functionpll(x)
pll(x, bandwidth; fs)
Phased-lock loop to track dominant carrier frequency in input signal.
SignalAnalysis.rcosfir
— Functionrcosfir(β, sps)
rcosfir(β, sps, span)
Raised cosine filter.
SignalAnalysis.removedc!
— Methodremovedc!(s; α)
DC removal filter. Parameter α
controls the cutoff frequency. Implementation based on Lyons 2011 (3rd ed) real-time DC removal filter in Fig. 13-62(d).
See also: removedc
SignalAnalysis.removedc
— Methodremovedc(s; α)
DC removal filter. Parameter α
controls the cutoff frequency. Implementation based on Lyons 2011 (3rd ed) real-time DC removal filter in Fig. 13-62(d).
See also: removedc!
SignalAnalysis.rrcosfir
— Functionrrcosfir(β, sps)
rrcosfir(β, sps, span)
Root-raised cosine filter.
SignalAnalysis.sfilt
— Methodsfilt(f, x[, si])
filt(f, x::SampledSignal[, si])
sfilt(b, a, x[, si])
filt(b, a, x::SampledSignal[, si])
Same as filt
, but retains sampling rate information.
SignalAnalysis.sfiltfilt
— Methodsfiltfilt(coef, x)
filtfilt(coef, x::SampledSignal)
Same as filtfilt
, but retains sampling rate information.
SignalAnalysis.sresample
— Methodsresample(x, rate[, coef])
resample(x::SampledSignal, rate[, coef])
Same as resample
, but correctly handles sampling rate conversion.
SignalAnalysis.upconvert
— Functionupconvert(s, sps, fc)
upconvert(s, sps, fc, pulseshape; fs)
Converts baseband signal with sps
symbols per passband sample to a real passband signal centered around carrier frequency fc
.
SignalAnalysis.whiten
— Methodwhiten(x; nfft, noverlap, window, γ)
Spectral whitening of input signal x
in the frequency domain. The parameters nfft
, noverlap
and window
are required for the computation of STFT coefficients of x
. Refer to DSP.Periodograms.spectrogram
for description of the parameters. γ
is a scaling or degree-of-flattening factor. The algorithm is based on Lee 1986.