
    h                    l   d dl mZ d dlZd dlZd dlZd dlZd dlZd dlZd dlm	Z	 d dlm
Z
 d dlmZ d dlmZmZmZmZmZmZmZmZ d dlZd dlmZ d dlmZ d d	lmZ d d
lmZm Z  d dl!m"Z"  G d de#ej                        Z$ddZ% G d de&e
      Z'e$jP                  Z)dZ*dZ+ G d de      Z, G d de      Z-y)    )annotationsN)OrderedDict)Enum)partial)AnyCallableDictIterableListOptionalTupleType)Document)
Embeddings)VectorStore)BaseSettingsSettingsConfigDict)maximal_marginal_relevancec                      e Zd ZdZdZdZdZy)DistanceStrategyz&Enumerator of the Distance strategies.l2cosineinnerN)__name__
__module____qualname____doc__	EUCLIDEANCOSINEMAX_INNER_PRODUCT     g/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/langchain_community/vectorstores/kinetica.pyr   r      s    0IFr"   r   c                8    | D cg c]  \  }}|	 c}}S c c}}w )z!Return docs from docs and scores.r!   )docs_and_scoresdoc_s      r#   _results_to_docsr(      s    -.FCC...s   c                      e Zd ZdZdZy)	Dimensionz-Some default dimensions for known embeddings.i   N)r   r   r   r   OPENAIr!   r"   r#   r*   r*   $   s
    7Fr"   r*   	langchainlangchain_kinetica_embeddingsc                      e Zd ZU dZdZded<   dZded<   dZd	ed
<   dZd	ed<   e	Z
ded<   eZded<   ej                  Zded<   ddZ edddd      Zy)KineticaSettingsa:  `Kinetica` client configuration.

    Attribute:
        host (str) : An URL to connect to MyScale backend.
                             Defaults to 'localhost'.
        port (int) : URL port to connect with HTTP. Defaults to 8443.
        username (str) : Username to login. Defaults to None.
        password (str) : Password to login. Defaults to None.
        database (str) : Database name to find the table. Defaults to 'default'.
        table (str) : Table name to operate on.
                      Defaults to 'vector_table'.
        metric (str) : Metric to compute distance,
                       supported are ('angular', 'euclidean', 'manhattan', 'hamming',
                       'dot'). Defaults to 'angular'.
                       https://github.com/spotify/annoy/blob/main/src/annoymodule.cc#L149-L169

    zhttp://127.0.0.1strhosti#  intportNzOptional[str]usernamepassworddatabasetablemetricc                    t        | |      S N)getattr)selfitems     r#   __getitem__zKineticaSettings.__getitem__O   s    tT""r"   z.envzutf-8	kinetica_ignore)env_fileenv_file_encoding
env_prefixextra)r=   r0   returnr   )r   r   r   r   r1   __annotations__r3   r4   r5   _LANGCHAIN_DEFAULT_SCHEMA_NAMEr6   "_LANGCHAIN_DEFAULT_COLLECTION_NAMEr7   DEFAULT_DISTANCE_STRATEGYvaluer8   r>   r   model_configr!   r"   r#   r/   r/   2   sr    $ #D#"D#"Hm""Hm"2Hc23E33+11FC1# &!	Lr"   r/   c                     e Zd ZdZeeedddf	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d dZd!dZd"dZ	e
d#d       Zeddeeddfed	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d$d	       Zd%d
Zd&dZd&dZd&dZ	 	 d'	 	 	 	 	 	 	 	 	 	 	 d(dZ	 	 d'	 	 	 	 	 	 	 	 	 d)dZ	 	 d*	 	 	 	 	 	 	 	 	 d+dZ	 	 d*	 	 	 	 	 	 	 d,dZ	 	 d*	 	 	 	 	 	 	 d-dZ	 	 d*	 	 	 	 	 	 	 	 	 d.dZd/dZd0dZe
d1d       Z	 	 d*	 	 	 	 	 	 	 d2dZ	 	 	 	 d3	 	 	 	 	 	 	 	 	 	 	 	 	 d4dZ	 	 	 	 d3	 	 	 	 	 	 	 	 	 	 	 	 	 d5dZ	 	 	 	 d3	 	 	 	 	 	 	 	 	 	 	 	 	 d6dZ	 	 	 	 d3	 	 	 	 	 	 	 	 	 	 	 	 	 d7dZ	 	 	 	 d3	 	 	 	 	 	 	 	 	 	 	 	 	 d7dZ ed e!       eeddfed	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d8d       Z"ed e!       e#jH                  eeddfed	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d9d       Z%e e!       deeddfed	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 	 d:d       Z&y);Kineticaa  `Kinetica` vector store.

    To use, you should have the ``gpudb`` python package installed.

    Args:
        config: Kinetica connection settings class.
        embedding_function: Any embedding function implementing
            `langchain.embeddings.base.Embeddings` interface.
        collection_name: The name of the collection to use. (default: langchain)
            NOTE: This is not the name of the table, but the name of the collection.
            The tables will be created when initializing the store (if not exists)
            So, make sure the user has the right permissions to create tables.
        distance_strategy: The distance strategy to use. (default: COSINE)
        pre_delete_collection: If True, will delete the collection if it exists.
            (default: False). Useful for testing.
        engine_args: SQLAlchemy's create engine arguments.

    Example:
        .. code-block:: python

            from langchain_community.vectorstores import Kinetica, KineticaSettings
            from langchain_community.embeddings.openai import OpenAIEmbeddings

            kinetica_settings = KineticaSettings(
                host="http://127.0.0.1", username="", password=""
                )
            COLLECTION_NAME = "kinetica_store"
            embeddings = OpenAIEmbeddings()
            vectorstore = Kinetica.from_documents(
                documents=docs,
                embedding=embeddings,
                collection_name=COLLECTION_NAME,
                config=kinetica_settings,
            )
    FNc	                    || _         || _        || _        || _        || _        || _        |xs t        j                  t              | _	        || _
        | j                  | j                         | _        y)a<  Constructor for the Kinetica class

        Args:
            config (KineticaSettings): a `KineticaSettings` instance
            embedding_function (Embeddings): embedding function to use
            collection_name (str, optional): the Kinetica table name.
                            Defaults to _LANGCHAIN_DEFAULT_COLLECTION_NAME.
            schema_name (str, optional): the Kinetica table name.
                            Defaults to _LANGCHAIN_DEFAULT_SCHEMA_NAME.
            distance_strategy (DistanceStrategy, optional): _description_.
                            Defaults to DEFAULT_DISTANCE_STRATEGY.
            pre_delete_collection (bool, optional): _description_. Defaults to False.
            logger (Optional[logging.Logger], optional): _description_.
                            Defaults to None.
        N)_configembedding_functioncollection_nameschema_name_distance_strategypre_delete_collectionlogging	getLoggerr   loggeroverride_relevance_score_fn_Kinetica__get_db_db)	r<   configrP   rQ   rR   distance_strategyrT   rW   relevance_score_fns	            r#   __init__zKinetica.__init__   sf    6 "4.&"3%:"; 1 1( ;+=(==.r"   c                   	 ddl m} || _        d| d}| j                  r| j                          | j                  | _        | j                  8t        | j                        dkD  r | j                   d| j                   | _        dd	gd
d|gg dg dg| _
        | j                          | j                         | _        y# t        $ r t        d      w xY w)z'
        Initialize the store.
        r   
GPUdbTableZCould not import Kinetica python API. Please install it with `pip install gpudb>=7.2.2.0`.zvector()N.textstring	embeddingbytes)metadatarf   json)idrf   uuid)gpudbra   ImportError
dimensionsrT   delete_schemarQ   
table_namerR   lentable_schemacreate_schemacreate_tables_if_not_existsEmbeddingStore)r<   ro   ra   dimension_fields       r#   __post_init__zKinetica.__post_init__   s    	( %#J<q1%% ..'C0@0@,AA,E!%!1!1 2!D4H4H3IJDO X'?3*$	
 	*.*J*J*L1  	G 	s   C   Cc                    	 ddl m} |j                         }|j                  |_        |j
                  |_        d|_         ||j                  |      S # t        $ r t        d      w xY w)Nr   )GPUdbrb   T)r1   options)rm   rz   rn   Optionsr4   r5   skip_ssl_cert_verificationr1   )r<   r[   rz   r{   s       r#   __get_dbzKinetica.__get_db   sl    	# --/!??!??-1*&++w77  	G 	s   A A*c                    | j                   S r:   )rP   r<   s    r#   
embeddingszKinetica.embeddings   s    &&&r"   )rR   c                  |*|D cg c]  }t        t        j                               ! }}|s|D cg c]  }i  }} | d|||||	|
|d|}|j                  |        |j                  d||||d| |S c c}w c c}w )a  Class method to assist in constructing the `Kinetica` store instance
            using different combinations of parameters

        Args:
            config (KineticaSettings): a `KineticaSettings` instance
            texts (List[str]): The list of texts to generate embeddings for and store
            embeddings (List[List[float]]): List of embeddings
            embedding (Embeddings): the Embedding function
            dimensions (int): The number of dimensions the embeddings have
            metadatas (Optional[List[dict]], optional): List of JSON data associated
                        with each text. Defaults to None.
            ids (Optional[List[str]], optional): List of unique IDs (UUID by default)
                        associated with each text. Defaults to None.
            collection_name (str, optional): Kinetica table name.
                        Defaults to _LANGCHAIN_DEFAULT_COLLECTION_NAME.
            schema_name (str, optional): Kinetica schema name.
                        Defaults to _LANGCHAIN_DEFAULT_SCHEMA_NAME.
            distance_strategy (DistanceStrategy, optional): Not used for now.
                        Defaults to DEFAULT_DISTANCE_STRATEGY.
            pre_delete_collection (bool, optional): Whether to delete the Kinetica
                        schema or not. Defaults to False.
            logger (Optional[logging.Logger], optional): Logger to use for logging at
                        different levels. Defaults to None.

        Returns:
            Kinetica: An instance of Kinetica class
        )r[   rQ   rR   rP   r\   rT   rW   textsr   	metadatasidsr!   )r0   rl   uuid4rx   add_embeddings)clsr[   r   r   rg   ro   r   r   rQ   r\   rT   rW   rR   kwargsr'   stores                   r#   __fromzKinetica.__from   s    Z ;.343tzz|$4C4%*++I+ 	
+#(/"7	
 	
 	J' 	
J)	
PV	
 - 5 ,s
   $A8	A=c                    	 ddl m}  || j                  | j                  | j
                  ddi      S # t        $ r t        d      w xY w)z2Create the table to store the texts and embeddingsr   r`   rb   is_replicatedtrue)_typenamedbr{   )rm   ra   rn   rs   rq   rZ   )r<   ra   s     r#   ru   z$Kinetica.create_tables_if_not_exists  s\    	( ##xx$f-	
 	
  	G 	s	   4 A	c                X    | j                   j                  | j                   ddi       y)zDelete the tableno_error_if_not_existsr   )r{   N)rZ   clear_tablerq   r   s    r#   drop_tableszKinetica.drop_tables.  s+    +CV*L 	 	
r"   c                N    | j                   j                  | j                         y)zCreate a new Kinetica schemaN)rZ   rt   rR   r   s    r#   rt   zKinetica.create_schema4  s    t//0r"   c                    | j                   j                  d       | j                  j                  | j                  ddd       y)z|Delete a Kinetica schema with cascade set to `true`
        This method will delete a schema with all tables in it.
        zTrying to delete collectionr   )r   cascadeN)rW   debugrZ   drop_schemarR   r   s    r#   rp   zKinetica.delete_schema8  s9     	78FS	
r"   c                   |*|D cg c]  }t        t        j                               ! }}|s|D cg c]  }i  }}g }t        ||||      D ]R  \  }}	}
}t	        j
                  d| j                  z  g|	 }|j                  ||t        j                  |
      |g       T | j                  j                  |       |S c c}w c c}w )ai  Add embeddings to the vectorstore.

        Args:
            texts: Iterable of strings to add to the vectorstore.
            embeddings: List of list of embedding vectors.
            metadatas: List of metadatas associated with the texts.
            ids: List of ids for the text embedding pairs
            kwargs: vectorstore specific parameters
        %sf)r0   rl   r   zipstructpackro   appendrj   dumpsrv   insert_records)r<   r   r   r   r   r   r'   recordsre   rg   ri   rk   bufs                r#   r   zKinetica.add_embeddingsA  s    " ;.343tzz|$4C4%*++I+-0
Is-S 	B)D)Xr++edoo5B	BCNND#tzz(';R@A	B 	**73
 5 ,s
   $C 	Cc                    | j                   j                  t        |            }t        |d         | _        t        | d      s| j                  | j                          | j                  d||||d|S )a  Run more texts through the embeddings and add to the vectorstore.

        Args:
            texts: Iterable of strings to add to the vectorstore.
            metadatas: Optional list of metadatas (JSON data) associated with the texts.
            ids: List of IDs (UUID) for the texts supplied; will be generated if None
            kwargs: vectorstore specific parameters

        Returns:
            List of ids from adding the texts into the vectorstore.
        r   rv   r   r!   )rP   embed_documentslistrr   ro   hasattrrx   r   )r<   r   r   r   r   r   s         r#   	add_textszKinetica.add_textsa  sv    $ ,,<<T%[I
jm,t-.t/"t"" 
J)
PV
 	
r"   c                b    | j                   j                  |      }| j                  |||      S )a^  Run similarity search with Kinetica with distance.

        Args:
            query (str): Query text to search for.
            k (int): Number of results to return. Defaults to 4.
            filter (Optional[Dict[str, str]]): Filter by metadata. Defaults to None.

        Returns:
            List of Documents most similar to the query.
        )re   rg   kfilter)rP   embed_querysimilarity_search_by_vector)r<   queryr   r   r   rg   s         r#   similarity_searchzKinetica.similarity_search{  s>    " ++77U7C	// 0 
 	
r"   c                d    | j                   j                  |      }| j                  |||      }|S )ab  Return docs most similar to query.

        Args:
            query: Text to look up documents similar to.
            k: Number of Documents to return. Defaults to 4.
            filter (Optional[Dict[str, str]]): Filter by metadata. Defaults to None.

        Returns:
            List of Documents most similar to the query and score for each
        r   )rP   r   &similarity_search_with_score_by_vector)r<   r   r   r   rg   docss         r#   similarity_search_with_scorez%Kinetica.similarity_search_with_score  s=      ++77>	::1V ; 
 r"   c                "   g }| j                  |||      }|rw|d   d   dk(  rl|d   }|dkD  r>|d   }t        t        t        |j                                      }| j	                  |      S | j
                  j                  d|d   d           |S )Nstatus_infostatusOKtotal_number_of_recordsr   r   zNo records found; status: )_Kinetica__query_collectionr   r   values_results_to_docs_and_scoresrW   warning)r<   rg   r   r   resultsresptotal_recordsr   s           r#   r   z/Kinetica.similarity_search_with_score_by_vector  s     ,,Y6BD'1T9 !:;Mq '+IsD)9$:;<77@@##0m1DX1N0OP r"   c                `    | j                  |||      }|D cg c]  \  }}|	 c}}S c c}}w )ak  Return docs most similar to embedding vector.

        Args:
            embedding: Embedding to look up documents similar to.
            k: Number of Documents to return. Defaults to 4.
            filter (Optional[Dict[str, str]]): Filter by metadata. Defaults to None.

        Returns:
            List of Documents most similar to the query vector.
        r   )r   )r<   rg   r   r   r   r%   r&   r'   s           r#   r   z$Kinetica.similarity_search_by_vector  s;    " EE1V F 
 #22Q222s   *c           
         t        |      dkD  rI|D cg c];  }t        |d   t        j                  |d               | j                  |d   ndf= c}}|S g }|S c c}w )z$Return docs and scores from results.r      )page_contentri   N   )rr   r   rj   loadsrP   )r<   r   resultr   s       r#   r   z$Kinetica._results_to_docs_and_scores  s     7|a &	  %+AY!%F1I!6 "&!8!8!DF1I$	 	   	 	s   A Ac                Z   | j                   | j                   S | j                  t        j                  k(  r| j                  S | j                  t        j
                  k(  r| j                  S | j                  t        j                  k(  r| j                  S t        d| j                   d      )a8  
        The 'correct' relevance function
        may differ depending on a few things, including:
        - the distance / similarity metric used by the VectorStore
        - the scale of your embeddings (OpenAI's are unit normed. Many others are not!)
        - embedding dimensionality
        - etc.
        z=No supported normalization function for distance_strategy of z?.Consider providing relevance_score_fn to Kinetica constructor.)
rX   rS   r   r   _cosine_relevance_score_fnr   _euclidean_relevance_score_fnr    %_max_inner_product_relevance_score_fn
ValueErrorr   s    r#   _select_relevance_score_fnz#Kinetica._select_relevance_score_fn  s     ++7333 ""&6&=&==222$$(8(B(BB555$$(8(J(JJ===--1-D-D,E FQQ r"   c                N   | j                   t        j                  k(  ry| j                   t        j                  k(  ry| j                   t        j                  k(  ryt        d| j                    ddj                  t        D cg c]  }|j                   c}       d      c c}w )Nl2_distancecosine_distancedot_productz#Got unexpected value for distance: z. Should be one of z, rd   )rS   r   r   r   r    r   joinrJ   )r<   dss     r#   r\   zKinetica.distance_strategy  s    ""&6&@&@@ $$(8(?(??$$$(8(J(JJ 5d6M6M5N O$$(IIBR.SBrxx.S$T#UUVX .Ss   B"c                   |t        j                  |      nd}|d| dnd}ddj                  |D cg c]  }t        |       c}      z   dz   }| j                  }d| d	| d
| j
                   d| j                   d| d| d}	| j                  j                  |	       | j                  j                  |	      }
| j                  j                  |
       |
S c c}w )zQuery the collection.Nz where 'z' = JSON(metadata)  [,]z(
                SELECT text, metadata, z(embedding, 'zA') 
                as distance, embedding
                FROM "z"."z"
                zH
                ORDER BY distance asc NULLS LAST
                LIMIT z	
        )rj   r   r   r0   r\   rR   rQ   rW   r   rZ   execute_sql_and_decode)r<   rg   r   r   json_filterwhere_clausexembedding_strdist_strategyquery_stringr   s              r#   __query_collectionzKinetica.__query_collection  s   2 -3,>djj(D & {m#67 	 chh	'B1A'BCCcI..((5mM? S''(D,@,@+A B c 	 	,'xx..|<$! (Cs   C
c                   | j                  |||      }|d   }t        t        t        |j                                      }	|d   D cg c]%  }t	        j
                  d| j                  z  |      ' }
}t        t        j                  t        j                        |
||      }| j                  |	      }t        |      D cg c]  \  }}||v s| c}}S c c}w c c}}w )a  Return docs selected using the maximal marginal relevance with score
            to embedding vector.

        Maximal marginal relevance optimizes for similarity to query AND diversity
            among selected documents.

        Args:
            embedding: Embedding to look up documents similar to.
            k (int): Number of Documents to return. Defaults to 4.
            fetch_k (int): Number of Documents to fetch to pass to MMR algorithm.
                Defaults to 20.
            lambda_mult (float): Number between 0 and 1 that determines the degree
                of diversity among the results with 0 corresponding
                to maximum diversity and 1 to minimum diversity.
                Defaults to 0.5.
            filter (Optional[Dict[str, str]]): Filter by metadata. Defaults to None.

        Returns:
            List[Tuple[Document, float]]: List of Documents selected by maximal marginal
                relevance to the query and score for each.
        r   r   rg   r   )dtype)r   lambda_mult)r   r   r   r   r   unpackro   r   nparrayfloat32r   	enumerate)r<   rg   r   fetch_kr   r   r   r   r   r   embedding_listmmr_selected
candidatesirs                  r#   2max_marginal_relevance_search_with_score_by_vectorz;Kinetica.max_marginal_relevance_search_with_score_by_vectorC  s    < &&gf&U#IsD!1234 %[1
 MM%$//19=
 

 2HHYbjj1#	
 55g>
'
3IdaqL7HII
 Js   	*CC C c                h    | j                   j                  |      } | j                  |f||||d|S )av  Return docs selected using the maximal marginal relevance.

        Maximal marginal relevance optimizes for similarity to query AND diversity
            among selected documents.

        Args:
            query (str): Text to look up documents similar to.
            k (int): Number of Documents to return. Defaults to 4.
            fetch_k (int): Number of Documents to fetch to pass to MMR algorithm.
                Defaults to 20.
            lambda_mult (float): Number between 0 and 1 that determines the degree
                of diversity among the results with 0 corresponding
                to maximum diversity and 1 to minimum diversity.
                Defaults to 0.5.
            filter (Optional[Dict[str, str]]): Filter by metadata. Defaults to None.

        Returns:
            List[Document]: List of Documents selected by maximal marginal relevance.
        r   r   r   r   )rP   r   'max_marginal_relevance_search_by_vector)r<   r   r   r   r   r   r   rg   s           r#   max_marginal_relevance_searchz&Kinetica.max_marginal_relevance_searchu  sM    8 ++77>	;t;;
#
 
 	
r"   c           	     l    | j                   j                  |      } | j                  d|||||d|}|S )a  Return docs selected using the maximal marginal relevance with score.

        Maximal marginal relevance optimizes for similarity to query AND diversity
            among selected documents.

        Args:
            query (str): Text to look up documents similar to.
            k (int): Number of Documents to return. Defaults to 4.
            fetch_k (int): Number of Documents to fetch to pass to MMR algorithm.
                Defaults to 20.
            lambda_mult (float): Number between 0 and 1 that determines the degree
                of diversity among the results with 0 corresponding
                to maximum diversity and 1 to minimum diversity.
                Defaults to 0.5.
            filter (Optional[Dict[str, str]]): Filter by metadata. Defaults to None.

        Returns:
            List[Tuple[Document, float]]: List of Documents selected by maximal marginal
                relevance to the query and score for each.
        )rg   r   r   r   r   r!   )rP   r   r   )	r<   r   r   r   r   r   r   rg   r   s	            r#   (max_marginal_relevance_search_with_scorez1Kinetica.max_marginal_relevance_search_with_score  sQ    : ++77>	FtFF 
#
 
 r"   c                H     | j                   |f||||d|}t        |      S )a  Return docs selected using the maximal marginal relevance
            to embedding vector.

        Maximal marginal relevance optimizes for similarity to query AND diversity
            among selected documents.

        Args:
            embedding (str): Text to look up documents similar to.
            k (int): Number of Documents to return. Defaults to 4.
            fetch_k (int): Number of Documents to fetch to pass to MMR algorithm.
                Defaults to 20.
            lambda_mult (float): Number between 0 and 1 that determines the degree
                of diversity among the results with 0 corresponding
                to maximum diversity and 1 to minimum diversity.
                Defaults to 0.5.
            filter (Optional[Dict[str, str]]): Filter by metadata. Defaults to None.

        Returns:
            List[Document]: List of Documents selected by maximal marginal relevance.
        r   )r   r(   )r<   rg   r   r   r   r   r   r%   s           r#   r   z0Kinetica.max_marginal_relevance_search_by_vector  sB    : R$QQ
#
 
  00r"   c                   K   t        | j                  |f||||d|}t        j                         j	                  d|       d{   S 7 w)z:Return docs selected using the maximal marginal relevance.r   N)r   r   asyncioget_event_looprun_in_executor)r<   rg   r   r   r   r   r   funcs           r#   (amax_marginal_relevance_search_by_vectorz1Kinetica.amax_marginal_relevance_search_by_vector  s_      88
 #
 
 ++-==dDIIIIs   AAAAc	               6   t        |      dk(  rt        d      	 |j                  |dd       }t        |d         }|j                  t        |            } | j                  d|||||||||	||d|
}|S # t        $ r |j	                  |d         g}Y hw xY w)a  Adds the texts passed in to the vector store and returns it

        Args:
            cls (Type[Kinetica]): Kinetica class
            texts (List[str]): A list of texts for which the embeddings are generated
            embedding (Embeddings): List of embeddings
            metadatas (Optional[List[dict]], optional): List of dicts, JSON
                        describing the texts/documents. Defaults to None.
            config (KineticaSettings): a `KineticaSettings` instance
            collection_name (str, optional): Kinetica schema name.
                        Defaults to _LANGCHAIN_DEFAULT_COLLECTION_NAME.
            schema_name (str, optional): Kinetica schema name.
                        Defaults to _LANGCHAIN_DEFAULT_SCHEMA_NAME.
            distance_strategy (DistanceStrategy, optional): Distance strategy
                        e.g., l2, cosine etc.. Defaults to DEFAULT_DISTANCE_STRATEGY.
            ids (Optional[List[str]], optional): A list of UUIDs for each
                        text/document. Defaults to None.
            pre_delete_collection (bool, optional): Indicates whether the Kinetica
                        schema is to be deleted or not. Defaults to False.

        Returns:
            Kinetica: a `Kinetica` instance
        r   ztexts is emptyr   r   r   rg   ro   r[   r   r   rQ   rR   r\   rT   r!   )rr   r   r   NotImplementedErrorr   r   _Kinetica__from)r   r   rg   r   r[   rQ   r\   r   rT   rR   r   first_embeddingro   r   kinetica_stores                  r#   
from_textszKinetica.from_texts  s    N u:?-..	@'77a
CO +,
..tE{;
# 
!!+#/"7
 
 + # 	@(44U1X>?O	@s   A7 7BBc
                   |D cg c]  }|d   	 }}|D cg c]  }|d   	 }}t        |d         } | j                  d|||||||||
||	d|S c c}w c c}w )a  Adds the embeddings passed in to the vector store and returns it

        Args:
            cls (Type[Kinetica]): Kinetica class
            text_embeddings (List[Tuple[str, List[float]]]): A list of texts
                            and the embeddings
            embedding (Embeddings): List of embeddings
            metadatas (Optional[List[dict]], optional): List of dicts, JSON describing
                        the texts/documents. Defaults to None.
            config (KineticaSettings): a `KineticaSettings` instance
            dimensions (int, optional): Dimension for the vector data, if not passed a
                        default will be used. Defaults to Dimension.OPENAI.
            collection_name (str, optional): Kinetica schema name.
                        Defaults to _LANGCHAIN_DEFAULT_COLLECTION_NAME.
            schema_name (str, optional): Kinetica schema name.
                        Defaults to _LANGCHAIN_DEFAULT_SCHEMA_NAME.
            distance_strategy (DistanceStrategy, optional): Distance strategy
                        e.g., l2, cosine etc.. Defaults to DEFAULT_DISTANCE_STRATEGY.
            ids (Optional[List[str]], optional): A list of UUIDs for each text/document.
                        Defaults to None.
            pre_delete_collection (bool, optional): Indicates whether the
                        Kinetica schema is to be deleted or not. Defaults to False.

        Returns:
            Kinetica: a `Kinetica` instance
        r   r   r   r!   )rr   r  )r   text_embeddingsrg   r   r[   ro   rQ   r\   r   rT   rR   r   tr   r   s                  r#   from_embeddingszKinetica.from_embeddingsG  s    V  //!1//$34qad4
4A'
szz 
!!+#/"7
 
 	
	 04s
   AAc	                   |D cg c]  }|j                    }}|D cg c]  }|j                   }} | j                  d||||||	|||d	|
S c c}w c c}w )a
  Adds the list of `Document` passed in to the vector store and returns it

        Args:
            cls (Type[Kinetica]): Kinetica class
            texts (List[str]): A list of texts for which the embeddings are generated
            embedding (Embeddings): List of embeddings
            config (KineticaSettings): a `KineticaSettings` instance
            metadatas (Optional[List[dict]], optional): List of dicts, JSON describing
                        the texts/documents. Defaults to None.
            collection_name (str, optional): Kinetica schema name.
                        Defaults to _LANGCHAIN_DEFAULT_COLLECTION_NAME.
            schema_name (str, optional): Kinetica schema name.
                        Defaults to _LANGCHAIN_DEFAULT_SCHEMA_NAME.
            distance_strategy (DistanceStrategy, optional): Distance strategy
                        e.g., l2, cosine etc.. Defaults to DEFAULT_DISTANCE_STRATEGY.
            ids (Optional[List[str]], optional): A list of UUIDs for each text/document.
                        Defaults to None.
            pre_delete_collection (bool, optional): Indicates whether the Kinetica
                        schema is to be deleted or not. Defaults to False.

        Returns:
            Kinetica: a `Kinetica` instance
        )	r   rg   r   r[   rQ   rR   r\   r   rT   r!   )r   ri   r  )r   	documentsrg   r[   r   rQ   r\   r   rT   rR   r   dr   s                r#   from_documentszKinetica.from_documents  sx    N *33A33)23AQZZ3	3s~~ 
+#/"7
 
 	
 43s
   AA)r[   r/   rP   r   rQ   r0   rR   r0   r\   r   rT   boolrW   Optional[logging.Logger]r]   z"Optional[Callable[[float], float]]rE   None)ro   r2   rE   r  )r[   r/   rE   r   )rE   r   )r[   r/   r   	List[str]r   List[List[float]]rg   r   ro   r2   r   Optional[List[dict]]r   Optional[List[str]]rQ   r0   r\   r   rT   r  rW   r  rR   r0   r   r   rE   rM   )rE   r   )rE   r  )NN)r   Iterable[str]r   r  r   r  r   r  r   r   rE   r  )
r   r  r   r  r   r  r   r   rE   r  )   N)
r   r0   r   r2   r   Optional[dict]r   r   rE   List[Document])r   r0   r   r2   r   r  rE   List[Tuple[Document, float]])rg   List[float]r   r2   r   r  rE   r  )
rg   r  r   r2   r   r  r   r   rE   r  )r   r   rE   r  )rE   zCallable[[float], float])rE   r0   )rg   r  r   r2   r   Optional[Dict[str, str]]rE   r	   )r     g      ?N)rg   r  r   r2   r   r2   r   floatr   r  r   r   rE   r  )r   r0   r   r2   r   r2   r   r  r   r  r   r   rE   r  )r   r0   r   r2   r   r2   r   r  r   r  r   r   rE   r  )rg   r  r   r2   r   r2   r   r  r   r  r   r   rE   r  )r   Type[Kinetica]r   r  rg   r   r   r  r[   r/   rQ   r0   r\   r   r   r  rT   r  rR   r0   r   r   rE   rM   )r   r  r  zList[Tuple[str, List[float]]]rg   r   r   r  r[   r/   ro   r2   rQ   r0   r\   r   r   r  rT   r  rR   r0   r   r   rE   rM   )r   r  r  r  rg   r   r[   r/   r   r  rQ   r0   r\   r   r   r  rT   r  rR   r0   r   r   rE   rM   )'r   r   r   r   rH   rG   rI   r^   rx   rY   propertyr   classmethodr  ru   r   rt   rp   r   r   r   r   r   r   r   r   r\   r   r   r   r   r   r   r/   r  r*   r+   r	  r  r!   r"   r#   rM   rM   Z   s   "P  B9.G&++/AE#/ #/ '#/ 	#/
 #/ ,#/  $#/ )#/ ?#/ 
#/JM@8 ' '  +/#'A.G&++/C :C C C &	C
 C C (C !C C ,C  $C )C C C  
!C CJ
"
1
 +/#' & (	
 !  
F +/#'	

 (
 !	

 
 

: !%	

 
 	

 
 

6 !%	  	
 
&2 !%	  	
 
&4 !%	33 3 	3
 3 
3,$6    +/	00 0 )	0
 
0j  +/0J0J 0J 	0J
 0J )0J 0J 
&0Jj  +/$
$
 $
 	$

 $
 )$
 $
 
$
R  !%&& & 	&
 & & & 
&&V  +/&1&1 &1 	&1
 &1 )&1 &1 
&1V  +/JJ J 	J
 J )J J 
J2 
 +/#3#5A.G#'&+@ :@@@ @ (	@
 !@ @ ,@ !@  $@ @ @ 
@ @D 
 +/#3#5#**A.G#'&+;
 :;
;
6;
 ;
 (	;

 !;
 ;
 ;
 ,;
 !;
  $;
 ;
 ;
 
;
 ;
z 
 $4#5*.A.G#'&+4
 :4
4
!4
 4
 !	4

 (4
 4
 ,4
 !4
  $4
 4
 4
 
4
 4
r"   rM   )r%   r   rE   r  ).
__future__r   r   enumrj   rU   r   rl   collectionsr   r   	functoolsr   typingr   r   r	   r
   r   r   r   r   numpyr   langchain_core.documentsr   langchain_core.embeddingsr   langchain_core.vectorstoresr   pydantic_settingsr   r   &langchain_community.vectorstores.utilsr   r0   r   r(   r2   r*   r   rI   rG   rH   r/   rM   r!   r"   r#   <module>r,     s    "       #   M M M  - 0 3 > M sDII  /
T  -66 !, # #
%| %P`
{ `
r"   