Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
gaoqiong
MIGraphX
Commits
2936a27f
Commit
2936a27f
authored
Oct 08, 2018
by
Scott Thornton
Browse files
Formatting
parent
39ca7206
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
29 additions
and
35 deletions
+29
-35
src/fwd_conv_batchnorm_rewrite.cpp
src/fwd_conv_batchnorm_rewrite.cpp
+2
-1
test/fwd_conv_batchnorm_rewrite_test.cpp
test/fwd_conv_batchnorm_rewrite_test.cpp
+27
-34
No files found.
src/fwd_conv_batchnorm_rewrite.cpp
View file @
2936a27f
...
@@ -52,7 +52,8 @@ void fwd_conv_batchnorm_rewrite::apply(program& p) const
...
@@ -52,7 +52,8 @@ void fwd_conv_batchnorm_rewrite::apply(program& p) const
gamma2
(
k
)
/
std
::
sqrt
(
variance2
(
k
)
+
epsilon
)
*
weights2
(
k
,
c
,
h
,
w
);
gamma2
(
k
)
/
std
::
sqrt
(
variance2
(
k
)
+
epsilon
)
*
weights2
(
k
,
c
,
h
,
w
);
});
});
dfor
(
new_bias
.
get_shape
().
elements
())([
&
](
std
::
size_t
c
)
{
dfor
(
new_bias
.
get_shape
().
elements
())([
&
](
std
::
size_t
c
)
{
new_bias2
(
c
)
=
bias2
(
c
)
-
(
gamma2
(
c
)
*
mean2
(
c
)
/
std
::
sqrt
(
variance2
(
c
)
+
epsilon
));
new_bias2
(
c
)
=
bias2
(
c
)
-
(
gamma2
(
c
)
*
mean2
(
c
)
/
std
::
sqrt
(
variance2
(
c
)
+
epsilon
));
});
});
});
});
// Replace convolution instruction with updated weights
// Replace convolution instruction with updated weights
...
...
test/fwd_conv_batchnorm_rewrite_test.cpp
View file @
2936a27f
...
@@ -6,37 +6,30 @@
...
@@ -6,37 +6,30 @@
#include <test.hpp>
#include <test.hpp>
#include <migraph/verify.hpp>
#include <migraph/verify.hpp>
void
fwd_conv_batchnorm_rewrite_test
()
{
void
fwd_conv_batchnorm_rewrite_test
()
std
::
vector
<
float
>
xdata
=
{
{
0.26485917
,
0.61703885
,
0.32762103
,
0.2503367
,
0.6552712
,
std
::
vector
<
float
>
xdata
=
{
0.07947932
,
0.95442678
,
0.70892651
,
0.890563
,
0.80808088
,
0.26485917
,
0.61703885
,
0.32762103
,
0.2503367
,
0.6552712
,
0.07947932
,
0.95442678
,
0.89540492
,
0.52657048
,
0.94614791
,
0.64371508
,
0.0971229
,
0.70892651
,
0.890563
,
0.80808088
,
0.89540492
,
0.52657048
,
0.94614791
,
0.64371508
,
0.2475562
,
0.47405955
,
0.85538928
,
0.05428386
,
0.993078
,
0.0971229
,
0.2475562
,
0.47405955
,
0.85538928
,
0.05428386
,
0.993078
,
0.72771973
,
0.72771973
,
0.18312255
,
0.3091522
,
0.51396558
,
0.35158192
,
0.18312255
,
0.3091522
,
0.51396558
,
0.35158192
,
0.2419852
,
0.83691474
,
0.36355352
,
0.2419852
,
0.83691474
,
0.36355352
,
0.04769134
,
0.08312604
,
0.04769134
,
0.08312604
,
0.61804092
,
0.0508887
,
0.30987137
,
0.81307629
,
0.16398955
,
0.61804092
,
0.0508887
,
0.30987137
,
0.81307629
,
0.16398955
,
0.69886166
,
0.02415926
,
0.60608918
,
0.81907569
,
0.13208211
,
0.48303735
,
0.87533734
,
0.69886166
,
0.02415926
,
0.60608918
,
0.81907569
,
0.13208211
,
0.92998813
,
0.65553674
,
0.73223327
,
0.99401001
,
0.09850688
,
0.76972609
,
0.11118327
,
0.48303735
,
0.87533734
,
0.92998813
,
0.65553674
,
0.73223327
,
0.04392097
,
0.39252306
,
0.91129653
,
0.89078693
,
0.60571206
,
0.98410397
,
0.15290698
,
0.99401001
,
0.09850688
,
0.76972609
,
0.11118327
,
0.04392097
,
0.86992609
,
0.7575111
,
0.80583525
,
0.23649562
,
0.7478029
,
0.62888878
,
0.39886601
,
0.39252306
,
0.91129653
,
0.89078693
,
0.60571206
,
0.98410397
,
0.37066793
,
0.72627947
,
0.8745595
,
0.13568234
,
0.7413787
,
0.5039495
,
0.18945697
,
0.15290698
,
0.86992609
,
0.7575111
,
0.80583525
,
0.23649562
,
0.87046838
,
0.63970494
,
0.01124038
,
0.27459063
,
0.65745586
,
0.69182619
,
0.80470603
,
0.7478029
,
0.62888878
,
0.39886601
,
0.37066793
,
0.72627947
,
0.58039348
,
0.36950583
,
0.43634225
,
0.01694425
,
0.14099377
,
0.77015849
,
0.35809292
,
0.8745595
,
0.13568234
,
0.7413787
,
0.5039495
,
0.18945697
,
0.40547674
,
0.46538817
,
0.65835358
,
0.2266954
,
0.39057646
,
0.64642207
,
0.84491134
,
0.87046838
,
0.63970494
,
0.01124038
,
0.27459063
,
0.65745586
,
0.20998067
,
0.41074121
,
0.73055221
,
0.26424874
,
0.10612507
,
0.24478521
,
0.24091282
,
0.69182619
,
0.80470603
,
0.58039348
,
0.36950583
,
0.43634225
,
0.52536754
,
0.57292341
,
0.82190903
,
0.51858515
,
0.17162996
,
0.52048114
,
0.96624787
,
0.01694425
,
0.14099377
,
0.77015849
,
0.35809292
,
0.40547674
,
0.17527163
,
0.56384485
,
0.91991603
};
0.46538817
,
0.65835358
,
0.2266954
,
0.39057646
,
0.64642207
,
std
::
vector
<
float
>
wdata
=
{
0.84491134
,
0.20998067
,
0.41074121
,
0.73055221
,
0.26424874
,
-
1.12125056
,
0.50228441
,
1.12719446
,
-
2.61705068
,
-
0.2027315
,
-
0.82199441
,
0.05337102
,
0.10612507
,
0.24478521
,
0.24091282
,
0.52536754
,
0.57292341
,
-
0.62146691
,
-
2.40572931
,
-
1.47175612
,
1.49654601
,
-
1.07070376
,
-
0.65908074
,
-
0.28457694
,
0.82190903
,
0.51858515
,
0.17162996
,
0.52048114
,
0.96624787
,
1.60046717
,
0.20677642
,
-
1.51844486
,
0.41203847
,
-
0.01285751
,
0.07948031
,
-
0.91507006
,
0.17527163
,
0.56384485
,
0.91991603
};
-
1.59481079
,
-
0.12856238
,
0.39970482
,
-
1.89015158
,
0.66969754
,
0.10312618
};
std
::
vector
<
float
>
wdata
=
{
-
1.12125056
,
0.50228441
,
1.12719446
,
-
2.61705068
,
-
0.2027315
,
-
0.82199441
,
0.05337102
,
-
0.62146691
,
-
2.40572931
,
-
1.47175612
,
1.49654601
,
-
1.07070376
,
-
0.65908074
,
-
0.28457694
,
1.60046717
,
0.20677642
,
-
1.51844486
,
0.41203847
,
-
0.01285751
,
0.07948031
,
-
0.91507006
,
-
1.59481079
,
-
0.12856238
,
0.39970482
,
-
1.89015158
,
0.66969754
,
0.10312618
};
migraph
::
shape
xs
{
migraph
::
shape
::
float_type
,
{
1
,
3
,
6
,
6
}};
migraph
::
shape
xs
{
migraph
::
shape
::
float_type
,
{
1
,
3
,
6
,
6
}};
migraph
::
shape
ws
{
migraph
::
shape
::
float_type
,
{
1
,
3
,
3
,
3
}};
migraph
::
shape
ws
{
migraph
::
shape
::
float_type
,
{
1
,
3
,
3
,
3
}};
migraph
::
shape
vars
{
migraph
::
shape
::
float_type
,
{
1
}};
migraph
::
shape
vars
{
migraph
::
shape
::
float_type
,
{
1
}};
...
@@ -50,7 +43,7 @@ void fwd_conv_batchnorm_rewrite_test() {
...
@@ -50,7 +43,7 @@ void fwd_conv_batchnorm_rewrite_test() {
auto
bias
=
p1
.
add_literal
(
migraph
::
literal
{
vars
,
{
8.1
f
}});
auto
bias
=
p1
.
add_literal
(
migraph
::
literal
{
vars
,
{
8.1
f
}});
auto
mean
=
p1
.
add_literal
(
migraph
::
literal
{
vars
,
{
4.0
f
}});
auto
mean
=
p1
.
add_literal
(
migraph
::
literal
{
vars
,
{
4.0
f
}});
auto
variance
=
p1
.
add_literal
(
migraph
::
literal
{
vars
,
{
37.11
f
}});
auto
variance
=
p1
.
add_literal
(
migraph
::
literal
{
vars
,
{
37.11
f
}});
p1
.
add_instruction
(
migraph
::
op
::
batch_norm_inference
{},
conv
,
scale
,
bias
,
mean
,
variance
);
p1
.
add_instruction
(
migraph
::
op
::
batch_norm_inference
{},
conv
,
scale
,
bias
,
mean
,
variance
);
}
}
{
{
auto
x
=
p2
.
add_literal
(
xs
,
xdata
);
auto
x
=
p2
.
add_literal
(
xs
,
xdata
);
...
@@ -60,14 +53,14 @@ void fwd_conv_batchnorm_rewrite_test() {
...
@@ -60,14 +53,14 @@ void fwd_conv_batchnorm_rewrite_test() {
auto
bias
=
p2
.
add_literal
(
migraph
::
literal
{
vars
,
{
8.1
f
}});
auto
bias
=
p2
.
add_literal
(
migraph
::
literal
{
vars
,
{
8.1
f
}});
auto
mean
=
p2
.
add_literal
(
migraph
::
literal
{
vars
,
{
4.0
f
}});
auto
mean
=
p2
.
add_literal
(
migraph
::
literal
{
vars
,
{
4.0
f
}});
auto
variance
=
p2
.
add_literal
(
migraph
::
literal
{
vars
,
{
37.11
f
}});
auto
variance
=
p2
.
add_literal
(
migraph
::
literal
{
vars
,
{
37.11
f
}});
p2
.
add_instruction
(
migraph
::
op
::
batch_norm_inference
{},
conv
,
scale
,
bias
,
mean
,
variance
);
p2
.
add_instruction
(
migraph
::
op
::
batch_norm_inference
{},
conv
,
scale
,
bias
,
mean
,
variance
);
}
}
std
::
cout
<<
p1
<<
std
::
endl
;
std
::
cout
<<
p1
<<
std
::
endl
;
migraph
::
fwd_conv_batchnorm_rewrite
opt
;
migraph
::
fwd_conv_batchnorm_rewrite
opt
;
opt
.
apply
(
p2
);
opt
.
apply
(
p2
);
p1
.
compile
(
migraph
::
cpu
::
cpu_target
{});
p1
.
compile
(
migraph
::
cpu
::
cpu_target
{});
p2
.
compile
(
migraph
::
cpu
::
cpu_target
{});
p2
.
compile
(
migraph
::
cpu
::
cpu_target
{});
auto
result1
=
p1
.
eval
({});
auto
result1
=
p1
.
eval
({});
auto
result2
=
p2
.
eval
({});
auto
result2
=
p2
.
eval
({});
...
...
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