Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Oneflow-Inc
oneflow
提交
6832d2f0
O
oneflow
项目概览
Oneflow-Inc
/
oneflow
上一次同步 2 年多
通知
13
Star
2733
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
oneflow
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
6832d2f0
编写于
6月 09, 2017
作者:
W
willzhang4a58
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
process regst msg in ModelUpdateCompActor
上级
3f4ee5c9
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
30 addition
and
3 deletion
+30
-3
oneflow/core/actor/actor.h
oneflow/core/actor/actor.h
+2
-0
oneflow/core/actor/model_update_comp_actor.cpp
oneflow/core/actor/model_update_comp_actor.cpp
+25
-2
oneflow/core/actor/model_update_comp_actor.h
oneflow/core/actor/model_update_comp_actor.h
+3
-1
未找到文件。
oneflow/core/actor/actor.h
浏览文件 @
6832d2f0
...
...
@@ -9,6 +9,8 @@
#include "oneflow/core/actor/actor_message.h"
#include "oneflow/core/actor/actor_message_bus.h"
#include "oneflow/core/register/register.h"
#include "oneflow/core/register/local_register_warpper.h"
#include "oneflow/core/register/remote_register_warpper.h"
#include "oneflow/core/register/register_manager.h"
#include "oneflow/core/thread/thread_context.h"
...
...
oneflow/core/actor/model_update_comp_actor.cpp
浏览文件 @
6832d2f0
...
...
@@ -58,15 +58,38 @@ void MdUpdtCompActor::HandleForUpdateModel(
const
KernelContext
&
kernel_ctx
)
{
if
(
actor_msg
.
msg_type
()
==
ActorMsgType
::
kCmdMsg
)
{
CHECK
(
actor_msg
.
actor_cmd
()
==
ActorCmd
::
kStop
);
cur_handle_
=
nullptr
;
TODO
();
cur_handle_
=
nullptr
;
}
else
if
(
actor_msg
.
msg_type
()
==
ActorMsgType
::
kRegstMsg
)
{
TODO
(
);
ProcessRegstFromMsg
(
actor_msg
.
regst_warpper
(),
kernel_ctx
);
}
else
{
UNEXPECTED_RUN
();
}
}
void
MdUpdtCompActor
::
ProcessRegstFromMsg
(
std
::
shared_ptr
<
RegstWarpper
>
regst_warpper
,
const
KernelContext
&
kernel_ctx
)
{
if
(
TryUpdtStateAsFromRegstReader
(
regst_warpper
->
regst_raw_ptr
())
!=
0
)
{
waiting_model_diff_acc_queue_
.
push
(
regst_warpper
);
}
if
(
!
waiting_model_diff_acc_queue_
.
empty
()
&&
IsWriteReady
())
{
auto
model_diff_acc_wpr
=
waiting_model_diff_acc_queue_
.
front
();
waiting_model_diff_acc_queue_
.
pop
();
Regst
*
model_regst
=
GetCurWriteableRegst
(
model_regst_desc_id_
);
auto
model_wpr
=
std
::
make_shared
<
LocalRegstWarpper
>
(
model_regst
);
WardKernel
(
kernel_ctx
,
[
&
](
uint64_t
regst_desc_id
)
->
std
::
shared_ptr
<
RegstWarpper
>
{
if
(
regst_desc_id
==
model_regst_desc_id_
)
{
return
model_wpr
;
}
else
{
return
model_diff_acc_wpr
;
}
});
model_regst
->
set_model_version_id
(
model_diff_acc_wpr
->
model_version_id
());
}
}
REGISTER_ACTOR
(
kMdUpdtCompTask
,
true
,
MdUpdtCompActor
);
}
// namespace oneflow
oneflow/core/actor/model_update_comp_actor.h
浏览文件 @
6832d2f0
...
...
@@ -15,14 +15,16 @@ class MdUpdtCompActor final : public CompActor {
void
ProcessMsg
(
const
ActorMsg
&
,
const
ThreadContext
&
)
override
;
private:
void
HandleBeforeInitializeModel
(
const
ActorMsg
&
,
const
KernelContext
&
);
void
HandleBeforeSendInitialModel
(
const
ActorMsg
&
,
const
KernelContext
&
);
void
HandleForUpdateModel
(
const
ActorMsg
&
,
const
KernelContext
&
);
void
ProcessRegstFromMsg
(
std
::
shared_ptr
<
RegstWarpper
>
,
const
KernelContext
&
);
void
(
MdUpdtCompActor
::*
cur_handle_
)(
const
ActorMsg
&
,
const
KernelContext
&
);
uint64_t
model_regst_desc_id_
;
uint64_t
model_tmp_regst_desc_id_
;
std
::
queue
<
std
::
shared_ptr
<
RegstWarpper
>>
waiting_model_diff_acc_queue_
;
};
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录