llama-index

Форк
0
71 строка · 2.7 Кб
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.anyscale_utils import (
7
    anyscale_modelname_to_contextsize,
8
)
9
from llama_index.legacy.llms.generic_utils import get_from_param_or_env
10
from llama_index.legacy.llms.openai import OpenAI
11
from llama_index.legacy.types import BaseOutputParser, PydanticProgramMode
12

13
DEFAULT_API_BASE = "https://api.endpoints.anyscale.com/v1"
14
DEFAULT_MODEL = "meta-llama/Llama-2-70b-chat-hf"
15

16

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

37
        api_base = get_from_param_or_env("api_base", api_base, "ANYSCALE_API_BASE")
38
        api_key = get_from_param_or_env("api_key", api_key, "ANYSCALE_API_KEY")
39

40
        super().__init__(
41
            model=model,
42
            temperature=temperature,
43
            max_tokens=max_tokens,
44
            api_base=api_base,
45
            api_key=api_key,
46
            additional_kwargs=additional_kwargs,
47
            max_retries=max_retries,
48
            callback_manager=callback_manager,
49
            system_prompt=system_prompt,
50
            messages_to_prompt=messages_to_prompt,
51
            completion_to_prompt=completion_to_prompt,
52
            pydantic_program_mode=pydantic_program_mode,
53
            output_parser=output_parser,
54
        )
55

56
    @classmethod
57
    def class_name(cls) -> str:
58
        return "Anyscale_LLM"
59

60
    @property
61
    def metadata(self) -> LLMMetadata:
62
        return LLMMetadata(
63
            context_window=anyscale_modelname_to_contextsize(self.model),
64
            num_output=self.max_tokens,
65
            is_chat_model=True,
66
            model_name=self.model,
67
        )
68

69
    @property
70
    def _is_chat_model(self) -> bool:
71
        return True
72

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

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

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

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