画像を5列の2D配列に変換します。各行の形式は[r, g, b, x, y]
。 x、yはピクセルの位置、r、g、bはピクセル値です。 (この配列を機械学習モデルへの入力として使用します)。 Pythonでこれよりも効率的な実装はありますか?
import Image
import numpy as np
im = Image.open("farm.jpg")
col,row = im.size
data = np.zeros((row*col, 5))
pixels = im.load()
for i in range(row):
for j in range(col):
r,g,b = pixels[i,j]
data[i*col + j,:] = r,g,b,i,j
最近これを書かなければならなかった
indices = np.dstack(np.indices(im.shape[:2]))
data = np.concatenate((im, indices), axis=-1)
ここで、im
はnumpy配列です。おそらくnumpy配列に画像を直接読み込む方が良いでしょう
from scipy.misc import imread
im = imread("farm.jpg")
または、Scikit Imageがインストールされている場合はさらに良い
from skimage.io import imread
im = imread("farm.jpg")
これが非常に効率的かどうかはわかりません。しかし、ここで、arr = np.array(im)
;と言います。その後、このようなことを行うことができます。
>>> arr = np.arange(150).reshape(5, 10, 3)
>>> x, y, z = arr.shape
>>> indices = np.vstack(np.unravel_index(np.arange(x*y), (y, x))).T
#or indices = np.hstack((np.repeat(np.arange(y), x)[:,np.newaxis], np.tile(np.arange(x), y)[:,np.newaxis]))
>>> np.hstack((arr.reshape(x*y, z), indices))
array([[ 0, 1, 2, 0, 0],
[ 3, 4, 5, 0, 1],
[ 6, 7, 8, 0, 2],
[ 9, 10, 11, 0, 3],
[ 12, 13, 14, 0, 4],
[ 15, 16, 17, 1, 0],
[ 18, 19, 20, 1, 1],
[ 21, 22, 23, 1, 2],
[ 24, 25, 26, 1, 3],
[ 27, 28, 29, 1, 4],
[ 30, 31, 32, 2, 0],
[ 33, 34, 35, 2, 1],
[ 36, 37, 38, 2, 2],
...
[129, 130, 131, 8, 3],
[132, 133, 134, 8, 4],
[135, 136, 137, 9, 0],
[138, 139, 140, 9, 1],
[141, 142, 143, 9, 2],
[144, 145, 146, 9, 3],
[147, 148, 149, 9, 4]])
「+」を使用して2つのタプルを結合し、.append()
を使用して「データ」リストを作成しました。ここではNumpyを使用する必要はありません。
row,col = im.size
data=[] #r,g,b,i,j
pixels=im.load()
for i in range(row):
for j in range(col):
data.append(pixels[i,j]+(i,j))