Предыстория

Представьте: вы в офисе, срабатывает пожарная сигнализация. Что вы делаете?

Идёте к эвакуационному плану на стене? Пытаетесь вспомнить, что показывали на последнем инструктаже? Или просто идёте за толпой, надеясь, что все знают, куда бежать?

Наша команда столкнулись с этим вопросом, когда начала работать над проектом для «Просоюза», профсоюзной организации «Сбера». Задача звучала просто: «Помочь людям не растеряться в чрезвычайной ситуации». Но когда мы начали погружаться в тему, оказалось, что не всё так однозначно.

Как это работает сейчас?

В «Сбере», как и в любой крупной организации, существуют мероприятия подготовки к чрезвычайным ситуациям (ЧС):

  • Сотрудники изучают нормативные документы и инструкции, проходят инструктажи и слушают лекции;

  • Сотрудники проходят тестирование для закрепления теоретических знаний;

  • Проводятся тренировки и учения, во время которых возможно получить практические навыки.

Однако ни одно из мероприятий не гарантирует того, что во время реальной ситуации человек вспомнит, как правильно действовать в той или иной ситуации, когда время идёт на секунды, а интернет и сотовая связь могут не работать.

Наше представление

Вместе с экспертами из «Просоюза» мы пришли к решению — разработать сервис, который станет помощником для человека в беде.

Должны быть реализованы следующие возможности:

  • Сотрудники могут получить пошаговую инструкцию (из официальной базы МЧС или внутренних документов), которая адаптирована под конкретную ситуацию;

  • При отсутствии связи и интернета сотрудники могут связаться друг с другом, чтобы скооперироваться, или получить сообщение от лица, ответственного за ГО и ЧС в организации;

  • Сотрудники могут проходить тесты на знание действий при ЧС и отслеживать свой прогресс.

Таким образом, ИИ‑агент «Спасатель» — корпоративный ИИ‑помощник с инструкциями МЧС, который позволяет закреплять знания через тесты и обмениваться сигналами с коллегами через локальную mesh‑сеть на базе Bluetooth и Wi‑Fi, не завися от интернета и сотовой связи.

В данной статье хотелось бы рассказать о том, как работает наш сервис при наличии и отсутствии интернета.

Способы взаимодействия

Мы хотели, чтобы решение было максимально доступным, но при этом учитывало технические ограничения разных платформ. Поэтому «ИИ‑Агент Спасатель» реализован в двух форматах.

Веб‑приложение (PWA). Онлайн‑режим

Данный способ подойдет для быстрого старта, он доступен на любом устройстве и не требует установки.

Режим работы: только онлайн.

Технологии: Python, Litestar, Docker, PostgreSQL, GigaChat, Bootstrap, Vite, TypeScript, Vue.

Интерфейс PWA

На изображении представлен интерфейс главного меню нашего PWA.

Главное меню с выбором режима
Главное меню с выбором режима

Генерация инструкций

Пользователь может получить понятную инструкцию по запросу. Для этого ему нужно нажать на кнопку «Что делать при ЧС?».

Выбор режима с генерацией инструкции
Выбор режима с генерацией инструкции

Итак, как же работает генерация? Разберем подробнее.

Превращаем вопрос в вектор

Когда пользователь отправляет запрос, система не работает с текстом напрямую. Вместо этого она превращает вопрос в эмбеддинг — вектор, который можно представить в виде координат в многомерном пространстве.

Простая аналогия: представьте, что каждый вопрос — это поиск книги в огромной библиотеке. Но вместо того, чтобы искать по названию, мы присваиваем каждой книге координаты на карте. Вопросы со схожим смыслом оказываются рядом на этой карте, даже если сформулированы разными словами. Например, «Горит офис» и «Задымление в помещении» — разные фразы, но их векторы будут находиться близко друг к другу, потому что смысл одинаковый.

Ищем ближайшую инструкцию в базе МЧС

В нашей RAG‑базе заранее подготовлены инструкции от МЧС и внутренние документы. Каждая из них тоже превращена в вектор и сохранена в базе данных.

Система берёт вектор вопроса пользователя и мгновенно сравнивает его со всеми векторами в базе. Алгоритм находит те инструкции, которые находятся «ближе всего» по смыслу (зачастую это топ-3 наиболее релевантных фрагмента).

Важный момент: поиск идёт не по ключевым словам, а по смыслу. Поэтому, если пользователь напишет «задымило в серваке» (сленг), система всё равно найдёт инструкцию про «возгорание электрооборудования в серверном помещении» (официальный язык МЧС).

Передаём найденное в LLM для «перевода» на человеческий

На этом этапе у системы есть всё необходимое: исходный вопрос пользователя и 3–4 наиболее подходящих фрагмента из официальных инструкций. Но сами по себе инструкции МЧС написаны сложным канцелярским языком — они не подходят для чтения в панике.

Здесь в работу вступает GigaChat. Мы передаём модели:

  • Найденные фрагменты инструкций из базы;

  • Системный промпт — набор правил, которые говорят ИИ, как отвечать (кратко, по шагам, без вежливости, с акцентом на безопасность);

  • Вопрос пользователя.

Модель не придумывает ответ с нуля, она адаптирует проверенную инструкцию под конкретную ситуацию. В результате получается пошаговый чек‑лист, который можно выполнить за секунды.

Что если в базе ничего похожего нет?

Иногда бывает, что запрос пользователя не находит близких совпадений в базе. Например, произошла нестандартная ситуация или вопрос сформулирован слишком размыто.

В этом случае система не молчит и не выдаёт ошибку. Она честно сообщает пользователю, что точной инструкции не найдено, но при этом:

  • Даёт общие рекомендации по безопасности из системного промпта;

  • Настоятельно рекомендует позвонить в экстренные службы (112);

  • Предлагает связаться с ответственным лицом в организации.

Лучше дать осторожный общий совет и направить к профессионалам, чем сгенерировать потенциально вредную «галлюцинацию».

Ответ пользователю

Готовая инструкция возвращается пользователю текстом в интерфейс PWA или в мобильное приложение. Всё это занимает 1–3 секунды, что критически важно в чрезвычайной ситуации.

Тесты для закрепления знаний

Чтобы воспользоваться тестами, пользователю предлагается зарегистрироваться.

Страница с регистрацией
Страница с регистрацией

Регистрация нужна для того, чтобы администратор мог назначить роль пользователю. В зависимости от роли меняется перечень доступных тестов. Например, офисному работнику тест на знание поведения при нападении на инкассаторскую машину не нужен.

Сами тесты удобно выделяются в верхней части экрана, сразу можно увидеть, сколько правильных ответов было выбрано.

Тесты для закрепления знаний
Тесты для закрепления знаний

Приложение для смартфона. Офлайн‑режим

Теперь разберёмся, что происходит, когда пользователь оказывается в зоне без интернета? например, в подвале, бомбоубежище или при отключении вышек сотовой связи. Как система продолжает работать?

Приложение на текущий момент доступно только на Android.

Режим работы: онлайн (аналогично PWA) или офлайн.

Технологии: Flutter, Qwen 0.5b, llamadart, flutter_mesh_network

Интерфейс приложения

Интерфейс приложения показан на рисунке ниже.

Интерфейс мобильного приложения
Интерфейс мобильного приложения

Генерация инструкций

Разберем, как работает генерация инструкций при отсутствии связи.

Загрузка локальных ресурсов

При первом запуске приложения устанавливается локальная ИИ‑модель Qwen 0.5b — компактная нейросеть, которая помещается в памяти телефона и может работать без подключения к серверу. Она не такая мощная, как облачный GigaChat, но для базовых задач её достаточно.

Автономная работа: ИИ без облака

Когда интернет пропадает, приложение автоматически переключается в офлайн‑режим. Пользователь видит соответствующее уведомление.

Теперь все запросы обрабатываются локально на устройстве: пользователь пишет вопрос, локальная модель ищет ответ в закэшированных инструкциях, ответ формируется по тем же правилам, что и в онлайн‑режиме.

Скорость ответа будет зависеть от технических характеристик устройства пользователя.

Также локальная модель не умеет работать со сложными контекстами и нестандартными ситуациями. Поэтому для редких сценариев она честно предупреждает об этом и предлагает в любом случае связаться с ответственными людьми.

Общение без интернета, mesh‑сеть

Самая интересная часть офлайн‑режима — возможность общаться с другими сотрудниками без интернета. Для этого используется технология mesh‑сети. Он доступен, если нажать на кнопку «Сообщить о проблеме».

Mesh-режим
Mesh‑режим
  • При первом включении mesh‑режима пользователь вводит своё имя и отдел (например, «Алексей, IT‑отдел»). Эти данные сохраняются на устройстве и становятся его «идентификатором» в локальной сети;

  • Телефон через Bluetooth сканирует пространство и находит другие устройства с запущенным приложением в радиусе до 15 метров

  • Теперь можно отправить сообщение конкретному человеку или всем устройствам поблизости

Каждый телефон становится маленькой радиостанцией. Сигнал не идёт через вышку оператора — он «перепрыгивает» напрямую с устройства на устройство

Возможность отправить сообщение устройствам поблизости
Возможность отправить сообщение устройствам поблизости

Как сигнал доходит дальше?

Что делать, если нужный человек находится не рядом, а за углом или на другом этаже? Здесь включается механизм ретрансляции.

Сообщение не обязательно летит напрямую от отправителя к получателю. Оно может пройти через несколько промежуточных устройств:

  • Пользователь 1 пишет сообщение Пользователю 2;

  • Прямой связи нет — Пользователь 2 слишком далеко;

  • Но между ними стоит Пользователь 3, чей телефон ловит сигнал от обоих;

  • Сообщение прыгает: Пользователь 1 → Пользователь 3 → Пользователь 2.

Всё это происходит автоматически. Пользователи даже не знают, что их телефон стал ретранслятором для чужого сообщения. Чем больше людей с приложением поблизости, тем устойчивее сеть. В критической ситуации ответственное лицо может отправить широковещательное сообщение на все устройства в радиусе действия.

Заключение

Важный вопрос, который мы задали себе во время работы: «Что будет, когда в чрезвычайной ситуации пропадёт связь?»

Ответ оказался неутешительным: большинство современных решений по безопасности бесполезны без интернета. Памятки на стенах могут быть пропущены в панике, анкеты и тесты «для галочки» не закрепляют знания, а обычные LLM молчат, когда вышки сотовой связи перегружены или связи нет вовсе.

За несколько месяцев студенческой разработки мы создали работающий прототип системы, которая:

  • Даёт проверенные инструкции на основе официальных документов МЧС через RAG‑архитектуру, без галлюцинаций ИИ;

  • Работает без интернета за счёт локальной модели и кэшированных инструкций;

  • Связывает людей без инфраструктуры при помощи mesh‑сети, превращая телефоны сотрудников в некоторое подобие раций;

  • Готовит заранее к экстренным ситуациям благодаря возможности пройти интерактивные тесты;

  • Масштабируется, ведь чем больше людей использует систему, тем устойчивее сеть.

Выражаем благодарность «Просоюзу Сбера» за возможность реализовать проект на реальной площадке и экспертную поддержку. Спасибо специалистам по охране труда и пожарной безопасности за помощь в верификации инструкций без вас система не была бы столь надёжной.

Отдельное спасибо сообществу Habr за вдохновение, ведь многие технические решения мы подсмотрели в ваших статьях!

Приглашаем к обсуждению!

Мы — студенческая команда и понимаем, что первое решение не бывает идеальным. Если у вас есть опыт в разработке mesh‑сетей, интеграции с системами безопасности предприятий, или вы просто видите ошибки в нашей архитектуре, пишите в комментариях! Будем рады конструктивной критике, советам и вопросам.

Комментарии (16)


  1. PechoraDev
    23.05.2026 07:41

    У МЧС есть такой ежегодный конкурс - Есть идея. Поучаствуйте, есть шанс выиграть, получите вознаграждение за это


  1. YMA
    23.05.2026 07:41

    Представьте: вы в офисе, срабатывает пожарная сигнализация. Что вы делаете?

    Идёте к эвакуационному плану на стене? Пытаетесь вспомнить, что показывали на последнем инструктаже? Или просто идёте за толпой, надеясь, что все знают, куда бежать?

    Нет, спокойно достаю телефон, запускаю приложение и спрашиваю у ИИ - что делать? ;)))

    Вообще, для этого есть учебные тревоги - у нас в офисе регулярно, раз в квартал примерно - включается сирена, и железная тетка объявляет о необходимости покинуть здание. Все уже наизусть знают, где кому надо спускаться, на лестницах включается воздушный подпор, и по выходу из здания все подразделения не толкутся рядом под падающими стеклами - а расходятся по своим определенным заранее местам, где сотрудники пересчитываются и ответственный подтверждает, что все, кто пришел сегодня на работу - покинули здание.

    На случай же ядерной атаки все и так знают, что бежать есть смысл только в сторону метро, которое закроется через 10 минут после начала тревоги. От нас успеть добежать в принципе можно, если не тратить время на открытие приложения и чтение указаний ИИ. ;)

    А вот это, что в статье - чисто сберовская показуха типа Друга и прочих.

    Теперь разберёмся, что происходит, когда пользователь оказывается в зоне без интернета? например, в подвале, бомбоубежище или при отключении вышек сотовой связи

    И в подвале, бомбоубежище - bluetooth с Wifi позволят общаться только с соседями по помещению, для чего в принципе и голоса вполне хватит. ;) Наружу ничего не уйдет, если дверь убежища не открыта нараспашку и там не стоит ретранслирующий сотрудник, вдыхая радиоактивную пыль.

    И в приложении нет пары главных вещей - фонарика :) и громкой автоматической пищалки, которая в случае ЧС включается автоматом и раз в минуту, если не отключить вручную, на максимальной громкости пищит SOS.


    1. xSVPx
      23.05.2026 07:41

      Ну вот кстати пищалка вещь может и неплохая бы была. Чтоб из под завалов проще было извлекать. Еще моргать фонариком можно. Кстати и вибро нелишне, думаю на него можно и собаку натренировать и какую-нибудь механику простую с микрофоном итп. И желательно как-то не тупо пищать, а подавать сигналы по которым можно будет понять сколько вас там.... лежит.

      А читать во время пожара инструкции.... Не во время землетрясения хоть и то спасибо.

      Чатботы не могут заменить тренировки. Это в чем-то вредная и опасная штука. Создает впечатление защищенности там, где ее нет.

      "Нахрена мне участвовать в учениях - потом прочитаю если будет надо..."


      1. xSVPx
        23.05.2026 07:41

        Я, наконец понял, что не сразу понял :).

        Вся идея заменить муштру информационным ботом порочна до основания. Когда землетрясение, у человека есть 2-3 секунды от момента как запищал телефон, чтобы спасти свою жизнь. Или ты сделал шаг вбок, или всё. В пожаре немножко больше. Но читать и разбираться некогда, ты должен делать то, на что УЖЕ натренирован. Ты должен знать где двери, в какую сторону они открываются, куда двигаться, какие наощупь ручки итд итп. В состоянии, когда вокруг "кровь, кишки и дым" даже имея тренировку выбираются совершенно не все. Это тот момент, когда надо не мозгом скрипеть и чатиться, а натренированными рефлексами очень быстро действовать. Мозг лучше бы зачастую отключить, собственно адреналин это и делает...

        А вот это вот всё вам даже при каком-нибудь крушении типа титаника или коста конкордиа вряд ли поможет(ситуация развивается относительно медленно и есть несколько часов времени). А при случае таких советов надаёт...


        1. nitro80
          23.05.2026 07:41

          Когда землетрясение, у человека есть 2-3 секунды от момента как запищал телефон, чтобы спасти свою жизнь

          А зачем ему пищать?


          1. YMA
            23.05.2026 07:41

            Это в случае, если есть система оповещения.

            Да и времени может быть побольше, уже упоминал про ситуацию во время землетрясения в Горном Алтае - во время повторных толчков разговаривал с коллегой в Горном по телефону, и он сказал, что их опять трясет. Так за то время, что импульс шел от Горного до Барнаула (а скорость у него 4-6 км/сек), мы успели много чего ;)


            1. nitro80
              23.05.2026 07:41

              У нас на Камчатке оповещения вообще не приходят.

              А когда 30 июля 2025 года жмыхуло 8.8 баллов, то и связь мобильная некоторое время не работала.

              Впрочем, в последующие толчки смс от МЧС проходили с очень сильным запозданием.


              1. xSVPx
                23.05.2026 07:41

                Смс это не то.

                Во многих странах андройд как минимум с гуглом умеют использовать все сотовые как сеть автоматически обнаруживающую землетрясения и мгновенно оповещающую всех окружающих. Если ты не в самом эпицентре есть время пока ударная волна до тебя дойдет. Если землятресение начинается с небольших толчков - тоже.

                Но для камчатки это, наверное нерелевантно, народу маловато. А вот в японии по отзывам работает.


                1. nitro80
                  23.05.2026 07:41

                  Во многих странах андройд как минимум с гуглом умеют использовать все сотовые как сеть автоматически обнаруживающую землетрясения и мгновенно оповещающую всех окружающих.

                  Я читал про это, но только про эксперименты.
                  Про то, что Google ввели в эксплуатацию - не попадалось.


          1. xSVPx
            23.05.2026 07:41

            Чтобы ты остался жив. Если ты не очень близко к эпицентру он пищит до землетрясения в твоей точке.


            1. nitro80
              23.05.2026 07:41

              Этих 2-3 секунды мне хватит только встать и обуться )))
              Если я побегу на улицу - как раз успею к окончанию толчков )


              1. xSVPx
                23.05.2026 07:41

                Тебе - да.

                Нормальному человеку в некоторых ситуациях хватит, чтобы остаться в живых или минимизировать травмы и вообще проблемы. В других ситуациях основной толчок бывает после предварительных и с довольно большой задержкой. Вещь совершенно небесполезная в густо населенных сейсмоопасных районах. Ну т.е. есть отчеты от людей, которым пригодилось.


                1. nitro80
                  23.05.2026 07:41

                  Ага, расскажите мне про землетрясения )))


              1. YMA
                23.05.2026 07:41

                Можно успеть встать в дверном проеме, если здание панельное или монолит - есть шансы сохранить приличное состояние своего тела к моменту разбора завалов. ;)


  1. skwo73
    23.05.2026 07:41

    странный проект для профсоюзной организации. похоже мало профсоюз сбера изменился с тех времен, когда я работал...


  1. NutsUnderline
    23.05.2026 07:41

    срабатывает пожарная сигнализация. Что вы делаете?

    Сижу ровно. Пока кто нить не проверит что это действительно где то дымом запахло и очередной дурацкий датчик глюкнул или очередной ... решил покурить в неположенном месте.