utils.cpp 1.7 KB
Newer Older
X
MS-154  
xj.lin 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13
////////////////////////////////////////////////////////////////////////////////
// Copyright 上海赜睿信息科技有限公司(Zilliz) - All Rights Reserved
// Unauthorized copying of this file, via any medium is strictly prohibited.
// Proprietary and confidential.
////////////////////////////////////////////////////////////////////////////////

#include <faiss/IndexFlat.h>

#include "utils.h"


void DataGenBase::GenData(const int &dim, const int &nb, const int &nq,
                          float *xb, float *xq, long *ids,
X
xj.lin 已提交
14
                          const int &k, long *gt_ids, float *gt_dis) {
X
MS-154  
xj.lin 已提交
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
    for (auto i = 0; i < nb; ++i) {
        for (auto j = 0; j < dim; ++j) {
            //p_data[i * d + j] = float(base + i);
            xb[i * dim + j] = drand48();
        }
        xb[dim * i] += i / 1000.;
        ids[i] = i;
    }
    for (size_t i = 0; i < nq * dim; ++i) {
        xq[i] = xb[i];
    }

    faiss::IndexFlatL2 index(dim);
    //index.add_with_ids(nb, xb, ids);
    index.add(nb, xb);
X
xj.lin 已提交
30
    index.search(nq, xq, k, gt_dis, gt_ids);
X
MS-154  
xj.lin 已提交
31 32 33 34 35 36 37 38 39
}

void DataGenBase::GenData(const int &dim,
                          const int &nb,
                          const int &nq,
                          std::vector<float> &xb,
                          std::vector<float> &xq,
                          std::vector<long> &ids,
                          const int &k,
X
xj.lin 已提交
40 41
                          std::vector<long> &gt_ids,
                          std::vector<float> &gt_dis) {
X
MS-154  
xj.lin 已提交
42 43 44 45
    xb.resize(nb * dim);
    xq.resize(nq * dim);
    ids.resize(nb);
    gt_ids.resize(nq * k);
X
xj.lin 已提交
46 47
    gt_dis.resize(nq * k);
    GenData(dim, nb, nq, xb.data(), xq.data(), ids.data(), k, gt_ids.data(), gt_dis.data());
X
MS-154  
xj.lin 已提交
48
}