Цифровая осциллография.
Apr. 30th, 2015 11:22 pmЦифровой осциллограф с красивым цветным экраном окончатильно вытеснил своего аналогового предка из исследовательских лабораторий. Удобный прибор, позволяющий не только посмотреть форму сигнала, но и измерить многие его параметры, а так же записать картинку на флешку, радует современного инженера.
Вот такую картинку синусоиды частотой 1 МГц рисует бюджетный Тектроникс TDS2022.

Сигнал на него поступает с замечательного генератора другой американской фирмы Аджилент.

Как можно заметить наблюдается полное соответствие показаний частоты и амплитуды на обоих приборах.
Сейчас я включу на генераторе амплитудную модуляцию частотой 400 Гц и глубиной 50%. Хотя этот вид модуляции почти умер в радиовещании, прибор позволяет это сделать.

Смотрим на осциллограф. Вместо картинки АМ из учебника на экране наблюдается очень неравномерное заполнение радиочастотой.

Или, несколько изменив уровень синхронизации, вот так.

Древний аналоговый осциллограф показывает при этом правильную картинку АМ сигнала.

Странность картинки на цифровом приборе вызвана кратностью частоты дискретизации осциллографа и частоты генератора. Если чуть изменить частоту генератора, то ситуация меняется и изображение становится правильным.
Даже вполне хорошие и исправные приборы иногда показывают фигню. И этому есть нормальное объяснение.
А сфотографированный мной С1-55 уже отправился в утиль. RIP.
Вот такую картинку синусоиды частотой 1 МГц рисует бюджетный Тектроникс TDS2022.

Сигнал на него поступает с замечательного генератора другой американской фирмы Аджилент.

Как можно заметить наблюдается полное соответствие показаний частоты и амплитуды на обоих приборах.
Сейчас я включу на генераторе амплитудную модуляцию частотой 400 Гц и глубиной 50%. Хотя этот вид модуляции почти умер в радиовещании, прибор позволяет это сделать.

Смотрим на осциллограф. Вместо картинки АМ из учебника на экране наблюдается очень неравномерное заполнение радиочастотой.

Или, несколько изменив уровень синхронизации, вот так.

Древний аналоговый осциллограф показывает при этом правильную картинку АМ сигнала.

Странность картинки на цифровом приборе вызвана кратностью частоты дискретизации осциллографа и частоты генератора. Если чуть изменить частоту генератора, то ситуация меняется и изображение становится правильным.
Даже вполне хорошие и исправные приборы иногда показывают фигню. И этому есть нормальное объяснение.
А сфотографированный мной С1-55 уже отправился в утиль. RIP.
no subject
Date: 2015-05-01 07:38 pm (UTC)no subject
Date: 2015-05-01 07:44 pm (UTC)no subject
Date: 2015-05-01 07:50 pm (UTC)DMA уже не относится к микроконтроллерам... и ваш Cortex-M уже процессор, если не верите посмотрите на сайте.
no subject
Date: 2015-05-01 07:51 pm (UTC)no subject
Date: 2015-05-01 09:55 pm (UTC)Разница между микроконтроллером и микропроцессором (по моему мнению) - в первую очередь в периферии - микроконтроллер - содержит микропроцессор + память разных фидов + всякие интерфейсы и т.п.
no subject
Date: 2015-05-02 03:41 pm (UTC)no subject
Date: 2015-05-02 03:47 pm (UTC)Вот что референс говорит:
The DMA controller performs direct memory transfer by sharing the system bus with the
Cortex-M0 core. The DMA request may stop the CPU access to the system bus for some
bus cycles, when the CPU and DMA are targeting the same destination (memory or
peripheral). The bus matrix implements round-robin scheduling, thus ensuring at least half
of the system bus bandwidth (both to memory and peripheral) for the CPU.
no subject
Date: 2015-05-02 06:29 pm (UTC)и даже шина там есть (AMBA) что в обычных микроконтроллерах отсутствует ( именно протокол доступа, транзакции) а просто имплементированна как набор проводов.
no subject
Date: 2015-05-02 06:33 pm (UTC)Производитель с вами не согласен.
Да и никто не согласен - ни разу не слышал чтобы STM32 называли SoC. Разве что W серия со встроенным радио.
no subject
Date: 2015-05-02 06:51 pm (UTC)они самые популяеные и определяют то, что принято называть микроконтроллером.
если подвесить на AMBA в вашем STM32 контролер памяти то он станет вообще полноценным SoC.
т.е. получается что это тупо урезанная версия ARM SoC.
no subject
Date: 2015-05-02 06:58 pm (UTC)no subject
Date: 2015-05-02 07:01 pm (UTC)они были и останутся классикой микроконтроллеров..
no subject
Date: 2015-05-02 07:05 pm (UTC)Пара серийных изделий какой-нибудь крупной фирмы и ардуине такое количество даже и не снилось :)
no subject
Date: 2015-05-02 07:10 pm (UTC)(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2015-05-04 11:55 am (UTC)впрочем, и сама ардуина разродилась ардуиной дуе на кортексе...
если учесть, что STM32F103C4T6A стоит в рознице 140 рублей, а атмега168 - 130 - смысл использовать в новых разработках 8-битники становится очень неочевидным ...
(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2015-05-02 06:10 pm (UTC)no subject
Date: 2015-05-02 06:14 pm (UTC)no subject
Date: 2015-05-02 06:18 pm (UTC)no subject
Date: 2015-05-02 06:26 pm (UTC)RCC->AHBENR |= RCC_AHBENR_DMA1EN;
DMA1_Channel3->CPAR = (uint32_t)&USART1->RDR; // Адрес регистра перефирии
DMA1_Channel3->CMAR = (uint32_t)&modbus.buffer[0]; // Адрес буфера в памяти
DMA1_Channel3->CCR = DMA_CCR_MINC; // Инкремент адреса памяти
dma_usart_rx_reset(); // Сбрасываем количество данных для обмена
}
void dma_usart_rx_stop(void){
DMA1_Channel3->CCR &= ~DMA_CCR_EN;
}
void dma_usart_rx_reset(void){
DMA1_Channel3->CCR &= ~DMA_CCR_EN;
DMA1_Channel3->CNDTR = 257;
DMA1_Channel3->CCR |= DMA_CCR_EN;
}
Да пожалуйста.
Инициализируем DMA, чтобы переписывал данные из USART в память. Все, после этого забываем.
Когда приходит байтик на USART снаружи он сам вызывает DMA и байтик переписывается в память без участия процессора.
Также можно и АЦП+DMA, например, настроить. Один раз настроили, после этого DMA автоматом после каждого измерения АЦП шлет данные в память.
no subject
Date: 2015-05-02 06:43 pm (UTC)что происходит потом? вызывается прерывание?
кстати в STM32 еще и большие проблемы с производительностью DMA и обычная memcpy его превосходит раза в 4ре.
no subject
Date: 2015-05-02 06:53 pm (UTC)С АЦП - тоже загляденье - настроил автоматические бесконечные преобразования АЦП и DMA, чтобы писал их прямо по адресу какой-нибудь переменной. Все, после этого момента в переменной всегда актуальное значение с АЦП, без прерываний вообще, про АЦП фактически можно забыть.
Ну про случаи работы с SD картой, например, где надо килобайты и мегабайты переписывать я вообще молчу.
no subject
Date: 2015-05-02 06:55 pm (UTC)no subject
Date: 2015-05-02 06:59 pm (UTC)https://www.google.ru/search?q=mcu+sd+card&ie=utf-8&oe=utf-8&gws_rd=cr&ei=eR5FVeqbO4G6sgHNtIDIBA
no subject
Date: 2015-05-02 06:58 pm (UTC)прерывания не такие дорогие, кроме того содержимое пакетов нужно както декодировать, это проще делать по прерыванию изменяя state machine. пропуская ненужные данные и т.д.
значения с ACP любой нормальный человек сначала усредняет, потом уже использует, что также принято делать с помощью различных running averages...
no subject
Date: 2015-05-02 07:04 pm (UTC)А уж как работать с данными АЦП, усреднять их или нет или делать это не в прерывании - это уже совершенно другое дело.
(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From: