JoJosmin commited on
Commit
e4aea0c
·
verified ·
1 Parent(s): a81aa5e

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +3 -29
app.py CHANGED
@@ -87,51 +87,25 @@ def segment_clothing(img, clothes=["Hat", "Upper-clothes", "Skirt", "Pants", "Dr
87
  return img_with_alpha.convert("RGB"), final_mask, detected_categories # Return detected categories
88
 
89
 
90
- #def find_similar_images(query_embedding, collection, top_k=5):
91
- # all_embeddings = collection.get(include=['embeddings'])['embeddings']
92
- # database_embeddings = np.array(all_embeddings)
93
- # similarities = np.dot(database_embeddings, query_embedding.T).squeeze()
94
- # top_indices = np.argsort(similarities)[::-1][:top_k]
95
- #
96
- # all_data = collection.get(include=['metadatas'])['metadatas']
97
- # top_metadatas = [all_data[idx] for idx in top_indices]
98
-
99
- # results = []
100
- # for idx, metadata in enumerate(top_metadatas):
101
- # results.append({
102
- # 'info': metadata,
103
- # 'similarity': similarities[top_indices[idx]]
104
- # })
105
- # return results
106
-
107
  def find_similar_images(query_embedding, collection, top_k=5):
108
- # 모든 임베딩을 가져옴
109
  all_embeddings = collection.get(include=['embeddings'])['embeddings']
110
  database_embeddings = np.array(all_embeddings)
111
-
112
- # 유사도 계산
113
- similarities = cosine_similarity(database_embeddings, query_embedding.reshape(1, -1)).squeeze()
114
  top_indices = np.argsort(similarities)[::-1][:top_k]
115
 
116
- # 메타데이터 가져옴
117
  all_data = collection.get(include=['metadatas'])['metadatas']
118
  top_metadatas = [all_data[idx] for idx in top_indices]
119
 
120
  results = []
121
  for idx, metadata in enumerate(top_metadatas):
122
- # 이미지 URLs 필드가 쉼표로 구분된 문자열로 저장된 경우, 이를 리스트로 변환
123
- image_urls = metadata['image_url'].split(',')
124
- # 첫 번째 이미지를 대표 이미지로 사용
125
- representative_image_url = image_urls[0] if image_urls else None
126
-
127
  results.append({
128
  'info': metadata,
129
- 'similarity': similarities[top_indices[idx]],
130
- 'image_url': representative_image_url # 첫 번째 이미지 URL 사용
131
  })
132
  return results
133
 
134
 
 
135
  # 세션 상태 초기화
136
  if 'step' not in st.session_state:
137
  st.session_state.step = 'input'
 
87
  return img_with_alpha.convert("RGB"), final_mask, detected_categories # Return detected categories
88
 
89
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
90
  def find_similar_images(query_embedding, collection, top_k=5):
 
91
  all_embeddings = collection.get(include=['embeddings'])['embeddings']
92
  database_embeddings = np.array(all_embeddings)
93
+ similarities = np.dot(database_embeddings, query_embedding.T).squeeze()
 
 
94
  top_indices = np.argsort(similarities)[::-1][:top_k]
95
 
 
96
  all_data = collection.get(include=['metadatas'])['metadatas']
97
  top_metadatas = [all_data[idx] for idx in top_indices]
98
 
99
  results = []
100
  for idx, metadata in enumerate(top_metadatas):
 
 
 
 
 
101
  results.append({
102
  'info': metadata,
103
+ 'similarity': similarities[top_indices[idx]]
 
104
  })
105
  return results
106
 
107
 
108
+
109
  # 세션 상태 초기화
110
  if 'step' not in st.session_state:
111
  st.session_state.step = 'input'