Spaces:
Runtime error
Runtime error
Commit
·
27514c1
1
Parent(s):
666646e
fixed
Browse files
app.py
CHANGED
|
@@ -1,5 +1,7 @@
|
|
| 1 |
import gradio as gr
|
| 2 |
import uuid
|
|
|
|
|
|
|
| 3 |
from qdrant_client import QdrantClient
|
| 4 |
from qdrant_client.models import PointStruct, VectorParams, Distance
|
| 5 |
from sentence_transformers import SentenceTransformer
|
|
@@ -8,8 +10,8 @@ from PIL import Image
|
|
| 8 |
# --------------------------
|
| 9 |
# Qdrant Cloud Connection
|
| 10 |
# --------------------------
|
| 11 |
-
QDRANT_URL = "https://ff4da494-27b1-413c-ba58-d5ea14932fe1.europe-west3-0.gcp.cloud.qdrant.io:6333"
|
| 12 |
-
QDRANT_API_KEY = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3MiOiJtIn0.jjeB1JgnUSlb1hOOKMdRpVvMrUER57-udT-X1AWXT1E"
|
| 13 |
COLLECTION_NAME = "lost_and_found"
|
| 14 |
|
| 15 |
# CLIP model (text + image embeddings)
|
|
@@ -35,6 +37,17 @@ qclient.recreate_collection(
|
|
| 35 |
# Helper Functions
|
| 36 |
# --------------------------
|
| 37 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 38 |
def embed_text(text: str):
|
| 39 |
return embedder.encode(text).tolist()
|
| 40 |
|
|
@@ -48,12 +61,14 @@ def add_item(image, description, finder_name, finder_phone):
|
|
| 48 |
|
| 49 |
# Encode image
|
| 50 |
embedding = embed_image(image)
|
|
|
|
| 51 |
|
| 52 |
-
# Store metadata
|
| 53 |
metadata = {
|
| 54 |
"description": description,
|
| 55 |
"finder_name": finder_name if finder_name.strip() else "NA",
|
| 56 |
"finder_phone": finder_phone if finder_phone.strip() else "NA",
|
|
|
|
| 57 |
}
|
| 58 |
|
| 59 |
# Insert into Qdrant
|
|
@@ -98,7 +113,13 @@ def search_items(query_text, query_image):
|
|
| 98 |
name = r.payload.get("finder_name", "NA")
|
| 99 |
phone = r.payload.get("finder_phone", "NA")
|
| 100 |
output_text += f"- **{desc}** (Finder: {name}, Phone: {phone})\n"
|
| 101 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 102 |
|
| 103 |
return output_text, gallery
|
| 104 |
|
|
|
|
| 1 |
import gradio as gr
|
| 2 |
import uuid
|
| 3 |
+
import base64
|
| 4 |
+
import io
|
| 5 |
from qdrant_client import QdrantClient
|
| 6 |
from qdrant_client.models import PointStruct, VectorParams, Distance
|
| 7 |
from sentence_transformers import SentenceTransformer
|
|
|
|
| 10 |
# --------------------------
|
| 11 |
# Qdrant Cloud Connection
|
| 12 |
# --------------------------
|
| 13 |
+
QDRANT_URL = "https://ff4da494-27b1-413c-ba58-d5ea14932fe1.europe-west3-0.gcp.cloud.qdrant.io:6333" # 🔑 Replace with your cluster URL
|
| 14 |
+
QDRANT_API_KEY = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3MiOiJtIn0.jjeB1JgnUSlb1hOOKMdRpVvMrUER57-udT-X1AWXT1E" # 🔑 Replace with your API key
|
| 15 |
COLLECTION_NAME = "lost_and_found"
|
| 16 |
|
| 17 |
# CLIP model (text + image embeddings)
|
|
|
|
| 37 |
# Helper Functions
|
| 38 |
# --------------------------
|
| 39 |
|
| 40 |
+
def image_to_base64(img: Image.Image) -> str:
|
| 41 |
+
"""Convert PIL image to base64 string"""
|
| 42 |
+
buf = io.BytesIO()
|
| 43 |
+
img.save(buf, format="PNG")
|
| 44 |
+
return base64.b64encode(buf.getvalue()).decode("utf-8")
|
| 45 |
+
|
| 46 |
+
def base64_to_image(b64_str: str) -> Image.Image:
|
| 47 |
+
"""Convert base64 string back to PIL image"""
|
| 48 |
+
img_bytes = base64.b64decode(b64_str)
|
| 49 |
+
return Image.open(io.BytesIO(img_bytes))
|
| 50 |
+
|
| 51 |
def embed_text(text: str):
|
| 52 |
return embedder.encode(text).tolist()
|
| 53 |
|
|
|
|
| 61 |
|
| 62 |
# Encode image
|
| 63 |
embedding = embed_image(image)
|
| 64 |
+
img_b64 = image_to_base64(image)
|
| 65 |
|
| 66 |
+
# Store metadata including image
|
| 67 |
metadata = {
|
| 68 |
"description": description,
|
| 69 |
"finder_name": finder_name if finder_name.strip() else "NA",
|
| 70 |
"finder_phone": finder_phone if finder_phone.strip() else "NA",
|
| 71 |
+
"image_b64": img_b64
|
| 72 |
}
|
| 73 |
|
| 74 |
# Insert into Qdrant
|
|
|
|
| 113 |
name = r.payload.get("finder_name", "NA")
|
| 114 |
phone = r.payload.get("finder_phone", "NA")
|
| 115 |
output_text += f"- **{desc}** (Finder: {name}, Phone: {phone})\n"
|
| 116 |
+
|
| 117 |
+
if "image_b64" in r.payload:
|
| 118 |
+
try:
|
| 119 |
+
img = base64_to_image(r.payload["image_b64"])
|
| 120 |
+
gallery.append(img)
|
| 121 |
+
except Exception:
|
| 122 |
+
pass
|
| 123 |
|
| 124 |
return output_text, gallery
|
| 125 |
|