Images#
import PIL
from PIL import Image
import numpy as np
import matplotlib.pyplot as plt
import scipy.signal as sp
import urllib.request
##download the image
imgURL = "https://raw.githubusercontent.com/smart-stats/ds4bio_book/main/qbook/assets/images/Duhauron1877.jpg"
urllib.request.urlretrieve(imgURL, "Duhauron1877.jpg")
## Load it into PIL
img = Image.open("Duhauron1877.jpg")
## You can see it with this, or img.show()
img
data:image/s3,"s3://crabby-images/ed38a/ed38ac655a2c450bd86370a182346adddb89ca98" alt="_images/56b195b136d2857a98349d9834dc3b31c1848316203cf5ccc9702d69c875105a.png"
PIL objects come with a ton of methods. For example, if we want to know whether we have an RGB or CMYK image, just print its mode.
print(img.mode)
RGB
r, g, b = img.split()
plt.figure(figsize=(10,4));
plt.subplot(1, 3, 1);
plt.axis('off');
plt.imshow(r);
plt.subplot(1, 3, 2);
plt.axis('off');
plt.imshow(g);
plt.subplot(1, 3, 3);
plt.axis('off');
plt.imshow(b);
data:image/s3,"s3://crabby-images/0d358/0d358692cfeda48c7d66ea00543ac7cdc2b99b1d" alt="_images/9df14ddc8212834ad0c1fb474f33b2b517c498eb7780833d6d584e453c9c2936.png"
If you’re tired of working with the image as a PIL object, it’s easy to convert to a np array.
img_array = np.array(img)
img_array.shape
(585, 800, 3)
Before we leave PIL, it should be said that most image operations can be done in it. For example, cropping. Consider cropping out this house.
bbox = [500, 200, 630, 280]
cropped = img.crop(bbox)
cropped
data:image/s3,"s3://crabby-images/8b16d/8b16d19eaa57aaf02f9529f4f50313259689012f" alt="_images/c0fde4b77fd3b890d1b7bfb086bbae86550f43d34ab480b81895d488a034aeed.png"
We can rotate the house and put it back
rot = cropped.transpose(Image.Transpose.ROTATE_180)
rot
data:image/s3,"s3://crabby-images/9d92f/9d92f4d5304826b2a7b866b582a55297dca0b7cf" alt="_images/89d3e50c8ed63a00b4a44f295def33051357b7098e1936e885d190b8a061c319.png"
##Note this overwrites the image
img.paste(rot, bbox)
img
data:image/s3,"s3://crabby-images/1afe6/1afe67ab07bf564be3ff7160fa11e84a7eedb00e" alt="_images/eaaf0233d2c9c6cef30ffff796ea6c970fde79de4fb09613f47b63014476ad87.png"