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

推荐订阅源

Engineering at Meta
Engineering at Meta
Help Net Security
Help Net Security
Blog — PlanetScale
Blog — PlanetScale
B
Blog RSS Feed
Recent Announcements
Recent Announcements
云风的 BLOG
云风的 BLOG
P
Proofpoint News Feed
阮一峰的网络日志
阮一峰的网络日志
MyScale Blog
MyScale Blog
WordPress大学
WordPress大学
M
MIT News - Artificial intelligence
L
LangChain Blog
J
Java Code Geeks
罗磊的独立博客
雷峰网
雷峰网
Microsoft Security Blog
Microsoft Security Blog
Microsoft Azure Blog
Microsoft Azure Blog
H
Help Net Security
Martin Fowler
Martin Fowler
Google DeepMind News
Google DeepMind News
博客园 - 聂微东
F
Full Disclosure
博客园 - 叶小钗
爱范儿
爱范儿
人人都是产品经理
人人都是产品经理
博客园 - 司徒正美
Hugging Face - Blog
Hugging Face - Blog
量子位
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
小众软件
小众软件
D
Docker
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
V
Visual Studio Blog
Last Week in AI
Last Week in AI
The Cloudflare Blog
MongoDB | Blog
MongoDB | Blog
T
The Blog of Author Tim Ferriss
H
Hackread – Cybersecurity News, Data Breaches, AI and More
V
V2EX
月光博客
月光博客
T
Tailwind CSS Blog
Vercel News
Vercel News
T
Threatpost
IT之家
IT之家
Simon Willison's Weblog
Simon Willison's Weblog
C
CXSECURITY Database RSS Feed - CXSecurity.com
GbyAI
GbyAI
NISL@THU
NISL@THU
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
博客园_首页

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

Ловим музу за клавиатуру: как айтишнику стать автором Что умеет Midjourney в 2026? Мой немного грустный разбор этого шикарного инструмента Никто не любит писать тесты, но ИИ может исправить это IPv8 выглядит как мечта. Поэтому почти наверняка не взлетит Производители вернули в продажу материнки с DDR3. Что происходит? Управление агентом с телефона через Telegram теперь в KodaCode От координации к лидерству: как меняется роль руководителя разработки Я сделала родителям бизнес вместо пенсии: зарабатываем 70 тысяч, мама не даёт продать В три раза быстрее приемка товара и оптимизация трудозатрат на 73%: как «РСТ-Инвент» помог Gulliver Group ИИ-шечный мир победил? О влиянии искусственного интеллекта на игропром Кремль снижает давление на Телеграмм пока Европа строит интернет по паспорту Как CEO, CTO и CIO за 8 часов собрали ИИ-директора, который умеет держать позицию под давлением Как (не) потерять домен за выходные Вместо 8 разных VPS: как я организовал практику студентам на одном сервере Почему твой Open Source проект не замечают? R&D: искусство управления неопределенностью в разработке AI-дефляция: вакансий для разработчиков больше, а рост зарплат — худший за 15 лет Мы отдали управление роботами OpenClaw. Что из этого вышло Галактический ID: система идентификации для всех форм разумной жизни Шесть основ бизнес-анализа: начинаем с вопроса «Кто в игре?» Код-ревью, в котором дело не в коде Данные переехали. Команда — нет Системной подход к сдаче OSWE в 2025 Почему комната управления реактором покрашена в цвет морской пены 4 YAML-файла вместо PySpark: как аналитикам строить пайплайны без разработчиков LLM-агент для поиска свободных доменов: автоматизируем подбор Когда, зачем и как правильно начинать новую сессию в Claude Code? Как я заставил нейросеть писать макросы для FreeCAD Анатомия ИИ‑агента для подбора персонала. От тысячи резюме к топ‑10 за минуты Опыт разработчика как экономика внимания Автономность как точка невозврата: кто будет субъектом в цифровом будущем Обучение ИИ в «диких» условиях: как рутинные действия превращаются в датасеты Как измерить LLM для задач кибербеза: обзор открытых бенчмарков Где хранить код? Сравнение GitHub, GitLab и Bitbucket Математика объясняет, почему нормальное распределение встречается повсюду Почему ваш FinOps не работает: 12 тезисов от практиков Как подписать проектную документацию УКЭП с использованием бесплатных лицензий Pilot Адаптивное администрирование Sigla Vision Я грузил уран в бочки, а потом 20 лет строил ИТ в атомной отрасли Чем позвонить с Эвереста? История и обзор спутниковой связи. Часть 2 Как языковая модель помогает контролировать качество инструктажей по охране труда в металлургии Как не передать на desktop свой IP в РКН Анатомия SAP Privileges: как устроено управление правами в macOS MoneyDev: Сказка про три главных слова Обновлённый токенизатор видео K-VAE 2.0 от Сбера Как сделать диспетчеризацию дома на 1284 квартиры почти бесплатно Как мы разогнали железную дорогу Мы дали агентам рутину. Теперь надо решить — что делать с освободившимся временем Токсичный контент, промпт-хакинг и защита ИИ — всё о Guardrails для LLM Умный город начинается с точного взгляда: как «Фалькон Тех» меняет пространство к лучшему Навайбкодил приложение для анализа графов Почему Дюну так интересно читать? Упрощаем работу с рутиной или как стать Гендальфом Белым Деконструкция Go: CPU, RAM и что там происходит. Go Assembler база. Часть 1.1 Какие профессии исчезнут из-за ИИ, а какие появятся? И что с этим делать Как мы построили IT-отдел, где хочется расти: архитектурные встречи, прозрачные метрики и книжные подарки Rufler: Делаем из Claude Code автономный рой через один YAML-конфиг Sing-box и белый список приложений Как построить надёжный обмен сообщениями в микросервисах: лучшие практики для enterprise OpenAI строит MLM-пирамиду, а McKinsey и Accenture помогают ей в этом Дом, который не построил Фишер (Часть 2) «Сверхзвуковой математик» против «Вдумчивого логиста»: битва алгоритмов 3D-упаковки Мультимодальные модели – грубый и дорогой инструмент Разговоры ничего не стоят. Код тоже Проверки физических лиц: с кого начнет ФНС Топ-10 бесплатных нейросетей для создания видео в 2026 году Первые слои кода: как наши решения сегодня определяют архитектуру ИИ на десятилетия Разработка нового статического анализатора: PVS-Studio JavaScript Поиск уязвимостей ПО: базовый минимум или роскошный максимум Почему оценка персонала не работает как инструмент управления Как мы разработали ИИ-ассистента и сократили рутину продуктовой команды на 50% Как я ушел из найма, нажарил косточек и продал на маркетплейсах на 168 млн в год Когда 1С:ERP уже внедрена, а нормального производственного плана всё ещё нет Как я сделал Claude мультимодальным, подключив к нему Qwen Omni Как приглашение на вакансию мечты превращается в атаку Infrastructure as Code: философия и лучшие практики IaC Тестируем Yandex Code Assistant на задаче, в которой нужно хранить секреты nxs-universal-chart v3.0: новое поколение универсального Helm-чарта Callback Injection: Техника, которая отправила Microsoft Defender в глухой нокаут «Все идеи на стол»: митап как способ вывести проект из тупика Сегодня я узнал нечто новое о GPU благодаря багу в своей игре Как заставить LLM ̶ ̶г̶а̶л̶л̶ю̶ ̶ эволюционировать Карта событий как фундамент аналитики: практический кейс для E-commerce Что выбрать для AI: x86, ARM или RISC-V? Дайджест железа за март Роль соматических мутаций в развитии аутоиммунных заболеваний: путь к избирательной терапии Mythos от Anthropic — тревожный сигнал для всех, а не только для банков Guardrails для LLM на Java: как приручить промпт‑инъекции и токсичные ответы Green-VLA: как мы собрали VLA-модель для реального антропоморфного робота и не потеряли обобщение Финансовая гонка вооружений: почему умные люди добровольно в ней участвуют Эра ИИ-агентов наступила: выбираем лучшего цифрового сотрудника # Практический опыт внедрения WinCC Redundancy на производственном предприятии Сделал MVP за 3 дня, а потом неделю прикручивал оплату. Оно того стоило? Физика против Маска: почему Starship V3 может оказаться ещё одной катастрофой Нефть Венесуэлы: крупнейшие запасы в мире, но не крупнейшая нефтяная держава JPA 4. Переосмысление Hibernate Почему зеркальная фотокамера Nikon D5 десятилетней давности идеально подошла для миссии «Артемида-2» Проект «Уровень-Спутник» или как мы сделали платформу для гидрологов «Замедлиться, чтобы ускориться»: почему ИИ повышает цену ошибок в требованиях и архитектуре Как с нуля поднять трафик IT-компании на 1657% при бюджете 55 тыс. и выжить Pixel-perfect Downsampling — идеальная отрисовка 50 миллионов точек без потерь
Добраться до центра
Вадим Башуров · 2026-06-15 · via Все публикации подряд на Хабре

Добраться до центра

Средний

5 мин

723

В прошлой жизни я опубликовал «Вариационные подходы к проблеме безопасности».

Суть идеи. Допустим, что вы злоумышленник, который хочет пробраться в Центр, но рискует быть обнаруженным охранниками, видеокамерами, локаторами. радарами и даже случайными прохожими. И вам на помощь приходит теория геометрической оптики.

Получается удивительная аналогия с распространением света в оптически неоднородной среде:

  • свет ищет путь минимального времени;

  • нарушитель ищет путь минимального риска.

Математика оказывается одной и той же.

От вероятности обнаружения к геометрической оптике

Пусть в каждой точке трёхмерного пространства

[\mathbf r=(x,y,z)]

задана вероятность обнаружения злоумышленника

[p(\mathbf r)]

Например, эта вероятность может зависеть от расположения охраны, датчиков движения, освещённости, рельефа местности и прочего.

Злоумышленник движется по некоторой траектории (\Gamma), разбитой на множество малых участков.

Вероятность остаться незамеченным на одном участке равна

[1-p_i]

Тогда вероятность пройти весь маршрут без обнаружения определяется произведением

[P_{safe}(\Gamma)=\prod_i (1-p_i)]

Работать с произведениями неудобно, поэтому перейдём к логарифму:

[-\ln P_{safe}(\Gamma)=-\sum_i \ln(1-p_i)]

В пределе получаем интеграл вдоль траектории

[R(\Gamma)=\int_\Gamma-\ln(1-p(\mathbf r))ds]

Функционал (R(\Gamma)) можно интерпретировать как накопленный риск обнаружения.

Наиболее безопасный маршрут соответствует условию

[R(\Gamma)\rightarrow \min]

Теперь сравним это выражение с принципом Ферма из геометрической оптики.

Согласно этому принципу луч света распространяется по траектории, минимизирующей оптическую длину пути

[\int_\Gamma n(\mathbf r)ds ]

где (n(\mathbf r)) — показатель преломления среды.

Сравнивая оба функционала, получаем естественное соответствие

[n(\mathbf r)=-\ln(1-p(\mathbf r))]

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

Области с высокой вероятностью обнаружения превращаются в области с большим показателем преломления, а безопасные зоны — в области с малым показателем преломления.

Оптимальный маршрут злоумышленника - путь светового луча

После такого преобразования задача поиска маршрута минимального риска становится эквивалентна задаче поиска траектории светового луча в неоднородной среде.

Это позволяет использовать хорошо известный аппарат вычислительной оптики, включая уравнение эйконала, Fast Marching Method и другие методы распространения волнового фронта.

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

[n(\mathbf r)=-\ln(1-p(\mathbf r))]

Именно эта идея легла в основу дальнейших экспериментов с картами городов и системами видеонаблюдения.

Поиск маршрута: от A* к распространению волны

После построения карты проницаемости метод A* выглядит вполне естественно. Каждому пикселю можно сопоставить стоимость прохождения

[cost=\frac{ds}{v(\mathbf r)}]

где (v(\mathbf r)) — локальная скорость распространения.

Белые области проходятся быстро, тёмные медленно, чёрные становятся практически непроходимыми.

Но соответствует ли это исходной физической модели?

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

Поэтому следующим шагом было отказаться от поиска маршрута как такового и вместо этого моделировать распространение волнового фронта.

Представим горный склон после сильного дождя.

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

Часть потока пойдёт быстрее.

Часть медленнее.

Где-то вода упрётся в препятствие.

Где-то найдёт обходной путь.

Через некоторое время каждая точка поверхности будет знать минимальное время, за которое до неё может добраться вода.

Именно эту идею мы используем для поиска маршрута.

В стартовой точке создаётся волновой фронт.

Далее он распространяется по карте со скоростью

[v(\mathbf r)]

В результате для каждой точки пространства вычисляется функция

[T(\mathbf r)]

которая показывает минимальное время достижения этой точки.

После завершения расчёта никакого маршрута ещё нет.

Есть только поле времён распространения.

На рисунке ниже его удобно представить как карту высот.

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

Высокие значения — областям, до которых волна добирается быстро.

Карта объета для злоумышленника

Карта объета для злоумышленника

Теперь начинается самая интересная часть.

Чтобы построить оптимальный маршрут из точки B в точку A, достаточно двигаться в направлении наибольшего уменьшения функции (T).

Или, если использовать физическую аналогию, бросить шарик на получившийся рельеф.

Шарик сам скатится в стартовую точку по траектории минимального времени.

Математически это соответствует движению по антиградиенту поля

[\frac{d\mathbf r}{ds}=-\nabla T(\mathbf r)]

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

Никакого специального алгоритма поиска пути больше не требуется.

Фактически задача поиска маршрута заменяется двумя значительно более физичными этапами:

  1. Распространить волновой фронт по всей области.

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

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

Почему Corona SDK (Solar2D)

Несмотря на то что задача выглядит достаточно математической, для реализации прототипа я использовал не Python и не MATLAB, а игровой движок Solar2D (бывший Corona SDK).

Причин было несколько.

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

Во-вторых, Lua остаётся одним из самых простых языков для быстрого создания подобных экспериментальных моделей.

И вообще, последние 10 лет я пишу игрушки только на Короне и не знаю других)

В моём прототипе карта хранится как обычное изображение в градациях серого размером 2048×2048 пикселей. После загрузки PNG-файл преобразуется в массив коэффициентов проницаемости

[v(x,y)\in[0,1]]

Каждый пиксель становится элементом вычислительной сетки.

Светлые области соответствуют высокой проходимости, тёмные — низкой.

Для ускорения расчётов карта сохраняется в формате PGM и загружается непосредственно в память как двумерный массив.

После этого выполняются три основных этапа:

  1. Построение поля проницаемости среды.

  2. Распространение волнового фронта от стартовой точки.

  3. Восстановление оптимальной траектории по градиенту поля времени.

С точки зрения программирования наиболее интересен второй этап.

Вместо перебора маршрутов строится поле минимальных времён достижения

[T(x,y)]

После вычисления поля (T(x,y)) маршрут восстанавливается очень просто. Из конечной точки выполняется движение по направлению максимального уменьшения функции времени, то есть по антиградиенту поля.

Отдельный модуль реализует систему видеонаблюдения.

Каждый радар добавляется интерактивно обычным касанием экрана. Для радаров рассчитывается область прямой видимости (Line Of Sight), учитывающая здания и другие непрозрачные препятствия. Далее строится дополнительное поле наблюдаемости

[C(x,y)]

в котором вклад каждой камеры уменьшается пропорционально квадрату расстояния

[C(r)\sim \frac{1}{r^2}]

Полученная карта наблюдаемости объединяется с исходной картой проницаемости, после чего выполняется повторный расчёт маршрута.

В результате на одном экране можно одновременно наблюдать:

  • карту местности;

  • расположение камер;

  • зоны наблюдения;

  • оптимальный маршрут без учёта наблюдения;

  • оптимальный маршрут с учётом наблюдения.

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

Модельные расчеты

Возьмем двухмерную (у трехмерной гриф СС) картинку без радаров и построим маршрут злоумышленника

Желтый маршрут - путь злоумышленника

Желтый маршрут - путь злоумышленника

Теперь добавим несколько радаров (СБ не лыком шита и знает теперь где перекрыть)

Новый желтый маршрут для злоумышленника

Новый желтый маршрут для злоумышленника

Вы снова нашли уязвимость? Поставим еще несколько камер

Новый маршрут злоумышленника после установки 50 камер наблюдения

Новый маршрут злоумышленника после установки 50 камер наблюдения

Ну и так можно баловаться до бесконечности выявляя новые уязвимости и защищая их.

Злоумышленник не сдается - нашел новый путь

Злоумышленник не сдается - нашел новый путь

Выводы

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

(с) Написана ИИ при поддержке автора