Skip to content

Commit

Permalink
Move np to ImageCube into images.py
Browse files Browse the repository at this point in the history
  • Loading branch information
jeffjennings authored Oct 31, 2023
1 parent 1b76a32 commit efa6807
Showing 1 changed file with 36 additions and 0 deletions.
36 changes: 36 additions & 0 deletions src/mpol/images.py
Original file line number Diff line number Diff line change
Expand Up @@ -316,3 +316,39 @@ def to_FITS(self, fname="cube.fits", overwrite=False, header_kwargs=None):
hdul.writeto(fname, overwrite=overwrite)

hdul.close()


def np_to_imagecube(image, coords, nchan=1, wrap=False):
"""Convenience function for converting a numpy image into an MPoL ImageCube
tensor (see mpol.images.ImageCube)
Parameters
----------
image : array
An image in numpy format
coords : `mpol.coordinates.GridCoords` object
Instance of the `mpol.coordinates.GridCoords` class
nchan : int, default=1
Number of channels in the image. Default assumes a single 2D image
wrap : bool, default=False
Whether to wrap the numpy image so that index 0 is in the image center
(FFT algorithms typically place index 0 in the image corner)
Returns
-------
icube : `mpol.images.ImageCube` object
The image cube tensor
"""
if wrap:
# move the 0 index to the image center
image = center_np_image(image)

# broadcast image to (nchan, npix, npix)
img_packed_cube = np.broadcast_to(image,
(nchan, coords.npix, coords.npix)).copy()

# convert to pytorch tensor
img_packed_tensor = torch.from_numpy(img_packed_cube)

# insert into ImageCube layer
return ImageCube(coords=coords, nchan=nchan, cube=img_packed_tensor)

0 comments on commit efa6807

Please sign in to comment.