1. CNN
data:image/s3,"s3://crabby-images/491dd/491dd40d430cea1909846ec0f1da0b2d55163e77" alt=""
data:image/s3,"s3://crabby-images/0e71d/0e71dc917d52220de51aae9c6297a6b4803871c4" alt=""
data:image/s3,"s3://crabby-images/58b5f/58b5fe193fd37fa8c10253265e911852593c37af" alt=""
2. DNN
data:image/s3,"s3://crabby-images/07db3/07db3d7116201871b7d76bfad11240ccd72e2b91" alt=""
3. 이미지 좌표계
data:image/s3,"s3://crabby-images/601b8/601b83282d25fa8b8e74eb256a9c8fecc52d4d9a" alt=""
import numpy as np
from PIL import Image
import matplotlib.pyplot as plt
img = Image.open('../images/justice.jpg')
print(type(img))
plt.imshow(img)
plt.show()
data:image/s3,"s3://crabby-images/58595/58595e7977b78980244afe29919881dc13602a70" alt=""
4. Pillow를 이용한 이미지 처리
1. Cropping (이미지 잘라내기)
crop(좌상,우하)
crop_img = img.crop((30,110,140,330))
plt.imshow(crop_img)
plt.show()
data:image/s3,"s3://crabby-images/cee18/cee182187b1aaead3c10269debe059d897177fd4" alt=""
2. Image Resize
print(img.size)
int(img.size[0] / 8)
resize_img = img.resize((int(img.size[0] / 8), int(img.size[1] / 8)))
plt.imshow(resize_img)
plt.show()
crop_img = img.crop((30,110,140,330))
plt.imshow(crop_img)
plt.show()
data:image/s3,"s3://crabby-images/45171/45171652e68edbb6670fa19faced2a0a5c4ebb85" alt=""
3. Image Rotate
rotate_img = img.rotate(180)
plt.imshow(rotate_img)
plt.show()
rotate_img.save('../images/rotate_justice.jpg')
data:image/s3,"s3://crabby-images/034ac/034ac8e980402abf9a6784af0eef8829ad30bfb2" alt=""
5. Digital Image 형태
data:image/s3,"s3://crabby-images/3e517/3e5171a086df6733fe8e8d8b9492ecb7d02244c3" alt=""
import numpy as np
from PIL import Image
import matplotlib.pyplot as plt
color_img = Image.open('../images/fruits.jpg')
plt.imshow(color_img)
plt.show()
data:image/s3,"s3://crabby-images/4d063/4d063bd4fb92e7605946b33978aab7eaa9472a7a" alt=""
color_pixel = np.array(color_img)
print(color_pixel.shape)
1. gray-scaled image로 변환
color image의 pixel값을 조절해서 변환
가장 쉬운 방법 : color image의 각 pixel을 구성하고 있는 RGB 값들의 평균값으로
이미지의 각 pixel의 RGB값을 다시 설정
ex) (0,0) 픽셀의 RGB 값이 [100,200,60] 일 때 RGB 평균 : 120
(0,0) 픽셀의 값을 [120,120,120]으로 변경하면 흑백처리
gray_pixel = color_pixel.copy()
print(gray_pixel.shape)
for y in range(gray_pixel.shape[0]):
for x in range(gray_pixel.shape[1]):
gray_pixel[y,x] = int(np.mean(gray_pixel[y,x]))
plt.imshow(gray_pixel)
plt.show()
print(gray_pixel.shape)
data:image/s3,"s3://crabby-images/9683d/9683dd2c95c7f5b372fdc2df3b9e243e1ecc1a4b" alt=""
2. 흑백이미지를 2차원으로 표현
gray_2d_pixel = gray_pixel[:,:,0]
print(gray_2d_pixel.shape)
plt.imshow(gray_2d_pixel, cmap='Greys_r')
plt.show()
data:image/s3,"s3://crabby-images/c3d64/c3d64dec36f276e5f86bf1a9e3c414762a1596b7" alt=""
6. 합성곱 연산
data:image/s3,"s3://crabby-images/ae11b/ae11b3fa749c7cf164a0853fd32ee54be6c581ea" alt=""
data:image/s3,"s3://crabby-images/75114/75114867808a42d5cd99c39f9014e9b6dcd1db6b" alt=""
data:image/s3,"s3://crabby-images/b786e/b786e1b406fe020734c6cc75675940400c4b856e" alt=""
data:image/s3,"s3://crabby-images/08f4e/08f4e5517520a51bd9c3696cf480c40fb33d45d5" alt=""
data:image/s3,"s3://crabby-images/01c4a/01c4af38ea6d0caa6c5c262ae80bb38f80b6c349" alt=""
zero padding
data:image/s3,"s3://crabby-images/c8d41/c8d418846ff28f10b3e9b078bfc8c6c889aff8da" alt=""
padding : 'VALID'(no padding) or "SAVE"
(convolution 결과가 원본 이미지의 크기와 같다)
import numpy as np
import tensorflow as tf
image = np.array([[[[9],[8],[7]],
[[6],[5],[4]],
[[3],[2],[1]]]], dtype=np.float64)
print(image.shape)
weight = np.array([[[[2]],[[2]]],
[[[2]],[[2]]]])
print(weight.shape)
con2d = tf.nn.conv2d(image,
weight,
strides=[1,1,1,1],
padding='VALID')
sess = tf.Session()
result = sess.run(con2d)
print(result)
data:image/s3,"s3://crabby-images/a390c/a390c33ffc323661d2523f60679f5fd61cf7a255" alt=""