
    Zi_N                         d dl mZmZmZmZmZ d dlmZmZm	Z	m
Z
mZmZmZmZmZmZmZmZmZmZmZmZmZmZmZ d dlmZ d dlmZ d dlmZ erd dl m!Z!  G d ded	                   Z"d
S )    )TYPE_CHECKINGOptionalUnionListcast)URICollectionMetadata	EmbeddingPyEmbeddingIncludeIndexingStatusMetadataDocumentImageWhereIDs	GetResultQueryResultID	OneOrMany	ReadLevelWhereDocumentSearchResultmaybe_cast_one_to_many)CollectionCommon)UpdateCollectionConfiguration)Search)AsyncServerAPIc                      e Zd Z	 	 	 	 	 d'dee         deeee         ee         f                  deee	                  deee
                  deee                  deee                  ddfd	Zdefd
ZdefdZdddddddgfdeee                  dee         dee         dee         dee         dedefdZd(dedefdZddddddddg df	deeee         ee         f                  deee
                  deee                  deee                  deee                  dedee         dee         dedefdZ	 	 	 d)dee         dee         dee         ddfdZdedd fd Zej         fd!ee!         d"ede"fd#Z#	 	 	 	 	 d'dee         deeee         ee         f                  deee	                  deee
                  deee                  deee                  ddfd$Z$	 	 	 	 	 d'dee         deeee         ee         f                  deee	                  deee
                  deee                  deee                  ddfd%Z%	 	 	 d)dee&         dee         dee         ddfd&Z'dS )*AsyncCollectionNids
embeddings	metadatas	documentsimagesurisreturnc           
         K   |                      ||||||          }| j                            | j        |d         |d         |d         |d         |d         | j        | j                   d{V  dS )	a]  Add embeddings to the data store.
        Args:
            ids: The ids of the embeddings you wish to add
            embeddings: The embeddings to add. If None, embeddings will be computed based on the documents or images using the embedding_function set for the Collection. Optional.
            metadatas: The metadata to associate with the embeddings. When querying, you can filter on this metadata. Optional.
            documents: The documents to associate with the embeddings. Optional.
            images: The images to associate with the embeddings. Optional.
            uris: The uris of the images to associate with the embeddings. Optional.

        Returns:
            None

        Raises:
            ValueError: If you don't provide either embeddings or documents
            ValueError: If the length of ids, embeddings, metadatas, or documents don't match
            ValueError: If you don't provide an embedding function and don't provide embeddings
            ValueError: If you provide both embeddings and documents
            ValueError: If you provide an id that already exists

        r!   r"   r#   r$   r%   r&   r!   r"   r#   r$   r&   collection_idr!   r"   r#   r$   r&   tenantdatabaseN)!_validate_and_prepare_add_request_client_addidr,   r-   )selfr!   r"   r#   r$   r%   r&   add_requests           `/root/projects/butler/venv/lib64/python3.11/site-packages/chromadb/api/models/AsyncCollection.pyaddzAsyncCollection.add"   s      D <<! = 
 
 l'E""<0!+.!+.V$;]   	
 	
 		
 		
 		
 		
 		
 		
 		
 		
 		
    c                 j   K   | j                             | j        | j        | j                   d{V S )zThe total number of embeddings added to the database

        Returns:
            int: The total number of embeddings added to the database

        r+   r,   r-   N)r/   _countr1   r,   r-   r2   s    r4   countzAsyncCollection.countX   sT       \((';] ) 
 
 
 
 
 
 
 
 	
r6   c                 j   K   | j                             | j        | j        | j                   d{V S )a  Get the indexing status of this collection.

        Returns:
            IndexingStatus: An object containing:
                - num_indexed_ops: Number of user operations that have been indexed
                - num_unindexed_ops: Number of user operations pending indexing
                - total_ops: Total number of user operations in collection
                - op_indexing_progress: Proportion of user operations that have been indexed as a float between 0 and 1
        r8   N)r/   _get_indexing_statusr1   r,   r-   r:   s    r4   get_indexing_statusz#AsyncCollection.get_indexing_statuse   sT       \66';] 7 
 
 
 
 
 
 
 
 	
r6   wherelimitoffsetwhere_documentincludec                   K   |                      ||||          }| j                            | j        |d         |d         |d         |d         ||| j        | j        	  	         d{V }|                     ||d                   S )	a  Get embeddings and their associate data from the data store. If no ids or where filter is provided returns
        all embeddings up to limit starting at offset.

        Args:
            ids: The ids of the embeddings to get. Optional.
            where: A Where type dict used to filter results by. E.g. `{"$and": [{"color" : "red"}, {"price": {"$gte": 4.20}}]}`. Optional.
            limit: The number of documents to return. Optional.
            offset: The offset to start returning results from. Useful for paging results with limit. Optional.
            where_document: A WhereDocument type dict used to filter by the documents. E.g. `{"$contains": "hello"}`. Optional.
            include: A list of what to include in the results. Can contain `"embeddings"`, `"metadatas"`, `"documents"`. Ids are always included. Defaults to `["metadatas", "documents"]`. Optional.

        Returns:
            GetResult: A GetResult object containing the results.

        )r!   r?   rB   rC   r!   r?   rB   rC   )	r+   r!   r?   rB   rC   r@   rA   r,   r-   NresponserC   )!_validate_and_prepare_get_requestr/   _getr1   r,   r-   _transform_get_response)	r2   r!   r?   r@   rA   rB   rC   get_requestget_resultss	            r4   getzAsyncCollection.getu   s      0 <<)	 = 
 
 !L--'E"g&&'78	*;] . 

 

 

 

 

 

 

 

 ++ +i*@ , 
 
 	
r6   
   c                    K   |                      | j                            | j        || j        | j                   d{V           S )zGet the first few results in the database up to limit

        Args:
            limit: The number of results to return.

        Returns:
            GetResult: A GetResult object containing the results.
        )r+   nr,   r-   N)_transform_peek_responser/   _peekr1   r,   r-   )r2   r@   s     r4   peekzAsyncCollection.peek   sj       ,,,$$"g{	 %        
 
 	
r6   )r#   r$   	distancesquery_embeddingsquery_textsquery_images
query_uris	n_resultsc
                 4  K   |                      |||||||||		  	        }
| j                            | j        |
d         |
d         |
d         |
d         |
d         |
d         | j        | j        	  	         d	{V }|                     ||
d         
          S )a  Get the n_results nearest neighbor embeddings for provided query_embeddings or query_texts.

        Args:
            query_embeddings: The embeddings to get the closes neighbors of. Optional.
            query_texts: The document texts to get the closes neighbors of. Optional.
            query_images: The images to get the closes neighbors of. Optional.
            ids: A subset of ids to search within. Optional.
            n_results: The number of neighbors to return for each query_embedding or query_texts. Optional.
            where: A Where type dict used to filter results by. E.g. `{"$and": [{"color" : "red"}, {"price": {"$gte": 4.20}}]}`. Optional.
            where_document: A WhereDocument type dict used to filter by the documents. E.g. `{"$contains": "hello"}`. Optional.
            include: A list of what to include in the results. Can contain `"embeddings"`, `"metadatas"`, `"documents"`, `"distances"`. Ids are always included. Defaults to `["metadatas", "documents", "distances"]`. Optional.

        Returns:
            QueryResult: A QueryResult object containing the results.

        Raises:
            ValueError: If you don't provide either query_embeddings, query_texts, or query_images
            ValueError: If you provide both query_embeddings and query_texts
            ValueError: If you provide both query_embeddings and query_images
            ValueError: If you provide both query_texts and query_images

        )	rT   rU   rV   rW   r!   rX   r?   rB   rC   r!   r"   rX   r?   rB   rC   )	r+   r!   rT   rX   r?   rB   rC   r,   r-   NrE   )#_validate_and_prepare_query_requestr/   _queryr1   r,   r-   _transform_query_response)r2   rT   rU   rV   rW   r!   rX   r?   rB   rC   query_requestquery_resultss               r4   queryzAsyncCollection.query   s      X @@-#%!) A 

 

 #l11'e$*<8#K0(()9:!),;] 2 

 

 

 

 

 

 

 

 --"M),D . 
 
 	
r6   namemetadataconfigurationc                    K   |                      |           | j                            | j        |||| j        | j                   d{V  |                     |||           dS )zModify the collection name or metadata

        Args:
            name: The updated name for the collection. Optional.
            metadata: The updated metadata for the collection. Optional.

        Returns:
            None
        )r1   new_namenew_metadatanew_configurationr,   r-   N)_validate_modify_requestr/   _modifyr1   r,   r-   "_update_model_after_modify_success)r2   r`   ra   rb   s       r4   modifyzAsyncCollection.modify   s        	%%h///
 l""w!+;] # 
 
 	
 	
 	
 	
 	
 	
 	
 	//hNNNNNr6   rd   c                    K   | j                             | j        || j        | j                   d{V }t          | j         || j        | j                  S )a  Fork the current collection under a new name. The returning collection should contain identical data to the current collection.
        This is an experimental API that only works for Hosted Chroma for now.

        Args:
            new_name: The name of the new collection.

        Returns:
            Collection: A new collection with the specified name and containing identical data to the current collection.
        )r+   rd   r,   r-   N)clientmodelembedding_functiondata_loader)r/   _forkr1   r,   r-   r    _embedding_function_data_loader)r2   rd   rm   s      r4   forkzAsyncCollection.fork  s       l((';]	 ) 
 
 
 
 
 
 
 
 <#7)	
 
 
 	
r6   searches
read_levelc                     K   t          |          }|g } fd|D             } j                             j        t	          t
          t                   |           j         j        |           d{V S )a  Perform hybrid search on the collection.
        This is an experimental API that only works for Hosted Chroma for now.

        Args:
            searches: A single Search object or a list of Search objects, each containing:
                - where: Where expression for filtering
                - rank: Ranking expression for hybrid search (defaults to Val(0.0))
                - limit: Limit configuration for pagination (defaults to no limit)
                - select: Select configuration for keys to return (defaults to empty)
            read_level: Controls whether to read from the write-ahead log (WAL):
                - ReadLevel.INDEX_AND_WAL: Read from both the compacted index and WAL (default).
                  All committed writes will be visible.
                - ReadLevel.INDEX_ONLY: Read only from the compacted index, skipping the WAL.
                  Faster, but recent writes that haven't been compacted may not be visible.

        Returns:
            SearchResult: Column-major format response with:
                - ids: List of result IDs for each search payload
                - documents: Optional documents for each payload
                - embeddings: Optional embeddings for each payload
                - metadatas: Optional metadata for each payload
                - scores: Optional scores for each payload
                - select: List of selected keys for each payload

        Raises:
            NotImplementedError: For local/segment API implementations

        Examples:
            # Using builder pattern with Key constants
            from chromadb.execution.expression import (
                Search, Key, K, Knn, Val
            )

            # Note: K is an alias for Key, so K.DOCUMENT == Key.DOCUMENT
            search = (Search()
                .where((K("category") == "science") & (K("score") > 0.5))
                .rank(Knn(query=[0.1, 0.2, 0.3]) * 0.8 + Val(0.5) * 0.2)
                .limit(10, offset=0)
                .select(K.DOCUMENT, K.SCORE, "title"))

            # Direct construction
            from chromadb.execution.expression import (
                Search, Eq, And, Gt, Knn, Limit, Select, Key
            )

            search = Search(
                where=And([Eq("category", "science"), Gt("score", 0.5)]),
                rank=Knn(query=[0.1, 0.2, 0.3]),
                limit=Limit(offset=0, limit=10),
                select=Select(keys={Key.DOCUMENT, Key.SCORE, "title"})
            )

            # Single search
            result = await collection.search(search)

            # Multiple searches at once
            searches = [
                Search().where(K("type") == "article").rank(Knn(query=[0.1, 0.2])),
                Search().where(K("type") == "paper").rank(Knn(query=[0.3, 0.4]))
            ]
            results = await collection.search(searches)

            # Skip WAL for faster queries (may miss recent uncommitted writes)
            from chromadb.api.types import ReadLevel
            result = await collection.search(search, read_level=ReadLevel.INDEX_ONLY)
        Nc                 :    g | ]}                     |          S  )_embed_search_string_queries).0searchr2   s     r4   
<listcomp>z*AsyncCollection.search.<locals>.<listcomp>  s4     
 
 
:@D--f55
 
 
r6   )r+   rt   r,   r-   ru   )	r   r/   _searchr1   r   r   r   r,   r-   )r2   rt   ru   searches_listembedded_searchess   `    r4   r{   zAsyncCollection.search8  s      P /x88 M
 
 
 
DQ
 
 
 \))'$v,(9::;]! * 
 
 
 
 
 
 
 
 	
r6   c           
         K   |                      ||||||          }| j                            | j        |d         |d         |d         |d         |d         | j        | j                   d{V  dS )	a  Update the embeddings, metadatas or documents for provided ids.

        Args:
            ids: The ids of the embeddings to update
            embeddings: The embeddings to update. If None, embeddings will be computed based on the documents or images using the embedding_function set for the Collection. Optional.
            metadatas:  The metadata to associate with the embeddings. When querying, you can filter on this metadata. Optional.
            documents: The documents to associate with the embeddings. Optional.
            images: The images to associate with the embeddings. Optional.
        Returns:
            None
        r)   r!   r"   r#   r$   r&   r*   N)$_validate_and_prepare_update_requestr/   _updater1   r,   r-   )r2   r!   r"   r#   r$   r%   r&   update_requests           r4   updatezAsyncCollection.update        2 BB! C 
 
 l""'u%%l3$[1$[1';] # 	
 	
 		
 		
 		
 		
 		
 		
 		
 		
 		
r6   c           
         K   |                      ||||||          }| j                            | j        |d         |d         |d         |d         |d         | j        | j                   d{V  dS )	aO  Update the embeddings, metadatas or documents for provided ids, or create them if they don't exist.

        Args:
            ids: The ids of the embeddings to update
            embeddings: The embeddings to add. If None, embeddings will be computed based on the documents using the embedding_function set for the Collection. Optional.
            metadatas:  The metadata to associate with the embeddings. When querying, you can filter on this metadata. Optional.
            documents: The documents to associate with the embeddings. Optional.

        Returns:
            None
        r)   r!   r"   r#   r$   r&   r*   N)$_validate_and_prepare_upsert_requestr/   _upsertr1   r,   r-   )r2   r!   r"   r#   r$   r%   r&   upsert_requests           r4   upsertzAsyncCollection.upsert  r   r6   c                    K   |                      |||          }| j                            | j        |d         |d         |d         | j        | j                   d{V  dS )a0  Delete the embeddings based on ids and/or a where filter

        Args:
            ids: The ids of the embeddings to delete
            where: A Where type dict used to filter the delection by. E.g. `{"$and": [{"color" : "red"}, {"price": {"$gte": 4.20}}]}`. Optional.
            where_document: A WhereDocument type dict used to filter the deletion by the document content. E.g. `{"$contains": "hello"}`. Optional.

        Returns:
            None

        Raises:
            ValueError: If you don't provide either ids, where, or where_document
        r!   r?   rB   )r+   r!   r?   rB   r,   r-   N)$_validate_and_prepare_delete_requestr/   _deleter1   r,   r-   )r2   r!   r?   rB   delete_requests        r4   deletezAsyncCollection.delete  s      & BB
 
 l""'u% ))*:;;] # 
 
 	
 	
 	
 	
 	
 	
 	
 	
 	
r6   )NNNNN)rM   )NNN)(__name__
__module____qualname__r   r   r   r   r
   r   r   r   r   r   r5   intr;   r   r>   r   r   r   r   rL   rR   r   r_   strr	   r   rj   rs   r   INDEX_AND_WALr   r   r{   r   r   r   r   rx   r6   r4   r    r    !   sg        3737-1)-4
 4
r]4
 )$+&(
4
 Ih/04
 Ih/04
 5)*4
 y~&4
 
4
 4
 4
 4
l
S 
 
 
 

> 
 
 
 
$ (,!%# $26'5-
 -
im$-
 -
 }	-

 -
 !/-
 -
 
-
 -
 -
 -
^
 
 
Y 
 
 
 
2 5937/3'+!%26
 
 
F
 F
")$+&(
F
 i12F
 y/0F
 Ys^,F
 im$F
 F
 F
 !/F
 F
( 
)F
 F
 F
 F
T #15AE	O OsmO -.O   =>	O
 
O O O O@

 

 
 
 
: !* 7W
 W
F#W
 W
 
	W
 W
 W
 W
B 3737-1)-+
 +
r]+
 )$+&(
+
 Ih/0+
 Ih/0+
 5)*+
 y~&+
 
+
 +
 +
 +
j 3737-1)-+
 +
r]+
 )$+&(
+
 Ih/0+
 Ih/0+
 5)*+
 y~&+
 
+
 +
 +
 +
^ "!%26	
 
c]
 
 !/	

 

 
 
 
 
 
r6   r    r   N)#typingr   r   r   r   r   chromadb.api.typesr   r	   r
   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   $chromadb.api.models.CollectionCommonr   %chromadb.api.collection_configurationr   "chromadb.execution.expression.planr   chromadb.apir   r    rx   r6   r4   <module>r      s   = = = = = = = = = = = = = =                                         , B A A A A A O O O O O O 5 5 5 5 5 5 ,++++++h
 h
 h
 h
 h
&'78 h
 h
 h
 h
 h
r6   