Jak podzielić Numpy Array (obraz) na kafelki, aby je iterować? [duplikować]
Mam obraz typu Numpy Array, który chciałbym podzielić na 9 (3 x 3) równych kafelków, które mogę powtórzyć. Jak mogę to zrobić?
Oto mój kod do wygenerowania numpy.ndarray, ale nie udało mi się go podzielić:
Tablica numpy obrazów do podziału to th1
import cv2
import numpy as np
# Only for the threshold display
from matplotlib import pyplot as plt
# The Image to be used
image = 'six.png'
# Finding the average greyscale value
image_bgr = cv2.imread(image, cv2.IMREAD_COLOR)
# Calculate the mean of each channel
channels = cv2.mean(image_bgr)
# Type Float
thresh = channels[0]/2
#print (thresh)
# Displaying the threshold value
img = cv2.imread(image,0)
img = cv2.medianBlur(img,5)
# If below then black else white
ret,th1 = cv2.threshold(img,thresh,255,cv2.THRESH_BINARY)
titles = ['Original Image', 'Global Thresholding']
images = [img, th1, ret]
for i in range(2):
plt.subplot(2,2,i+1),plt.imshow(images[i],'gray')
plt.title(titles[i])
plt.xticks([]),plt.yticks([])
# Shows single image on its' own
plt.imshow(images[1], 'gray')
plt.xticks([]),plt.yticks([])
Oto obraz (six.png):

Odpowiedzi
To, co zrobiłbym, to stworzyć listę lub dwuwymiarową tablicę, w której zapisałbym „kafelki” pełnego obrazu. Kafelki zostaną skopiowane przy użyciu poniższego kodu:
height, width, dim = img.shape
image_tile = img[0:height/3, 0:width/3]
Tworzy nowy ndarray image_tile, który zawiera część pełnej tablicy obrazu, która jest wewnątrz współrzędnych. W tym przypadku jest to lewy górny kafelek.
Cały przykład z pętlą for wyglądałby mniej więcej tak:
image_tile = []
for i in range(0,3):
for j in range(0,3):
image_tile.append(img[i * height/3:(i+1) * height/3, j * width/3:(j+1) * width/3])
Mam nadzieję, że to pomoże i powodzenia!
Znalazłem rozwiązanie zaadaptowane gdzie indziej i działa świetnie!
img = th1
numrows, numcols = 3, 3
height = int(img.shape[0] / numrows)
width = int(img.shape[1] / numcols)
for row in range(numrows):
for col in range(numcols):
y0 = row * height
y1 = y0 + height
x0 = col * width
x1 = x0 + width
individual = (img[y0:y1, x0:x1])
plt.imshow(individual, 'gray')
plt.xticks([]),plt.yticks([])
plt.show()