45 lines
1.1 KiB
C++
45 lines
1.1 KiB
C++
/*
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
// -*- c++ -*-
|
|
|
|
#include "index_factory_c.h"
|
|
#include <faiss/index_factory.h>
|
|
#include <cstring>
|
|
#include "macros_impl.h"
|
|
|
|
using faiss::Index;
|
|
|
|
/** Build an index with the sequence of processing steps described in
|
|
* the string.
|
|
*/
|
|
int faiss_index_factory(
|
|
FaissIndex** p_index,
|
|
int d,
|
|
const char* description,
|
|
FaissMetricType metric) {
|
|
try {
|
|
*p_index = reinterpret_cast<FaissIndex*>(faiss::index_factory(
|
|
d, description, static_cast<faiss::MetricType>(metric)));
|
|
}
|
|
CATCH_AND_HANDLE
|
|
}
|
|
|
|
/** Build an index with the sequence of processing steps described in
|
|
* the string.
|
|
*/
|
|
int faiss_index_binary_factory(
|
|
FaissIndexBinary** p_index,
|
|
int d,
|
|
const char* description) {
|
|
try {
|
|
*p_index = reinterpret_cast<FaissIndexBinary*>(
|
|
faiss::index_binary_factory(d, description));
|
|
}
|
|
CATCH_AND_HANDLE
|
|
}
|