乘积量化(PQ)算法的nanopq库python

import nanopq
import numpy as np

N, Nt, D = 1000000, 100000, 128
X = np.random.random((N, D)).astype(np.float32)  # 10,000 128-dim vectors to be indexed

Xt = np.random.random((Nt, D)).astype(np.float32)  # 2,000 128-dim vectors for training
print('Xt')
print(Xt.shape)

query = np.random.random((D,)).astype(np.float32)  # a 128-dim query vector

#print(query)
# Instantiate with M=8 sub-spaces
pq = nanopq.PQ(M=16)

# Train codewords
pq.fit(Xt)

print('pq')
print(pq.codewords)

with open('/Users/dl/Documents/bak/' + "codewords.txt", 'w') as fp:
    fp.write(str(pq.codewords))
print('codewords')
print(np.array(pq.codewords).shape)

# Encode to PQ-codes
X_code = pq.encode(X)  # (10000, 8) with dtype=np.uint8
print('X_code')
print(X_code.shape)
print(X_code)

# Results: create a distance table online, and compute Asymmetric Distance to each PQ-code
dists = pq.dtable(query).adist(X_code)

dtable = pq.dtable(query)
print('dtable')
print(dtable.__sizeof__())
print(dtable)
print('dists')
print(dists.shape)
print(dists)






  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值