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

推荐订阅源

Latest news
Latest news
T
The Blog of Author Tim Ferriss
T
Tailwind CSS Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Last Week in AI
Last Week in AI
Y
Y Combinator Blog
雷峰网
雷峰网
V
Visual Studio Blog
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Vercel News
Vercel News
博客园_首页
P
Palo Alto Networks Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Stack Overflow Blog
Stack Overflow Blog
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
N
News and Events Feed by Topic
博客园 - Franky
Webroot Blog
Webroot Blog
L
LINUX DO - 热门话题
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
G
GRAHAM CLULEY
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
H
Help Net Security
T
Threat Research - Cisco Blogs
AWS News Blog
AWS News Blog
WordPress大学
WordPress大学
N
News | PayPal Newsroom
Hugging Face - Blog
Hugging Face - Blog
小众软件
小众软件
Forbes - Security
Forbes - Security
The Cloudflare Blog
大猫的无限游戏
大猫的无限游戏
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
The Hacker News
The Hacker News
P
Proofpoint News Feed
D
Darknet – Hacking Tools, Hacker News & Cyber Security
C
Cisco Blogs
V
V2EX
Know Your Adversary
Know Your Adversary
博客园 - 三生石上(FineUI控件)
GbyAI
GbyAI
F
Full Disclosure
S
Securelist
O
OpenAI News
Jina AI
Jina AI
U
Unit 42
罗磊的独立博客
L
Lohrmann on Cybersecurity
H
Heimdal Security Blog
NISL@THU
NISL@THU

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

Ловим музу за клавиатуру: как айтишнику стать автором Что умеет 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 миллионов точек без потерь
Нейросетевой эквалайзер на PlutoSDR: от синтетики к железу
Даниил · 2026-06-17 · via Все публикации подряд на Хабре

Средний

4 мин

0

Зачем вообще трогать LMS

Любой реальный радиоканал «размазывает» символы во времени: соседние отсчёты накладываются друг на друга, и приёмник видит межсимвольную интерференцию (ISI). Классический способ с этим бороться — адаптивный фильтр LMS. Он прост, дёшев и хорошо работает, пока канал близок к линейному. Но это именно линейный фильтр: когда лучей несколько и у них разные фазы, одной линейной комбинацией отсчётов идеально восстановить символ уже не получается.

Отсюда идея, которую я и проверял: заменить (или дополнить) LMS компактной свёрточной сетью. Сеть смотрит не на один отсчёт, а на целое окно принятого сигнала и учится по нему обратному отображению канала — то есть восстанавливать исходную точку созвездия с учётом совместной статистики соседних символов. Сначала всё это обучается и сравнивается на синтетике, а потом проверяется на настоящем железе — модуле ADALM-PLUTO.

Как устроена модель

Эквалайзер — это одномерная свёрточная сеть (1D-CNN), в коде она называется legacy_big. На вход подаётся окно из 51 принятого отсчёта, разложенное на два канала — синфазную (I) и квадратурную (Q) составляющие, то есть тензор формы (batch, 2, 51).

Дальше идут три свёрточных блока. Первый Conv1d расширяет 2 канала до 32 с ядром 5, второй — 32 → 64 тоже с ядром 5, третий — 64 → 128 с ядром 3. То есть число каналов наращивается по схеме 2 → 32 → 64 → 128: с каждым блоком сеть выделяет всё более сложные признаки из окна сигнала. После каждой свёртки стоит BatchNorm и LeakyReLU с наклоном 0.1. BatchNorm (батч-нормализация) нужен для стабилизации обучения: он нормирует выходы свёртки внутри мини-батча и тем самым уменьшает внутренний ковариационный сдвиг (internal covariate shift) — изменение распределения активаций от слоя к слою по ходу обучения, из-за которого тренировка идёт медленнее и менее устойчиво. LeakyReLU с наклоном 0.1 берётся вместо обычного ReLU, чтобы предотвратить проблему «мёртвых нейронов»: у обычного ReLU отрицательная часть зануляется, и нейрон, попавший в эту зону, перестаёт получать градиент и обучаться, а небольшой ненулевой наклон 0.1 на отрицательной полуоси сохраняет градиент и не даёт нейронам «умирать». Затем результат разворачивается (Flatten): 128 каналов × 51 отсчёт дают 128 × 51 = 6528 признаков, которые вытягиваются в один вектор. Этот вектор проходит полносвязный слой 6528 → 256 с LeakyReLU 0.1 и Dropout 0.3. Dropout 0.3 добавлен для регуляризации: при обучении он случайно обнуляет 30 % активаций слоя, что мешает сети переобучаться и заставляет её не полагаться на отдельные нейроны. Финальный слой 256 → 2 выполняет регрессию на I и Q центрального символа окна.

На выходе — два числа: оценка I и Q центрального символа окна. По сути это регрессия: предсказать идеальную точку созвездия по зашумлённому и искажённому окружению. Сеть получается достаточно крупной — 1 707 746 обучаемых параметров.

Рисунок 1 — Архитектура нейросетевого эквалайзера 1D-CNN

Рисунок 1 — Архитектура нейросетевого эквалайзера 1D-CNN

Откуда брать данные

Обучать сеть прямо в эфире дорого и невоспроизводимо, поэтому датасет генерируется синтетически полным DSP-пайплайном. Случайные биты отображаются в символы QPSK, апсемплируются с sps = 4 и проходят формирующий RRC-фильтр с roll-off β = 0.35. Дальше сигнал сворачивается с импульсной характеристикой канала, добавляется шум под заданный SNR, на приёме делается согласованная фильтрация и даунсемплинг до одного отсчёта на символ, после чего поток нарезается скользящими окнами по 51 отсчёту.

Ключевая особенность датасета — четыре фиксированных профиля канала разной тяжести: базовый fixed_default (4 отвода), mild_isi (3 отвода, мягкая ISI), moderate_isi (4 отвода) и strong_isi (5 отводов, самые сильные отражения). Для каждого профиля генерируется по 50 000 символов в диапазоне SNR 0–30 дБ. Важная оговорка про честность эксперимента: в этом multi-profile режиме несущая частота не сдвигается (CFO = 0) и нелинейности тракта не применяются — то есть сеть учится бороться именно с многолучевостью и шумом, а не с искусственно добавленными артефактами.

Результаты на синтетике

На программном стенде я сравнивал настроенный LMS-baseline и обученную CNN на одних и тех же данных. Это контролируемая среда: обучающее и тестовое распределения совпадают, канал известен, шум — белый. В таких условиях нейросеть честно конкурирует с LMS и на части профилей ведёт себя устойчивее за счёт того, что видит окружение символа целиком, а не складывает отсчёты линейно.

Проверка на PlutoSDR

Дальше — железо. Цель этого этапа была не в том, чтобы сравнивать CNN с LMS, а в том, чтобы убедиться в работоспособности тракта — что весь приёмо-передающий путь и инференс сети действительно работают на реальном устройстве. Аппаратный этап выполнялся на модуле PlutoSDR в кабельном шлейфовом режиме TX1 → RX1: передатчик и приёмник одного и того же устройства соединены напрямую. И LMS, и CNN получают один и тот же выровненный поток.

По части производительности на PlutoSDR сеть показала себя хорошо: CNN успевает обрабатывать поток в реальном времени на видеокарте (GPU). Сравнивать CNN с LMS на Pluto не было главной целью — на этом этапе важно было проверить, что тракт работает. Главное направление — перенос модели на ПЛИС и проверка её работы уже там.

Что дальше

Короткий итог. На данном этапе подход в теории рабочий, но требует доработок и улучшений: нужно закрыть domain gap, дообучить сеть на реальных данных и довести инференс до аппаратной реализации. Как первый прототип результат очень хороший — он подтверждает, что 1D-CNN способна выполнять роль эквалайзера и работает в реальном времени, а дальнейшая доводка — вопрос инженерной работы.