mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-08 18:18:30 +08:00
124 lines
3.5 KiB
C++
124 lines
3.5 KiB
C++
////////////////////////////////////////////////////////////////////////////////
|
|
// Copyright 上海赜睿信息科技有限公司(Zilliz) - All Rights Reserved
|
|
// Unauthorized copying of this file, via any medium is strictly prohibited.
|
|
// Proprietary and confidential.
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
#include <gtest/gtest.h>
|
|
#include <boost/filesystem.hpp>
|
|
|
|
#include "db/engine/EngineFactory.h"
|
|
#include "db/engine/ExecutionEngineImpl.h"
|
|
#include "server/ServerConfig.h"
|
|
|
|
#include <vector>
|
|
|
|
using namespace zilliz::milvus;
|
|
|
|
TEST(EngineTest, FACTORY_TEST) {
|
|
{
|
|
auto engine_ptr = engine::EngineFactory::Build(
|
|
512,
|
|
"/tmp/milvus_index_1",
|
|
engine::EngineType::INVALID,
|
|
engine::MetricType::IP,
|
|
1024
|
|
);
|
|
|
|
ASSERT_TRUE(engine_ptr == nullptr);
|
|
}
|
|
|
|
{
|
|
auto engine_ptr = engine::EngineFactory::Build(
|
|
512,
|
|
"/tmp/milvus_index_1",
|
|
engine::EngineType::FAISS_IDMAP,
|
|
engine::MetricType::IP,
|
|
1024
|
|
);
|
|
|
|
ASSERT_TRUE(engine_ptr != nullptr);
|
|
}
|
|
|
|
{
|
|
auto engine_ptr = engine::EngineFactory::Build(
|
|
512,
|
|
"/tmp/milvus_index_1",
|
|
engine::EngineType::FAISS_IVFFLAT,
|
|
engine::MetricType::IP,
|
|
1024
|
|
);
|
|
|
|
ASSERT_TRUE(engine_ptr != nullptr);
|
|
}
|
|
|
|
{
|
|
auto engine_ptr = engine::EngineFactory::Build(
|
|
512,
|
|
"/tmp/milvus_index_1",
|
|
engine::EngineType::FAISS_IVFSQ8,
|
|
engine::MetricType::IP,
|
|
1024
|
|
);
|
|
|
|
ASSERT_TRUE(engine_ptr != nullptr);
|
|
}
|
|
|
|
{
|
|
auto engine_ptr = engine::EngineFactory::Build(
|
|
512,
|
|
"/tmp/milvus_index_1",
|
|
engine::EngineType::NSG_MIX,
|
|
engine::MetricType::IP,
|
|
1024
|
|
);
|
|
|
|
ASSERT_TRUE(engine_ptr != nullptr);
|
|
}
|
|
}
|
|
|
|
TEST(EngineTest, ENGINE_IMPL_TEST) {
|
|
uint16_t dimension = 64;
|
|
std::string file_path = "/tmp/milvus_index_1";
|
|
auto engine_ptr = engine::EngineFactory::Build(
|
|
dimension,
|
|
file_path,
|
|
engine::EngineType::FAISS_IVFFLAT,
|
|
engine::MetricType::IP,
|
|
1024
|
|
);
|
|
|
|
std::vector<float> data;
|
|
std::vector<long> ids;
|
|
const int row_count = 10000;
|
|
data.reserve(row_count*dimension);
|
|
ids.reserve(row_count);
|
|
for(long i = 0; i < row_count; i++) {
|
|
ids.push_back(i);
|
|
for(uint16_t k = 0; k < dimension; k++) {
|
|
data.push_back(i*dimension + k);
|
|
}
|
|
}
|
|
|
|
auto status = engine_ptr->AddWithIds((long)ids.size(), data.data(), ids.data());
|
|
ASSERT_TRUE(status.ok());
|
|
|
|
ASSERT_EQ(engine_ptr->Dimension(), dimension);
|
|
ASSERT_EQ(engine_ptr->Count(), ids.size());
|
|
|
|
server::ConfigNode& config = server::ServerConfig::GetInstance().GetConfig(server::CONFIG_CACHE);
|
|
config.AddSequenceItem(server::CONFIG_GPU_IDS, "0");
|
|
|
|
status = engine_ptr->CopyToGpu(0);
|
|
//ASSERT_TRUE(status.ok());
|
|
|
|
auto new_engine = engine_ptr->Clone();
|
|
ASSERT_EQ(new_engine->Dimension(), dimension);
|
|
ASSERT_EQ(new_engine->Count(), ids.size());
|
|
status = new_engine->CopyToCpu();
|
|
//ASSERT_TRUE(status.ok());
|
|
|
|
auto engine_build = new_engine->BuildIndex("/tmp/milvus_index_2", engine::EngineType::FAISS_IVFSQ8);
|
|
//ASSERT_TRUE(status.ok());
|
|
|
|
}
|