Skip to main content

Mô tả ngắn gọn về package

Project description

MySearch

Giới thiệu

MySearch là một module tìm kiếm dựa trên FAISS (Facebook AI Similarity Search) để thực hiện tìm kiếm vector hiệu quả. Hệ thống hỗ trợ tìm kiếm theo khoảng cách cosine và L2, đồng thời quản lý dữ liệu thông qua các lớp hỗ trợ như IndexDB, FaissDB, InfoDB.

Tính năng chính

  • Thêm vector embedding vào FAISS.
  • Tìm kiếm các vector gần nhất dựa trên chỉ số khoảng cách.
  • Xóa vector khỏi cơ sở dữ liệu FAISS.
  • Cập nhật hoặc thay thế vector embedding.
  • Kiểm tra tính nhất quán của cơ sở dữ liệu.

Cấu trúc thư mục

.
├── logs/
│   ├── log_handler.py  # Xử lý ghi log
├── modules/
│   ├── utils/
│   │   ├── checker.py  # Kiểm tra tính hợp lệ của dữ liệu
│   │   ├── faiss_db.py  # Quản lý FAISS
│   │   ├── helper.py  # Hỗ trợ xử lý vector
│   │   ├── index_db.py  # Quản lý index của vector
│   │   ├── info_db.py  # Quản lý thông tin đối tượng
├── my_search.py  # Lớp chính MySearch
├── README.md  # Tài liệu này

Cài đặt

Yêu cầu Python 3.8 trở lên và các thư viện:

pip install faiss-cpu numpy

Hướng dẫn sử dụng

Khởi tạo MySearch

from my_search import MySearch

search_engine = MySearch(distance_type="cosin", element=512)

Tạo collection

list_field = ["id", "name", "vector"]
key_main = "id"
search_engine.create_collection(list_field, key_main)

Thêm dữ liệu vào FAISS

embedding = [[0.1, 0.2, 0.3, ..., 0.512]]  # Danh sách embedding có kích thước 512
list_field = [{"id": 1, "name": "Object1", "vector": embedding[0]}]

search_engine.add(embedding, list_field)

Tìm kiếm

query_vector = [0.1, 0.2, 0.3, ..., 0.512]
result = search_engine.search(query_vector, result_of_num=5)
print(result)

Xóa dữ liệu

search_engine.delete(key_mains=[1])

Cập nhật dữ liệu

new_vector = [0.2, 0.3, 0.4, ..., 0.512]
search_engine.replace(key_mains=[1], embeddings=[new_vector], indexs=[0])

Cấu trúc lớp

MySearch

  • add(embedding, list_field): Thêm một hoặc nhiều vector embedding vào FAISS.
  • search(embedding, result_of_num): Tìm kiếm vector gần nhất.
  • delete(key_mains): Xóa vector theo khóa chính.
  • replace(key_mains, embeddings, indexs, new_key_mains): Thay thế hoặc cập nhật vector.
  • create_collection(list_field, key_main): Tạo tập dữ liệu mới.

Cấu trúc dữ liệu

  • IndexDB: Lưu trữ ánh xạ giữa index FAISS và khóa chính (key_main).
  • FaissDB: Quản lý cơ sở dữ liệu FAISS và thực hiện truy vấn.
  • InfoDB: Quản lý thông tin đối tượng liên quan đến embedding.

Ghi log

Module sử dụng logger để ghi lại quá trình hoạt động. Log được lưu trong thư mục logs/.

Đóng góp

Mọi đóng góp vui lòng gửi pull request hoặc mở issue trên GitHub.

Giấy phép

Dự án này sử dụng giấy phép MIT.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tsearch-1.0.5.tar.gz (2.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tsearch-1.0.5-py3-none-any.whl (2.6 kB view details)

Uploaded Python 3

File details

Details for the file tsearch-1.0.5.tar.gz.

File metadata

  • Download URL: tsearch-1.0.5.tar.gz
  • Upload date:
  • Size: 2.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.20

File hashes

Hashes for tsearch-1.0.5.tar.gz
Algorithm Hash digest
SHA256 b314148b921d459e93ce58e234674f34777753a110a2f89a87f905ae9d97b011
MD5 611bdda28f4d7c1da121c0ca2dc3b552
BLAKE2b-256 c2c9871d1287f1763aded35004ac1082f9f48cb812fb180b907d4453b1f12576

See more details on using hashes here.

File details

Details for the file tsearch-1.0.5-py3-none-any.whl.

File metadata

  • Download URL: tsearch-1.0.5-py3-none-any.whl
  • Upload date:
  • Size: 2.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.20

File hashes

Hashes for tsearch-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 eef757f04fbab1064af7396ace7968b721beb70d1c7781e976a7c87acec00e3f
MD5 aa4bf8687baada0150f9f0e95355ad78
BLAKE2b-256 6898d901791615249c3c9d4e8460c0180e5d5153f4018a75bb5450f4774af6d9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page