Load Packages
1 2 3 4 5
| import numpy as np from PIL import Image import matplotlib.pyplot as plt
%matplotlib inline
|
이미지 불러오기
1 2 3 4 5 6 7 8 9
| path = 'images/dog.jpg'
image_pil = Image.open(path) image = np.array(image_pil)
image.shape
(300, 400, 3)
|
이미지 들여다 보기
1 2 3 4
| np.min(image), np.max(image)
(0, 255)
|
그래프로 시각화하기
1 2
| plt.hist(image.ravel(), 256, [0, 256]) plt.show()
|
data:image/s3,"s3://crabby-images/0d5fc/0d5fca678bda577226846aba0b55a5a7cd6c3c64" alt=""
그림 나타내기
1 2
| plt.imshow(image) plt.show()
|
data:image/s3,"s3://crabby-images/96feb/96feb026e9fadf66930d36302e943256b15f8b5f" alt=""
이미지 흑백으로 열기
1 2 3 4 5 6 7
| image_pil = Image.open(path).convert("L") image_bw = np.array(image_pil)
image_bw.shape
(300, 400)
|
흑백 이미지 열기
1 2
| plt.imshow(image_bw, 'gray') plt.show()
|
data:image/s3,"s3://crabby-images/91cbf/91cbf9b30c6903846a1e1eefb8a64541c50dd2c0" alt=""
다른 색상으로 cmap 표현하기
gray scale
1 2
| plt.imshow(image_bw, 'gray') plt.show()
|
data:image/s3,"s3://crabby-images/91cbf/91cbf9b30c6903846a1e1eefb8a64541c50dd2c0" alt=""
RdBu(Red and Blue)
1 2
| plt.imshow(image_bw, 'RdBu') plt.show()
|
data:image/s3,"s3://crabby-images/7d76f/7d76f8dec0e12ee5862dd61bf51965f70bd1faec" alt=""
jet
색상 값이 높을수록 빨간색, 낮을수록 파란색으로 표현한다.
1 2
| plt.imshow(image_bw, 'jet') plt.show()
|
data:image/s3,"s3://crabby-images/84cb5/84cb5f0dba448beeb702b22804ea6b26d901c480" alt=""
Colorbar 추가하기
1 2 3
| plt.imshow(image_bw, 'jet') plt.colorbar() plt.show()
|
data:image/s3,"s3://crabby-images/d56af/d56af1b87a0d1c3ae0f10a6ab4abfc0e90ee5c2c" alt=""
이미지 설정
이미지 보기 사이즈를 조절한다.
1 2 3
| plt.figure(figsize=(10, 10)) plt.imshow(image) plt.show()
|
data:image/s3,"s3://crabby-images/92e6f/92e6f77055a216dba066d6a29ddb86afce83cbd5" alt=""
이미지에 제목 추가
1 2 3
| plt.title('Dog') plt.imshow(image) plt.show()
|
data:image/s3,"s3://crabby-images/aa6c3/aa6c3e3df9bd60003b80ca8928a6fc4f6a82f15d" alt=""
두 번째 이미지 열기
1 2 3 4 5 6 7
| cat_path = 'images/cat.jpg'
cat_pil = Image.open(cat_path) cat_image = np.array(cat_pil)
plt.imshow(cat_image) plt.show()
|
data:image/s3,"s3://crabby-images/01167/01167c9e254c22a3e3ae7208172a10c833593e2e" alt=""
두 번째 이미지를 첫 번째 이미지 모양에 맞추기
준비
먼저 opencv 패키지를 설치한다.
1
| $ pip install opencv-python
|
1 2 3 4 5 6 7 8
| import cv2
dog_image = cv2.resize(image, (400, 300)) dog_image.shape, cat_image.shape
((300, 400, 3), (300, 400, 3))
|
이미지 합치기
1 2 3
| plt.imshow(dog_image) plt.imshow(cat_image, alpha=0.5) plt.show()
|
data:image/s3,"s3://crabby-images/e1575/e1575a9fcbd345ac0a73c76ef7a50473f11064c5" alt=""
Subplot
1 2 3 4 5 6 7 8
| plt.figure(figsize=(10, 10)) plt.subplot(221) plt.imshow(dog_image) plt.subplot(222) plt.imshow(image_bw, 'gray') plt.subplot(223) plt.imshow(cat_image) plt.show()
|
data:image/s3,"s3://crabby-images/9c884/9c884cbd4cfd04eac9bcc271e2ebf3d643135a23" alt=""