Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MindSpore
mindinsight
提交
34648a48
M
mindinsight
项目概览
MindSpore
/
mindinsight
通知
7
Star
3
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
mindinsight
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
34648a48
编写于
5月 22, 2020
作者:
L
liangyongxiong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update cache status on loading
上级
16e94c3f
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
54 addition
and
28 deletion
+54
-28
mindinsight/datavisual/common/enums.py
mindinsight/datavisual/common/enums.py
+10
-2
mindinsight/datavisual/data_transform/data_manager.py
mindinsight/datavisual/data_transform/data_manager.py
+18
-11
mindinsight/datavisual/data_transform/loader_generators/loader_struct.py
...avisual/data_transform/loader_generators/loader_struct.py
+12
-0
mindinsight/datavisual/processors/train_task_manager.py
mindinsight/datavisual/processors/train_task_manager.py
+14
-15
未找到文件。
mindinsight/datavisual/common/enums.py
浏览文件 @
34648a48
...
@@ -14,9 +14,9 @@
...
@@ -14,9 +14,9 @@
# ============================================================================
# ============================================================================
"""Enums."""
"""Enums."""
from
enum
import
E
num
import
e
num
class
BaseEnum
(
Enum
):
class
BaseEnum
(
enum
.
Enum
):
@
classmethod
@
classmethod
def
list_members
(
cls
):
def
list_members
(
cls
):
...
@@ -38,3 +38,11 @@ class PluginNameEnum(BaseEnum):
...
@@ -38,3 +38,11 @@ class PluginNameEnum(BaseEnum):
SCALAR
=
'scalar'
SCALAR
=
'scalar'
GRAPH
=
'graph'
GRAPH
=
'graph'
HISTOGRAM
=
'histogram'
HISTOGRAM
=
'histogram'
@
enum
.
unique
class
CacheStatus
(
enum
.
Enum
):
"""Train job cache status."""
NOT_IN_CACHE
=
"NOT_IN_CACHE"
CACHING
=
"CACHING"
CACHED
=
"CACHED"
mindinsight/datavisual/data_transform/data_manager.py
浏览文件 @
34648a48
...
@@ -22,7 +22,6 @@ This module also acts as a thread pool manager.
...
@@ -22,7 +22,6 @@ This module also acts as a thread pool manager.
"""
"""
import
abc
import
abc
import
datetime
import
datetime
import
enum
import
threading
import
threading
import
time
import
time
import
os
import
os
...
@@ -34,6 +33,7 @@ from mindinsight.datavisual.data_transform.summary_watcher import SummaryWatcher
...
@@ -34,6 +33,7 @@ from mindinsight.datavisual.data_transform.summary_watcher import SummaryWatcher
from
mindinsight.conf
import
settings
from
mindinsight.conf
import
settings
from
mindinsight.datavisual.common
import
exceptions
from
mindinsight.datavisual.common
import
exceptions
from
mindinsight.datavisual.common.enums
import
CacheStatus
from
mindinsight.datavisual.common.log
import
logger
from
mindinsight.datavisual.common.log
import
logger
from
mindinsight.datavisual.common.enums
import
DataManagerStatus
from
mindinsight.datavisual.common.enums
import
DataManagerStatus
from
mindinsight.datavisual.common.enums
import
PluginNameEnum
from
mindinsight.datavisual.common.enums
import
PluginNameEnum
...
@@ -44,14 +44,6 @@ from mindinsight.utils.exceptions import MindInsightException
...
@@ -44,14 +44,6 @@ from mindinsight.utils.exceptions import MindInsightException
from
mindinsight.utils.exceptions
import
ParamValueError
from
mindinsight.utils.exceptions
import
ParamValueError
@
enum
.
unique
class
CacheStatus
(
enum
.
Enum
):
"""Train job cache status."""
NOT_IN_CACHE
=
"NOT_IN_CACHE"
CACHING
=
"CACHING"
CACHED
=
"CACHED"
class
_BasicTrainJob
:
class
_BasicTrainJob
:
"""
"""
Basic info about train job.
Basic info about train job.
...
@@ -267,6 +259,11 @@ class TrainJob:
...
@@ -267,6 +259,11 @@ class TrainJob:
"""Get cache status."""
"""Get cache status."""
return
self
.
_cache_status
return
self
.
_cache_status
@
cache_status
.
setter
def
cache_status
(
self
,
cache_status
):
"""Set cache status."""
self
.
_cache_status
=
cache_status
class
BaseCacheItemUpdater
(
abc
.
ABC
):
class
BaseCacheItemUpdater
(
abc
.
ABC
):
"""Abstract base class for other modules to update cache content."""
"""Abstract base class for other modules to update cache content."""
...
@@ -464,6 +461,11 @@ class _DetailCacheManager(_BaseCacheManager):
...
@@ -464,6 +461,11 @@ class _DetailCacheManager(_BaseCacheManager):
if
loader
is
None
:
if
loader
is
None
:
raise
TrainJobNotExistError
(
train_id
)
raise
TrainJobNotExistError
(
train_id
)
# Update cache status loader to CACHING if loader is NOT_IN_CACHE
# before triggering the next interval.
if
loader
.
cache_status
==
CacheStatus
.
NOT_IN_CACHE
:
loader
.
cache_status
=
CacheStatus
.
CACHING
self
.
_add_loader
(
loader
)
self
.
_add_loader
(
loader
)
need_reload
=
True
need_reload
=
True
...
@@ -520,7 +522,13 @@ class _DetailCacheManager(_BaseCacheManager):
...
@@ -520,7 +522,13 @@ class _DetailCacheManager(_BaseCacheManager):
if
loader
is
None
:
if
loader
is
None
:
logger
.
debug
(
"Loader %r has been deleted, will not load data."
,
loader_id
)
logger
.
debug
(
"Loader %r has been deleted, will not load data."
,
loader_id
)
return
return
loader
.
data_loader
.
load
()
loader
.
data_loader
.
load
()
# Update loader cache status to CACHED.
# Loader with cache status CACHED should remain the same cache status.
loader
.
cache_status
=
CacheStatus
.
CACHED
except
MindInsightException
as
ex
:
except
MindInsightException
as
ex
:
logger
.
warning
(
"Data loader %r load data failed. "
logger
.
warning
(
"Data loader %r load data failed. "
"Delete data_loader. Detail: %s"
,
loader_id
,
ex
)
"Delete data_loader. Detail: %s"
,
loader_id
,
ex
)
...
@@ -711,8 +719,7 @@ class _DetailCacheManager(_BaseCacheManager):
...
@@ -711,8 +719,7 @@ class _DetailCacheManager(_BaseCacheManager):
train_job_obj
=
CachedTrainJob
(
basic_info
=
None
)
train_job_obj
=
CachedTrainJob
(
basic_info
=
None
)
train_job_obj
.
set
(
DATAVISUAL_CACHE_KEY
,
train_job
)
train_job_obj
.
set
(
DATAVISUAL_CACHE_KEY
,
train_job
)
# Will assign real value in future.
train_job_obj
.
cache_status
=
loader
.
cache_status
train_job_obj
.
cache_status
=
CacheStatus
.
CACHED
return
train_job_obj
return
train_job_obj
...
...
mindinsight/datavisual/data_transform/loader_generators/loader_struct.py
浏览文件 @
34648a48
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
# limitations under the License.
# limitations under the License.
# ============================================================================
# ============================================================================
"""Loader struct."""
"""Loader struct."""
from
mindinsight.datavisual.common.enums
import
CacheStatus
class
LoaderStruct
:
class
LoaderStruct
:
...
@@ -27,6 +28,7 @@ class LoaderStruct:
...
@@ -27,6 +28,7 @@ class LoaderStruct:
self
.
_path
=
path
self
.
_path
=
path
self
.
_latest_update_time
=
latest_update_time
self
.
_latest_update_time
=
latest_update_time
self
.
_data_loader
=
data_loader
self
.
_data_loader
=
data_loader
self
.
_cache_status
=
CacheStatus
.
NOT_IN_CACHE
@
property
@
property
def
loader_id
(
self
):
def
loader_id
(
self
):
...
@@ -48,11 +50,21 @@ class LoaderStruct:
...
@@ -48,11 +50,21 @@ class LoaderStruct:
"""Get data loader."""
"""Get data loader."""
return
self
.
_data_loader
return
self
.
_data_loader
@
property
def
cache_status
(
self
):
"""Get cache status of loader."""
return
self
.
_cache_status
@
latest_update_time
.
setter
@
latest_update_time
.
setter
def
latest_update_time
(
self
,
latest_update_time
):
def
latest_update_time
(
self
,
latest_update_time
):
"""Set the latest update time of loader."""
"""Set the latest update time of loader."""
self
.
_latest_update_time
=
latest_update_time
self
.
_latest_update_time
=
latest_update_time
@
cache_status
.
setter
def
cache_status
(
self
,
cache_status
):
"""Set cache status of loader."""
self
.
_cache_status
=
cache_status
def
to_dict
(
self
):
def
to_dict
(
self
):
"""Transform LoaderStruct to dict."""
"""Transform LoaderStruct to dict."""
return
dict
(
return
dict
(
...
...
mindinsight/datavisual/processors/train_task_manager.py
浏览文件 @
34648a48
...
@@ -17,10 +17,10 @@
...
@@ -17,10 +17,10 @@
from
mindinsight.datavisual.common.log
import
logger
from
mindinsight.datavisual.common.log
import
logger
from
mindinsight.datavisual.common
import
exceptions
from
mindinsight.datavisual.common
import
exceptions
from
mindinsight.datavisual.common.enums
import
PluginNameEnum
from
mindinsight.datavisual.common.enums
import
PluginNameEnum
from
mindinsight.datavisual.common.enums
import
CacheStatus
from
mindinsight.datavisual.common.validation
import
Validation
from
mindinsight.datavisual.common.validation
import
Validation
from
mindinsight.datavisual.processors.base_processor
import
BaseProcessor
from
mindinsight.datavisual.processors.base_processor
import
BaseProcessor
from
mindinsight.datavisual.data_transform.data_manager
import
DATAVISUAL_PLUGIN_KEY
,
DATAVISUAL_CACHE_KEY
from
mindinsight.datavisual.data_transform.data_manager
import
DATAVISUAL_PLUGIN_KEY
,
DATAVISUAL_CACHE_KEY
from
mindinsight.datavisual.data_transform.data_manager
import
CacheStatus
class
TrainTaskManager
(
BaseProcessor
):
class
TrainTaskManager
(
BaseProcessor
):
...
@@ -132,23 +132,22 @@ class TrainTaskManager(BaseProcessor):
...
@@ -132,23 +132,22 @@ class TrainTaskManager(BaseProcessor):
Returns:
Returns:
dict, indicates train job ID and its current cache status.
dict, indicates train job ID and its current cache status.
"""
"""
brief_cache
=
self
.
_data_manager
.
get_brief_cache
()
brief_train_jobs
=
brief_cache
.
get_train_jobs
()
for
train_id
in
train_ids
:
brief_train_job
=
brief_train_jobs
.
get
(
train_id
)
if
brief_train_job
is
None
:
raise
exceptions
.
TrainJobNotExistError
(
f
'Train id
{
train_id
}
not exists'
)
cache_result
=
[]
cache_result
=
[]
for
train_id
in
train_ids
:
for
train_id
in
train_ids
:
brief_train_job
=
brief_train_jobs
.
get
(
train_id
)
try
:
if
brief_train_job
.
cache_status
.
value
==
CacheStatus
.
NOT_IN_CACHE
.
value
:
train_job
=
self
.
_data_manager
.
get_train_job
(
train_id
)
except
exceptions
.
TrainJobNotExistError
:
logger
.
warning
(
'Train job %s not existed'
,
train_id
)
continue
if
train_job
.
cache_status
==
CacheStatus
.
NOT_IN_CACHE
:
self
.
_data_manager
.
cache_train_job
(
train_id
)
self
.
_data_manager
.
cache_train_job
(
train_id
)
# Update loader cache status to CACHING for consistency in response.
train_job
.
cache_status
=
CacheStatus
.
CACHING
cache_result
.
append
(
{
cache_result
.
append
(
dict
(
'train_id'
:
train_id
,
train_id
=
train_id
,
'cache_status'
:
brief_
train_job
.
cache_status
.
value
,
cache_status
=
train_job
.
cache_status
.
value
,
}
)
)
)
return
cache_result
return
cache_result
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录