dilation1dilation1Dilation1Dilation1 (Operator)

Name

dilation1dilation1Dilation1Dilation1 — Ausdehnen von Regionen.

Signatur

dilation1(Region, StructElement : RegionDilation : Iterations : )

Herror dilation1(const Hobject Region, const Hobject StructElement, Hobject* RegionDilation, const Hlong Iterations)

Herror T_dilation1(const Hobject Region, const Hobject StructElement, Hobject* RegionDilation, const Htuple Iterations)

void Dilation1(const HObject& Region, const HObject& StructElement, HObject* RegionDilation, const HTuple& Iterations)

HRegion HRegion::Dilation1(const HRegion& StructElement, Hlong Iterations) const

static void HOperatorSet.Dilation1(HObject region, HObject structElement, out HObject regionDilation, HTuple iterations)

HRegion HRegion.Dilation1(HRegion structElement, int iterations)

Beschreibung

dilation1dilation1Dilation1Dilation1Dilation1 berechnet die Dilatation der Eingaberegionen mit einem strukturierenden Element. Die Anwendung von dilation1dilation1Dilation1Dilation1Dilation1 glättet die Ränder der Regionen. Gleichzeitig vergrößert sich die Fläche dieser Regionen. Darüberhinaus kann es vorkommen, dass vorher nicht zusammenhängende Regionen verschmolzen werden. Dennoch bleiben solche Regionen logisch verschiedene Region. Die Dilatation ist eine mengentheoretische Regionenoperation. Sie verwendet die Operation Vereinigung.

Seien M (StructElementStructElementStructElementStructElementstructElement) und R (RegionRegionRegionRegionregion) Regionen, wobei M das „strukturierende Element“ und R die zu verarbeitende Region darstellt. Sei weiterhin m ein Punkt aus M, dann wird der Verschiebungsvektor definiert als die Differenz des Schwerpunktvektors von M mit dem Vektor . Die Translation einer Region R um einen Vektor sei mit bezeichnet. Dann ist

Es wird für jeden Punkt m in M eine Translation mit der Region R durchgeführt. Die Vereinigung über all diese Verschiebungen ist die Dilatation der Region R mit M. dilation1dilation1Dilation1Dilation1Dilation1 entspricht dem Operator minkowski_add1minkowski_add1MinkowskiAdd1MinkowskiAdd1MinkowskiAdd1 mit dem Unterschied, dass bei dilation1dilation1Dilation1Dilation1Dilation1 das strukturierende Element punktgespiegelt wird. Die Position von StructElementStructElementStructElementStructElementstructElement ist ohne Bedeutung, da die Verschiebungsvektoren bzgl. des Schwerpunktes bestimmt werden.

Der Parameter IterationsIterationsIterationsIterationsiterations bezeichnet die Anzahl der Iterationen, die mit dem strukturierenden Elemente ausgeführt werden sollen. Als Eingaberegion für die Iteration n wird die Ergebnisregion der Iteration (n-1) verwendet. Aus der obigen Definition ergibt sich, dass bei einem leeren strukturierenden Element eine leere Region erzeugt wird.

Strukturierende Elemente (StructElementStructElementStructElementStructElementstructElement) können mit Operatoren wie gen_circlegen_circleGenCircleGenCircleGenCircle, gen_rectangle1gen_rectangle1GenRectangle1GenRectangle1GenRectangle1, gen_rectangle2gen_rectangle2GenRectangle2GenRectangle2GenRectangle2, gen_ellipsegen_ellipseGenEllipseGenEllipseGenEllipse, draw_regiondraw_regionDrawRegionDrawRegionDrawRegion, gen_region_polygongen_region_polygonGenRegionPolygonGenRegionPolygonGenRegionPolygon, gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsGenRegionPoints etc. erzeugt werden.

Achtung

Eine Dilatation führt grundsätzlich zu einer Vergrößerung der Regionen. Eng benachbarte Regionen, die nach Ausführung des Operators zusammenstoßen oder sich überlappen, werden weiterhin als zwei getrennte Regionen behandelt. Um eine Vereinigung zweier Regionen zu erreichen muss zuerst ein union1union1Union1Union1Union1 durchgeführt werden.

Ausführungsinformationen

Parameter

RegionRegionRegionRegionregion (input_object)  region(-array) objectHRegionHRegionHobject

Regionen,die verarbeitet werden sollen.

StructElementStructElementStructElementStructElementstructElement (input_object)  region objectHRegionHRegionHobject

Strukturierendes Element.

RegionDilationRegionDilationRegionDilationRegionDilationregionDilation (output_object)  region(-array) objectHRegionHRegionHobject *

Ergebnis der Dilation-Operation.

IterationsIterationsIterationsIterationsiterations (input_control)  integer HTupleHTupleHtuple (integer) (int / long) (Hlong) (Hlong)

Anzahl der Iterationen.

Defaultwert: 1

Wertevorschläge: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 15, 17, 20, 30, 40, 50

Typischer Wertebereich: 1 ≤ Iterations Iterations Iterations Iterations iterations (lin)

Minimale Schrittweite: 1

Empfohlene Schrittweite: 1

Komplexität

Sei F1 die Fläche einer Eingaberegion und F2 die Fläche des strukturierenden Elementes, dann ist die Laufzeitkomplexität für ein Objekt:

Ergebnis

Bei korrekter Parametrisierung liefert die Funktion dilation1dilation1Dilation1Dilation1Dilation1 den Wert 2 (H_MSG_TRUE). Das Funktionsverhalten für die beiden Fälle leere und keine Eingaberegion lässt sich wie folgt kontrollieren:

Andernfalls wird eine Fehlerbehandlung durchgeführt.

Vorgänger

thresholdthresholdThresholdThresholdThreshold, regiongrowingregiongrowingRegiongrowingRegiongrowingRegiongrowing, connectionconnectionConnectionConnectionConnection, union1union1Union1Union1Union1, watershedswatershedsWatershedsWatershedsWatersheds, class_ndim_normclass_ndim_normClassNdimNormClassNdimNormClassNdimNorm, gen_circlegen_circleGenCircleGenCircleGenCircle, gen_ellipsegen_ellipseGenEllipseGenEllipseGenEllipse, gen_rectangle1gen_rectangle1GenRectangle1GenRectangle1GenRectangle1, gen_rectangle2gen_rectangle2GenRectangle2GenRectangle2GenRectangle2, draw_regiondraw_regionDrawRegionDrawRegionDrawRegion, gen_region_pointsgen_region_pointsGenRegionPointsGenRegionPointsGenRegionPoints, gen_region_polygon_filledgen_region_polygon_filledGenRegionPolygonFilledGenRegionPolygonFilledGenRegionPolygonFilled

Nachfolger

reduce_domainreduce_domainReduceDomainReduceDomainReduceDomain, add_channelsadd_channelsAddChannelsAddChannelsAddChannels, select_shapeselect_shapeSelectShapeSelectShapeSelectShape, area_centerarea_centerAreaCenterAreaCenterAreaCenter, connectionconnectionConnectionConnectionConnection

Alternativen

minkowski_add1minkowski_add1MinkowskiAdd1MinkowskiAdd1MinkowskiAdd1, minkowski_add2minkowski_add2MinkowskiAdd2MinkowskiAdd2MinkowskiAdd2, dilation2dilation2Dilation2Dilation2Dilation2

Siehe auch

erosion1erosion1Erosion1Erosion1Erosion1, erosion2erosion2Erosion2Erosion2Erosion2, openingopeningOpeningOpeningOpening, closingclosingClosingClosingClosing

Modul

Foundation