Inhaltsverzeichnis
Inflation ist das Gegenteil und kann ausgedrückt werden als
Heim Backend-Entwicklung Python-Tutorial So implementieren Sie grundlegende morphologische Filterung in Python

So implementieren Sie grundlegende morphologische Filterung in Python

May 21, 2023 pm 11:29 PM
python

Es gibt vier grundlegendste morphologische Operationen, nämlich Erosion, Erweiterung, offene Berechnung und geschlossene Berechnung. „scipy.ndimage implementiert diese vier Operationen für binäre Arrays bzw. Graustufen-Arrays.“

binary_erosiongrey_erosiongrey_dilationexpansionbin ary_closinggrey_closingSchließen (zuerst Ausdehnung und dann Korrosion)binäres_Öffnen graues_ÖffnenÖffnen ( zuerst Korrosion und dann Ausdehnung)Die sogenannte Korrosion wird in mathematischen Symbolen ausgedrückt alswobei B bedeutet, wenn der Ursprung von B BB bei (i, j) liegt , die Menge aller Werte, die in B 1 sind. Diese Formel bedeutet, dass, wenn Struktur B zum Korrodieren von A verwendet wird, der Ursprung von B auf das Pixel (i, j) von Bild A übertragen wird und B vollständig vom überlappenden Bereich der beiden umgeben ist Der Wert wird mit 1 belegt. Ansonsten ist der Wert 0. Wenn ein bestimmtes Element in B 1 ist und die entsprechende Position in A ebenfalls 1 ist, ist der Wert bei (i, j) 1. Dies ist ein intuitiveres Beispiel.
corrosion binary_dilation
Binäre Morphologie
ij

Inflation ist das Gegenteil und kann ausgedrückt werden als

So implementieren Sie grundlegende morphologische Filterung in PythonMit anderen Worten, solange der Überlappungsbereich von B und A keine leere Menge ist, wird der (i, j)-Punkt auf gesetzt 1.

Ein Beispiel ist wie folgt

import numpy as np
import matplotlib.pyplot as plt
import scipy.ndimage as sn

x = np.zeros([20,20])
x[5:15, 5:15] = 1
x_ero = sn.binary_erosion(x)
x_dil = sn.binary_dilation(x)

fig = plt.figure()
ax = fig.add_subplot(1,3,1)
ax.imshow(x)
plt.title("original")
ax = fig.add_subplot(1,3,2)
ax.imshow(x_ero)
plt.title("erosion")
ax = fig.add_subplot(1,3,3)
ax.imshow(x_dil)
plt.title("dilation")
plt.show()
Nach dem Login kopieren
Der Öffnungsvorgang besteht darin, zuerst zu korrodieren und sich dann auszudehnen; der Schließvorgang besteht darin, sich zuerst auszudehnen und dann zu korrodieren. Das Beispiel ist wie folgt:

x = np.zeros([20,20])
x[5:15, 5:15] = 1
x[10:12,10:12] = 0
x[2:4, 2:4] = 1

x_open = sn.binary_opening(x)
x_close = sn.binary_closing(x)

fig = plt.figure()
ax = fig.add_subplot(1,3,1)
ax.imshow(x)
plt.title("original")
ax = fig.add_subplot(1,3,2)
ax.imshow(x_open)
plt.title("opening")
ax = fig.add_subplot(1,3,3)
ax.imshow(x_close)
plt.title("closing")
plt.show()
Nach dem Login kopieren

Der Effekt ist wie folgt. Es ist ersichtlich, dass die Öffnungsoperation die isolierte 1 entfernt und die Schließoperation die isolierte 1 entfernt. Die Operation entfernt isolierte Nullen.

So implementieren Sie grundlegende morphologische Filterung in PythonGraustufenmorphologie

Die Korrosions-, Erweiterungs- und Öffnungs- und Schließoperationen von Graustufenbildern sind eine Erweiterung ihrer Binärform, wobei eine Faltungslogik direkt aus

abgerufen wird und Korrosion und Erweiterung durchführt und Öffnungs- und Schließvorgänge nacheinander.

from scipy.misc import ascent
img = ascent()

funcs = {
    "original": lambda x, tmp:x,
    "erosion" : sn.grey_erosion,
    "dilation" : sn.grey_dilation,
    "opening" : sn.grey_opening,
    "closing" : sn.grey_closing
}

fig = plt.figure()
for i, key in enumerate(funcs):
    ax = fig.add_subplot(2,3,i+1)
    plt.imshow(funcs[key](img, (10,10)), cmap=plt.cm.gray)
    plt.title(key)

plt.show()
Nach dem Login kopieren

Parameterliste

So implementieren Sie grundlegende morphologische Filterung in PythonDie Parameter der Binärfunktion und der Graustufenfunktion sind nicht identisch. Am Beispiel der folgenden Abschlussoperation sind alle Parameter der Binär- und Graustufenfunktionen mit Ausnahme der Eingabeeingabe gleich beides.

Struktur ist ein Array-Typ, der das Konstruktionselement darstellt, das als Faltungsvorlage verstanden werden kann

So implementieren Sie grundlegende morphologische Filterung in Python

Ausgabe ist ein Array mit den gleichen Abmessungen wie die Eingabe, und die Ergebnisse können gespeichert werden

scipyOrgin-Filtereinstellungen, der Standardwert ist 0

Andere Parameter der binären morphologischen Filterung sind wie folgt

binary_closing(input, iterations=1, mask=None, border_value=0, brute_force=False)
Nach dem Login kopieren

wobei

  • iterationen die Anzahl der Ausführungen ist

  • Mask-Masken-Array, bei dem es sich um ein Bool-Array handelt Typ, und die Position, die False entspricht, ändert sich nicht

  • border_value Der Wert an der Kante

brute_force Wenn es False ist, wird nur der Wert aktualisiert, der sich in der letzten Iteration geändert hat

grey_closing(input, size=None, footprint=None, mode='reflect', cval=0.0)
Nach dem Login kopieren
  • Größe ist die Filtervorlage. Modus optional: Reflektieren, Konstante, Nächster, Spiegel, Umbruch, Kantenfüllmethode

Das obige ist der detaillierte Inhalt vonSo implementieren Sie grundlegende morphologische Filterung in Python. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Wie löste ich das Problem der Berechtigungen beim Betrachten der Python -Version in Linux Terminal? Apr 01, 2025 pm 05:09 PM

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Wie kann ich die gesamte Spalte eines Datenrahmens effizient in einen anderen Datenrahmen mit verschiedenen Strukturen in Python kopieren? Apr 01, 2025 pm 11:15 PM

Bei der Verwendung von Pythons Pandas -Bibliothek ist das Kopieren von ganzen Spalten zwischen zwei Datenrahmen mit unterschiedlichen Strukturen ein häufiges Problem. Angenommen, wir haben zwei Daten ...

Warum kann mein Code nicht die von der API zurückgegebenen Daten erhalten? Wie löst ich dieses Problem? Warum kann mein Code nicht die von der API zurückgegebenen Daten erhalten? Wie löst ich dieses Problem? Apr 01, 2025 pm 08:09 PM

Warum kann mein Code nicht die von der API zurückgegebenen Daten erhalten? Bei der Programmierung stoßen wir häufig auf das Problem der Rückgabe von Nullwerten, wenn API aufruft, was nicht nur verwirrend ist ...

Können Python -Parameteranmerkungen Zeichenfolgen verwenden? Können Python -Parameteranmerkungen Zeichenfolgen verwenden? Apr 01, 2025 pm 08:39 PM

Alternative Verwendung von Python -Parameteranmerkungen in der Python -Programmierung, Parameteranmerkungen sind eine sehr nützliche Funktion, die den Entwicklern helfen kann, Funktionen besser zu verstehen und zu verwenden ...

Wie lösten Python -Skripte an einem bestimmten Ort die Ausgabe in Cursorposition? Wie lösten Python -Skripte an einem bestimmten Ort die Ausgabe in Cursorposition? Apr 01, 2025 pm 11:30 PM

Wie lösten Python -Skripte an einem bestimmten Ort die Ausgabe in Cursorposition? Beim Schreiben von Python -Skripten ist es üblich, die vorherige Ausgabe an die Cursorposition zu löschen ...

Python Cross-Platform Desktop-Anwendungsentwicklung: Welche GUI-Bibliothek ist die beste für Sie? Python Cross-Platform Desktop-Anwendungsentwicklung: Welche GUI-Bibliothek ist die beste für Sie? Apr 01, 2025 pm 05:24 PM

Auswahl der Python-plattformübergreifenden Desktop-Anwendungsentwicklungsbibliothek Viele Python-Entwickler möchten Desktop-Anwendungen entwickeln, die sowohl auf Windows- als auch auf Linux-Systemen ausgeführt werden können ...

Python Hourglass Graph Drawing: Wie vermeiden Sie variable undefinierte Fehler? Python Hourglass Graph Drawing: Wie vermeiden Sie variable undefinierte Fehler? Apr 01, 2025 pm 06:27 PM

Erste Schritte mit Python: Hourglas -Grafikzeichnung und Eingabeüberprüfung In diesem Artikel wird das Problem der Variablendefinition gelöst, das von einem Python -Anfänger im Hourglass -Grafikzeichnungsprogramm auftritt. Code...

Wie kann ich große Produktdatensätze in Python effizient zählen und sortieren? Wie kann ich große Produktdatensätze in Python effizient zählen und sortieren? Apr 01, 2025 pm 08:03 PM

Datenkonvertierung und Statistik: Effiziente Verarbeitung großer Datensätze In diesem Artikel werden ausführlich das Umwandeln einer Datenliste in eine andere enthält ...

See all articles