Реализация голосового AI-бота для call-центра

Проектируем и внедряем системы искусственного интеллекта: от прототипа до production-ready решения. Наша команда объединяет экспертизу в машинном обучении, дата-инжиниринге и MLOps, чтобы AI работал не в лаборатории, а в реальном бизнесе.
Показано 1 из 1 услугВсе 1566 услуг
Реализация голосового AI-бота для call-центра
Средняя
от 1 недели до 3 месяцев
Часто задаваемые вопросы
Направления AI-разработки
Этапы разработки AI-решения
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1218
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1161
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    853
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1047
  • image_logo-advance_0.png
    Разработка логотипа компании B2B Advance
    561
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    825

Реализация голосового AI-бота для call-центра

Голосовой бот для колл-центра обрабатывает входящие и исходящие звонки, снимая нагрузку с операторов на типовые запросы: проверку статуса заказа, изменение данных, ответы на FAQ. При Containment Rate >60% бот окупается за 4–8 месяцев.

Типовые сценарии и покрытие

Сценарий Доля звонков Автоматизация
Статус заказа 30–40% 95%
Изменение адреса 10–15% 80%
FAQ по продукту 15–20% 85%
Жалобы 5–10% 30% (далее оператор)
Запись/отмена 10–15% 90%

Архитектура бота для call-центра

from enum import Enum
from dataclasses import dataclass

class DialogState(Enum):
    GREETING = "greeting"
    INTENT_RECOGNITION = "intent_recognition"
    COLLECTING_DATA = "collecting_data"
    PROCESSING = "processing"
    CONFIRMATION = "confirmation"
    TRANSFER_TO_AGENT = "transfer_to_agent"
    FAREWELL = "farewell"

@dataclass
class CallSession:
    call_id: str
    phone_number: str
    state: DialogState = DialogState.GREETING
    intent: str = None
    collected: dict = None
    retry_count: int = 0
    max_retries: int = 3

    def should_transfer(self) -> bool:
        return (self.retry_count >= self.max_retries or
                self.intent in ["complaint", "complex_issue"])

Intent recognition с примерами

async def recognize_intent(user_text: str) -> dict:
    response = await client.chat.completions.create(
        model="gpt-4o-mini",
        messages=[{
            "role": "system",
            "content": """Определи намерение клиента. Верни JSON:
            {"intent": "order_status|change_address|cancel_order|complaint|other",
             "entities": {"order_id": "...", "address": "..."}}"""
        }, {
            "role": "user",
            "content": user_text
        }],
        response_format={"type": "json_object"}
    )
    return json.loads(response.choices[0].message.content)

Условия эскалации на оператора

ESCALATION_TRIGGERS = [
    "оператор", "живой человек", "соедините с человеком",
    "не понимаете", "бесполезный", "жалоба", "претензия",
    "верните деньги", "суд", "роспотребнадзор"
]

def should_escalate(text: str, session: CallSession) -> bool:
    text_lower = text.lower()
    if any(trigger in text_lower for trigger in ESCALATION_TRIGGERS):
        return True
    if session.retry_count >= 2:
        return True
    return False

Интеграция с CRM

async def lookup_customer(phone: str) -> dict | None:
    # Запрос в CRM (Bitrix24, amoCRM, Salesforce)
    async with aiohttp.ClientSession() as session:
        resp = await session.get(
            f"{CRM_API_URL}/contacts/search",
            params={"phone": phone},
            headers={"Authorization": f"Bearer {CRM_TOKEN}"}
        )
        data = await resp.json()
        return data.get("contact")

Сроки: MVP с 3–5 сценариями — 4–6 недель. Полная система с аналитикой и A/B тестами — 3–4 месяца.