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
556307a2
Commit
556307a2
authored
Feb 17, 2017
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1004 from dkurt:missed_layer_params
parents
06752e51
d95fdc7d
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
49 additions
and
16 deletions
+49
-16
layer_loaders.cpp
modules/dnn/src/caffe/layer_loaders.cpp
+41
-14
elementwise_layers.cpp
modules/dnn/src/layers/elementwise_layers.cpp
+8
-2
No files found.
modules/dnn/src/caffe/layer_loaders.cpp
View file @
556307a2
...
@@ -72,17 +72,22 @@ Ptr<Layer> createLayerFromCaffe<PoolingLayer>(LayerParams ¶ms)
...
@@ -72,17 +72,22 @@ Ptr<Layer> createLayerFromCaffe<PoolingLayer>(LayerParams ¶ms)
pad
.
height
,
pad
.
width
,
stride
.
height
,
stride
.
width
,
padMode
);
pad
.
height
,
pad
.
width
,
stride
.
height
,
stride
.
width
,
padMode
);
//getCaffeConvParams(params, kernel, pad, stride);
//getCaffeConvParams(params, kernel, pad, stride);
Ptr
<
Layer
>
l
;
if
(
!
globalPooling
)
if
(
!
globalPooling
)
return
Ptr
<
Layer
>
(
PoolingLayer
::
create
(
type
,
kernel
,
stride
,
pad
,
padMode
)
);
l
=
PoolingLayer
::
create
(
type
,
kernel
,
stride
,
pad
,
padMode
);
else
else
return
Ptr
<
Layer
>
(
PoolingLayer
::
createGlobal
(
type
));
l
=
PoolingLayer
::
createGlobal
(
type
);
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
template
<>
Ptr
<
Layer
>
createLayerFromCaffe
<
SoftmaxLayer
>
(
LayerParams
&
params
)
Ptr
<
Layer
>
createLayerFromCaffe
<
SoftmaxLayer
>
(
LayerParams
&
params
)
{
{
int
axis
=
params
.
get
<
int
>
(
"axis"
,
1
);
int
axis
=
params
.
get
<
int
>
(
"axis"
,
1
);
return
Ptr
<
Layer
>
(
SoftmaxLayer
::
create
(
axis
));
Ptr
<
Layer
>
l
(
SoftmaxLayer
::
create
(
axis
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
//InnerProduct specialization
template
<>
//InnerProduct specialization
...
@@ -129,17 +134,21 @@ Ptr<Layer> createLayerFromCaffe<LRNLayer>(LayerParams& params)
...
@@ -129,17 +134,21 @@ Ptr<Layer> createLayerFromCaffe<LRNLayer>(LayerParams& params)
double
bias
=
params
.
get
<
double
>
(
"bias"
,
1
);
double
bias
=
params
.
get
<
double
>
(
"bias"
,
1
);
bool
normBySize
=
params
.
get
<
bool
>
(
"norm_by_size"
,
true
);
bool
normBySize
=
params
.
get
<
bool
>
(
"norm_by_size"
,
true
);
return
Ptr
<
Layer
>
(
LRNLayer
::
create
(
type
,
size
,
alpha
,
beta
,
bias
,
normBySize
));
Ptr
<
Layer
>
l
(
LRNLayer
::
create
(
type
,
size
,
alpha
,
beta
,
bias
,
normBySize
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
template
<>
Ptr
<
Layer
>
createLayerFromCaffe
<
MVNLayer
>
(
LayerParams
&
params
)
Ptr
<
Layer
>
createLayerFromCaffe
<
MVNLayer
>
(
LayerParams
&
params
)
{
{
return
Ptr
<
Layer
>
(
MVNLayer
::
create
(
Ptr
<
Layer
>
l
(
MVNLayer
::
create
(
params
.
get
<
bool
>
(
"normalize_variance"
,
true
),
params
.
get
<
bool
>
(
"normalize_variance"
,
true
),
params
.
get
<
bool
>
(
"across_channels"
,
false
),
params
.
get
<
bool
>
(
"across_channels"
,
false
),
params
.
get
<
double
>
(
"eps"
,
1e-9
)
params
.
get
<
double
>
(
"eps"
,
1e-9
)
));
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
/* Reshape layers */
/* Reshape layers */
...
@@ -164,13 +173,17 @@ Ptr<Layer> createLayerFromCaffe<ReshapeLayer>(LayerParams ¶ms)
...
@@ -164,13 +173,17 @@ Ptr<Layer> createLayerFromCaffe<ReshapeLayer>(LayerParams ¶ms)
else
else
newShape
=
Shape
::
all
(
0
);
newShape
=
Shape
::
all
(
0
);
return
Ptr
<
Layer
>
(
ReshapeLayer
::
create
(
newShape
,
applyingRange
,
enableReordering
));
Ptr
<
Layer
>
l
(
ReshapeLayer
::
create
(
newShape
,
applyingRange
,
enableReordering
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
template
<>
Ptr
<
Layer
>
createLayerFromCaffe
<
ConcatLayer
>
(
LayerParams
&
params
)
Ptr
<
Layer
>
createLayerFromCaffe
<
ConcatLayer
>
(
LayerParams
&
params
)
{
{
return
Ptr
<
Layer
>
(
ConcatLayer
::
create
(
params
.
get
<
int
>
(
"axis"
,
1
)));
Ptr
<
Layer
>
l
(
ConcatLayer
::
create
(
params
.
get
<
int
>
(
"axis"
,
1
)));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
template
<>
...
@@ -189,7 +202,9 @@ Ptr<Layer> createLayerFromCaffe<SplitLayer>(LayerParams ¶ms)
...
@@ -189,7 +202,9 @@ Ptr<Layer> createLayerFromCaffe<SplitLayer>(LayerParams ¶ms)
outputsCount
=
-
1
;
outputsCount
=
-
1
;
}
}
return
Ptr
<
Layer
>
(
SplitLayer
::
create
(
outputsCount
));
Ptr
<
Layer
>
l
(
SplitLayer
::
create
(
outputsCount
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
template
<>
...
@@ -197,9 +212,10 @@ Ptr<Layer> createLayerFromCaffe<SliceLayer>(LayerParams& params)
...
@@ -197,9 +212,10 @@ Ptr<Layer> createLayerFromCaffe<SliceLayer>(LayerParams& params)
{
{
int
axis
=
params
.
get
<
int
>
(
"axis"
,
1
);
int
axis
=
params
.
get
<
int
>
(
"axis"
,
1
);
Ptr
<
Layer
>
l
;
if
(
!
params
.
has
(
"slice_point"
))
if
(
!
params
.
has
(
"slice_point"
))
{
{
return
Ptr
<
Layer
>
(
SliceLayer
::
create
(
axis
)
);
l
=
SliceLayer
::
create
(
axis
);
}
}
else
else
{
{
...
@@ -208,8 +224,10 @@ Ptr<Layer> createLayerFromCaffe<SliceLayer>(LayerParams& params)
...
@@ -208,8 +224,10 @@ Ptr<Layer> createLayerFromCaffe<SliceLayer>(LayerParams& params)
for
(
int
i
=
0
;
i
<
indicesValue
.
size
();
i
++
)
for
(
int
i
=
0
;
i
<
indicesValue
.
size
();
i
++
)
sliceIndices
[
i
]
=
indicesValue
.
get
<
int
>
(
i
);
sliceIndices
[
i
]
=
indicesValue
.
get
<
int
>
(
i
);
return
Ptr
<
Layer
>
(
SliceLayer
::
create
(
axis
,
sliceIndices
)
);
l
=
SliceLayer
::
create
(
axis
,
sliceIndices
);
}
}
l
->
setParamsFrom
(
params
);
return
l
;
}
}
/* Activation layers */
/* Activation layers */
...
@@ -224,7 +242,9 @@ template<> //ReLU specialization
...
@@ -224,7 +242,9 @@ template<> //ReLU specialization
Ptr
<
Layer
>
createLayerFromCaffe
<
ReLULayer
>
(
LayerParams
&
params
)
Ptr
<
Layer
>
createLayerFromCaffe
<
ReLULayer
>
(
LayerParams
&
params
)
{
{
float
negative_slope
=
params
.
get
<
float
>
(
"negative_slope"
,
0.
f
);
float
negative_slope
=
params
.
get
<
float
>
(
"negative_slope"
,
0.
f
);
return
Ptr
<
Layer
>
(
ReLULayer
::
create
(
negative_slope
));
Ptr
<
Layer
>
l
(
ReLULayer
::
create
(
negative_slope
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
//Power specialization
template
<>
//Power specialization
...
@@ -233,7 +253,9 @@ Ptr<Layer> createLayerFromCaffe<PowerLayer>(LayerParams& params)
...
@@ -233,7 +253,9 @@ Ptr<Layer> createLayerFromCaffe<PowerLayer>(LayerParams& params)
float
power
=
params
.
get
<
float
>
(
"power"
,
1.0
f
);
float
power
=
params
.
get
<
float
>
(
"power"
,
1.0
f
);
float
scale
=
params
.
get
<
float
>
(
"scale"
,
1.0
f
);
float
scale
=
params
.
get
<
float
>
(
"scale"
,
1.0
f
);
float
shift
=
params
.
get
<
float
>
(
"shift"
,
0.0
f
);
float
shift
=
params
.
get
<
float
>
(
"shift"
,
0.0
f
);
return
Ptr
<
Layer
>
(
PowerLayer
::
create
(
power
,
scale
,
shift
));
Ptr
<
Layer
>
l
(
PowerLayer
::
create
(
power
,
scale
,
shift
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
//CropLayer specialization
template
<>
//CropLayer specialization
...
@@ -249,7 +271,9 @@ Ptr<Layer> createLayerFromCaffe<CropLayer>(LayerParams& params)
...
@@ -249,7 +271,9 @@ Ptr<Layer> createLayerFromCaffe<CropLayer>(LayerParams& params)
offset
.
push_back
(
paramOffset
->
get
<
int
>
(
i
));
offset
.
push_back
(
paramOffset
->
get
<
int
>
(
i
));
}
}
return
Ptr
<
Layer
>
(
CropLayer
::
create
(
start_axis
,
offset
));
Ptr
<
Layer
>
l
(
CropLayer
::
create
(
start_axis
,
offset
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
//Eltwise specialization
template
<>
//Eltwise specialization
...
@@ -279,7 +303,9 @@ Ptr<Layer> createLayerFromCaffe<EltwiseLayer>(LayerParams& params)
...
@@ -279,7 +303,9 @@ Ptr<Layer> createLayerFromCaffe<EltwiseLayer>(LayerParams& params)
coeffs
[
i
]
=
paramCoeff
.
get
<
int
>
(
i
);
coeffs
[
i
]
=
paramCoeff
.
get
<
int
>
(
i
);
}
}
}
}
return
Ptr
<
Layer
>
(
EltwiseLayer
::
create
(
op
,
coeffs
));
Ptr
<
Layer
>
l
(
EltwiseLayer
::
create
(
op
,
coeffs
));
l
->
setParamsFrom
(
params
);
return
l
;
}
}
template
<>
//BatchNormLayer specialization
template
<>
//BatchNormLayer specialization
...
@@ -313,6 +339,7 @@ Ptr<Layer> createLayerFromCaffe<MaxUnpoolLayer>(LayerParams& params)
...
@@ -313,6 +339,7 @@ Ptr<Layer> createLayerFromCaffe<MaxUnpoolLayer>(LayerParams& params)
Size
outSize
(
params
.
get
<
int
>
(
"out_w"
),
Size
outSize
(
params
.
get
<
int
>
(
"out_w"
),
params
.
get
<
int
>
(
"out_h"
));
params
.
get
<
int
>
(
"out_h"
));
Ptr
<
MaxUnpoolLayer
>
l
=
MaxUnpoolLayer
::
create
(
outSize
);
Ptr
<
MaxUnpoolLayer
>
l
=
MaxUnpoolLayer
::
create
(
outSize
);
l
->
setParamsFrom
(
params
);
return
Ptr
<
Layer
>
(
l
);
return
Ptr
<
Layer
>
(
l
);
}
}
...
...
modules/dnn/src/layers/elementwise_layers.cpp
View file @
556307a2
...
@@ -14,7 +14,9 @@ Ptr<_Layer> _Layer::create() { \
...
@@ -14,7 +14,9 @@ Ptr<_Layer> _Layer::create() { \
Ptr
<
ReLULayer
>
ReLULayer
::
create
(
double
negativeSlope
)
Ptr
<
ReLULayer
>
ReLULayer
::
create
(
double
negativeSlope
)
{
{
return
Ptr
<
ReLULayer
>
(
new
ElementWiseLayer
<
ReLUFunctor
>
(
ReLUFunctor
(
negativeSlope
)));
Ptr
<
ReLULayer
>
layer
(
new
ElementWiseLayer
<
ReLUFunctor
>
(
ReLUFunctor
(
negativeSlope
)));
layer
->
negativeSlope
=
negativeSlope
;
return
layer
;
}
}
Ptr
<
TanHLayer
>
TanHLayer
::
create
()
Ptr
<
TanHLayer
>
TanHLayer
::
create
()
...
@@ -40,7 +42,11 @@ Ptr<BNLLLayer> BNLLLayer::create()
...
@@ -40,7 +42,11 @@ Ptr<BNLLLayer> BNLLLayer::create()
Ptr
<
PowerLayer
>
PowerLayer
::
create
(
double
power
/*= 1*/
,
double
scale
/*= 1*/
,
double
shift
/*= 0*/
)
Ptr
<
PowerLayer
>
PowerLayer
::
create
(
double
power
/*= 1*/
,
double
scale
/*= 1*/
,
double
shift
/*= 0*/
)
{
{
const
PowerFunctor
f
(
power
,
scale
,
shift
);
const
PowerFunctor
f
(
power
,
scale
,
shift
);
return
Ptr
<
PowerLayer
>
(
new
ElementWiseLayer
<
PowerFunctor
>
(
f
));
Ptr
<
PowerLayer
>
layer
(
new
ElementWiseLayer
<
PowerFunctor
>
(
f
));
layer
->
power
=
power
;
layer
->
scale
=
scale
;
layer
->
shift
=
shift
;
return
layer
;
}
}
////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////
...
...
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