Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
D
dlib
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
钟尚武
dlib
Commits
463ef33f
Commit
463ef33f
authored
Sep 25, 2011
by
Davis King
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added the label_connected_blobs() routine.
parent
27a6ad45
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
368 additions
and
0 deletions
+368
-0
image_transforms.h
dlib/image_transforms.h
+1
-0
label_connected_blobs.h
dlib/image_transforms/label_connected_blobs.h
+176
-0
label_connected_blobs_abstract.h
dlib/image_transforms/label_connected_blobs_abstract.h
+191
-0
No files found.
dlib/image_transforms.h
View file @
463ef33f
...
...
@@ -12,6 +12,7 @@
#include "image_transforms/draw.h"
#include "image_transforms/integral_image.h"
#include "image_transforms/image_pyramid.h"
#include "image_transforms/label_connected_blobs.h"
#endif // DLIB_IMAGE_TRANSFORMs_
dlib/image_transforms/label_connected_blobs.h
0 → 100644
View file @
463ef33f
// Copyright (C) 2011 Davis E. King (davis@dlib.net)
// License: Boost Software License See LICENSE.txt for the full license.
#ifndef DLIB_LABEL_CONNeCTED_BLOBS_H_
#define DLIB_LABEL_CONNeCTED_BLOBS_H_
#include "label_connected_blobs_abstract.h"
#include "../geometry.h"
#include <stack>
#include <vector>
namespace
dlib
{
// ----------------------------------------------------------------------------------------
struct
neighbors_8
{
void
operator
()
(
const
point
&
p
,
std
::
vector
<
point
>&
neighbors
)
const
{
neighbors
.
push_back
(
point
(
p
.
x
()
+
1
,
p
.
y
()
+
1
));
neighbors
.
push_back
(
point
(
p
.
x
()
+
1
,
p
.
y
()
));
neighbors
.
push_back
(
point
(
p
.
x
()
+
1
,
p
.
y
()
-
1
));
neighbors
.
push_back
(
point
(
p
.
x
(),
p
.
y
()
+
1
));
neighbors
.
push_back
(
point
(
p
.
x
(),
p
.
y
()
-
1
));
neighbors
.
push_back
(
point
(
p
.
x
()
-
1
,
p
.
y
()
+
1
));
neighbors
.
push_back
(
point
(
p
.
x
()
-
1
,
p
.
y
()
));
neighbors
.
push_back
(
point
(
p
.
x
()
-
1
,
p
.
y
()
-
1
));
}
};
struct
neighbors_4
{
void
operator
()
(
const
point
&
p
,
std
::
vector
<
point
>&
neighbors
)
const
{
neighbors
.
push_back
(
point
(
p
.
x
()
+
1
,
p
.
y
()));
neighbors
.
push_back
(
point
(
p
.
x
()
-
1
,
p
.
y
()));
neighbors
.
push_back
(
point
(
p
.
x
(),
p
.
y
()
+
1
));
neighbors
.
push_back
(
point
(
p
.
x
(),
p
.
y
()
-
1
));
}
};
// ----------------------------------------------------------------------------------------
struct
connected_if_both_not_zero
{
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
img
,
const
point
&
a
,
const
point
&
b
)
const
{
return
(
img
[
a
.
y
()][
a
.
x
()]
!=
0
&&
img
[
b
.
y
()][
b
.
x
()]
!=
0
);
}
};
struct
connected_if_equal
{
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
img
,
const
point
&
a
,
const
point
&
b
)
const
{
return
(
img
[
a
.
y
()][
a
.
x
()]
==
img
[
b
.
y
()][
b
.
x
()]);
}
};
// ----------------------------------------------------------------------------------------
struct
zero_pixels_are_background
{
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
img
,
const
point
&
p
)
const
{
return
img
[
p
.
y
()][
p
.
x
()]
==
0
;
}
};
struct
nothing_is_background
{
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
,
const
point
&
)
const
{
return
false
;
}
};
// ----------------------------------------------------------------------------------------
template
<
typename
image_type
,
typename
label_image_type
,
typename
background_functor_type
,
typename
neighbors_functor_type
,
typename
connected_functor_type
>
unsigned
long
label_connected_blobs
(
const
image_type
&
img
,
const
background_functor_type
&
is_background
,
const
neighbors_functor_type
&
get_neighbors
,
const
connected_functor_type
&
is_connected
,
label_image_type
&
label_img
)
{
std
::
stack
<
point
>
neighbors
;
label_img
.
set_size
(
img
.
nr
(),
img
.
nc
());
assign_all_pixels
(
label_img
,
0
);
unsigned
long
next
=
1
;
const
rectangle
area
=
get_rect
(
img
);
std
::
vector
<
point
>
window
;
for
(
long
r
=
0
;
r
<
img
.
nr
();
++
r
)
{
for
(
long
c
=
0
;
c
<
img
.
nc
();
++
c
)
{
// skip already labeled pixels or background pixels
if
(
label_img
[
r
][
c
]
!=
0
||
is_background
(
img
,
point
(
c
,
r
)))
continue
;
label_img
[
r
][
c
]
=
next
;
// label all the neighbors of this point
neighbors
.
push
(
point
(
c
,
r
));
while
(
neighbors
.
size
()
>
0
)
{
const
point
p
=
neighbors
.
top
();
neighbors
.
pop
();
window
.
clear
();
get_neighbors
(
p
,
window
);
for
(
unsigned
long
i
=
0
;
i
<
window
.
size
();
++
i
)
{
if
(
area
.
contains
(
window
[
i
])
&&
// point in image.
!
is_background
(
img
,
window
[
i
])
&&
// isn't background.
label_img
[
window
[
i
].
y
()][
window
[
i
].
x
()]
==
0
&&
// haven't already labeled it.
is_connected
(
img
,
p
,
window
[
i
]))
// it's connected.
{
label_img
[
window
[
i
].
y
()][
window
[
i
].
x
()]
=
next
;
neighbors
.
push
(
window
[
i
]);
}
}
}
++
next
;
}
}
return
next
;
}
// ----------------------------------------------------------------------------------------
}
#endif // DLIB_LABEL_CONNeCTED_BLOBS_H_
dlib/image_transforms/label_connected_blobs_abstract.h
0 → 100644
View file @
463ef33f
// Copyright (C) 2011 Davis E. King (davis@dlib.net)
// License: Boost Software License See LICENSE.txt for the full license.
#undef DLIB_LABEL_CONNeCTED_BLOBS_ABSTRACT_H_
#ifdef DLIB_LABEL_CONNeCTED_BLOBS_ABSTRACT_H_
#include "../geometry.h"
#include <vector>
namespace
dlib
{
// ----------------------------------------------------------------------------------------
struct
neighbors_8
{
/*!
WHAT THIS OBJECT REPRESENTS
This object is a pixel neighborhood generating functor for
use with the label_connected_blobs() routine defined below.
!*/
void
operator
()
(
const
point
&
p
,
std
::
vector
<
point
>&
neighbors
)
const
;
/*!
ensures
- adds the 8 neighboring pixels surrounding p into neighbors
!*/
};
struct
neighbors_4
{
/*!
WHAT THIS OBJECT REPRESENTS
This object is a pixel neighborhood generating functor for
use with the label_connected_blobs() routine defined below.
!*/
void
operator
()
(
const
point
&
p
,
std
::
vector
<
point
>&
neighbors
)
const
;
/*!
ensures
- adds the 4 neighboring pixels of p into neighbors. These
are the ones immediately to the left, top, right, and bottom.
!*/
};
// ----------------------------------------------------------------------------------------
struct
connected_if_both_not_zero
{
/*!
WHAT THIS OBJECT REPRESENTS
This object is a pixel connection testing functor for use
with the label_connected_blobs() routine defined below.
!*/
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
img
,
const
point
&
a
,
const
point
&
b
)
const
{
return
(
img
[
a
.
y
()][
a
.
x
()]
!=
0
&&
img
[
b
.
y
()][
b
.
x
()]
!=
0
);
}
};
struct
connected_if_equal
{
/*!
WHAT THIS OBJECT REPRESENTS
This object is a pixel connection testing functor for use
with the label_connected_blobs() routine defined below.
!*/
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
img
,
const
point
&
a
,
const
point
&
b
)
const
{
return
(
img
[
a
.
y
()][
a
.
x
()]
==
img
[
b
.
y
()][
b
.
x
()]);
}
};
// ----------------------------------------------------------------------------------------
struct
zero_pixels_are_background
{
/*!
WHAT THIS OBJECT REPRESENTS
This object is a background testing functor for use
with the label_connected_blobs() routine defined below.
!*/
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
img
,
const
point
&
p
)
const
{
return
img
[
p
.
y
()][
p
.
x
()]
==
0
;
}
};
struct
nothing_is_background
{
/*!
WHAT THIS OBJECT REPRESENTS
This object is a background testing functor for use
with the label_connected_blobs() routine defined below.
!*/
template
<
typename
image_type
>
bool
operator
()
(
const
image_type
&
,
const
point
&
)
const
{
return
false
;
}
};
// ----------------------------------------------------------------------------------------
template
<
typename
image_type
,
typename
label_image_type
,
typename
background_functor_type
,
typename
neighbors_functor_type
,
typename
connected_functor_type
>
unsigned
long
label_connected_blobs
(
const
image_type
&
img
,
const
background_functor_type
&
is_background
,
const
neighbors_functor_type
&
get_neighbors
,
const
connected_functor_type
&
is_connected
,
label_image_type
&
label_img
);
/*!
requires
- image_type == is an implementation of array2d/array2d_kernel_abstract.h
- label_image_type == is an implementation of array2d/array2d_kernel_abstract.h
and it must contain integers.
- is_background(img, point(c,r)) is a legal expression that evaluates to bool.
- get_neighbors(point(c,r), neighbors) is a legal expression where neighbors
is of type std::vector<point>.
- is_connected(img, point(c,r), point(c2,r2)) is a valid expression.
ensures
- This function labels each of the connected blobs in img with a unique integer
label.
- An image can be thought of as a graph where pixels A and B are connected if
and only if the following two statements are satisfied:
- is_connected(img,A,B) == true
- get_neighbors(A, neighbors) results in neighbors containing B or
get_neighbors(B, neighbors) results in neighbors containing A.
Then this function can be understood as labeling all the connected components
of this pixel graph such that all pixels in a component get the same label while
pixels in different components get different labels. Note that there is a
special "background" component determined by is_background(). Any pixels which
are "background" always get a blob id of 0 regardless of any other considerations.
- #label_img.nr() == img.nr()
- #label_img.nc() == img.nc()
- for all valid r and c:
- #label_img[r][c] == the blob label number for pixel img[r][c].
- #label_img[r][c] >= 0
- if (is_background(img, point(c,r))) then
- #label_img[r][c] == 0
- else
- #label_img[r][c] != 0
- returns max(array_to_matrix(label_img))+1
(i.e. returns a number one greater than the maximum blob id number)
- blob labels are contiguous, therefore, the number returned by this function is
the number of blobs in the image (including the background blob).
- It is guaranteed that is_connected() and is_background() will never be
called with points outside the image.
!*/
// ----------------------------------------------------------------------------------------
}
#endif // DLIB_LABEL_CONNeCTED_BLOBS_ABSTRACT_H_
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment