Grok 4.20
grok-4.20-non-reasoning
Grok 4.20 — текстовая модель от xai, доступная через единый Ranvik API. Контекстное окно — 2M токенов. Максимум выходных токенов за один запрос — 64k. Поддерживаемые возможности: function_calling, prompt_caching, streaming, vision.
от 350 ₽ / 1M
Технические характеристики
grok-4.20-non-reasoningВозможности
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
- Streaming
- Vision
Цены
| Единица | Цена |
|---|---|
| за 1М input | 350 ₽ |
| за 1М output | 700 ₽ |
| web_search | 1.4 ₽ |
| code_interpreter | 1.4 ₽ |
Цены указаны в рублях. Списываются с баланса проекта при каждом успешном запросе.
Поддерживаемые параметры
Параметры передаются вендору как есть (pure proxy) — мы не валидируем их у себя на стороне. Если вендор не примет — вернётся его ошибка.
| Параметр | Тип | Диапазон / values | Default | Описание |
|---|---|---|---|---|
max_completion_tokens | integer | min: 1 · max: 256000 | 8192 | grok-4 принимает только max_completion_tokens. |
temperature | number | min: 0 · max: 2 | 1 | — |
top_p | number | min: 0 · max: 1 | 1 | — |
n | integer | min: 1 · max: 8 | 1 | — |
reasoning_effort | enum | low, high | — | Только для grok-4.20-reasoning. low — быстро, high — глубокое. |
response_format | object | — | — | — |
tools | array | — | — | — |
tool_choice | object | — | — | — |
parallel_tool_calls | boolean | — | true | — |
seed | integer | — | — | — |
logprobs | boolean | — | false | — |
top_logprobs | integer | min: 0 · max: 8 | — | — |
search_parameters | object | — | — | Live search: {mode:"on/off/auto", sources, ...}. |
deferred | boolean | — | false | — |
user | string | — | — | — |
stream | boolean | — | false | — |
messagesrequired | array | — | — | Массив сообщений диалога OpenAI-compatible: [{role, content}]. Поддержка multimodal — image_url в content для vision-моделей. примеры значенийПримеры [
{
"role": "system",
"content": "You are a helpful assistant."
},
{
"role": "user",
"content": "Привет!"
}
] |
frequency_penalty | number | min: -2 · max: 2 | 0 | Penalty за повторение токенов (-2..2). |
presence_penalty | number | min: -2 · max: 2 | 0 | Penalty за повторение тем (-2..2). |
stop | array of strings | — | — | До 4 stop-последовательностей. |
logit_bias | object | — | — | 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-non-reasoning",
messages=[{"role": "user", "content": "Привет!"}],
)
print(resp.choices[0].message.content)
# ── С веб-поиском ──
resp = client.responses.create(
model="grok-4.20-non-reasoning",
input="Что нового в AI сегодня?",
tools=[{"type": "web_search"}],
)
print(resp.output_text) Замените rk_live_... на ваш ключ из кабинета.