惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Apple Machine Learning Research
Apple Machine Learning Research
The GitHub Blog
The GitHub Blog
Hugging Face - Blog
Hugging Face - Blog
阮一峰的网络日志
阮一峰的网络日志
爱范儿
爱范儿
量子位
宝玉的分享
宝玉的分享
人人都是产品经理
人人都是产品经理
博客园_首页
博客园 - 【当耐特】
Last Week in AI
Last Week in AI
Martin Fowler
Martin Fowler
Microsoft Azure Blog
Microsoft Azure Blog
美团技术团队
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
aimingoo的专栏
aimingoo的专栏
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
GbyAI
GbyAI
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
腾讯CDC

Все публикации подряд на Хабре

Как я сократил рутину QA до пары кликов: генератор API-тестов и тест-кейсов на LLM, которым хочу поделиться QNAME minimisation на практике: RFC 7816, реализация, грабли Агенты, роботы и мы: как ИИ перекраивает рынок труда в Европе От боли к npm install: TDLib для React-Native, или как я делал проект, а получилась библиотека Написание консольного симулятора баттл-арены на языке С++ с реализацией «умных» ботов Очень много букв… Или кейс по специфической настройке рабочего окружения Segmentation Fault: как оно устроено? Python в enterprise: момент, когда пора открыть Java не только ради собеседований MonoGame — игровой движок для тех, кто любит изобретать велосипеды Спасти рядового Буридана Рефакторинг выпадающих списков: от enum к конфигу-константе Free Porn Storage: передаём мемы в TLS-трафике, не привлекая внимания санитаров Мониторинг цен на Авито: MikroTik RouterOS Script Венесуэльская нефть после января 2026 Разговоры с ИИ Хотел упростить мониторинг проектов и в отпуск — пришлось обучать свой LLM. Часть 4. Тестирование Как вытащить ИТ из кризиса перегрузки, если найм запрещён Как мы подключили LLM к поддержке, а получили идеального лжеца Zero — новый agent-first язык программирования от Vercel, который изменит все (нет) Запускаем рекламу в дачной нише: какие креативы и форматы работают, на что смотреть в аналитике Паттерны организационного дизайна: практическое руководство Почему алгоритмы сливают твой депозит? 3 причины, о которых молчат «успешные» бэктесты Как «спят» вкладки в браузере Приоритет задач определяется не только ощущением срочности [Перевод] Махинации с прибылью Anthropic Project Loom: Virtual Threads, Scoped Values и preview #7 Structured Concurrency Мнения математиков о том, как ИИ опроверг гипотезу Эрдёша Слабоумие и отвага: как я за выходные сделала прототип ИИ-помощника для UX-дизайнера ИИ учит нас писать лучше. Или хуже? Как проектировать ИИ-инструменты, которые делают пользователей лучше «Раньше хотел каждый, сейчас и бесплатно не надо»: гаджеты, про которые мы все забыли ИИ-агенты в бизнесе: почему 80% компаний увольняют людей, но не получают ROI Как я строил ИИ-стартап, или Новые архитектурные риски 2026 4 интересных парадокса, рождающих жаркие дискуссии Рабочее место не-вайбкодера: настраиваем harness Когнитивный инжиниринг Feature Based Clean Architecture. Часть 1: Эволюция NestJS-приложения в неподдерживаемое состояние Как мы перестали бояться «пустых охватов» и сделали инфлюенс-маркетинг управляемым каналом роста Подключили B2B email-платформу к голосовым ассистентам через MCP. Архитектура, код, где ломается [Перевод] Почему AI-агенты ломаются на длинных задачах — и как обвязка помогает им дописывать приложения Облачно, возможны нейросети: кризис датасетов и ахиллесова пята систем машинного зрения — DIY-чтение на выходные Спустя 5 лет и $5 миллионов: почему создание нового языка для веб-разработки оказалось ошибкой Безопасная песочница Облачная LLM на 16 ГБ VRAM — часть 2: LangGraph Server, LangSmith и SDK Современный SSH-клиент для MS-DOS Как продвигать агентство недвижимости: от вывески до прямых эфиров MCP для GitHub + GitLab: инженерный гайд 2026 Вы платите OpenAI $20 в месяц, а он зарабатывает на вас ещё $100 млн за полтора месяца. И это только начало ИИ забирает работу «белых воротничков»: чему учить детей, чтобы выжить в будущем Практический ИИ-агент Python: LangGraph + Qdrant Как я делал ping и traceroute на iOS без entitlements — и почему это оказалось проще, чем UMP-консент для AdMob 4 MVP за 4 месяца, 30 холодных DM, 1 регистрация: building in public по-русски VPS-бастион: доступ к домашнему серверу без белого IP Kampus AI — нейросеть для генерации учебных работ для студентов и школьников Игры, помогающие продавать — примеры интересных рекламных акций с видеоиграми €500 в Telegram Ads принесли сделку на 350 000 ₽. Разбор B2B-кампании Чтение на выходные: «Разработка игр и теория развлечений» Рафа Костера Личный архив: сбор, бэкап, таймлайн фотографий INFOSTART TECH EVENT или INFOSTART A&PM EVENT — как понять, куда вам нужнее? Peer testing на основе Закона Линуса Релиз GitLab 19.0: ИИ-оркестрация, которая наконец-то догнала темп написания кода Как бизнесу оценить готовность к аттестации по новому Приказу ФСТЭК № 117 Технический гайд по сторис – часть 4: как мы добавили видео формат Представительство в арбитражном процессе: правовые различия между внешним защитником и инхаусом «Где новые фичи?» — Как AI-миграция легаси вернет IT-бюджет бизнесу Что нужно знать работнику про увольнение Новые требования Москвы к ЦИМ для АГР: готовый инструмент для проектировщиков в nanoCAD BIM Строительство WireGuard: простота и надёжность современного VPN-туннеля или секретное рукопожатие в тёмной комнате Выйдет ли GTA 6 в 2026 году, и чего ждать от игры Как меня назвали «невовлечённым», а я нашёл офшоры на Кипре Как LLM научила рекомендательную модель видеть больше, чем историю взаимодействий От хаоса к экосистеме: Модель зрелости комьюнити в бизнесе Свет, тьма, VEML7700 и Python Сказ о том, как мы процессы разработки в GRI меняли. Часть 2 Майский «В тренде VM»: громкие уязвимости в Linux, ActiveMQ, SharePoint и Acrobat Reader Статический анализ, заряженный ИИ: как LLM ищут уязвимости в коде и где их границы Блок “Процессы” и почему мы называем его нашим мини-n8n Как поменялся рынок интернет-рекламы: сравнение первых кварталов 2025 и 2026 годов: исследование click.ru Мониторинг Kerio Connect через Zabbix 7: разбор шаблона без агентов и regex по DAT 671 Allow в Claude Code за день: как родился сетап Spec-build 3 известные интересные задачи на логику Как айтишнику позаботиться о менталке и не перерабатывать OpenAI vs Anthropic: битва экс-коллег за корпоративного клиента и $1 трлн на IPO SEO для интернет-магазина в 2026: что поменялось и как с этим работать Сможете ли вы спроектировать Maven‑монорепозиторий для 5 микросервисов? 6 неудобных вопросов про американское произношение, которые айтишники боятся задать Неожиданная встреча: теория графов вновь помогла решить проблему в анализе Фурье Иллюзия трансформации: почему компании платят за спектакль вместо изменений AMD представила Ryzen 9 PRO 9965X3D и еще 5 процессоров, которые пойдут далеко не всем История IDE в Google Первые отзывы на новинки о System Design Влияние параметра planner_upper_limit_estimation на планы выполнения и профиль нагрузки PostgreSQL при использовании 1C Границы 100% разработки с агентами Быстрый OCR на основе Paddle Дооснащение любительской электровакуумной мастерской. Вакуумметр, течеискатель, полярископ Mythos: модель, о которой Anthropic не говорит. Реверс по жертвам — от 27-летней дыры в OpenBSD до побега из песочницы Как использовать Qwen3.7-Max и Grok Build 0.1 для ИИ-агентов в России Suricata IPS NFQueue with nDPI. Часть VI Важные изменения в защите информации в России: что нового? В чем секрет достоверного замедления биологического старения?
ИИ‑спасатель в кармане: как мы сделали агента для помощи при ЧС, который работает без интернета
SinSab · 2026-05-23 · via Все публикации подряд на Хабре

ИИ‑спасатель в кармане: как мы сделали агента для помощи при ЧС, который работает без интернета

Уровень сложностиПростой

Время на прочтение8 мин

Охват и читатели710

Предыстория

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Таким образом, ИИ‑агент «Спасатель» — корпоративный ИИ‑помощник с инструкциями МЧС, который позволяет закреплять знания через тесты и обмениваться сигналами с коллегами через локальную 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‑сетей, интеграции с системами безопасности предприятий, или вы просто видите ошибки в нашей архитектуре, пишите в комментариях! Будем рады конструктивной критике, советам и вопросам.