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/c5cf2/c5cf2f9cf955fb96955abb411ebc9e5aee4cae53" alt="_images/1dtransform-1_00.png"
data:image/s3,"s3://crabby-images/81259/81259e856aac8405e3aa23db2957ab031d73ae59" alt="_images/1dtransform-1_01.png"
data:image/s3,"s3://crabby-images/7bbe9/7bbe9761de43a67ac05e5ef3e1a1c3973badeadf" alt="_images/1dtransform-1_02.png"
data:image/s3,"s3://crabby-images/1f0a7/1f0a7b6167c49143132a54181a72573db765b4b0" alt="_images/1dtransform-1_03.png"
data:image/s3,"s3://crabby-images/7ee58/7ee5882996bdb9ed7a31349a55f8c35a7dff39e2" alt="_images/1dtransform-1_04.png"