
    hz9                        d dl mZ d dlZd dlmZmZmZmZmZm	Z	 d dl
mZmZ d dlmZ d dlmZ d dlmZm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Z G d de      Z G d dee      Zy)    )annotationsN)AnyAsyncIteratorDictIteratorListOptional)AsyncCallbackManagerForLLMRunCallbackManagerForLLMRun)LLM)Serializable)GenerationChunk	LLMResult)pre_init)get_from_dict_or_env)convert_to_secret_str)Field	SecretStrc                    | j                  dd      st        d      S t        | j                  d   j                        S )z0Convert a stream response to a generation chunk.choicesN )textr   )getr   r   r   )stream_responses    _/var/www/html/eduruby.in/venv/lib/python3.12/site-packages/langchain_community/llms/friendli.py$_stream_response_to_generation_chunkr      s@     y$/B''$$Q',,     c                      e Zd ZU dZ edd      Zded<    edd      Zded<   dZd	ed
<   dZ	ded<   dZ
ded<   dZded<   dZded<   dZded<   dZded<   dZded<   dZded<   dZded<   edd       Zy)BaseFriendlizBase class of Friendli.NT)defaultexcluder   clientasync_clientzmeta-llama-3.1-8b-instructstrmodelzOptional[SecretStr]friendli_tokenzOptional[str]friendli_teamFbool	streamingzOptional[float]frequency_penaltypresence_penaltyzOptional[int]
max_tokensOptional[List[str]]stoptemperaturetop_pc                V   	 ddl }t        t        |dd            }||d<   |j	                         }|d   xs t        j                  d      }||d<   |d   xs |j                  ||	      |d<   |d
   xs |j                  ||	      |d
<   |S # t        $ r}t        d      |d}~ww xY w)z=Validate if personal access token is provided in environment.r   NzfCould not import friendli-client python package. Please install it with `pip install friendli-client`.r&   FRIENDLI_TOKENr'   FRIENDLI_TEAMr"   )tokenteam_idr#   )	friendliImportErrorr   r   get_secret_valueosgetenvFriendliAsyncFriendli)clsvaluesr6   er&   friendli_token_strr'   s          r   validate_environmentz!BaseFriendli.validate_environmentK   s    	 / )9;KL
 $2 +<<>/M299_3M"/!(+ 
x/@/@$m 0A 0
x "(!7 "
8;Q;Q$m <R <
~ '  	H 	s   B 	B(B##B()r>   r   returnr   )__name__
__module____qualname____doc__r   r"   __annotations__r#   r%   r&   r'   r)   r*   r+   r,   r.   r/   r0   r   rA    r   r   r   r   "   s    ! d3FC3dD9L#9-E3-*.N'.#'M='It
 *.- )-o, !%J$ !%D
$ $(K' "E?! r   r   c                  >    e Zd ZdZedd       Zedd       Zedd       Ze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 fdZ	 	 d	 	 	 	 	 	 	 	 	 d fdZ xZS )r;   a  Friendli LLM.

    ``friendli-client`` package should be installed with `pip install friendli-client`.
    You must set ``FRIENDLI_TOKEN`` environment variable or provide the value of your
    personal access token for the ``friendli_token`` argument.

    Example:
        .. code-block:: python

            from langchain_community.llms import Friendli

            friendli = Friendli(
                model="meta-llama-3.1-8b-instruct", friendli_token="YOUR FRIENDLI TOKEN"
            )
    c                
    ddiS )Nr&   r2   rH   selfs    r   
lc_secretszFriendli.lc_secretsw   s     "233r   c                    | j                   | j                  | j                  | j                  | j                  | j
                  dS )z@Get the default parameters for calling Friendli completions API.r*   r+   r,   r.   r/   r0   rO   rK   s    r   _default_paramszFriendli._default_params{   s>     "&!7!7 $ 5 5//II++ZZ
 	
r   c                6    d| j                   i| j                  S )zGet the identifying parameters.r%   )r%   rP   rK   s    r   _identifying_paramszFriendli._identifying_params   s     <t';';<<r   c                     y)zReturn type of llm.r6   rH   rK   s    r   	_llm_typezFriendli._llm_type   s     r   c                    | j                   }| j                  |t        d      | j                  | j                  |d<   n||d<   i ||S )z,Get the parameters used to invoke the model.z2`stop` found in both the input and default params.r.   )rP   r.   
ValueError)rL   r.   kwargsparamss       r   _get_invocation_paramszFriendli._get_invocation_params   sZ     %%99 T%5QRRYY"!YYF6N!F6N#&#F##r   c                     | j                   dd|i|} | j                  j                  j                  d| j                  |dd|}|j
                  d   j                  S )a1  Call out Friendli's completions API.

        Args:
            prompt (str): The text prompt to generate completion for.
            stop (Optional[List[str]], optional): When one of the stop phrases appears
                in the generation result, the API will stop generation. The stop phrases
                are excluded from the result. If beam search is enabled, all of the
                active beams should contain the stop phrase to terminate generation.
                Before checking whether a stop phrase is included in the result, the
                phrase is converted into tokens. We recommend using stop_tokens because
                it is clearer. For example, after tokenization, phrases "clear" and
                " clear" can result in different token sequences due to the prepended
                space character. Defaults to None.

        Returns:
            str: The generated text output.

        Example:
            .. code-block:: python

                response = frienldi("Give me a recipe for the Old Fashioned cocktail.")
        r.   Fr%   promptstreamr   rH   )rY   r"   completionscreater%   r   r   rL   r\   r.   run_managerrW   rX   
completions          r   _callzFriendli._call   sk    : -,,A$A&A3T[[,,33 
**VE
=C

 !!!$)))r   c                   K    | j                   dd|i|} | j                  j                  j                  d| j                  |dd| d{   }|j
                  d   j                  S 7 w)a%  Call out Friendli's completions API Asynchronously.

        Args:
            prompt (str): The text prompt to generate completion for.
            stop (Optional[List[str]], optional): When one of the stop phrases appears
                in the generation result, the API will stop generation. The stop phrases
                are excluded from the result. If beam search is enabled, all of the
                active beams should contain the stop phrase to terminate generation.
                Before checking whether a stop phrase is included in the result, the
                phrase is converted into tokens. We recommend using stop_tokens because
                it is clearer. For example, after tokenization, phrases "clear" and
                " clear" can result in different token sequences due to the prepended
                space character. Defaults to None.

        Returns:
            str: The generated text output.

        Example:
            .. code-block:: python

                response = await frienldi("Tell me a joke.")
        r.   Fr[   Nr   rH   )rY   r#   r^   r_   r%   r   r   r`   s          r   _acallzFriendli._acall   s{     : -,,A$A&A?4,,88?? 
**VE
=C
 

 !!!$)))
s   AA.A,A.c              +    K    | j                   dd|i|} | j                  j                  j                  d| j                  |dd|}|D ]0  }t        |      }|r|j                  |j                  |       | 2 y wNr.   Tr[   )chunkrH   )rY   r"   r^   r_   r%   r   on_llm_new_tokenr   	rL   r\   r.   ra   rW   rX   r]   linerh   s	            r   _streamzFriendli._stream   s      -,,A$A&A/((// 
**VD
<B
  	D8>E,,TYYe,DK		s   A?Bc               @  K    | j                   dd|i|} | j                  j                  j                  d| j                  |dd| d {   }|2 3 d {   }t        |      }|r%|j                  |j                  |       d {    | A7 G7 >7 6 y wrg   )rY   r#   r^   r_   r%   r   ri   r   rj   s	            r   _astreamzFriendli._astream   s      -,,A$A&A;t((44;; 
**VD
<B
 
 ! 	 	$8>E!22499E2JJJK
	 K !sH   ABBBBBB.BBBBBBc                   d| j                   i}| j                  rUt        |      dkD  rt        d      d} | j                  |d   ||fi |D ]  }||}||z  } |J t        |gg|      S t        	|   |||fi |}||_        |S )a1  Call out Friendli's completions API with k unique prompts.

        Args:
            prompt (str): The text prompt to generate completion for.
            stop (Optional[List[str]], optional): When one of the stop phrases appears
                in the generation result, the API will stop generation. The stop phrases
                are excluded from the result. If beam search is enabled, all of the
                active beams should contain the stop phrase to terminate generation.
                Before checking whether a stop phrase is included in the result, the
                phrase is converted into tokens. We recommend using stop_tokens because
                it is clearer. For example, after tokenization, phrases "clear" and
                " clear" can result in different token sequences due to the prepended
                space character. Defaults to None.

        Returns:
            str: The generated text output.

        Example:
            .. code-block:: python

                response = frienldi.generate(["Tell me a joke."])
        r%      ,Cannot stream results with multiple prompts.Nr   generations
llm_output)	r%   r)   lenrV   rl   r   super	_generatert   
rL   promptsr.   ra   rW   rt   
generationrh   
llm_result	__class__s
            r   rw   zFriendli._generate  s    : tzz*
>>7|a !OPP48J%gaj$NvN (%!&J%'J	(
 ))):,JOOW&wkLVL
 *
r   c                D  K   d| j                   i}| j                  rGt        |      dkD  rt        d      d} | j                  |d   ||fi |2 3 d{   }||}||z  }t        	|   |||fi | d{   }||_        |S 7 26 |J t        |gg|      S 7 #w)a  Call out Friendli's completions API asynchronously with k unique prompts.

        Args:
            prompt (str): The text prompt to generate completion for.
            stop (Optional[List[str]], optional): When one of the stop phrases appears
                in the generation result, the API will stop generation. The stop phrases
                are excluded from the result. If beam search is enabled, all of the
                active beams should contain the stop phrase to terminate generation.
                Before checking whether a stop phrase is included in the result, the
                phrase is converted into tokens. We recommend using stop_tokens because
                it is clearer. For example, after tokenization, phrases "clear" and
                " clear" can result in different token sequences due to the prepended
                space character. Defaults to None.

        Returns:
            str: The generated text output.

        Example:
            .. code-block:: python

                response = await frienldi.agenerate(
                    ["Give me a recipe for the Old Fashioned cocktail."]
                )
        r%   rp   rq   Nr   rr   )	r%   r)   ru   rV   rn   r   rv   
_ageneratert   rx   s
            r   r~   zFriendli._agenerate5  s     > tzz*
>>7|a !OPPJ,t}}WQZ{UfU ( (e%!&J%'J !7-gt[SFSS
 *
(U
 ))):,JOOSs6   AB B
BB
!B :B;B B

B )rB   zDict[str, str])rB   Dict[str, Any])rB   r$   )N)r.   r-   rW   r   rB   r   )NN)
r\   r$   r.   r-   ra   "Optional[CallbackManagerForLLMRun]rW   r   rB   r$   )
r\   r$   r.   r-   ra   'Optional[AsyncCallbackManagerForLLMRun]rW   r   rB   r$   )
r\   r$   r.   r-   ra   r   rW   r   rB   zIterator[GenerationChunk])
r\   r$   r.   r-   ra   r   rW   r   rB   zAsyncIterator[GenerationChunk])
ry   	list[str]r.   r-   ra   r   rW   r   rB   r   )
ry   r   r.   r-   ra   r   rW   r   rB   r   )rC   rD   rE   rF   propertyrM   rP   rR   rT   rY   rc   re   rl   rn   rw   r~   __classcell__)r|   s   @r   r;   r;   f   s     4 4 	
 	
 = =  
 +/$'$:=$	$  %):>	!*!* "!* 8	!*
 !* 
!*L %)?C	!*!* "!* =	!*
 !* 
!*L %):>	 " 8	
  
#( %)?C	 " =	
  
(( %):>	-- "- 8	-
 - 
-d %)?C	// "/ =	/
 / 
/ /r   r;   )r   r   rB   r   ) 
__future__r   r9   typingr   r   r   r   r   r	    langchain_core.callbacks.managerr
   r   #langchain_core.language_models.llmsr    langchain_core.load.serializabler   langchain_core.outputsr   r   langchain_core.utilsr   langchain_core.utils.envr   langchain_core.utils.utilsr   pydanticr   r   r   r   r;   rH   r   r   <module>r      sa    " 	 E E 4 9 = ) 9 < %A< AH~sL ~r   