Ssylka

Пять способов генерации случайного сигнала на stm32

Микроконтроллеры stm32 могут генерировать псевдослучайные и случайные сигналы различными методами, избавляя от необходимости в дополнительных компонентах для задач, вроде построения АЧХ или генерации шума для аудио. Встроенный цифро-аналоговый преобразователь (ЦАП) способен выдавать псевдослучайный сигнал, используя 12-битный РСЛОС, однако, из-за короткого периода последовательности, такой сигнал имеет тональные составляющие. Модуль CRC, при подаче в него нулей и подходящем полиноме, может работать как 32-битный РСЛОС, генерируя псевдослучайную последовательность большой длины, что дает равномерный спектр, близкий к белому шуму. Этот метод требует использования DMA и ограничивает использование выводов порта GPIO.
Пять способов генерации случайного сигнала на stm32
Изображение носит иллюстративный характер

АЦП, настроенный на быстрые измерения и работу с DMA, также позволяет генерировать шум, используя «дрожание» младшего бита измерений, хотя этот метод может зависеть от конкретной модели микроконтроллера и также ограничивает использование порта GPIO. Альтернативно, можно программно реализовать РСЛОС в прерывании таймера, переключая выходной вывод в зависимости от значения регистра, однако, это требует процессорных ресурсов и может создавать неравномерности в спектре при низкой частоте прерываний.

Для более требовательных задач подойдет настоящий генератор случайных чисел (RNG), доступный в старших моделях stm32. Он выдает действительно случайные числа, которые можно вывести на порт GPIO через DMA. Хотя все эти аппаратные методы, кроме программного РСЛОС, требуют использования DMA и ограничивают функциональность порта GPIO, они могут упростить конструкцию устройств, где необходима генерация случайного шума.


Новое на сайте

18687Кем на самом деле были мифические «покорители неба» и как генетика раскрыла тысячелетнюю... 18686Астрономы обнаружили крупнейшую вращающуюся структуру во вселенной протяженностью 5,5... 18685Критическая уязвимость React Server Components с максимальным рейтингом опасности... 18684Критическая уязвимость в плагине King Addons для Elementor позволяет хакерам получать... 18683Столетний температурный рекорд долины смерти оказался результатом человеческой ошибки 18682Почему пользователи чаще эксплуатируют алгоритмы с «женскими» признаками, чем с... 18681Как превратить подрывную технологию ИИ в контролируемый стратегический ресурс? 18680Телескоп Джеймс Уэбб раскрыл детали стремительного разрушения атмосферы уникальной... 18679Почему диета из сырых лягушек привела к тяжелому поражению легких? 18678Способны ли три критические уязвимости в Picklescan открыть дорогу атакам на цепочки... 18677Как поддельные инструменты EVM на crates.io открывали доступ к системам тысяч... 18676Закон максимальной случайности и универсальная математика разрушения материалов 18675Символ падения власти: тайна древнего захоронения женщины с перевернутой диадемой 18674Индия вводит жесткую привязку мессенджеров к активным SIM-картам для борьбы с... 18673Почему вернувшаяся кампания GlassWorm угрожает разработчикам через 24 вредоносных...