llama-index

Форк
0
67 строк · 2.5 Кб
1
from typing import Any, Callable, Dict, Optional, Sequence
2

3
from llama_index.legacy.callbacks import CallbackManager
4
from llama_index.legacy.constants import DEFAULT_NUM_OUTPUTS, DEFAULT_TEMPERATURE
5
from llama_index.legacy.core.llms.types import ChatMessage, LLMMetadata
6
from llama_index.legacy.llms.everlyai_utils import everlyai_modelname_to_contextsize
7
from llama_index.legacy.llms.generic_utils import get_from_param_or_env
8
from llama_index.legacy.llms.openai import OpenAI
9
from llama_index.legacy.types import BaseOutputParser, PydanticProgramMode
10

11
EVERLYAI_API_BASE = "https://everlyai.xyz/hosted"
12
DEFAULT_MODEL = "meta-llama/Llama-2-7b-chat-hf"
13

14

15
class EverlyAI(OpenAI):
16
    def __init__(
17
        self,
18
        model: str = DEFAULT_MODEL,
19
        temperature: float = DEFAULT_TEMPERATURE,
20
        max_tokens: int = DEFAULT_NUM_OUTPUTS,
21
        additional_kwargs: Optional[Dict[str, Any]] = None,
22
        max_retries: int = 10,
23
        api_key: Optional[str] = None,
24
        callback_manager: Optional[CallbackManager] = None,
25
        system_prompt: Optional[str] = None,
26
        messages_to_prompt: Optional[Callable[[Sequence[ChatMessage]], str]] = None,
27
        completion_to_prompt: Optional[Callable[[str], str]] = None,
28
        pydantic_program_mode: PydanticProgramMode = PydanticProgramMode.DEFAULT,
29
        output_parser: Optional[BaseOutputParser] = None,
30
    ) -> None:
31
        additional_kwargs = additional_kwargs or {}
32
        callback_manager = callback_manager or CallbackManager([])
33

34
        api_key = get_from_param_or_env("api_key", api_key, "EverlyAI_API_KEY")
35

36
        super().__init__(
37
            model=model,
38
            temperature=temperature,
39
            max_tokens=max_tokens,
40
            api_base=EVERLYAI_API_BASE,
41
            api_key=api_key,
42
            additional_kwargs=additional_kwargs,
43
            max_retries=max_retries,
44
            callback_manager=callback_manager,
45
            system_prompt=system_prompt,
46
            messages_to_prompt=messages_to_prompt,
47
            completion_to_prompt=completion_to_prompt,
48
            pydantic_program_mode=pydantic_program_mode,
49
            output_parser=output_parser,
50
        )
51

52
    @classmethod
53
    def class_name(cls) -> str:
54
        return "EverlyAI_LLM"
55

56
    @property
57
    def metadata(self) -> LLMMetadata:
58
        return LLMMetadata(
59
            context_window=everlyai_modelname_to_contextsize(self.model),
60
            num_output=self.max_tokens,
61
            is_chat_model=True,
62
            model_name=self.model,
63
        )
64

65
    @property
66
    def _is_chat_model(self) -> bool:
67
        return True
68

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.