mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-31 16:05:30 +08:00
69 lines
2.3 KiB
C++
69 lines
2.3 KiB
C++
#include "VectorSource.h"
|
|
#include "db/engine/ExecutionEngine.h"
|
|
#include "db/engine/EngineFactory.h"
|
|
#include "db/Log.h"
|
|
#include "metrics/Metrics.h"
|
|
|
|
|
|
namespace zilliz {
|
|
namespace milvus {
|
|
namespace engine {
|
|
|
|
|
|
VectorSource::VectorSource(const size_t &n,
|
|
const float *vectors) :
|
|
n_(n),
|
|
vectors_(vectors),
|
|
id_generator_(std::make_shared<SimpleIDGenerator>()) {
|
|
current_num_vectors_added = 0;
|
|
}
|
|
|
|
Status VectorSource::Add(const ExecutionEnginePtr &execution_engine,
|
|
const meta::TableFileSchema &table_file_schema,
|
|
const size_t &num_vectors_to_add,
|
|
size_t &num_vectors_added,
|
|
IDNumbers &vector_ids) {
|
|
|
|
server::CollectAddMetrics metrics(n_, table_file_schema.dimension_);
|
|
|
|
num_vectors_added = current_num_vectors_added + num_vectors_to_add <= n_ ?
|
|
num_vectors_to_add : n_ - current_num_vectors_added;
|
|
IDNumbers vector_ids_to_add;
|
|
if (vector_ids.empty()) {
|
|
id_generator_->GetNextIDNumbers(num_vectors_added, vector_ids_to_add);
|
|
} else {
|
|
vector_ids_to_add.resize(num_vectors_added);
|
|
for (int pos = current_num_vectors_added; pos < current_num_vectors_added + num_vectors_added; pos++) {
|
|
vector_ids_to_add[pos-current_num_vectors_added] = vector_ids[pos];
|
|
}
|
|
}
|
|
Status status = execution_engine->AddWithIds(num_vectors_added,
|
|
vectors_ + current_num_vectors_added * table_file_schema.dimension_,
|
|
vector_ids_to_add.data());
|
|
if (status.ok()) {
|
|
current_num_vectors_added += num_vectors_added;
|
|
vector_ids_.insert(vector_ids_.end(),
|
|
std::make_move_iterator(vector_ids_to_add.begin()),
|
|
std::make_move_iterator(vector_ids_to_add.end()));
|
|
} else {
|
|
ENGINE_LOG_ERROR << "VectorSource::Add failed: " + status.ToString();
|
|
}
|
|
|
|
return status;
|
|
}
|
|
|
|
size_t VectorSource::GetNumVectorsAdded() {
|
|
return current_num_vectors_added;
|
|
}
|
|
|
|
bool VectorSource::AllAdded() {
|
|
return (current_num_vectors_added == n_);
|
|
}
|
|
|
|
IDNumbers VectorSource::GetVectorIds() {
|
|
return vector_ids_;
|
|
}
|
|
|
|
} // namespace engine
|
|
} // namespace milvus
|
|
} // namespace zilliz
|