aboutsummaryrefslogtreecommitdiff
path: root/.venv/lib/python3.12/site-packages/pgvector/django/indexes.py
diff options
context:
space:
mode:
authorS. Solomon Darnell2025-03-28 21:52:21 -0500
committerS. Solomon Darnell2025-03-28 21:52:21 -0500
commit4a52a71956a8d46fcb7294ac71734504bb09bcc2 (patch)
treeee3dc5af3b6313e921cd920906356f5d4febc4ed /.venv/lib/python3.12/site-packages/pgvector/django/indexes.py
parentcc961e04ba734dd72309fb548a2f97d67d578813 (diff)
downloadgn-ai-4a52a71956a8d46fcb7294ac71734504bb09bcc2.tar.gz
two version of R2R are hereHEADmaster
Diffstat (limited to '.venv/lib/python3.12/site-packages/pgvector/django/indexes.py')
-rw-r--r--.venv/lib/python3.12/site-packages/pgvector/django/indexes.py46
1 files changed, 46 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/pgvector/django/indexes.py b/.venv/lib/python3.12/site-packages/pgvector/django/indexes.py
new file mode 100644
index 00000000..5bec0eba
--- /dev/null
+++ b/.venv/lib/python3.12/site-packages/pgvector/django/indexes.py
@@ -0,0 +1,46 @@
+from django.contrib.postgres.indexes import PostgresIndex
+
+
+class IvfflatIndex(PostgresIndex):
+ suffix = 'ivfflat'
+
+ def __init__(self, *expressions, lists=None, **kwargs):
+ self.lists = lists
+ super().__init__(*expressions, **kwargs)
+
+ def deconstruct(self):
+ path, args, kwargs = super().deconstruct()
+ if self.lists is not None:
+ kwargs['lists'] = self.lists
+ return path, args, kwargs
+
+ def get_with_params(self):
+ with_params = []
+ if self.lists is not None:
+ with_params.append('lists = %d' % self.lists)
+ return with_params
+
+
+class HnswIndex(PostgresIndex):
+ suffix = 'hnsw'
+
+ def __init__(self, *expressions, m=None, ef_construction=None, **kwargs):
+ self.m = m
+ self.ef_construction = ef_construction
+ super().__init__(*expressions, **kwargs)
+
+ def deconstruct(self):
+ path, args, kwargs = super().deconstruct()
+ if self.m is not None:
+ kwargs['m'] = self.m
+ if self.ef_construction is not None:
+ kwargs['ef_construction'] = self.ef_construction
+ return path, args, kwargs
+
+ def get_with_params(self):
+ with_params = []
+ if self.m is not None:
+ with_params.append('m = %d' % self.m)
+ if self.ef_construction is not None:
+ with_params.append('ef_construction = %d' % self.ef_construction)
+ return with_params