2018年11月5日月曜日

開発環境

実践 コンピュータビジョン (Jan Erik Solem (著)、相川 愛三 (翻訳)、オライリージャパン)の1章(基本的な画像処理)、1.6(演習問題)4.を取り組んでみる。

コード(Emacs)

Python 3

#!/usr/bin/env python3
from PIL import Image
import numpy as np
from scipy import ndimage
import imageio

print('4.')


def find_contour(im: np.array) -> np.array:
    imx = np.zeros(im.shape)
    ndimage.filters.sobel(im, 1, imx)
    imy = np.zeros(im.shape)
    ndimage.filters.sobel(im, 0, imy)

    return np.sqrt(imx ** 2 + imy ** 2)


name = 'ginza_blurred_gray'
im_gray = np.array(Image.open(f'{name}.jpg'))

im = find_contour(im_gray)

imageio.imwrite(f'{name}_contours.jpg', im)

# 警告が出るから np.uint8(im2)、im2.astype('uint8')でfloat64を変換
# そうしたら画像が真っ黒になった
# 解決方法がわかるまでは変換しないことに

入出力結果(Terminal, Jupyter(IPython))

$ ./sample4.py
4.
WARNING:root:Lossy conversion from float64 to uint8. Range [0.0, 67.89698078707183]. Convert image to uint8 prior to saving to suppress this warning.
$

0 コメント:

コメントを投稿