An easy-to-use vector database.
Project description
Powered by Dipamkara
Bhakti is
-
A light-weight vector database
-
Easy to use
-
Thread safe
-
Portable
-
Reliable
-
Suitable for small-sized datasets
Installation
-
From PYPI
pip install bhakti
-
From Github
Download .whl first then run
pip install ./bhakti-X.X.X-py3-none-any.whl
Quick Start
Before all, make sure you've successfully installed Bhakti :)
-
Run Bhakti Server
-
To begin, create a path for storing data
mkdir -p /path/to/db
-
Start server using shell command
-
Create configuration file (.yaml)
# bhakti.yaml DIMENSION: 1024 DB_PATH: /path/to/db DB_ENGINE: dipamkara # optional, default to dipamkara CACHED: false # optional, default to false HOST: 0.0.0.0 # optional, default to 0.0.0.0 PORT: 23860 # optional, default to 23860 EOF: <eof> # optional, default to <eof> TIMEOUT: 4.0 # optional, default to 4.0 seconds BUFFER_SIZE: 256 # optional, default to 256 bytes VERBOSE: false # optional, default to false
-
Run bhakti in shell
# bash bhakti ./bhakti.yaml
-
-
Start server using Python
# main.py from bhakti import BhaktiServer from bhakti.database import DBEngine if __name__ == '__main__': bhakti_server = BhaktiServer( dimension=1024, # required, only vectors with 1024 dimensions are acceptable db_path='/path/to/db', # required, path where stores data, portable db_engine=DBEngine.DIPAMKARA, # optional, default to dipamkara cached=False, # optional, default to false host='0.0.0.0', # optional, default to 0.0.0.0 port=23860, # optional, default to 23860 eof=b'<eof>', # optional, default to b'<eof>' timeout=4.0, # optional, default to 4.0 seconds buffer_size=256, # optional, default to 256 bytes verbose=False # optional, default to false ) # run server bhakti_server.run()
-
-
Interact With A Bhakti Client
Currently, Python(>=3.10) is supported
# main.py import asyncio import numpy as np from bhakti import BhaktiClient from bhakti.database import Metric from bhakti.database import DBEngine async def main(): client = BhaktiClient( server='127.0.0.1', # optional, default to 127.0.0.1 port=23860, # optional, default to 23860 eof=b'<eof>', # optional, default to b'<eof>' timeout=4.0, # optional, default to 4.0 seconds buffer_size=256, # optional, default to 256 bytes db_engine=DBEngine.DIPAMKARA, # optional, default to dipamkara verbose=False # optional, default to false ) vector = np.random.randn(1024) await client.create(vector=vector, document={'age': 31, 'gender': 'male'}) await client.create_index('age') await client.create_index('gender') results = await client.find_documents_by_vector_indexed( query='age <= 31 && gender != "female"', vector=vector, metric=Metric.EUCLIDEAN_Z_SCORE, top_k=3 ) print(results) if __name__ == '__main__': asyncio.run(main())
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
bhakti-0.2.18.tar.gz
(52.1 kB
view details)
Built Distribution
bhakti-0.2.18-py3-none-any.whl
(46.0 kB
view details)
File details
Details for the file bhakti-0.2.18.tar.gz
.
File metadata
- Download URL: bhakti-0.2.18.tar.gz
- Upload date:
- Size: 52.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 16f029701ae543ba2fc379b9ff6273d77d8c0741c3741e14d7e88697f82fec95 |
|
MD5 | 3172bd005d4fc137154abfc705d99ff4 |
|
BLAKE2b-256 | 7b61ec255d2e55be38d8358a4d8f797a2dcc0fdf1e2bfde989722ce51d6688e9 |
File details
Details for the file bhakti-0.2.18-py3-none-any.whl
.
File metadata
- Download URL: bhakti-0.2.18-py3-none-any.whl
- Upload date:
- Size: 46.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 750fda93656c4b6afaac788649f85f8cf188d1a71560efe04c8e6286ee7d5830 |
|
MD5 | f6bf6fc530fc950854501e01c9050fb3 |
|
BLAKE2b-256 | f957d6274ee1191549a8e1ba35d929b3f4bb8a7e0fe78d5c9bd38968e4973d69 |