Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
milvus
提交
062c3aad
milvus
项目概览
BaiXuePrincess
/
milvus
与 Fork 源项目一致
从无法访问的项目Fork
通知
7
Star
4
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
milvus
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
062c3aad
编写于
4月 26, 2019
作者:
X
Xu Peng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(db): merge file optimize
Former-commit-id: fea0d7970fab88f995d9d16d7dfea84dd4fbacb7
上级
1d9946ff
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
5 addition
and
1 deletion
+5
-1
cpp/src/db/DBImpl.cpp
cpp/src/db/DBImpl.cpp
+5
-1
未找到文件。
cpp/src/db/DBImpl.cpp
浏览文件 @
062c3aad
...
...
@@ -113,6 +113,7 @@ Status DBImpl::search(const std::string &group_id, size_t k, size_t nq,
index
=
read_index
(
file
.
location
.
c_str
());
zilliz
::
vecwise
::
cache
::
CpuCacheMgr
::
GetInstance
()
->
InsertItem
(
file
.
location
,
index
);
}
LOG
(
DEBUG
)
<<
"Search Index Of Size: "
<<
index
->
dim
*
index
->
ntotal
*
4
/
(
1024
*
1024
)
<<
" M"
;
index
->
search
(
nq
,
vectors
,
k
,
output_distence
,
output_ids
);
cluster
(
output_ids
,
output_distence
);
// cluster to each query
memset
(
output_distence
,
0
,
k
*
nq
*
sizeof
(
float
));
...
...
@@ -207,6 +208,7 @@ Status DBImpl::merge_files(const std::string& group_id, const meta::DateT& date,
std
::
shared_ptr
<
faiss
::
Index
>
index
(
faiss
::
index_factory
(
group_file
.
dimension
,
"IDMap,Flat"
));
meta
::
GroupFilesSchema
updated
;
long
index_size
=
0
;
for
(
auto
&
file
:
files
)
{
auto
to_merge
=
zilliz
::
vecwise
::
cache
::
CpuCacheMgr
::
GetInstance
()
->
GetIndex
(
file
.
location
);
...
...
@@ -221,9 +223,11 @@ Status DBImpl::merge_files(const std::string& group_id, const meta::DateT& date,
updated
.
push_back
(
file_schema
);
LOG
(
DEBUG
)
<<
"About to merge file "
<<
file_schema
.
file_id
<<
" of size="
<<
file_schema
.
rows
;
index_size
=
group_file
.
dimension
*
index
->
ntotal
;
if
(
index_size
>=
_options
.
index_trigger_size
)
break
;
}
auto
index_size
=
group_file
.
dimension
*
index
->
ntotal
;
faiss
::
write_index
(
index
.
get
(),
group_file
.
location
.
c_str
());
if
(
index_size
>=
_options
.
index_trigger_size
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录