Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv_contrib
Commits
590dc298
Commit
590dc298
authored
Nov 25, 2016
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
text: fix valgrind errors, minor changes
parent
afd8a833
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
18 additions
and
25 deletions
+18
-25
detect_er_chars.py
modules/text/samples/detect_er_chars.py
+5
-6
erfilter.cpp
modules/text/src/erfilter.cpp
+13
-19
No files found.
modules/text/samples/detect_er_chars.py
View file @
590dc298
...
@@ -5,7 +5,6 @@ import os
...
@@ -5,7 +5,6 @@ import os
import
cv2
import
cv2
import
numpy
as
np
import
numpy
as
np
from
matplotlib
import
pyplot
as
plt
print
(
'
\n
detect_er_chars.py'
)
print
(
'
\n
detect_er_chars.py'
)
print
(
' A simple demo script using the Extremal Region Filter algorithm described in:'
)
print
(
' A simple demo script using the Extremal Region Filter algorithm described in:'
)
...
@@ -32,8 +31,8 @@ regions = cv2.text.detectRegions(gray,er1,er2)
...
@@ -32,8 +31,8 @@ regions = cv2.text.detectRegions(gray,er1,er2)
#Visualization
#Visualization
rects
=
[
cv2
.
boundingRect
(
p
.
reshape
(
-
1
,
1
,
2
))
for
p
in
regions
]
rects
=
[
cv2
.
boundingRect
(
p
.
reshape
(
-
1
,
1
,
2
))
for
p
in
regions
]
for
rect
in
rects
:
for
rect
in
rects
:
cv2
.
rectangle
(
img
,
rect
[
0
:
2
],
(
rect
[
0
]
+
rect
[
2
],
rect
[
1
]
+
rect
[
3
]),
(
0
,
0
,
255
),
2
)
cv2
.
rectangle
(
img
,
rect
[
0
:
2
],
(
rect
[
0
]
+
rect
[
2
],
rect
[
1
]
+
rect
[
3
]),
(
0
,
0
,
0
),
2
)
img
=
img
[:,:,::
-
1
]
#flip the colors dimension from BGR to RGB
for
rect
in
rects
:
plt
.
imshow
(
img
)
cv2
.
rectangle
(
img
,
rect
[
0
:
2
],
(
rect
[
0
]
+
rect
[
2
],
rect
[
1
]
+
rect
[
3
]),
(
255
,
255
,
255
),
1
)
plt
.
xticks
([]),
plt
.
yticks
([])
# to hide tick values on X and Y axis
cv2
.
imshow
(
"Text detection result"
,
img
)
plt
.
show
(
)
cv2
.
waitKey
(
0
)
modules/text/src/erfilter.cpp
View file @
590dc298
...
@@ -275,24 +275,18 @@ void ERFilterNM::er_tree_extract( InputArray image )
...
@@ -275,24 +275,18 @@ void ERFilterNM::er_tree_extract( InputArray image )
// the component stack
// the component stack
vector
<
ERStat
*>
er_stack
;
vector
<
ERStat
*>
er_stack
;
//the quads for euler number calculation
// the quads for euler number calculation
unsigned
char
quads
[
3
][
4
];
// quads[2][2] and quads[2][3] are never used.
quads
[
0
][
0
]
=
1
<<
3
;
quads
[
0
][
1
]
=
1
<<
2
;
quads
[
0
][
2
]
=
1
<<
1
;
quads
[
0
][
3
]
=
1
;
quads
[
1
][
0
]
=
(
1
<<
2
)
|
(
1
<<
1
)
|
(
1
);
quads
[
1
][
1
]
=
(
1
<<
3
)
|
(
1
<<
1
)
|
(
1
);
quads
[
1
][
2
]
=
(
1
<<
3
)
|
(
1
<<
2
)
|
(
1
);
quads
[
1
][
3
]
=
(
1
<<
3
)
|
(
1
<<
2
)
|
(
1
<<
1
);
quads
[
2
][
0
]
=
(
1
<<
2
)
|
(
1
<<
1
);
quads
[
2
][
1
]
=
(
1
<<
3
)
|
(
1
);
// quads[2][2] and quads[2][3] are never used so no need to initialize them.
// The four lowest bits in each quads[i][j] correspond to the 2x2 binary patterns
// The four lowest bits in each quads[i][j] correspond to the 2x2 binary patterns
// Q_1, Q_2, Q_3 in the Neumann and Matas CVPR 2012 paper
// Q_1, Q_2, Q_3 in the Neumann and Matas CVPR 2012 paper
// (see in page 4 at the end of first column).
// (see in page 4 at the end of first column).
// Q_1 and Q_2 have four patterns, while Q_3 has only two.
// Q_1 and Q_2 have four patterns, while Q_3 has only two.
const
int
quads
[
3
][
4
]
=
{
{
1
<<
3
,
1
<<
2
,
1
<<
1
,
1
<<
0
},
{
(
1
<<
2
)
|
(
1
<<
1
)
|
(
1
),
(
1
<<
3
)
|
(
1
<<
1
)
|
(
1
),
(
1
<<
3
)
|
(
1
<<
2
)
|
(
1
),
(
1
<<
3
)
|
(
1
<<
2
)
|
(
1
<<
1
)
},
{
(
1
<<
2
)
|
(
1
<<
1
)
,
(
1
<<
3
)
|
(
1
),
/*unused*/
-
1
,
/*unused*/
-
1
}
};
// masks to know if a pixel is accessible and if it has been already added to some region
// masks to know if a pixel is accessible and if it has been already added to some region
vector
<
bool
>
accessible_pixel_mask
(
width
*
height
);
vector
<
bool
>
accessible_pixel_mask
(
width
*
height
);
...
@@ -392,8 +386,8 @@ void ERFilterNM::er_tree_extract( InputArray image )
...
@@ -392,8 +386,8 @@ void ERFilterNM::er_tree_extract( InputArray image )
int
non_boundary_neighbours
=
0
;
int
non_boundary_neighbours
=
0
;
int
non_boundary_neighbours_horiz
=
0
;
int
non_boundary_neighbours_horiz
=
0
;
unsigned
char
quad_before
[
4
]
=
{
0
,
0
,
0
,
0
};
int
quad_before
[
4
]
=
{
0
,
0
,
0
,
0
};
unsigned
char
quad_after
[
4
]
=
{
0
,
0
,
0
,
0
};
int
quad_after
[
4
]
=
{
0
,
0
,
0
,
0
};
quad_after
[
0
]
=
1
<<
1
;
quad_after
[
0
]
=
1
<<
1
;
quad_after
[
1
]
=
1
<<
3
;
quad_after
[
1
]
=
1
<<
3
;
quad_after
[
2
]
=
1
<<
2
;
quad_after
[
2
]
=
1
<<
2
;
...
@@ -542,9 +536,9 @@ void ERFilterNM::er_tree_extract( InputArray image )
...
@@ -542,9 +536,9 @@ void ERFilterNM::er_tree_extract( InputArray image )
current_edge
=
boundary_edges
[
threshold_level
].
back
();
current_edge
=
boundary_edges
[
threshold_level
].
back
();
boundary_edges
[
threshold_level
].
erase
(
boundary_edges
[
threshold_level
].
end
()
-
1
);
boundary_edges
[
threshold_level
].
erase
(
boundary_edges
[
threshold_level
].
end
()
-
1
);
while
(
boundary_pixes
[
threshold_level
].
empty
()
&&
(
threshold_level
<
(
255
/
thresholdDelta
)
+
1
)
)
for
(;
threshold_level
<
(
255
/
thresholdDelta
)
+
1
;
threshold_level
++
)
threshold_level
++
;
if
(
!
boundary_pixes
[
threshold_level
].
empty
())
break
;
int
new_level
=
image_data
[
current_pixel
];
int
new_level
=
image_data
[
current_pixel
];
...
...
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