3-D Computer Vision CSc – Ioannis Stamos 3-D Computer Vision CSc Binary Images Horn (Robot Vision): pages
3-D Computer Vision CSc – Ioannis Stamos Binary Images Binary Image b(x,y): Obtained from Gray-Level (or other image) g(x,y) By Thresholding. Characteristic Function: 1 g(x,y) < T b(x,y)= 0 g(x,y) >= T 1)Geometrical Properties 2)Discrete Binary Images 3)Multiple objects 4)Sequential and Iterative Processing.
3-D Computer Vision CSc – Ioannis Stamos Selecting the Threshold (T) g(x,y) HISTOGRAM h(i) T i (intensity) BIMODAL b(x,y)
3-D Computer Vision CSc – Ioannis Stamos Histogram Thresholding T
3-D Computer Vision CSc – Ioannis Stamos Geometric Properties Assume: 1) b(x,y) is continuous 2) Only one object y x b(x,y)
3-D Computer Vision CSc – Ioannis Stamos Geometric Properties Assume: 1) b(x,y) is continuous 2) Only one object y x b(x,y) Area: (Zeroth Moment)
3-D Computer Vision CSc – Ioannis Stamos Geometric Properties Assume: 1) b(x,y) is continuous 2) Only one object y x b(x,y) Area: (Zeroth Moment) Position: “Center” (x,y) of Area (First Moment)
3-D Computer Vision CSc – Ioannis StamosOrientation Difficult to define! We use axis of least second moment (x,y) r ρ θ axis y x
3-D Computer Vision CSc – Ioannis StamosOrientation Difficult to define! We use axis of least second moment For mass distribution: Axis of minimum Inertia. (x,y) r ρ θ axis y x Minimize:
Orientation Difficult to define! We use axis of least second moment For mass distribution: Axis of minimum Inertia. (x,y) r ρ θ axis y x Minimize: Equation of Axis: y=mx+b ??? 0<= m <= infinity We use: ( ρ, θ) finite. Find ( ρ, θ) that minimize E for a given b(x,y)
3-D Computer Vision CSc – Ioannis Stamos We can show that: So:
3-D Computer Vision CSc – Ioannis Stamos We can show that: So: Using dE/dρ=0 we get:
3-D Computer Vision CSc – Ioannis Stamos We can show that: So: Using dE/dρ=0 we get: Note: Axis passes through center (x,y)!! So, change coordinates: x’=x-x, y’=y-y
3-D Computer Vision CSc – Ioannis Stamos We can show that: So: Using dE/dρ=0 we get: Note: Axis passes through center (x,y)!! So, change coordinates: x’=x-x, y’=y-y We get: Second Moments w.r.t. (x, y)
3-D Computer Vision CSc – Ioannis Stamos We can show that: So: Using dE/dρ=0 we get: Note: Axis passes through center (x,y)!! So, change coordinates: x’=x-x, y’=y-y We get: Second Moments w.r.t. (x, y) Mistake in your handout.
3-D Computer Vision CSc – Ioannis Stamos Using dE/dθ=0, we get: tan(2θ)=b/(a-c) 2θ b a-c
3-D Computer Vision CSc – Ioannis Stamos Using dE/dθ=0, we get: tan(2θ)=b/(a-c) So: 2θ b a-c
3-D Computer Vision CSc – Ioannis Stamos Using dE/dθ=0, we get: tan(2θ)=b/(a-c) So: Solutions with positive sign may be used to find θ that minimizes E (why??). Emin/Emax -> (ROUDNESS of the OBJECT). 2θ b a-c
3-D Computer Vision CSc – Ioannis Stamos Discrete Binary Images bij: value at pixel in row i & column j O j (y) m i (x) n
3-D Computer Vision CSc – Ioannis Stamos Discrete Binary Images bij: value at pixel in row i & column j. Assume pixel area is 1. Area: Position (Center of Area): O j (y) m i (x) n
3-D Computer Vision CSc – Ioannis Stamos Discrete Binary Images bij: value at pixel in row i & column j. Assume pixel area is 1. Area: Position (Center of Area): O j (y) m i (x) n Second Moments.
3-D Computer Vision CSc – Ioannis Stamos Discrete Binary Images (cont) Note: a’,b’,c’ are second moments w.r.t ORIGIN a,b,c (w.r.t “center”) can be found from (a’,b’,c’,x,y,A). Note: UPDATE (a’,b’,c’,x,y,A) during RASTER SCAN.
3-D Computer Vision CSc – Ioannis Stamos Multiple Objects Need to SEGMENT image into separate COMPONENTS (regions). Connected Component: Maximal Set of Connected Points: B A Points A and B are connected: Path exists between A and B along which b(x,y) is constant.
3-D Computer Vision CSc – Ioannis Stamos Connected Components Label all pixels that are connected 4-way connected8-way connected
3-D Computer Vision CSc – Ioannis Stamos Region Growing Algorithm (Connected Component Labeling) Start with “seed” point where bij=1. Assign LABEL to seed point. Assign SAME LABEL to its NEIGHBORS (b=1). Assign SAME LABEL to NEIGHBORS of NEIGHBORS. Terminates when a component is completely labeled. Then pick another UNLABELED seed point.
3-D Computer Vision CSc – Ioannis Stamos What do we mean by NEIGHBORS? Connectedness 4-Connectedness (4-c) 8-Connectedness (8-c) Neither is perfect!
3-D Computer Vision CSc – Ioannis Stamos What do we mean by NEIGHBORS? Jordan’s Curve Theorem: Closed curve -> 2 connected regions B1O1B1 O2 O4 O3B2 B1 (4-c) Hole without closed curve!
What do we mean by NEIGHBORS? Jordan’s Curve Theorem: Closed curve -> 2 connected regions B1O1B1 O2 O4 O3B2 B1 BOB O O OB BB (4-c) Hole without closed curve! (8-c) Connected background with closed ring!
3-D Computer Vision CSc – Ioannis Stamos Solution: Introduce Assymetry Use: or BO1B O2 O1B BB (a)(b) Using (a) Two separate line segments. Hexagonal Tesselation Above assymetry makes SQUARE grid like HEXAGONAL grid.
3-D Computer Vision CSc – Ioannis Stamos Sequential Labeling Algorithm A BD C Raster Scan Note: B,C,D are already labeled
3-D Computer Vision CSc – Ioannis Stamos Sequential Labeling Algorithm A BD C Raster Scan Note: B,C,D are already labeled 0 XX X a. Label(A) = background 1 XD X b. Label(A) = label(D)
3-D Computer Vision CSc – Ioannis Stamos Sequential Labeling Algorithm A BD C Raster Scan Note: B,C,D are already labeled 1 00 C c. Label(A) = label(C) 1 B0 0 d. Label(A) = label(B) 1 B0 C d. If Label(B) = label(C ), then Label(A)=Label(B)= Label(C)
3-D Computer Vision CSc – Ioannis Stamos Sequential Labeling Algorithm A BD C Raster Scan Note: B,C,D are already labeled 0 XX X a. Label(A) = background 1 XD X b. Label(A) = label(D) 1 00 C c. Label(A) = label(C) 1 B0 0 d. Label(A) = label(B) 1 B0 C d. If Label(B) = label(C ), then Label(A)=Label(B)= Label(C)
3-D Computer Vision CSc – Ioannis Stamos Sequential Labeling (Cont.) What if B & C are labeled but label(B) label(C) ?
3-D Computer Vision CSc – Ioannis Stamos Sequential Labeling (Cont.) What if B & C are labeled but label(B) label(C) ? ?
3-D Computer Vision CSc – Ioannis Stamos Sequential Labeling (Cont.) Solution: Let: Label(A)=Label(B) =2 & create an EQUIVALENCE TABLE. Resolve Equivalences in SECOND PASS. 73,6,4 21 …