Cropping images#

When working with microscopy images, it often makes limited sense to process the whole image. We typically crop out interesting regions and process them in detail.

from import imread, imshow
image = imread("../data/blobs.tif")

Before we can crop an image, we may want to know its precise shape (dimensions):

(254, 256)

Recap: Visualization using imshow:

<matplotlib.image.AxesImage at 0x2990e248520>

Cropping images works exactly like cropping lists and tuples:

cropped_image1 = image[0:128]

<matplotlib.image.AxesImage at 0x2990e347190>

To crop the image in the second dimension as well, we add a , in the square brackets:

cropped_image2 = image[0:128, 128:]

<matplotlib.image.AxesImage at 0x2990e3b6280>

Sub-sampling images#

Also step sizes can be specified as if we would process lists and tuples. Technically, we are sub-sampling the image in this case. We sample a subset of the original pixels:

sampled_image = image[::5, ::5]

<matplotlib.image.AxesImage at 0x2990e416f10>

Flipping images#

Negative step sizes flip the image.

flipped_image = image[::, ::-1]

<matplotlib.image.AxesImage at 0x2990f453160>


Open the banana020.tif data set and crop out the region where the banana slice is located.