Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleDetection
提交
a9228e2a
P
PaddleDetection
项目概览
PaddlePaddle
/
PaddleDetection
大约 2 年 前同步成功
通知
708
Star
11112
Fork
2696
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
184
列表
看板
标记
里程碑
合并请求
40
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleDetection
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
184
Issue
184
列表
看板
标记
里程碑
合并请求
40
合并请求
40
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
a9228e2a
编写于
1月 23, 2017
作者:
H
hedaoyuan
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix CrossMapNormalGradFunc
上级
c4437fa2
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
43 addition
and
21 deletion
+43
-21
paddle/function/CrossMapNormalOp.cpp
paddle/function/CrossMapNormalOp.cpp
+39
-20
paddle/function/Function.h
paddle/function/Function.h
+4
-1
未找到文件。
paddle/function/CrossMapNormalOp.cpp
浏览文件 @
a9228e2a
...
@@ -196,8 +196,8 @@ public:
...
@@ -196,8 +196,8 @@ public:
}
}
void
check
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
override
{
void
check
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
override
{
CHECK_EQ
(
(
size_t
)
numInputs_
,
inputs
.
size
());
CHECK_EQ
(
numInputs_
,
inputs
.
size
());
CHECK_EQ
(
(
size_t
)
numOutputs_
,
outputs
.
size
());
CHECK_EQ
(
numOutputs_
,
outputs
.
size
());
CHECK_EQ
(
inputs
[
0
].
shape
().
ndims
(),
(
size_t
)
4
);
CHECK_EQ
(
inputs
[
0
].
shape
().
ndims
(),
(
size_t
)
4
);
CHECK
(
inputs
[
0
].
shape
()
==
outputs
[
0
].
shape
());
CHECK
(
inputs
[
0
].
shape
()
==
outputs
[
0
].
shape
());
...
@@ -215,7 +215,7 @@ public:
...
@@ -215,7 +215,7 @@ public:
// number of floating-point operations
// number of floating-point operations
// an approximate value
// an approximate value
size_t
ops
=
batchSize
*
maps
*
((
rows
*
columns
)
*
size_
);
size_t
ops
=
batchSize
*
maps
*
rows
*
columns
*
(
size_
*
2
+
3
);
return
ops
;
return
ops
;
}
}
...
@@ -273,15 +273,7 @@ public:
...
@@ -273,15 +273,7 @@ public:
}
}
void
calc
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
override
{
void
calc
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
override
{
CHECK_EQ
((
size_t
)
numInputs_
,
inputs
.
size
());
check
(
inputs
,
outputs
);
CHECK_EQ
((
size_t
)
numOutputs_
,
outputs
.
size
());
CHECK_EQ
(
inputs
[
0
].
shape
().
ndims
(),
(
size_t
)
4
);
CHECK
(
inputs
[
0
].
shape
()
==
inputs
[
1
].
shape
());
CHECK
(
inputs
[
0
].
shape
()
==
inputs
[
2
].
shape
());
CHECK
(
inputs
[
0
].
shape
()
==
inputs
[
3
].
shape
());
CHECK
(
inputs
[
0
].
shape
()
==
outputs
[
0
].
shape
());
if
(
outputs
[
0
].
getArgType
()
!=
ADD_TO
)
{
if
(
outputs
[
0
].
getArgType
()
!=
ADD_TO
)
{
// Currently, some algorithm implementations are ASSIGN_TO mode,
// Currently, some algorithm implementations are ASSIGN_TO mode,
// if need to support the ADD_TO calculation, need to clear the output.
// if need to support the ADD_TO calculation, need to clear the output.
...
@@ -290,25 +282,52 @@ public:
...
@@ -290,25 +282,52 @@ public:
tmp
.
zero
();
tmp
.
zero
();
}
}
size_t
samples
=
inputs
[
0
].
shape
()[
0
];
size_t
batchSize
=
inputs
[
0
].
shape
()[
0
];
size_t
channel
s
=
inputs
[
0
].
shape
()[
1
];
size_t
map
s
=
inputs
[
0
].
shape
()[
1
];
size_t
height
=
inputs
[
0
].
shape
()[
2
];
size_t
rows
=
inputs
[
0
].
shape
()[
2
];
size_t
width
=
inputs
[
0
].
shape
()[
3
];
size_t
columns
=
inputs
[
0
].
shape
()[
3
];
CrossMapNormalGrad
<
Device
>
(
outputs
[
0
].
data
<
real
>
(),
CrossMapNormalGrad
<
Device
>
(
outputs
[
0
].
data
<
real
>
(),
inputs
[
0
].
data
<
real
>
(),
inputs
[
0
].
data
<
real
>
(),
inputs
[
1
].
data
<
real
>
(),
inputs
[
1
].
data
<
real
>
(),
inputs
[
2
].
data
<
real
>
(),
inputs
[
2
].
data
<
real
>
(),
inputs
[
3
].
data
<
real
>
(),
inputs
[
3
].
data
<
real
>
(),
samples
,
batchSize
,
channel
s
,
map
s
,
height
,
rows
,
width
,
columns
,
size_
,
size_
,
scale_
,
scale_
,
pow_
);
pow_
);
}
}
void
check
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
override
{
CHECK_EQ
(
numInputs_
,
inputs
.
size
());
CHECK_EQ
(
numOutputs_
,
outputs
.
size
());
CHECK_EQ
(
inputs
[
0
].
shape
().
ndims
(),
(
size_t
)
4
);
CHECK
(
inputs
[
0
].
shape
()
==
inputs
[
1
].
shape
());
CHECK
(
inputs
[
0
].
shape
()
==
inputs
[
2
].
shape
());
CHECK
(
inputs
[
0
].
shape
()
==
inputs
[
3
].
shape
());
CHECK
(
inputs
[
0
].
shape
()
==
outputs
[
0
].
shape
());
}
// Only need the shape of one input, can calculate the
// floating-point operation.
size_t
ops
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
override
{
CHECK_LT
((
size_t
)
1
,
inputs
.
size
());
size_t
batchSize
=
inputs
[
0
].
shape
()[
0
];
size_t
maps
=
inputs
[
0
].
shape
()[
1
];
size_t
rows
=
inputs
[
0
].
shape
()[
2
];
size_t
columns
=
inputs
[
0
].
shape
()[
3
];
// number of floating-point operations
// an approximate value
size_t
ops
=
batchSize
*
maps
*
rows
*
columns
*
(
size_
*
4
+
2
);
return
ops
;
}
private:
private:
size_t
size_
;
size_t
size_
;
real
scale_
;
real
scale_
;
...
...
paddle/function/Function.h
浏览文件 @
a9228e2a
...
@@ -156,12 +156,15 @@ public:
...
@@ -156,12 +156,15 @@ public:
// This member function is used to check whether the BufferType and shape of
// This member function is used to check whether the BufferType and shape of
// the inputs and outputs arguments of the Function are correct.
// the inputs and outputs arguments of the Function are correct.
// General calc function which will call this check to do arguments check.
// General calc function which will call this check to do arguments check.
// A
lso before the call calc
, the caller can also check their own arguments.
// A
nd before the calc called
, the caller can also check their own arguments.
virtual
void
check
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
{}
virtual
void
check
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
{}
// Calculate the number of floating-point operations of this Function.
// Calculate the number of floating-point operations of this Function.
// The inputs and outputs arguments do not need to contain the actual data,
// The inputs and outputs arguments do not need to contain the actual data,
// only the shape.
// only the shape.
// And some Functions have the same input and output shapes,
// so you may not need to enter the complete number of arguments.
// But entering the full arguments is always correct for this interface.
virtual
size_t
ops
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
{
virtual
size_t
ops
(
const
BufferArgs
&
inputs
,
const
BufferArgs
&
outputs
)
{
return
0
;
return
0
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录