1. Binary Image B(r,c) 2 0 represents the background 1 represents the foreground 00010010001000 00011110001000 00010010001000.

Slides:



Advertisements
Similar presentations
Binary Image Analysis Selim Aksoy Department of Computer Engineering Bilkent University
Advertisements

Binary Image Analysis Selim Aksoy Department of Computer Engineering Bilkent University
電腦視覺 Computer and Robot Vision I Chapter2: Binary Machine Vision: Thresholding and Segmentation Instructor: Shih-Shinh Huang 1.
Chapter 9: Morphological Image Processing
Morphology – Chapter 10. Binary image processing Often it is advantageous to reduce an image from gray level (multiple bits/pixel) to binary (1 bit/pixel)
Each pixel is 0 or 1, background or foreground Image processing to
Morphological Image Processing Md. Rokanujjaman Assistant Professor Dept of Computer Science and Engineering Rajshahi University.
September 10, 2013Computer Vision Lecture 3: Binary Image Processing 1Thresholding Here, the right image is created from the left image by thresholding,
Common Low-level Operations for Processing & Enhancement
Morphology Structural processing of images Image Processing and Computer Vision: 33 Morphological Transformations Set theoretic methods of extracting.
Processing Digital Images. Filtering Analysis –Recognition Transmission.
Segmentation Divide the image into segments. Each segment:
1 Binary Image Analysis Binary image analysis consists of a set of image analysis operations that are used to produce or process binary images, usually.
Binary Image Analysis: Part 2 Readings: Chapter 3: mathematical morphology region properties region adjacency 1.
Computer Vision Basics Image Terminology Binary Operations Filtering Edge Operators.
1. Binary Image B(r,c) 2 0 represents the background 1 represents the foreground
E.G.M. PetrakisBinary Image Processing1 Binary Image Analysis Segmentation produces homogenous regions –each region has uniform gray-level –each region.
Chapter 3 Binary Image Analysis. Types of images ► Digital image = I[r][c] is discrete for I, r, and c.  B[r][c] = binary image - range of I is in {0,1}
Machine Vision for Robots
Lecture 5. Morphological Image Processing. 10/6/20152 Introduction ► ► Morphology: a branch of biology that deals with the form and structure of animals.
Recap CSC508.
Chapter 9.  Mathematical morphology: ◦ A useful tool for extracting image components in the representation of region shape.  Boundaries, skeletons,
Chap 3 : Binary Image Analysis. Counting Foreground Objects.
CS 6825: Binary Image Processing – binary blob metrics
CS 376b Introduction to Computer Vision 02 / 22 / 2008 Instructor: Michael Eckmann.
Digital Image Processing CCS331 Relationships of Pixel 1.
Morphological Image Processing
1 Binary Image Analysis Binary image analysis consists of a set of image analysis operations that are used to produce or process binary images, usually.
Image Segmentation and Morphological Processing Digital Image Processing in Life- Science Aviad Baram
Digital Camera and Computer Vision Laboratory Department of Computer Science and Information Engineering National Taiwan University, Taipei, Taiwan, R.O.C.
1 Regions and Binary Images Hao Jiang Computer Science Department Sept. 25, 2014.
CS654: Digital Image Analysis
Digital Image Processing CSC331 Morphological image processing 1.
CS 376b Introduction to Computer Vision 02 / 11 / 2008 Instructor: Michael Eckmann.
Morphological Image Processing การทำงานกับรูปภาพด้วยวิธีมอร์โฟโลจิคัล
Low level Computer Vision 1. Thresholding 2. Convolution 3. Morphological Operations 4. Connected Component Extraction 5. Feature Extraction 1.
CS654: Digital Image Analysis
Nottingham Image Analysis School, 23 – 25 June NITS Image Segmentation Guoping Qiu School of Computer Science, University of Nottingham
CSSE463: Image Recognition Day 9 Lab 3 (edges) due Weds, 3:25 pm Lab 3 (edges) due Weds, 3:25 pm Take home quiz due Friday, 4:00 pm. Take home quiz due.
1 Mathematic Morphology used to extract image components that are useful in the representation and description of region shape, such as boundaries extraction.
Morphological Image Processing Robotics. 2/22/2016Introduction to Machine Vision Remember from Lecture 12: GRAY LEVEL THRESHOLDING Objects Set threshold.
Digital Camera and Computer Vision Laboratory Department of Computer Science and Information Engineering National Taiwan University, Taipei, Taiwan, R.O.C.
Machine Vision ENT 273 Hema C.R. Binary Image Processing Lecture 3.
Course 3 Binary Image Binary Images have only two gray levels: “1” and “0”, i.e., black / white. —— save memory —— fast processing —— many features of.
Lecture(s) 3-4. Morphological Image Processing. 3/13/20162 Introduction ► ► Morphology: a branch of biology that deals with the form and structure of.
Chapter 6 Skeleton & Morphological Operation. Image Processing for Pattern Recognition Feature Extraction Acquisition Preprocessing Classification Post.
Morphological Image Processing (Chapter 9) CSC 446 Lecturer: Nada ALZaben.
Morphological Image Processing
1. Images as Functions 2 A Binary image is a function B(x,y) Є [0,1] Gray-tone image is a function: g(x,y) Є [0.,1,….L-1] A color image is represented.
CSSE463: Image Recognition Day 9
COMP 9517 Computer Vision Binary Image Analysis 4/15/2018
Common Low-level Operations for Processing & Enhancement
Digital Image Processing CP-7008 Lecture # 09 Morphological Image Processing Fall 2011.
Binary Image Analysis Gokberk Cinbis
Introduction to Morphological Operators
Computer Vision Lecture 5: Binary Image Processing
Binary Image Analysis: Part 1 Readings: Chapter 3: 3.1, 3.4, 3.8
Binary Image Analysis used in a variety of applications:
Binary Image Analysis: Part 1 Readings: Chapter 3: 3.1, 3.4, 3.8
Binary Image processing بهمن 92
CSSE463: Image Recognition Day 9
Department of Computer Engineering
Digital Image Processing Lecture 15: Morphological Algorithms
Binary Image Analysis: Part 2 Readings: Chapter 3:
CSSE463: Image Recognition Day 9
Computer and Robot Vision I
Computer and Robot Vision I
DIGITAL IMAGE PROCESSING Elective 3 (5th Sem.)
Binary Image Analysis used in a variety of applications:
Morphological Filters Applications and Extension Morphological Filters
Presentation transcript:

1

Binary Image B(r,c) 2 0 represents the background 1 represents the foreground

Binary Image Analysis  is used in a number of practical applications, e.g. 3 Part inspection Shape analysis Enhancement Document processing

What kinds of operations? 4 Separate objects from background and from one another Aggregate pixels for each object Compute features for each object

Example: red blood cell image  Many blood cells are separate objects  Many touch – bad!  Salt and pepper noise from thresholding  How useable is this data? 5

Results of analysis  63 separate objects detected  Single cells have area about 50  Noise spots  Gobs of cells 6

Binary Image Operations 7 1.Thresholding a gray-tone image 2.Convolution 3.Morphology 4.Feature extractions (area, centroid) 5.Connected components analysis

1. Thresholding 8 Convert gray level or color image into binary image Use histogram Definition: The Histogram of a gray-level image I is defined as H(m) = { (r,c) : I(r,c) =m) } Where m spans the gray values

Histogram-Directed Thresholding 9 How can we use a histogram to separate an image into 2 (or several) different regions? Is there a single clear threshold? 2? 3?

Histogram  Background is black  Healthy cherry is bright  Bruise is medium dark  Histogram shows two cherry regions (black background has been removed) 10 gray-tone values pixel counts 0 256

Automatic Thresholding: Otsu’s Method 11 Assumption: the histogram is bimodal t Method: find the threshold t that minimizes the weighted sum of within-group variances for the two groups that result from separating the gray tones at value t. Grp 1 Grp 2

Thresholding Example 12 original gray tone imagebinary thresholded image

2. Convolution  Given a gray level image I(r,c) and a mask m(r,c) convolution is I(r,c)*m(r,c)= ΣΣ I(k,l). m(r-k,m-l) 13 Masks

SMOOTHING MASKS

Convolution of an İmage with a Mask 15

Image Enhancement WITH AVERAGING AND THRESHOLDING Image Enhancement WITH AVERAGING AND THRESHOLDING

3. Mathematical Morphology  Morphology: Study of forms of animals and plants  Mathematical Morphology: Study of shapes  Similar to convolution  Arithmetic operations Set Operations 18

Need to define Image as a Set  Given a binary image I (r,c), assume 1 correspond to object 0 correspond to backround.  Define a set with elements to the coordinates of the object  X = { (r1,c1), (r2,c2),….} 19

 X= 20

Set Operations

Set Operations on Images AND, OR Set Operations on Images AND, OR

TRANSLATION REFLECTION

Set Operations

Morphologic Operations 25 Binary mathematical morphology consists of two basic operations dilation and erosion and several composite relations closing and opening

Dilation: 26 Dilation expands the connected sets of 1s of a binary image. It can be used for 1. growing regions 2. filling holes and gaps

Structuring Elements 27 A structuring element is a shape mask used in the basic morphological operations. They can be any shape and size that is digitally representable, and each has an origin. box hexagon disk something box(length,width) disk(diameter)

Dilation with Structuring Element S: ={ Z: (S z )∩ B≠ Φ} 28 The arguments to dilation and erosion are 1.a binary image B 2.a structuring element S dilate(B,S) takes binary image B, places the origin of structuring element S over each 1-pixel, and ORs the structuring element S into the output image at the corresponding position origin B S dilate B  S

DILATION

Erosion BΘS ={ Z: (Sz)  B} 31 Erosion shrinks the connected sets of 1s of a binary image. It can be used for 1. shrinking features 2. Removing bridges, branches and small protrusions

Erosion with Structuring Elements 32 erode(B,S) takes a binary image B, places the origin of structuring element S over every pixel position, and ORs a binary 1 into that position of the output image only if every position of S (with a 1) covers a 1 in B B S origin erode B S

EROSİON:

IMAGE ENHANCEMENT WİTH MORPHOLOGY

Example to Try erode dilate with same structuring element S B

Opening and Closing 36 Closing is the compound operation of dilation followed by erosion (with the same structuring element) Opening is the compound operation of erosion followed by dilation (with the same structuring element)

Use of Opening 37 Original Opening Corners 1.What kind of structuring element was used in the opening? 2.How did we get the corners?

OPENİNG AND CLOSİNG

FINGERPRİNT RECOGNİTİON

HOW DO YOU REMOVE THE HOLES Hole: A closed backround region surrounded by object pixels HOW DO YOU REMOVE THE HOLES Hole: A closed backround region surrounded by object pixels

41 Erode with hole ring and dilate with hole mask

Morphological Analysis for Bone detection

OBJECT DETECTION

BOUNDARY EXTRACTİON Boundary: A set of one-pixel-wide connected pixels which has at least one neighbor outside the object BOUNDARY EXTRACTİON Boundary: A set of one-pixel-wide connected pixels which has at least one neighbor outside the object

BOUNDARY EXTRACTİON

Skeleton Finding Skeleton: Set of one-pixel wide connected pixels which are at equal distance from at least two boundary pixels Skeleton Finding Skeleton: Set of one-pixel wide connected pixels which are at equal distance from at least two boundary pixels

Morphological Image Processing

Morphological Operations

Skeleton finding: Skeleton: Set of one-pixel wide connected pixels which are at equal distance from at least two boundary pixels Skeleton finding: Skeleton: Set of one-pixel wide connected pixels which are at equal distance from at least two boundary pixels

Gear Tooth Inspection 52 original binary image detected defects How did they do it?

Some Details 53

Region Properties-Features 54 Properties of the regions can be used to recognize objects. geometric properties (Ch 3) gray-tone properties color properties texture properties shape properties (a few in Ch 3) motion properties relationship properties (1 in Ch 3)

Geometric and Shape Properties 55 area: centroid: perimeter : perimeter length: circularity:

elongation mean and standard deviation of radial distance bounding box extremal axis length from bounding box second order moments (row, column, mixed) lengths and orientations of axes of best-fit ellipse 56

4. Connected Components Labeling 57 Once you have a binary image, you can identify and then analyze each connected set of pixels. The connected components operation takes in a binary image and produces a labeled image in which each pixel has the integer label of either the background (0) or a component. binary image after morphology connected components

Methods for CC Analysis Recursive Tracking (almost never used) 2. Parallel Growing (needs parallel hardware) 3. Row-by-Row (most common) Classical Algorithm (see text) Efficient Run-Length Algorithm (developed for speed in real industrial applications)

Equivalent Labels Original Binary Image

Equivalent Labels The Labeling Process 1  2 1  3

Run-Length Data Structure U N U S E D row scol ecol label Rstart Rend Runs Row Index Binary Image

Run-Length Algorithm 62 Procedure run_length_classical { initialize Run-Length and Union-Find data structures count <- 0 /* Pass 1 (by rows) */ for each current row and its previous row { move pointer P along the runs of current row move pointer Q along the runs of previous row

Case 1: No Overlap 63 |/////| |/////| |////| |///| |///| |/////| Q P Q P /* new label */ count <- count + 1 label(P) <- count P <- P + 1 /* check Q’s next run */ Q <- Q + 1

Case 2: Overlap 64 Subcase 1: P’s run has no label yet |///////| |/////| |/////////////| Subcase 2: P’s run has a label that is different from Q’s run |///////| |/////| |/////////////| Q Q P P label(P) <- label(Q) move pointer(s) union(label(P),label(Q)) move pointer(s) }

Pass 2 (by runs) 65 /* Relabel each run with the name of the equivalence class of its label */ For each run M { label(M) <- find(label(M)) } where union and find refer to the operations of the Union-Find data structure, which keeps track of sets of equivalent labels.

Labeling shown as Pseudo-Color 66 connected components of 1’s from thresholded image connected components of cluster labels

Region Adjacency Graph 67 A region adjacency graph (RAG) is a graph in which each node represents a region of the image and an edge connects two nodes if the regions are adjacent