Skip to content

Commit

Permalink
bprj: add output=None convenience
Browse files Browse the repository at this point in the history
- follow-up to NiftyPET#36
- part of NiftyPET#33
  • Loading branch information
casperdcl authored and fdellekart committed Oct 1, 2024
1 parent 2a22c48 commit 1a405e4
Showing 1 changed file with 10 additions and 2 deletions.
12 changes: 10 additions & 2 deletions niftypet/nipet/prj/mmrprj.py
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,7 @@ def frwd_prj(im, scanner_params, isub=ISUB_DEFAULT, dev_out=False, attenuation=F
# ------------------------------------------------------------------------


def back_prj(sino, scanner_params, isub=ISUB_DEFAULT, dev_out=False):
def back_prj(sino, scanner_params, isub=ISUB_DEFAULT, dev_out=False, output=None):
'''
Calculate forward projection for the provided input image.
Arguments:
Expand All @@ -152,6 +152,7 @@ def back_prj(sino, scanner_params, isub=ISUB_DEFAULT, dev_out=False):
transaxial and axial look up tables (LUT).
isub -- array of transaxial indices of all sinograms (angles x bins) used for subsets;
when the first element is negative, all transaxial bins are used (as in pure EM-ML).
output(CuVec, optional) -- output image.
'''
# Get particular scanner parameters: Constants, transaxial and axial LUTs
Cnt = scanner_params['Cnt']
Expand Down Expand Up @@ -199,7 +200,14 @@ def back_prj(sino, scanner_params, isub=ISUB_DEFAULT, dev_out=False):
nvz = Cnt['rSZ_IMZ']
else:
nvz = Cnt['SZ_IMZ']
bimg = cu.zeros((Cnt['SZ_IMX'], Cnt['SZ_IMY'], nvz), dtype=np.float32)

out_shape = Cnt['SZ_IMX'], Cnt['SZ_IMY'], nvz
if output is None:
bimg = cu.zeros(out_shape, dtype=np.float32)
else:
bimg = cu.asarray(output)
assert bimg.shape == out_shape
assert bimg.dtype == np.dtype('float32')

# > run back-projection
petprj.bprj(bimg.cuvec, cu.asarray(sinog).cuvec, txLUT, axLUT, isub, Cnt)
Expand Down

0 comments on commit 1a405e4

Please sign in to comment.