-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathquery-missing.js
80 lines (64 loc) · 3.04 KB
/
query-missing.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
const {makePineconeClient} = require("./src/pinecone")
const {loadVectorGroups, outputResultCSV} = require("./src/common");
const pineconeApiKey = process.env.PINECONE_API_KEY
if (!pineconeApiKey) {
throw new Error("Pinecone API key not found")
}
async function getResults(name, pinecone, metric, vectorGroups) {
const highestScore = [];
const allScores = [];
let numQueried = 0;
const toQuery = Object.keys(vectorGroups).length
for (const vectorGroup of Object.values(vectorGroups)) {
const results = await pinecone.query(vectorGroup.same, 10);
if (results && results.length > 0) {
highestScore.push(results[0].score)
results.forEach(result => allScores.push(result.score))
}
numQueried++
console.error(`Queried ${metric} for ${numQueried}/${toQuery}`)
}
highestScore.sort((a, b) => a - b)
allScores.sort((a, b) => a - b)
console.log("Similarity Function,Distance Metric")
console.log(`${name},${metric}`)
console.log()
console.log("Category,Average,Minimum,25th Percentile,50th Percentile,75th Percentile,90th Percentile,95th Percentile,99th Percentile,99.9th Percentile,Max")
outputResultCSV("Missing - Highest Score", highestScore)
outputResultCSV("Missing - All Scores", allScores)
}
async function run(name, vectorFile, pineconeUrls) {
const pinecones = {}
for (let [metric, url] of Object.entries(pineconeUrls)) {
pinecones[metric] = makePineconeClient(pineconeApiKey, url)
}
const vectorGroups = await loadVectorGroups(vectorFile)
for (let [metric, pinecone] of Object.entries(pinecones)) {
await getResults(name, pinecone, metric, vectorGroups)
}
}
(async () => {
const start = Date.now()
const goldbergPineconeUrls = {
Cosine: "https://goldberg-544-cosine-b335ecb.svc.us-west1-gcp.pinecone.io",
DotProduct: "https://goldberg-544-dot-b335ecb.svc.us-west1-gcp.pinecone.io",
Euclidean: "https://goldberg-544-euclid-b335ecb.svc.us-west1-gcp.pinecone.io"
}
await run("Goldberg", "missing-Goldberg-vectors-1660564797912.json", goldbergPineconeUrls)
const pHashPineconeUrls = {
Cosine: "https://phash-1024-cosine-b335ecb.svc.us-west1-gcp.pinecone.io",
Euclidean: "https://phash-1024-euclid-b335ecb.svc.us-west1-gcp.pinecone.io"
}
await run("pHash", "missing-pHash-vectors-1660564896508.json", pHashPineconeUrls)
const dctPineconeUrls = {
Cosine: "https://dct-1024-cosine-b335ecb.svc.us-west1-gcp.pinecone.io",
Euclidean: "https://dct-1024-euclid-b335ecb.svc.us-west1-gcp.pinecone.io"
}
await run("DCT", "missing-DCT-vectors-1660564864437.json", dctPineconeUrls)
const intensityPineconeUrls = {
Cosine: "https://intensity-1024-cosine-b335ecb.svc.us-west1-gcp.pinecone.io",
Euclidean: "https://intensity-1024-euclid-b335ecb.svc.us-west1-gcp.pinecone.io"
}
await run("Intensity", "missing-Intensity-vectors-1660564928478.json", intensityPineconeUrls)
console.error(`Finished in ${Date.now() - start}ms`)
})()