Skip to content

Instantly share code, notes, and snippets.

@purva91
Last active March 22, 2021 07:39
Show Gist options
  • Save purva91/1775c4d702f0cbd5cddce4717f6aa244 to your computer and use it in GitHub Desktop.
Save purva91/1775c4d702f0cbd5cddce4717f6aa244 to your computer and use it in GitHub Desktop.
from sentence_transformers import SentenceTransformer
sbert_model = SentenceTransformer('bert-base-nli-mean-tokens')
sentence_embeddings = model.encode(sentences)
#print('Sample BERT embedding vector - length', len(sentence_embeddings[0]))
#print('Sample BERT embedding vector - note includes negative values', sentence_embeddings[0])
query = "I had pizza and pasta"
query_vec = model.encode([query])[0]
for sent in sentences:
sim = cosine(query_vec, model.encode([sent])[0])
print("Sentence = ", sent, "; similarity = ", sim)
@AsharParacha
Copy link

Hi dear. .encode function is not working.
Error is : ----> 'Doc2Vec' object has no attribute 'encode'

@ganbaaelmer
Copy link

NameError: name 'cosine' is not defined

@ganbaaelmer
Copy link

ganbaaelmer commented Mar 22, 2021

Correct one is:

from scipy.spatial import distance

for sent in sentences:
sim = distance.cosine(query_vec, model.encode([sent])[0])
print("Sentence = ", sent, "; similarity (close is good) = ", sim)

@ganbaaelmer
Copy link

from sentence_transformers import SentenceTransformer
sbert_model = SentenceTransformer('bert-base-nli-mean-tokens')

to

model = SentenceTransformer('bert-base-nli-mean-tokens')

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment