import spidev
import time
import numpy as np
import matplotlib
matplotlib.use('Agg')
import matplotlib.pyplot as plt
import json
import time
from pyUn0 import *
%matplotlib inline
import os
from scipy.signal import hilbert, resample
import cv2
Not loading RPi.GPIO as not on RPi
for MyDataFile in os.listdir("data/"):
if MyDataFile.endswith(".json"):
x = us_json()
x.JSONprocessing("data/"+MyDataFile)
CleanImage = x.mk2DArray()
S = x.mkSpectrum(CleanImage)
Data acquired
data:image/s3,"s3://crabby-images/73f5d/73f5dc5404d53e48ea63d011397ffaa8550271b2" alt="png"
Data acquired
data:image/s3,"s3://crabby-images/24eee/24eee45fdfec7e4ecfbce3c4cd3cb9e9ee7041fb" alt="png"
data:image/s3,"s3://crabby-images/fbbc7/fbbc78fc3607f7d5c7c6edce0e5c71af524dc646" alt="png"
Data acquired
data:image/s3,"s3://crabby-images/27a65/27a6581a78be9b496d09ca06e7280827d4edcbed" alt="png"
data:image/s3,"s3://crabby-images/43be2/43be29a99495673a22882946d5744443381d5133" alt="png"
Data acquired
data:image/s3,"s3://crabby-images/724d4/724d423a212a922cb9534a1e3dc46270a561eeb1" alt="png"
data:image/s3,"s3://crabby-images/c3483/c34830266642e6f4bfbb5fd5b7e999ba929da6b2" alt="png"
Data acquired
data:image/s3,"s3://crabby-images/27762/27762140e4924af5698f4b4c6b6dede3b9fac5cc" alt="png"
data:image/s3,"s3://crabby-images/04669/046696c59c22f5510b881124ff65a9a691d0921a" alt="png"
Data acquired
data:image/s3,"s3://crabby-images/1b610/1b610cb74a9731e5449c79039c6b43a75cdd4355" alt="png"
data:image/s3,"s3://crabby-images/832cd/832cd1d97a1779722405b5a4a6b55c8d0a3cfe27" alt="png"
Data acquired
data:image/s3,"s3://crabby-images/ca9af/ca9afffc43dcc9f42b7b66447418e6e033425546" alt="png"
data:image/s3,"s3://crabby-images/ab994/ab994e4b7189e952a908958e8ece960e5509d3f1" alt="png"
data:image/s3,"s3://crabby-images/7cabd/7cabd58683487ba8cecd7050427d15ad5ca3f77a" alt="png"
for MyDataFile in os.listdir("data/"):
if MyDataFile.endswith("c-6.json"):
x = us_json()
x.JSONprocessing("data/"+MyDataFile)
CleanImage = x.mk2DArray()
S = x.mkSpectrum(CleanImage)
Data acquired
data:image/s3,"s3://crabby-images/c1e82/c1e8231c2a84abb3acc56b1372297f482c9be0a8" alt="png"
data:image/s3,"s3://crabby-images/e240b/e240b7656eae81b64ac15b91c41f4ee6378d30eb" alt="png"
Building clean image
plt.imshow((CleanImage[:,10:400]))
<matplotlib.image.AxesImage at 0x7f21d431b750>
data:image/s3,"s3://crabby-images/2a337/2a3373a8be642be447c970cafa63f6883200885c" alt="png"
MV = np.argmax(np.var(CleanImage, axis=1))
L = len(CleanImage[MV])
f = [k*x.f/L for k in range(L)]
plt.plot(f, np.abs(np.fft.fft(CleanImage[MV])))
plt.show()
x.f
data:image/s3,"s3://crabby-images/6631b/6631b1c23ee097b1854868773f3f7a1991bfe23e" alt="png"
16.0
N,L = np.shape(CleanImage)
HMatrix = []
for m in range(N):
line = CleanImage[m]
L = len(line)
A = np.fft.fft(line)
for k in range (L/2 + 1):
if k < (L * x.fPiezo * 0.2 / x.f):
A[k] = 0
A[-k] = 0
if k > (L * x.fPiezo *1.7 / x.f):
A[k] = 0
A[-k] = 0
CleanImage[m] = np.real(np.fft.ifft(A))
HMatrix.append(resample(np.abs(hilbert(CleanImage[m])),1000))
plt.plot(np.abs(A))
plt.show()
data:image/s3,"s3://crabby-images/90938/9093898ece8da044ce74ffefb217a5524f7ae0da" alt="png"
ProbeOffset = int(x.timings['t4'] *x.f / 1000)
CledImage = np.pad(CleanImage, ((0,0),(ProbeOffset,0)), 'constant')
HMatrixCld = np.pad(HMatrix, ((0,0),(ProbeOffset,0)), 'constant')
np.shape(HMatrix)
(365, 1000)
plt.figure(figsize = (15,15))
im = plt.imshow(np.sqrt(HMatrixCld), cmap='gray', aspect=1*(len(HMatrix[0])/len(HMatrix)), interpolation='nearest')
data:image/s3,"s3://crabby-images/378a5/378a555e0a6c9c7282acd8c7486ce423616aef27" alt="png"
%%time
import cv2
CPU times: user 0 ns, sys: 0 ns, total: 0 ns
Wall time: 18.1 µs
n,l = np.shape(HMatrixCld)
print n,l
365 1560
%%time
maxRadius = l
print("maxRadius = {} pixels".format(maxRadius))
plt.imshow(HMatrixCld, cmap='gray')
plt.title("Input image")
plt.show()
angle_range = np.pi/2
theta_scale_factor = n / angle_range
print("{} rows per radian".format(theta_scale_factor))
theta_min = 3/2*np.pi - angle_range/2
theta_max = 3/2*np.pi + angle_range/2
print("theta: [{}, {}] radians".format(theta_min, theta_max))
pad_below = int(theta_min * theta_scale_factor)
pad_above = int((2*np.pi - theta_max) * theta_scale_factor)
print("Padding {} above and {} below".format(pad_above, pad_below))
im_below = np.zeros((pad_below, maxRadius))
im_above = np.zeros((pad_above, maxRadius))
padded_image = np.vstack((im_above, HMatrixCld, im_below))
plt.imshow(padded_image, cmap='gray')
plt.title("Vertically Padded image")
plt.show()
scaled_image = cv2.resize(padded_image, (2*maxRadius, maxRadius), interpolation=cv2.INTER_CUBIC)
plt.imshow(scaled_image, cmap='gray')
plt.title("Scaled image")
plt.show()
center = (int(scaled_image.shape[0]/2),int(scaled_image.shape[1])/2)
flags = cv2.WARP_INVERSE_MAP
im_out = cv2.linearPolar(scaled_image, center, maxRadius, flags)
plt.imshow(im_out, cmap='gray')
plt.title("Output image")
plt.show()
maxRadius = 1560 pixels
data:image/s3,"s3://crabby-images/fa8f5/fa8f5e10187b12443ebbc9e02418324f393b813f" alt="png"
232.366216914 rows per radian
theta: [2.35619449019, 3.92699081699] radians
Padding 547 above and 547 below
data:image/s3,"s3://crabby-images/efeda/efedac0acbd25f412312e2c87ba08bfc9d72f2c1" alt="png"
data:image/s3,"s3://crabby-images/5af78/5af78fcd82865fd54e5367014a066802d73aeaf2" alt="png"
data:image/s3,"s3://crabby-images/66ea8/66ea874b4decb2248cb2859ccafa0831e3e51885" alt="png"
CPU times: user 2.52 s, sys: 2.68 s, total: 5.21 s
Wall time: 4.31 s
im_in = np.asarray(HMatrix)
im_in.shape[0]
365
maxRadius = im_in.shape[1]
print("maxRadius = {} pixels".format(maxRadius))
angle_range = np.pi/2
theta_scale_factor = im_in.shape[0] / angle_range
print("{} rows per radian".format(theta_scale_factor))
theta_min = 3/2*np.pi - angle_range/2
theta_max = 3/2*np.pi + angle_range/2
print("theta: [{}, {}] radians".format(theta_min, theta_max))
pad_below = int(0.5* theta_min * theta_scale_factor)
pad_above = int(0.5* (2*np.pi - theta_max) * theta_scale_factor)
print("Padding {} above and {} below".format(pad_above, pad_below))
im_below = np.zeros((pad_below, maxRadius), dtype='uint16')
im_above = np.zeros((pad_above, maxRadius), dtype='uint16')
padded_image = np.vstack((im_above, im_in, im_below))
scaled_image = cv2.resize(padded_image, (2*maxRadius, maxRadius), interpolation=cv2.INTER_CUBIC)
center = (int(scaled_image.shape[1]/2), 0)
flags = cv2.WARP_INVERSE_MAP
im_out = cv2.linearPolar(scaled_image, center, maxRadius, flags)
maxRadius = 1000 pixels
232.366216914 rows per radian
theta: [2.35619449019, 3.92699081699] radians
Padding 273 above and 273 below
plt.imshow(scaled_image)
plt.show()
data:image/s3,"s3://crabby-images/2a921/2a92151b525beff7e4ec036de23c73cde0be10de" alt="png"
center = (2200, 500)
maxRadius = 2000
flags = cv2.WARP_INVERSE_MAP
dst = cv2.linearPolar(scaled_image, center, maxRadius, flags)
plt.imshow(np.flipud(np.transpose(dst)), cmap='gray')
<matplotlib.image.AxesImage at 0x7f21d4554d50>
data:image/s3,"s3://crabby-images/b393d/b393d3fe9a5fe2554e5bb0323f9724ed095a851f" alt="png"