-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathembedding.py
37 lines (30 loc) · 1.05 KB
/
embedding.py
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
import os
import requests
from dotenv import load_dotenv
load_dotenv()
EMBEDDING_API_URL = os.getenv("EMBEDDING_API_URL")
def create_embeddings(text):
"""
Sends paragraphs to the locally running Ollama API for embedding creation.
Args:
paragraphs (list of str): A list of paragraphs to embed.
Returns:
list: A list of embedding vectors.
"""
# Prepare the payload
payload = {
"model": "nomic-embed-text", # https://ollama.com/library/nomic-embed-text
#"prompt": "\n".join(text) # Combine paragraphs into a single prompt if needed
"prompt": text
}
# Make the HTTP POST request
response = requests.post(EMBEDDING_API_URL, json=payload)
print(f"Payload sent to API: {payload}")
#print(f"Response Status Code: {response.status_code}")
#print(f"Response JSON: {response.json()}")
#print(response.json().get("embedding"))
# Check for successful response
if response.status_code == 200:
return response.json().get("embedding")
else:
raise Exception(f"Failed to get embeddings: {response.status_code}, {response.text}")