Текстовая модель · xai

Grok 4.20 Multi-Agent

grok-4.20-multi-agent

Grok 4.20 Multi-Agent — текстовая модель от xai, доступная через единый Ranvik API. Контекстное окно — 2M токенов. Максимум выходных токенов за один запрос — 64k. Поддерживаемые возможности: function_calling, prompt_caching, reasoning, streaming, vision, web_search.

от 350 ₽ / 1M

Технические характеристики

МодальностьТекстовая модель
Провайдерxai
Контекст2M токенов
Max output64k токенов
СтатусАктивна
ID для запросовgrok-4.20-multi-agent

Возможности

Prompt caching— Повторно используемые префиксы (системный промпт, документы) кэшируются — цена в 5-10× ниже.

Зачем

Если ты отправляешь один и тот же системный промпт + документы на каждом запросе — модель повторно тратит compute на их обработку. Prompt caching сохраняет эти токены и заряжает 10× меньше при попадании.

Базовая формула экономии:

  • Cache write — обычно 1.25× цены input (5-минутный TTL) или 2× (1-часовой).
  • Cache hit — 0.1× цены input.
  • Окупается с 2-3 повторений того же префикса в течение TTL.

Что кэшируется

Префикс должен быть идентичным byte-в-byte: системный промпт, статические документы, фиксированные few-shot примеры. Динамическая часть (юзер-промпт, переменные) идёт ПОСЛЕ кэшированной.

Когда использовать

  • RAG: документы в context каждого запроса (кэшируй документы).
  • Агенты: длинная инструкция системы (кэшируй её).
  • Few-shot prompting: фиксированные примеры (кэшируй блок примеров).

Особенности у xAI Grok

Автоматический, как у OpenAI. Префикс ≥256 токенов кэшируется на ~5 минут. usage.prompt_tokens_details.cached_tokens в ответе.

Streaming (SSE)— Получение ответа по мере генерации — токен за токеном через Server-Sent Events.

Как работает

Передай stream: true в теле запроса — сервер вернёт SSE-поток с заголовком content-type: text/event-stream. Каждый чанк — строка вида data: {...}\n\n. Конец потока — data: [DONE]\n\n.

curl -N https://api.ranvik.ru/v1/chat/completions \
  -H "Authorization: Bearer rk_live_..." \
  -H "Content-Type: application/json" \
  -d '{
    "model": "gpt-5",
    "messages": [{"role": "user", "content": "Привет"}],
    "stream": true,
    "stream_options": {"include_usage": true}
  }'

Каждый чанк содержит choices[0].delta — частичные данные. Последний чанк перед [DONE] (если включить stream_options.include_usage: true) содержит usage с реальным числом токенов — используй для биллинг-учёта на клиенте.

Когда использовать

  • Чат-интерфейсы, где важна перцептивная скорость отклика.
  • Длинные ответы (> 1000 токенов) — пользователь видит прогресс.
  • Streaming tool-calls — delta.tool_calls[i].function.arguments приходят инкрементально.

Когда НЕ использовать

  • Backend-to-backend интеграции, где нужен только финальный JSON — добавляет парсинг SSE без выгод.
  • Когда обязательно знать стоимость до отправки в БД — без include_usage затраты неизвестны.
Vision (анализ изображений)— Картинки на вход вместе с текстом — OCR, распознавание объектов, описание сцен, анализ графиков.

Как передать изображение

Через массив content в сообщении вместо строки. Поддерживается URL и base64 (data URI).

{
  "model": "gpt-5",
  "messages": [{
    "role": "user",
    "content": [
      {"type": "text", "text": "Что на этой схеме?"},
      {"type": "image_url", "image_url": {"url": "https://.../diagram.png"}}
    ]
  }]
}

Для base64: "url": "data:image/png;base64,iVBOR...". Размер ограничен ~20MB.

Биллинг изображений

Картинка считается как input-токены — точное число зависит от размера и detail. Грубо: 512×512 ≈ 250 токенов, 2048×2048 ≈ 1500. Минимизируй размер если нужно много кадров.

Что НЕ умеют vision-модели

  • Точные измерения (расстояния, размеры в пикселях).
  • Распознавание текста на сложных шрифтах при низком DPI — лучше OCR-модель.
  • Деанонимизация лиц / людей — модели отказываются.
  • Function Calling
  • Prompt Caching
  • Reasoning
  • Streaming
  • Vision
  • Веб-поиск

Цены

ЕдиницаЦена
за 1М input350 ₽
за 1М output700 ₽
web_search1.4 ₽
code_interpreter1.4 ₽

Цены указаны в рублях. Списываются с баланса проекта при каждом успешном запросе.

Поддерживаемые параметры

Параметры передаются вендору как есть (pure proxy) — мы не валидируем их у себя на стороне. Если вендор не примет — вернётся его ошибка.

ПараметрТипДиапазон / valuesDefaultОписание
max_completion_tokensintegermin: 1 · max: 2560008192 grok-4 принимает только max_completion_tokens.
temperaturenumbermin: 0 · max: 21
top_pnumbermin: 0 · max: 11
nintegermin: 1 · max: 81
reasoning_effortenumlow, high Только для grok-4.20-reasoning. low — быстро, high — глубокое.
response_formatobject
toolsarray
tool_choiceobject
parallel_tool_callsbooleantrue
seedinteger
logprobsbooleanfalse
top_logprobsintegermin: 0 · max: 8
search_parametersobject Live search: {mode:"on/off/auto", sources, ...}.
deferredbooleanfalse
userstring
streambooleanfalse
messagesrequiredarray Массив сообщений диалога OpenAI-compatible: [{role, content}]. Поддержка multimodal — image_url в content для vision-моделей.
примеры значений
Примеры
[
  {
    "role": "system",
    "content": "You are a helpful assistant."
  },
  {
    "role": "user",
    "content": "Привет!"
  }
]
frequency_penaltynumbermin: -2 · max: 20 Penalty за повторение токенов (-2..2).
presence_penaltynumbermin: -2 · max: 20 Penalty за повторение тем (-2..2).
stoparray of strings До 4 stop-последовательностей.
logit_biasobject Map token_id → bias (-100..100).

Пример запроса

from openai import OpenAI

client = OpenAI(api_key="rk_live_...", base_url="https://api.ranvik.ru/v1")
resp = client.chat.completions.create(
    model="grok-4.20-multi-agent",
    messages=[{"role": "user", "content": "Привет!"}],
)
print(resp.choices[0].message.content)

# ── С веб-поиском ──
resp = client.responses.create(
    model="grok-4.20-multi-agent",
    input="Что нового в AI сегодня?",
    tools=[{"type": "web_search"}],
)
print(resp.output_text)

Замените rk_live_... на ваш ключ из кабинета.