llama-index

Форк
0
60 строк · 2.0 Кб
1
from typing import Any, Dict, Optional
2

3
from llama_index.legacy.bridge.pydantic import Field
4
from llama_index.legacy.constants import (
5
    DEFAULT_CONTEXT_WINDOW,
6
    DEFAULT_NUM_OUTPUTS,
7
    DEFAULT_TEMPERATURE,
8
)
9
from llama_index.legacy.core.llms.types import LLMMetadata
10
from llama_index.legacy.llms.generic_utils import get_from_param_or_env
11
from llama_index.legacy.llms.openai_like import OpenAILike
12

13
DEFAULT_API_BASE = "https://openrouter.ai/api/v1"
14
DEFAULT_MODEL = "gryphe/mythomax-l2-13b"
15

16

17
class OpenRouter(OpenAILike):
18
    model: str = Field(
19
        description="The OpenRouter model to use. See https://openrouter.ai/models for options."
20
    )
21
    context_window: int = Field(
22
        default=DEFAULT_CONTEXT_WINDOW,
23
        description="The maximum number of context tokens for the model. See https://openrouter.ai/models for options.",
24
        gt=0,
25
    )
26
    is_chat_model: bool = Field(
27
        default=True,
28
        description=LLMMetadata.__fields__["is_chat_model"].field_info.description,
29
    )
30

31
    def __init__(
32
        self,
33
        model: str = DEFAULT_MODEL,
34
        temperature: float = DEFAULT_TEMPERATURE,
35
        max_tokens: int = DEFAULT_NUM_OUTPUTS,
36
        additional_kwargs: Optional[Dict[str, Any]] = None,
37
        max_retries: int = 5,
38
        api_base: Optional[str] = DEFAULT_API_BASE,
39
        api_key: Optional[str] = None,
40
        **kwargs: Any,
41
    ) -> None:
42
        additional_kwargs = additional_kwargs or {}
43

44
        api_base = get_from_param_or_env("api_base", api_base, "OPENROUTER_API_BASE")
45
        api_key = get_from_param_or_env("api_key", api_key, "OPENROUTER_API_KEY")
46

47
        super().__init__(
48
            model=model,
49
            temperature=temperature,
50
            max_tokens=max_tokens,
51
            api_base=api_base,
52
            api_key=api_key,
53
            additional_kwargs=additional_kwargs,
54
            max_retries=max_retries,
55
            **kwargs,
56
        )
57

58
    @classmethod
59
    def class_name(cls) -> str:
60
        return "OpenRouter_LLM"
61

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

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

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

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