SciPy - Ndimage
Moduł podrzędny SciPy ndimage jest przeznaczony do przetwarzania obrazu. Tutaj ndimage oznacza n-wymiarowy obraz.
Oto niektóre z najczęściej wykonywanych zadań podczas przetwarzania obrazu & miuns;
- Wejście / Wyjście, wyświetlanie obrazów
- Podstawowe czynności - kadrowanie, przerzucanie, obracanie itp.
- Filtrowanie obrazu - usuwanie szumów, wyostrzanie itp.
- Segmentacja obrazu - oznaczanie pikseli odpowiadających różnym obiektom
- Classification
- Ekstrakcja cech
- Registration
Omówmy, jak niektóre z nich można osiągnąć za pomocą SciPy.
Otwieranie i zapisywanie do plików graficznych
Plik misc packagew SciPy zawiera kilka obrazów. Używamy tych obrazów, aby nauczyć się manipulacji obrazami. Rozważmy następujący przykład.
from scipy import misc
f = misc.face()
misc.imsave('face.png', f) # uses the Image module (PIL)
import matplotlib.pyplot as plt
plt.imshow(f)
plt.show()
Powyższy program wygeneruje następujące dane wyjściowe.
Wszystkie obrazy w formacie surowym to kombinacja kolorów reprezentowanych przez liczby w formacie macierzy. Maszyna rozumie obrazy i manipuluje nimi tylko na podstawie tych liczb. RGB to popularny sposób reprezentacji.
Zobaczmy informacje statystyczne z powyższego obrazu.
from scipy import misc
face = misc.face(gray = False)
print face.mean(), face.max(), face.min()
Powyższy program wygeneruje następujące dane wyjściowe.
110.16274388631184, 255, 0
Teraz wiemy, że obraz składa się z liczb, więc każda zmiana wartości liczby zmienia oryginalny obraz. Wykonajmy na obrazie transformacje geometryczne. Podstawową operacją geometryczną jest kadrowanie
from scipy import misc
face = misc.face(gray = True)
lx, ly = face.shape
# Cropping
crop_face = face[lx / 4: - lx / 4, ly / 4: - ly / 4]
import matplotlib.pyplot as plt
plt.imshow(crop_face)
plt.show()
Powyższy program wygeneruje następujące dane wyjściowe.
Możemy również wykonać podstawowe operacje, takie jak odwracanie obrazu do góry nogami, jak opisano poniżej.
# up <-> down flip
from scipy import misc
face = misc.face()
flip_ud_face = np.flipud(face)
import matplotlib.pyplot as plt
plt.imshow(flip_ud_face)
plt.show()
Powyższy program wygeneruje następujące dane wyjściowe.
Poza tym mamy rotate() function, który obraca obraz pod określonym kątem.
# rotation
from scipy import misc,ndimage
face = misc.face()
rotate_face = ndimage.rotate(face, 45)
import matplotlib.pyplot as plt
plt.imshow(rotate_face)
plt.show()
Powyższy program wygeneruje następujące dane wyjściowe.
Filtry
Omówmy, jak filtry pomagają w przetwarzaniu obrazu.
Co to jest filtrowanie w przetwarzaniu obrazu?
Filtrowanie to technika modyfikowania lub ulepszania obrazu. Na przykład możesz przefiltrować obraz, aby podkreślić określone cechy lub usunąć inne cechy. Operacje przetwarzania obrazu zaimplementowane z filtrowaniem obejmują wygładzanie, wyostrzanie i ulepszanie krawędzi.
Filtrowanie to operacja sąsiedztwa, w której wartość dowolnego piksela w obrazie wyjściowym jest określana przez zastosowanie pewnego algorytmu do wartości pikseli w sąsiedztwie odpowiedniego piksela wejściowego. Wykonajmy teraz kilka operacji za pomocą SciPy ndimage.
Zamazywanie
Rozmycie jest szeroko stosowane w celu zmniejszenia szumów obrazu. Możemy wykonać operację filtrowania i zobaczyć zmianę na obrazie. Rozważmy następujący przykład.
from scipy import misc
face = misc.face()
blurred_face = ndimage.gaussian_filter(face, sigma=3)
import matplotlib.pyplot as plt
plt.imshow(blurred_face)
plt.show()
Powyższy program wygeneruje następujące dane wyjściowe.
Wartość sigma wskazuje poziom rozmycia w pięciostopniowej skali. Możemy zobaczyć zmianę jakości obrazu, dostrajając wartość sigma. Aby uzyskać więcej informacji na temat rozmycia, kliknij → Samouczek DIP (Digital Image Processing).
Wykrywanie krawędzi
Omówmy, jak wykrywanie krawędzi pomaga w przetwarzaniu obrazu.
Co to jest wykrywanie krawędzi?
Wykrywanie krawędzi to technika przetwarzania obrazu służąca do znajdowania granic obiektów na obrazach. Działa poprzez wykrywanie nieciągłości jasności. Wykrywanie krawędzi służy do segmentacji obrazu i ekstrakcji danych w takich obszarach, jak przetwarzanie obrazu, wizja komputerowa i widzenie maszynowe.
Do najczęściej używanych algorytmów wykrywania krawędzi należą
- Sobel
- Canny
- Prewitt
- Roberts
- Metody Fuzzy Logic
Rozważmy następujący przykład.
import scipy.ndimage as nd
import numpy as np
im = np.zeros((256, 256))
im[64:-64, 64:-64] = 1
im[90:-90,90:-90] = 2
im = ndimage.gaussian_filter(im, 8)
import matplotlib.pyplot as plt
plt.imshow(im)
plt.show()
Powyższy program wygeneruje następujące dane wyjściowe.
Obraz wygląda jak kwadratowy blok kolorów. Teraz wykryjemy krawędzie tych kolorowych bloków. Tutaj ndimage udostępnia funkcję o nazwieSobeldo wykonania tej operacji. Podczas gdy NumPy zapewniaHypot funkcja, aby połączyć dwie wynikowe macierze w jedną.
Rozważmy następujący przykład.
import scipy.ndimage as nd
import matplotlib.pyplot as plt
im = np.zeros((256, 256))
im[64:-64, 64:-64] = 1
im[90:-90,90:-90] = 2
im = ndimage.gaussian_filter(im, 8)
sx = ndimage.sobel(im, axis = 0, mode = 'constant')
sy = ndimage.sobel(im, axis = 1, mode = 'constant')
sob = np.hypot(sx, sy)
plt.imshow(sob)
plt.show()
Powyższy program wygeneruje następujące dane wyjściowe.