summaryrefslogtreecommitdiffstats
path: root/Wrappers/Python
diff options
context:
space:
mode:
authorVaggelis <epapoutsellis@gmail.com>2019-04-01 20:22:40 +0100
committerVaggelis <epapoutsellis@gmail.com>2019-04-01 20:22:40 +0100
commit4ad78278713683e4c7ba225d303f5e3d1690f979 (patch)
tree091576ae3d7c528436200bf1fcedd37f8e83891c /Wrappers/Python
parentab212446e6e4bf450b38375c3650c643b9c4dffb (diff)
downloadframework-4ad78278713683e4c7ba225d303f5e3d1690f979.tar.gz
framework-4ad78278713683e4c7ba225d303f5e3d1690f979.tar.bz2
framework-4ad78278713683e4c7ba225d303f5e3d1690f979.tar.xz
framework-4ad78278713683e4c7ba225d303f5e3d1690f979.zip
update pdhg TV tomo 2D
Diffstat (limited to 'Wrappers/Python')
-rw-r--r--Wrappers/Python/wip/pdhg_TV_tomography2D.py24
1 files changed, 21 insertions, 3 deletions
diff --git a/Wrappers/Python/wip/pdhg_TV_tomography2D.py b/Wrappers/Python/wip/pdhg_TV_tomography2D.py
index 640e776..52b7922 100644
--- a/Wrappers/Python/wip/pdhg_TV_tomography2D.py
+++ b/Wrappers/Python/wip/pdhg_TV_tomography2D.py
@@ -26,6 +26,22 @@ from skimage.util import random_noise
#%%###############################################################################
# Create phantom for TV tomography
+import os
+import tomophantom
+from tomophantom import TomoP2D
+from tomophantom.supp.qualitymetrics import QualityTools
+
+#model = 1 # select a model number from the library
+#N = 150 # set dimension of the phantom
+## one can specify an exact path to the parameters file
+## path_library2D = '../../../PhantomLibrary/models/Phantom2DLibrary.dat'
+#path = os.path.dirname(tomophantom.__file__)
+#path_library2D = os.path.join(path, "Phantom2DLibrary.dat")
+##This will generate a N_size x N_size phantom (2D)
+#phantom_2D = TomoP2D.Model(model, N, path_library2D)
+#ig = ImageGeometry(voxel_num_x = N, voxel_num_y = N)
+#data = ImageData(phantom_2D, geometry=ig)
+
N = 150
x = np.zeros((N,N))
x[round(N/4):round(3*N/4),round(N/4):round(3*N/4)] = 0.5
@@ -34,7 +50,8 @@ x[round(N/8):round(7*N/8),round(3*N/8):round(5*N/8)] = 1
data = ImageData(x)
ig = ImageGeometry(voxel_num_x = N, voxel_num_y = N)
-detectors = 100
+
+detectors = 150
angles = np.linspace(0,np.pi,100)
ag = AcquisitionGeometry('parallel','2D',angles, detectors)
@@ -57,9 +74,10 @@ plt.title('Noisy Sinogram')
plt.colorbar()
plt.show()
+
#%% Works only with Composite Operator Structure of PDHG
-ig = ImageGeometry(voxel_num_x = N, voxel_num_y = N)
+#ig = ImageGeometry(voxel_num_x = N, voxel_num_y = N)
# Create operators
op1 = Gradient(ig)
@@ -83,7 +101,7 @@ tau = 1/(sigma*normK**2)
pdhg = PDHG(f=f,g=g,operator=operator, tau=tau, sigma=sigma)
pdhg.max_iteration = 5000
-pdhg.update_objective_interval = 500
+pdhg.update_objective_interval = 250
pdhg.run(5000)