1D transform
This example generates two 1D random walks and demonstrates reconstructing them
using the forward and inverse 1D transforms. Note that
:py:func`dtcwt.Transform1d.forward` and dtcwt.Transform1d.inverse()
will transform columns of an input array independently
from matplotlib.pylab import *
import dtcwt
# Generate a 300x2 array of a random walk
vecs = np.cumsum(np.random.rand(300,2) - 0.5, 0)
# Show input
figure()
plot(vecs)
title('Input')
# 1D transform, 5 levels
transform = dtcwt.Transform1d()
vecs_t = transform.forward(vecs, nlevels=5)
# Show level 2 highpass coefficient magnitudes
figure()
plot(np.abs(vecs_t.highpasses[1]))
title('Level 2 wavelet coefficient magnitudes')
# Show last level lowpass image
figure()
plot(vecs_t.lowpass)
title('Lowpass signals')
# Inverse
vecs_recon = transform.inverse(vecs_t)
# Show output
figure()
plot(vecs_recon)
title('Output')
# Show error
figure()
plot(vecs_recon - vecs)
title('Reconstruction error')
print('Maximum reconstruction error: {0}'.format(np.max(np.abs(vecs - vecs_recon))))
data:image/s3,"s3://crabby-images/7de54/7de54cd6859c622be8bfedeca62838f3032c5f66" alt="_images/1dtransform-1_00.png"
data:image/s3,"s3://crabby-images/ca317/ca317021c7635a5fae1859fef1c649b26b05d3f3" alt="_images/1dtransform-1_01.png"
data:image/s3,"s3://crabby-images/40eda/40edad524250aef7223d85fae89c596c070cb516" alt="_images/1dtransform-1_02.png"
data:image/s3,"s3://crabby-images/1841f/1841fa5bd015737cd1e2872a9f47bbcff66ca775" alt="_images/1dtransform-1_03.png"
data:image/s3,"s3://crabby-images/b6262/b6262c581abc1e54db13c54c982e322515931fcd" alt="_images/1dtransform-1_04.png"