From 456c8b1140fb1e4ab99ae985a70f025f6157e337 Mon Sep 17 00:00:00 2001 From: Edoardo Pasca Date: Fri, 27 Oct 2017 16:45:38 +0100 Subject: further development using abstract forward/backward projector --- src/Python/ccpi/reconstruction/AstraDevice.py | 36 ++++++++++++++-------- src/Python/ccpi/reconstruction/DeviceModel.py | 7 ++++- .../ccpi/reconstruction/FISTAReconstructor.py | 33 +++++--------------- 3 files changed, 37 insertions(+), 39 deletions(-) (limited to 'src/Python/ccpi') diff --git a/src/Python/ccpi/reconstruction/AstraDevice.py b/src/Python/ccpi/reconstruction/AstraDevice.py index d854183..ba174b3 100644 --- a/src/Python/ccpi/reconstruction/AstraDevice.py +++ b/src/Python/ccpi/reconstruction/AstraDevice.py @@ -1,5 +1,5 @@ import astra -from DeviceModel import DeviceModel +from ccpi.reconstruction.DeviceModel import DeviceModel class AstraDevice(DeviceModel): '''Concrete class for Astra Device''' @@ -9,6 +9,9 @@ class AstraDevice(DeviceModel): data_aquisition_geometry, reconstructed_volume_geometry): + super(AstraDevice, self).__init__(device_type, + data_aquisition_geometry, + reconstructed_volume_geometry) self.proj_geom = astra.creators.create_proj_geom( device_type, @@ -17,7 +20,6 @@ class AstraDevice(DeviceModel): self.acquisition_data_geometry['cameraX'], self.acquisition_data_geometry['cameraY'], self.acquisition_data_geometry['angles'], - angles_rad ) self.vol_geom = astra.creators.create_vol_geom( @@ -48,19 +50,27 @@ Uses Astra-toolbox self.vol_geom) astra.matlab.data3d('delete', idx) return volume - def createReducedDevice(self): - return AstraDevice(self.proj_geom['type'], - {'detectorSpacingX' : self.proj_geom['DetectorSpacingX'] , - 'detectorSpacingY' : self.proj_geom['DetectorSpacingY'] , - 'cameraX' : self.proj_geom['DetectorColCount'] , - 'cameraY' : 1 , - 'angles' : self.proj_geom['ProjectionAngles'] } , - { - 'X' : self.vol_geom['GridColCount'], - 'Y' : self.vol_geom['GridRowCount'] - 'Z' : 1} ) + proj_geom = astra.creators.create_proj_geom( + device_type, + self.acquisition_data_geometry['detectorSpacingX'], + self.acquisition_data_geometry['detectorSpacingX'], + self.acquisition_data_geometry['cameraX'], + 1, + self.acquisition_data_geometry['angles'], + ) + vol_geom = astra.creators.create_vol_geom( + self.reconstructed_volume_geometry['X'], + self.reconstructed_volume_geometry['Y'], + 1 + ) + return AstraDevice(proj_geom['type'] , + proj_geom, + vol_geom) + + + if __name__=="main": a = AstraDevice() diff --git a/src/Python/ccpi/reconstruction/DeviceModel.py b/src/Python/ccpi/reconstruction/DeviceModel.py index 1717321..6214437 100644 --- a/src/Python/ccpi/reconstruction/DeviceModel.py +++ b/src/Python/ccpi/reconstruction/DeviceModel.py @@ -44,7 +44,7 @@ reconstructed_volume_geometry: tuple (dimX,dimY,dimZ) 'Z': reconstructed_volume_geometry[2] } @abstractmethod - def doFowardProject(self, volume): + def doForwardProject(self, volume): '''Forward projects the volume according to the device geometry''' return NotImplemented @@ -53,5 +53,10 @@ reconstructed_volume_geometry: tuple (dimX,dimY,dimZ) def doBackwardProject(self, projections): '''Backward projects the projections according to the device geometry''' return NotImplemented + + @abstractmethod + def createReducedDevice(self): + '''Create a Device to do forward/backward projections on 2D slices''' + return NotImplemented diff --git a/src/Python/ccpi/reconstruction/FISTAReconstructor.py b/src/Python/ccpi/reconstruction/FISTAReconstructor.py index 1e464a1..d2eefc0 100644 --- a/src/Python/ccpi/reconstruction/FISTAReconstructor.py +++ b/src/Python/ccpi/reconstruction/FISTAReconstructor.py @@ -27,7 +27,7 @@ import numpy from enum import Enum import astra -from ccpi.reconstruction.AstraDevice import AstraDevice +#from ccpi.reconstruction.AstraDevice import AstraDevice @@ -74,7 +74,10 @@ class FISTAReconstructor(): # 3. "A novel tomographic reconstruction method based on the robust # Student's t function for suppressing data outliers" D. Kazantsev et.al. # D. Kazantsev, 2016-17 - def __init__(self, projector_geometry, output_geometry, input_sinogram, + def __init__(self, projector_geometry, + output_geometry, + input_sinogram, + device, **kwargs): # handle parmeters: # obligatory parameters @@ -87,16 +90,10 @@ class FISTAReconstructor(): self.pars['number_of_angles'] = nangles self.pars['SlicesZ'] = sliceZ self.pars['output_volume'] = None - + self.pars['device'] = device - device = createAstraDevice(projector_geometry, output_geometry) - self.setParameter(device_model=device) - proj_geomT = projector_geometry.copy(); - proj_geomT['DetectorRowCount'] = 1; - vol_geomT = output_geometry.copy(); - vol_geomT['GridSliceCount'] = 1; - reduced_device = createAstraDevice(proj_geomT, vol_geomT) + reduced_device = device.createReducedDevice() self.setParameter(reduced_device_model=reduced_device) self.use_device = True @@ -187,21 +184,7 @@ class FISTAReconstructor(): self.pars['initialize'] = False - def createAstraDevice(self, projector_geometry, output_geometry): - '''TODO remove''' - - device = AstraDevice(DeviceModel.PARALLEL3D, - {'detectorSpacingX' : projector_geometry['DetectorSpacingX'] , - 'detectorSpacingY' : projector_geometry['DetectorSpacingY'] , - 'cameraX' : projector_geometry['DetectorColCount'] , - 'cameraY' : projector_geometry['DetectorRowCount'] , - 'angles' : projector_geometry['ProjectionAngles'] } , - { - 'X' : output_geometry['GridColCount'], - 'Y' : output_geometry['GridRowCount'] - 'Z' : output_geometry['GridSliceCount']} ) - return device - + def setParameter(self, **kwargs): '''set named parameter for the reconstructor engine -- cgit v1.2.3