diff options
author | Suren A. Chilingaryan <csa@ipecompute4.ands.kit.edu> | 2022-07-27 00:28:05 +0200 |
---|---|---|
committer | Suren A. Chilingaryan <csa@ipecompute4.ands.kit.edu> | 2022-07-27 00:28:05 +0200 |
commit | 5e72985e2983e9be8117696fe0ec02388e7153f1 (patch) | |
tree | 1fe327b22f4689a36badb65a63f1bd557e04810a /src/operators/UfoStandardProjector.py | |
parent | 003beff76cd87b50a7a858a6b056fe2ff30bac3f (diff) | |
download | ccpi-ufo-harish.tar.gz ccpi-ufo-harish.tar.bz2 ccpi-ufo-harish.tar.xz ccpi-ufo-harish.zip |
Latest stuff I found from Harishharish
Diffstat (limited to 'src/operators/UfoStandardProjector.py')
-rw-r--r-- | src/operators/UfoStandardProjector.py | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/src/operators/UfoStandardProjector.py b/src/operators/UfoStandardProjector.py new file mode 100644 index 0000000..cef1a36 --- /dev/null +++ b/src/operators/UfoStandardProjector.py @@ -0,0 +1,58 @@ +# ======================================================================== +# Copyright 2019 Science Technology Facilities Council +# Copyright 2019 University of Manchester +# +# This work is part of the Core Imaging Library developed by Science Technology +# Facilities Council and University of Manchester +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0.txt +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# ========================================================================= + +from cil.optimisation.operators import LinearOperator +from src.processors import UfoStandardForwardProjector, UfoStandardBackProjector + +class UfoStandardProjector(LinearOperator): + """UFO projector modified to use DataSet and geometry.""" + + def __init__(self, geomv, geomp): + + super(UfoStandardProjector, self).__init__(domain_geometry=geomv, range_geometry=geomp) + + self.sinogram_geometry = geomp + self.volume_geometry = geomv + + self.fp = UfoStandardForwardProjector(volume_geometry=geomv, sinogram_geometry=geomp) + self.bp = UfoStandardBackProjector(volume_geometry=geomv, sinogram_geometry=geomp) + + def direct(self, IM, out=None): + self.fp.set_input(IM) + + if out is None: + return self.fp.get_output() + else: + out.fill(self.fp.get_output()) + + def adjoint(self, DATA, out=None): + self.bp.set_input(DATA) + + if out is None: + return self.bp.get_output() + else: + out.fill(self.bp.get_output()) + + def domain_geometry(self): + return self.volume_geometry + + def range_geometry(self): + return self.sinogram_geometry |