AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Polygon aus Kantenbild extrahieren

Ein Thema von Nikolas · begonnen am 17. Jun 2008 · letzter Beitrag vom 13. Jul 2012
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Nikolas
Nikolas

Registriert seit: 28. Jul 2003
1.528 Beiträge
 
Delphi 2005 Personal
 
#1

Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 15:26
Hallo

Ich schreibe gerade an einer kleinen Objekterkennungssoftware die auf Fourierdeskriptoren basiert und habe ein kleines Problem.

Nachdem ich in meinem Bild die Kanten gefunden habe, habe ich rote Konturlinie auf schwarzem Grund, die ich jetzt als Polynom darstellen will. Leider fehlt mir da ein schöner Ansatz.

Wenn ich jedes gefärbte Pixel als Ecke benutze, kann ich sie in keine Sinnvolle Reihenfolge bringen und wie ich Pixel auslassen soll, weiss ich auch nicht.
Vielleicht ist ja einer von euch schon über einen passenden Algorithmus gestolpert.

Nikolas
Erwarte das Beste und bereite dich auf das Schlimmste vor.
  Mit Zitat antworten Zitat
taaktaak

Registriert seit: 25. Okt 2007
Ort: Radbruch
1.990 Beiträge
 
Delphi 7 Professional
 
#2

Re: Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 15:30
Ähhh, du sprichst von Konturlinien auf schwarzem Grund. OK. Aber wieso soll dann jedes gefärbte Pixel eine Ecke sein? Eine Ecke ist dort, wo sich die Steigung der Linie ändert - oder?

// edit: Vorausgesetzt, dass Linie = Gerade
Ralph
  Mit Zitat antworten Zitat
Benutzerbild von Nikolas
Nikolas

Registriert seit: 28. Jul 2003
1.528 Beiträge
 
Delphi 2005 Personal
 
#3

Re: Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 15:39
Mit Konturlinie meine ich nur eine geschlossene Linie. Also einmal Stift aufgesetzt, ohne Überkreuzungen gemalt und wieder zum Ausgangspunkt.
Erwarte das Beste und bereite dich auf das Schlimmste vor.
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#4

Re: Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 16:12
Zunächst einmal müsstest du die Nachbarschaft klären. Es werden hierbei 8er und 4er Nachbarschaften unterschieden, und auf eine davon sollte man die Konturlinien normieren (edit: 4er sind üblich). Anschließend ist es üblich eine Punktliste zu erzeugen, in dem man zunächst linear im Bild einen ersten Pixel sucht, der noch nicht zugeordnet ist, und entsprechend seiner Nachbarschaft um ihn herum nach weiteren sucht. Alle gefundenen Pixel werden in der Finde-Reihenfolge in eine Liste gespeichert, und so markiert, dass sie kein zweites Mal gefunden werden (z.B. schwarz überzeichnen). Findet man um einen Pixel keinen weiteren mehr, ist die Kontur vollständig, und das ganze beginnt von vorne.
Sobald jeder Konturpixel in einer Liste gelandet ist, hast du sämtliche Konturen als geordnete Pixellisten vorliegen. Die einzige Unschönheit ist: Man kann nicht sagen, wie die Listen orientiert sind, bovor sie nicht vollständig sind. Möchtest du also alle Listen z.B. im Uhrzeigersinn haben, musst du hinterher alle überprüfen und ggf. umsortieren.
Edit: Auch ist undefiniert welcher Pixel am Anfang/Ende der Liste Steht. Hier könnte man auch durch nachgelagerte Verarbeitung beikommen.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von Nikolas
Nikolas

Registriert seit: 28. Jul 2003
1.528 Beiträge
 
Delphi 2005 Personal
 
#5

Re: Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 16:40
Wie meinst du das mit der 4er Nachbarschaft?

so:

Delphi-Quellcode:
foo(x,y):
if (pixel(x,y)==rot) then
schreibe (x,y) in die Liste und mache foo (x-1,y), foo (x+1,y),foo(x,y+1), foo(x,y-1)
Meine extrahierte Konturlinie ist grob 3-4Pixel breit. Mit obiger Methode hätte ich ja alle Pixel in der Liste, oder wird da noch eine Auswahl getroffen?
Erwarte das Beste und bereite dich auf das Schlimmste vor.
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#6

Re: Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 17:45
Zitat von Nikolas:
Wie meinst du das mit der 4er Nachbarschaft?

so:
Jap. Bei der 8er kommen die diagonalen hinzu. Aber das interessiert dich noch nicht, weil:
Zitat:
Meine extrahierte Konturlinie ist grob 3-4Pixel breit.
D.h. du brauchst noch einen Verarbeitungsschritt davor, da die Linie auf 1px Breite geracht werden muss, da sonst die Nachbarschaften ja auch keinen Sinn machen. 4er Nachbarschaft heisst, dass ein Pixel der Kontur in seinen 4 Nachbarn (oben, unten, links, rechts) maximal 2 weitere Pixel haben darf: Einen Vorgänger und einen Nachfolger. Diese Bedingung ist logischerweise nicht mit >1px breiten Konturen erfüllbar. Du musst, wie man es so schön nennt, vor her skelettieren. Dieses PDF beschreibt einen möglichen Algo dazu. Bevor das nicht geschehen ist, kannst du mit deinen Konturen nichts machen, da sie eigentlich gar keine sind.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von Nikolas
Nikolas

Registriert seit: 28. Jul 2003
1.528 Beiträge
 
Delphi 2005 Personal
 
#7

Re: Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 20:04
Das klingt sehr gut. Wenn ich nur noch eine Linie (1px) habe, kann ich auch deutlich einfacher Pixel entfernen, die nichts zur Kontur beitragen. Alternativ kann ich sie auch einfach drinlassen, der Berechnungsaufwand ist linear und recht klein,
und sobald ich bei den Fourierkoeffizienten die höheren Terme weglasse, habe ich auch so eine Glättung im kleinen Bereich.
Hast du da irgendwo eine Implementierung rumliegen? (Sprache egal, da ich eigentlich in Java schreibe?) Beim einfachen Skelletieren mit den 3x3Matrizen weiss ich nicht genau, was mit den 9 Vergleichsmasken gemeint ist. Bei der Durchlaufrichtung steht "oben links nach unten links"... Was soll ich mir darunter vorstellen?

Vielen Dank
Erwarte das Beste und bereite dich auf das Schlimmste vor.
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#8

Re: Polygon aus Kantenbild extrahieren

  Alt 17. Jun 2008, 23:37
Ich würde das Verfahren nach Zhang und Suen eher empfehlen, als die 9-Matrizen Variante. (Das ist in o.g. auch beschrieben.) Klingt zwar zunächst etwas aufwendig, aber wenn man sich dazu einmal die Basisoperationen gebastelt hat gehts.

Um einzelne "Fransen" und lose Pixel loszuwerden, kann man ein sog. Opening durchführen, welches sich wiederum aus den Schritten Erosion und Dilatation zusammensetzt. Das hier enthält eine der besser verständlichen Beschreibungen des ganzen (ziemlich am Ende). Der Kram ist an sich total Simpel, nur irgendwie recht kompliziert zu erklären...
Opening kann nur dazu führen, dass ab und an mal eine eigentlich geschlossene Kontur unterbrochen wird, je nach Bild und gewähltem Strukturelement. Das müsste man dann in Kauf nehmen.
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von Nikolas
Nikolas

Registriert seit: 28. Jul 2003
1.528 Beiträge
 
Delphi 2005 Personal
 
#9

Re: Polygon aus Kantenbild extrahieren

  Alt 18. Jun 2008, 08:20
Für Zhang/Suen habe ich ich mich jetzt auch entschieden.
Die Implementation ist ja eher einfach, und bringt schöne Ergebnisse.

Vielen Dank für deine Hilfe, dass hat mich doch ordentlich weitergebracht.

Leider ist der Code in Java, sonst hätte ich ihn in die CodeLib gestellt.

Vielleicht hat ja einer der Leute, die nie wissen, was sie schreiben sollen, Lust ihn umzuschreiben und etwas zu beschleunigen.

Eine Anleitung und Code gibt's hier.

Meine JavaAnpassung mit ein paar Hilfsfunktionen für rgb-Bilder sind im Anhang.
Miniaturansicht angehängter Grafiken
gedrehtoriginal_202.jpg   gedreht_612.jpg  
Angehängte Dateien
Dateityp: pas utilities_212.pas (6,8 KB, 14x aufgerufen)
Erwarte das Beste und bereite dich auf das Schlimmste vor.
  Mit Zitat antworten Zitat
Benutzerbild von Nikolas
Nikolas

Registriert seit: 28. Jul 2003
1.528 Beiträge
 
Delphi 2005 Personal
 
#10

Re: Polygon aus Kantenbild extrahieren

  Alt 18. Jun 2008, 16:32
So, da bin ich wieder. Ich schaffe es leider nicht, aus der Pixellinie jetzt ein Polygon zu machen
Mein Ansatz sieht so aus, dass ich mit einem Pixel starte, alle Objektpixel in der 8er Nachbarschaft auf einen Stack schreibe, dann das oberste Objekt vom Stack nehme, denn Nachbarn draufschreibe usw. Alle gepopten Elemente schreibe ich dann in eine Liste

Damit erreiche ich zwar alle Punkte, nur leider stimmt die Reihenfolge nicht so ganz. Ich kann leider nicht ganz naiv die Pixel entlang gehen, da ich bei manchen Kanten noch kleine Kreuzungen habe, an denen ein paar Pixel der Kontur falsch abbiegen.

Hast da jemand eine Idee?
Erwarte das Beste und bereite dich auf das Schlimmste vor.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:32 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz