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
d3118ad0
Commit
d3118ad0
authored
Nov 02, 2017
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1408 from VenkateshVijaykumar:ridge_filter
parents
4a066317
17ffd282
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
198 additions
and
1 deletion
+198
-1
README.md
modules/README.md
+1
-1
README.md
modules/ximgproc/README.md
+1
-0
ximgproc.hpp
modules/ximgproc/include/opencv2/ximgproc.hpp
+1
-0
ridgefilter.hpp
modules/ximgproc/include/opencv2/ximgproc/ridgefilter.hpp
+51
-0
perf_ridge_detection_filter.cpp
modules/ximgproc/perf/perf_ridge_detection_filter.cpp
+39
-0
ridgedetectionfilter.cpp
modules/ximgproc/src/ridgedetectionfilter.cpp
+73
-0
test_ridge_detection_filter.cpp
modules/ximgproc/test/test_ridge_detection_filter.cpp
+32
-0
No files found.
modules/README.md
View file @
d3118ad0
...
...
@@ -62,7 +62,7 @@ $ cmake -D OPENCV_EXTRA_MODULES_PATH=<opencv_contrib>/modules -D BUILD_opencv_<r
-
**xfeatures2d**
: Features2D extra -- Extra 2D Features Framework containing experimental and non-free 2D feature detector/descriptor algorithms. SURF, SIFT, BRIEF, Censure, Freak, LUCID, Daisy, Self-similar.
-
**ximgproc**
: Extended Image Processing -- Structured Forests / Domain Transform Filter / Guided Filter / Adaptive Manifold Filter / Joint Bilateral Filter / Superpixels.
-
**ximgproc**
: Extended Image Processing -- Structured Forests / Domain Transform Filter / Guided Filter / Adaptive Manifold Filter / Joint Bilateral Filter / Superpixels
/ Ridge Detection Filter
.
-
**xobjdetect**
: Boosted 2D Object Detection -- Uses a Waldboost cascade and local binary patterns computed as integral features for 2D object detection.
...
...
modules/ximgproc/README.md
View file @
d3118ad0
...
...
@@ -14,3 +14,4 @@ Extended Image Processing
-
Fast Line Detector
-
Deriche Filter
-
Pei&Lin Normalization
-
Ridge Detection Filter
modules/ximgproc/include/opencv2/ximgproc.hpp
View file @
d3118ad0
...
...
@@ -54,6 +54,7 @@
#include "ximgproc/deriche_filter.hpp"
#include "ximgproc/peilin.hpp"
#include "ximgproc/fourier_descriptors.hpp"
#include "ximgproc/ridgefilter.hpp"
/** @defgroup ximgproc Extended Image Processing
...
...
modules/ximgproc/include/opencv2/ximgproc/ridgefilter.hpp
0 → 100644
View file @
d3118ad0
// This file is part of OpenCV project.
// It is subject to the license terms in the LICENSE file found in the top-level directory
// of this distribution and at http://opencv.org/license.html.
/*
Ridge Detection Filter.
OpenCV port by : Kushal Vyas (@kushalvyas), Venkatesh Vijaykumar(@venkateshvijaykumar)
*/
#ifndef __OPENCV_XIMGPROC_RIDGEFILTER_HPP__
#define __OPENCV_XIMGPROC_RIDGEFILTER_HPP__
#include <opencv2/core.hpp>
namespace
cv
{
namespace
ximgproc
{
//! @addtogroup ximgproc_filters
//! @{
/** @brief Applies Ridge Detection Filter to an input image.
Implements Ridge detection similar to the one in [Mathematica](http://reference.wolfram.com/language/ref/RidgeFilter.html)
using the eigen values from the Hessian Matrix of the input image using Sobel Derivatives.
Additional refinement can be done using Skeletonization and Binarization.
*/
class
CV_EXPORTS_W
RidgeDetectionFilter
:
public
Algorithm
{
public
:
/**
@brief Create pointer to the Ridge detection filter.
@param ddepth Specifies output image depth. Defualt is CV_32FC1
@param dx Order of derivative x, default is 1
@param dy Order of derivative y, default is 1
@param ksize Sobel kernel size , default is 3
@param out_dtype Converted format for output, default is CV_8UC1
@param scale Optional scale value for derivative values, default is 1
@param delta Optional bias added to output, default is 0
@param borderType Pixel extrapolation method, default is BORDER_DEFAULT
@see Sobel, threshold, getStructuringElement, morphologyEx.( for additional refinement)
*/
CV_WRAP
static
Ptr
<
RidgeDetectionFilter
>
create
(
int
ddepth
=
CV_32FC1
,
int
dx
=
1
,
int
dy
=
1
,
int
ksize
=
3
,
int
out_dtype
=
CV_8UC1
,
double
scale
=
1
,
double
delta
=
0
,
int
borderType
=
BORDER_DEFAULT
);
/**
@brief Apply Ridge detection filter on input image.
@param _img InputArray as supported by Sobel. img can be 1-Channel or 3-Channels.
@param out OutputAray of structure as RidgeDetectionFilter::ddepth. Output image with ridges.
*/
CV_WRAP
virtual
void
getRidgeFilteredImage
(
InputArray
_img
,
OutputArray
out
)
=
0
;
};
//! @}
}}
// namespace
#endif
modules/ximgproc/perf/perf_ridge_detection_filter.cpp
0 → 100644
View file @
d3118ad0
// This file is part of OpenCV project.
// It is subject to the license terms in the LICENSE file found in the top-level directory
// of this distribution and at http://opencv.org/license.html.
#include "perf_precomp.hpp"
namespace
cvtest
{
using
namespace
perf
;
using
namespace
testing
;
using
namespace
cv
;
using
namespace
cv
::
ximgproc
;
typedef
tuple
<
MatDepth
,
int
,
Size
>
RDFParams
;
typedef
TestBaseWithParam
<
RDFParams
>
RidgeDetectionFilterPerfTest
;
PERF_TEST_P
(
RidgeDetectionFilterPerfTest
,
perf
,
Combine
(
Values
((
MatDepth
)
CV_32F
),
Values
(
3
),
SZ_TYPICAL
))
{
RDFParams
params
=
GetParam
();
int
ddepth
=
get
<
0
>
(
params
);
int
ksize
=
get
<
1
>
(
params
);
Size
sz
=
get
<
2
>
(
params
);
Mat
src
(
sz
,
ddepth
);
Mat
out
(
sz
,
src
.
type
());
declare
.
in
(
src
).
out
(
out
);
Ptr
<
RidgeDetectionFilter
>
rdf
=
RidgeDetectionFilter
::
create
(
ddepth
,
1
,
1
,
ksize
);
TEST_CYCLE
()
rdf
->
getRidgeFilteredImage
(
src
,
out
);
SANITY_CHECK_NOTHING
();
}
}
// namespace
modules/ximgproc/src/ridgedetectionfilter.cpp
0 → 100644
View file @
d3118ad0
// This file is part of OpenCV project.
// It is subject to the license terms in the LICENSE file found in the top-level directory
// of this distribution and at http://opencv.org/license.html.
#include "precomp.hpp"
#include "opencv2/imgproc.hpp"
#include "opencv2/ximgproc/ridgefilter.hpp"
namespace
cv
{
namespace
ximgproc
{
class
RidgeDetectionFilterImpl
:
public
RidgeDetectionFilter
{
public
:
int
_ddepth
,
_dx
,
_dy
,
_ksize
;
double
_scale
,
_delta
;
int
_borderType
;
int
_out_dtype
;
RidgeDetectionFilterImpl
(
int
ddepth
=
CV_32FC1
,
int
dx
=
1
,
int
dy
=
1
,
int
ksize
=
3
,
int
out_dtype
=
CV_8UC1
,
double
scale
=
1
,
double
delta
=
0
,
int
borderType
=
BORDER_DEFAULT
)
{
CV_Assert
((
ksize
==
1
||
ksize
==
3
||
ksize
==
5
||
ksize
==
7
));
CV_Assert
((
ddepth
==
CV_32FC1
||
ddepth
==
CV_64FC1
));
_ddepth
=
ddepth
;
_dx
=
dx
;
_dy
=
dy
;
_ksize
=
ksize
;
_scale
=
scale
;
_delta
=
delta
;
_borderType
=
borderType
;
_out_dtype
=
out_dtype
;
}
virtual
void
getRidgeFilteredImage
(
InputArray
_img
,
OutputArray
out
);
};
void
RidgeDetectionFilterImpl
::
getRidgeFilteredImage
(
InputArray
_img
,
OutputArray
out
)
{
Mat
img
=
_img
.
getMat
();
CV_Assert
(
img
.
channels
()
==
1
||
img
.
channels
()
==
3
);
if
(
img
.
channels
()
==
3
)
cvtColor
(
img
,
img
,
COLOR_BGR2GRAY
);
Mat
sbx
,
sby
;
Sobel
(
img
,
sbx
,
_ddepth
,
_dx
,
0
,
_ksize
,
_scale
,
_delta
,
_borderType
);
Sobel
(
img
,
sby
,
_ddepth
,
0
,
_dy
,
_ksize
,
_scale
,
_delta
,
_borderType
);
Mat
sbxx
,
sbyy
,
sbxy
;
Sobel
(
sbx
,
sbxx
,
_ddepth
,
_dx
,
0
,
_ksize
,
_scale
,
_delta
,
_borderType
);
Sobel
(
sby
,
sbyy
,
_ddepth
,
0
,
_dy
,
_ksize
,
_scale
,
_delta
,
_borderType
);
Sobel
(
sbx
,
sbxy
,
_ddepth
,
0
,
_dy
,
_ksize
,
_scale
,
_delta
,
_borderType
);
Mat
sb2xx
,
sb2yy
,
sb2xy
;
multiply
(
sbxx
,
sbxx
,
sb2xx
);
multiply
(
sbyy
,
sbyy
,
sb2yy
);
multiply
(
sbxy
,
sbxy
,
sb2xy
);
Mat
sbxxyy
;
multiply
(
sbxx
,
sbyy
,
sbxxyy
);
Mat
rootex
;
rootex
=
(
sb2xx
+
(
sb2xy
+
sb2xy
+
sb2xy
+
sb2xy
)
-
(
sbxxyy
+
sbxxyy
)
+
sb2xy
);
Mat
root
;
sqrt
(
rootex
,
root
);
Mat
ridgexp
;
ridgexp
=
(
(
sbxx
+
sbyy
)
+
root
);
ridgexp
.
convertTo
(
out
,
_out_dtype
,
0.5
);
}
Ptr
<
RidgeDetectionFilter
>
RidgeDetectionFilter
::
create
(
int
ddepth
,
int
dx
,
int
dy
,
int
ksize
,
int
out_dtype
,
double
scale
,
double
delta
,
int
borderType
)
{
return
makePtr
<
RidgeDetectionFilterImpl
>
(
ddepth
,
dx
,
dy
,
ksize
,
out_dtype
,
scale
,
delta
,
borderType
);
}
}}
// namespace
modules/ximgproc/test/test_ridge_detection_filter.cpp
0 → 100644
View file @
d3118ad0
// This file is part of OpenCV project.
// It is subject to the license terms in the LICENSE file found in the top-level directory
// of this distribution and at http://opencv.org/license.html.
#include "test_precomp.hpp"
namespace
cvtest
{
using
namespace
cv
;
using
namespace
cv
::
ximgproc
;
TEST
(
ximgproc_ridgedetectionfilter
,
ReferenceAccuracy
)
{
String
openCVExtraDir
=
cvtest
::
TS
::
ptr
()
->
get_data_path
();
String
srcImgPath
=
"cv/ximgproc/sources/04.png"
;
String
refPath
=
"cv/ximgproc/results/ridge_filter_test_ref/04.png"
;
Mat
src
=
imread
(
openCVExtraDir
+
srcImgPath
);
Mat
ref
=
imread
(
openCVExtraDir
+
refPath
,
0
);
Mat
n_ref
;
ref
.
convertTo
(
n_ref
,
CV_8UC1
);
Ptr
<
RidgeDetectionFilter
>
rdf
=
RidgeDetectionFilter
::
create
();
Mat
out
;
rdf
->
getRidgeFilteredImage
(
src
,
out
);
Mat
out_cmp
;
out
.
convertTo
(
out_cmp
,
CV_8UC1
);
Mat
sb
;
subtract
(
out_cmp
,
n_ref
,
sb
);
int
zeros
=
countNonZero
(
sb
);
EXPECT_EQ
(
zeros
,
0
);
}
}
// namespace
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