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
7c885dbb
Commit
7c885dbb
authored
Jun 25, 2018
by
Paul
Browse files
Add test for miopen gemm
parent
84af2e9e
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
60 additions
and
3 deletions
+60
-3
src/targets/miopen/miopen_target.cpp
src/targets/miopen/miopen_target.cpp
+36
-0
test/miopen/miopen.cpp
test/miopen/miopen.cpp
+24
-3
No files found.
src/targets/miopen/miopen_target.cpp
View file @
7c885dbb
...
...
@@ -5,6 +5,7 @@
#include <rtg/shape_for_each.hpp>
#include <rtg/miopen/miopen.hpp>
#include <rtg/miopen/hip.hpp>
#include <rtg/dfor.hpp>
namespace
rtg
{
namespace
miopen
{
...
...
@@ -140,6 +141,29 @@ struct miopen_add
}
};
struct
miopen_gemm
{
gemm
op
;
std
::
string
name
()
const
{
return
"miopen::convolution"
;
}
shape
compute_shape
(
std
::
vector
<
shape
>
inputs
)
const
{
check_shapes
{
inputs
}.
has
(
4
);
return
op
.
compute_shape
({
inputs
.
at
(
1
),
inputs
.
at
(
2
)});
}
argument
compute
(
shape
output_shape
,
std
::
vector
<
argument
>
args
)
const
{
argument
result
{
output_shape
};
visit_all
(
result
,
from_gpu
(
args
[
1
]),
from_gpu
(
args
[
2
]))(
[
&
](
auto
output
,
auto
input1
,
auto
input2
)
{
dfor
(
input1
.
get_shape
().
lens
()[
0
],
input2
.
get_shape
().
lens
()[
1
],
input2
.
get_shape
().
lens
()[
0
])([
&
](
auto
i
,
auto
j
,
auto
k
)
{
output
(
i
,
j
)
+=
input1
(
i
,
k
)
*
input2
(
k
,
j
);
});
});
return
to_gpu
(
result
);
}
};
struct
miopen_relu
{
shared
<
activation_descriptor
>
ad
;
...
...
@@ -194,6 +218,10 @@ struct miopen_apply
{
apply_add
(
it
);
}
else
if
(
it
->
op
.
name
()
==
"gemm"
)
{
apply_gemm
(
it
);
}
}
}
...
...
@@ -253,6 +281,14 @@ struct miopen_apply
prog
->
replace_instruction
(
ins
,
miopen_add
{},
handle
,
ins
->
arguments
.
at
(
0
),
ins
->
arguments
.
at
(
1
),
output
);
}
void
apply_gemm
(
instruction_ref
ins
)
{
auto
&&
op
=
any_cast
<
gemm
>
(
ins
->
op
);
auto
output
=
insert_allocation
(
ins
,
ins
->
result
);
prog
->
replace_instruction
(
ins
,
miopen_gemm
{
op
},
handle
,
ins
->
arguments
.
at
(
0
),
ins
->
arguments
.
at
(
1
),
output
);
}
};
std
::
string
miopen_target
::
name
()
const
{
return
"miopen"
;
}
...
...
test/miopen/miopen.cpp
View file @
7c885dbb
...
...
@@ -136,10 +136,31 @@ struct test_conv_pooling
}
};
struct
test_gemm
{
rtg
::
program
create_program
()
const
{
rtg
::
program
p
;
auto
a
=
p
.
add_parameter
(
"a"
,
rtg
::
shape
{
rtg
::
shape
::
float_type
,
{
4
,
5
}});
auto
b
=
p
.
add_parameter
(
"b"
,
rtg
::
shape
{
rtg
::
shape
::
float_type
,
{
5
,
3
}});
p
.
add_instruction
(
rtg
::
gemm
{},
a
,
b
);
return
p
;
}
rtg
::
program
::
parameter_map
create_params
()
const
{
rtg
::
program
::
parameter_map
m
;
m
[
"a"
]
=
rtg
::
generate_argument
({
rtg
::
shape
::
float_type
,
{
4
,
5
}});
m
[
"b"
]
=
rtg
::
generate_argument
({
rtg
::
shape
::
float_type
,
{
5
,
3
}});
return
m
;
}
};
int
main
()
{
//
verify_program<test_add>();
verify_program
<
test_add
>
();
verify_program
<
test_add_broadcast
>
();
// verify_program<test_conv_relu>();
// verify_program<test_conv_pooling>();
verify_program
<
test_conv_relu
>
();
verify_program
<
test_conv_pooling
>
();
verify_program
<
test_gemm
>
();
}
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