Перейти к содержанию

stm32f ADC >PWM


Ivan Rusev

Рекомендуемые сообщения

 

Цитата

 

Как мне сделать так что бы ацп управляло шим?

отдельно работают а вместе не хотят.На avr я так делал на stm не получается?

Поделитесь инфой?

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

PWM_data = ADC_data;

//Скопировать прочитанные данные с АЦП в регистр ШИМ 

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

всё верно но на практике не получается  я  беру   таймер 2 может взять другой .Принцып я понимаю   adc_data = ADC1->DR; TIM2->CCR1= adc_data;

а на atmega32 всё чётко.И в прерываниях тоже.

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Ну так иногда нужно масштабировать АЦП , чтобы поместить данные в регистр ШИМ . Например , если АЦП 12бит , а ШИМ используется 16бит.

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

Сколько бит АЦП и сколько бит ШИМ будет? И как вывод в ШИМ должен работать?

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

АЦП умножить на 16 . И если нужно инвертировано выводить в ШИМ , то :

PWM_data=65535-ADC_data*16;

PWM_data=ADC_data*16; // без инверсии

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

Да , так будет работать . Переменная одна только. Читаем с АЦП в переменную , потом с нее копируем в ШИМ предварительно промасштабировав полученные значения с АЦП .

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

не работает  таймере  2 вот кусок кода    ADC1->CR2 |= ADC_CR2_SWSTART;
                    while (!(ADC1->SR & ADC_SR_EOC)); //ждем пока первое преобразование завершится
                        ADC1->SR &= ~ADC_SR_EOC;
                  
                        adc_data = ADC1->DR;
                      
                      TIM2->CCR1=adc_data*16;

Ссылка на комментарий
Поделиться на другие сайты

Что именно не работает ? Как себя ведёт? И где копирование выполняешь в регистр ШИМ ?

Как ШИМ настроен?

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

шим не работает с ацп.?

 

static void MX_TIM2_Init(void)
{

  /* USER CODE BEGIN TIM2_Init 0 */

  /* USER CODE END TIM2_Init 0 */

  LL_TIM_InitTypeDef TIM_InitStruct = {0};
  LL_TIM_OC_InitTypeDef TIM_OC_InitStruct = {0};

  LL_GPIO_InitTypeDef GPIO_InitStruct = {0};

  /* Peripheral clock enable */
  LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_TIM2);

  /* USER CODE BEGIN TIM2_Init 1 */

  /* USER CODE END TIM2_Init 1 */
  TIM_InitStruct.Prescaler = 0;
  TIM_InitStruct.CounterMode = LL_TIM_COUNTERMODE_UP;
  TIM_InitStruct.Autoreload = 65535;
  TIM_InitStruct.ClockDivision = LL_TIM_CLOCKDIVISION_DIV1;
  LL_TIM_Init(TIM2, &TIM_InitStruct);
  LL_TIM_DisableARRPreload(TIM2);
  LL_TIM_SetClockSource(TIM2, LL_TIM_CLOCKSOURCE_INTERNAL);
  LL_TIM_OC_EnablePreload(TIM2, LL_TIM_CHANNEL_CH1);
  TIM_OC_InitStruct.OCMode = LL_TIM_OCMODE_PWM1;
  TIM_OC_InitStruct.OCState = LL_TIM_OCSTATE_DISABLE;
  TIM_OC_InitStruct.OCNState = LL_TIM_OCSTATE_DISABLE;
  TIM_OC_InitStruct.CompareValue = 0;
  TIM_OC_InitStruct.OCPolarity = LL_TIM_OCPOLARITY_HIGH;
  LL_TIM_OC_Init(TIM2, LL_TIM_CHANNEL_CH1, &TIM_OC_InitStruct);
  LL_TIM_OC_DisableFast(TIM2, LL_TIM_CHANNEL_CH1);
  LL_TIM_OC_EnablePreload(TIM2, LL_TIM_CHANNEL_CH2);
  TIM_OC_InitStruct.OCState = LL_TIM_OCSTATE_DISABLE;
  TIM_OC_InitStruct.OCNState = LL_TIM_OCSTATE_DISABLE;
  LL_TIM_OC_Init(TIM2, LL_TIM_CHANNEL_CH2, &TIM_OC_InitStruct);
  LL_TIM_OC_DisableFast(TIM2, LL_TIM_CHANNEL_CH2);
  LL_TIM_OC_EnablePreload(TIM2, LL_TIM_CHANNEL_CH3);
  TIM_OC_InitStruct.OCState = LL_TIM_OCSTATE_DISABLE;
  TIM_OC_InitStruct.OCNState = LL_TIM_OCSTATE_DISABLE;
  LL_TIM_OC_Init(TIM2, LL_TIM_CHANNEL_CH3, &TIM_OC_InitStruct);
  LL_TIM_OC_DisableFast(TIM2, LL_TIM_CHANNEL_CH3);
  LL_TIM_OC_EnablePreload(TIM2, LL_TIM_CHANNEL_CH4);
  TIM_OC_InitStruct.OCState = LL_TIM_OCSTATE_DISABLE;
  TIM_OC_InitStruct.OCNState = LL_TIM_OCSTATE_DISABLE;
  LL_TIM_OC_Init(TIM2, LL_TIM_CHANNEL_CH4, &TIM_OC_InitStruct);
  LL_TIM_OC_DisableFast(TIM2, LL_TIM_CHANNEL_CH4);
  LL_TIM_SetTriggerOutput(TIM2, LL_TIM_TRGO_RESET);
  LL_TIM_DisableMasterSlaveMode(TIM2);
  /* USER CODE BEGIN TIM2_Init 2 */

  /* USER CODE END TIM2_Init 2 */
  LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOB);
  LL_APB2_GRP1_EnableClock(LL_APB2_GRP1_PERIPH_GPIOA);
  /**TIM2 GPIO Configuration  
  PB10   ------> TIM2_CH3
  PB11   ------> TIM2_CH4
  PA15   ------> TIM2_CH1
  PB3   ------> TIM2_CH2 
  */
  GPIO_InitStruct.Pin = LL_GPIO_PIN_10|LL_GPIO_PIN_11|LL_GPIO_PIN_3;
  GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
  GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
  GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
  LL_GPIO_Init(GPIOB, &GPIO_InitStruct);

  GPIO_InitStruct.Pin = LL_GPIO_PIN_15;
  GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
  GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
  GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
  LL_GPIO_Init(GPIOA, &GPIO_InitStruct);

  LL_GPIO_AF_EnableRemap_TIM2();

}

вот его настройка

на cmsis шим настроить не получается.

Ссылка на комментарий
Поделиться на другие сайты

Если по отдельности работает и то и другое , то должно и так работать .

Может ещё быть из-за типов данных. Приведи явно к uint32_t. Вот так:

 TIM2->CCR1=(uint32_t)adc_data*16;

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

Посмотри отладчиком . Или подними уарт, пропиши отладочный вывод , и посмотри что там творится .

Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ?

Ссылка на комментарий
Поделиться на другие сайты

Ты ж писал по отдельности работает! Есть такой ютуб канал NarodStream начни хоть с него. Так у тебя Atollic или CubeIDE, а то как то несовместимо с утверждением "нынешняя версия"

Изменено пользователем MasterElectric
Ссылка на комментарий
Поделиться на другие сайты

Если код на ацп и шим брался из примеров, то я сталкивался с тем, что шим менялся только через его инициализацию. Т.е. пример шим для данного применения непригоден.

Никогда не спорьте с дураками. Они опустят Вас до своего уровня и победят за счет опыта.

 

 

Ссылка на комментарий
Поделиться на другие сайты

Если не в ручную а через Куб .То раньше в студии можно было спокойно команды писать на cmsis в регистрах а сейчас не всё проходит.

АЦП  например.

И дело не в отладчике а в кубе.

Ссылка на комментарий
Поделиться на другие сайты

У меня в кубе всё получилось а вот напрямую cmsis шим не получаетя.

 


    RCC->APB2ENR|=RCC_APB2ENR_IOPAEN;

    RCC-> APB1ENR     |=RCC_APB1ENR_TIM2EN;
       RCC->APB2ENR|=RCC_APB2ENR_AFIOEN;
       GPIOA->CRH&=~GPIO_CRH_CNF15_1;
       GPIOA->CRH|=GPIO_CRH_CNF15_1;

           GPIOA->CRH&=~GPIO_CRH_MODE15;
           GPIOA->CRH|=GPIO_CRH_MODE15;
     
            TIM2->PSC = 0; // Настраиваем делитель что таймер тикал 1000 раз в секунду
              TIM2->ARR = 65535 ;
         
             //TIM2->EGR |= TIM_EGR_UG ;
              TIM2->CCMR1 = TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC1M_1;
            
              TIM2->CCER&=~TIM_CCER_CC1P;
              TIM2->CR1&=~TIM_CR1_DIR;
            
              TIM2->CCR1=0;
    

              TIM2->CR1|=   TIM_CR1_CEN;
           
}

вот кусок настроек что не так?

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • Доброго времени суток. Столкнулся с проблемой: не получается скачать пакет STM32F4 (пробовал и другие, ошибка та же) при нажатии кнопки install появляется ошибка (первый скриншот). Такое ощущение, что CubeIDE не может подключиться к сети, постоянно появляется окно как на втором скиншоте. Подскажите как можно исправить проблему?
    • Я вас конечно уважаю, но хамить мне не надо. Все УНЧ что я создавал сначала до идеала дорабатывались в симуляторе, и только потом собирались. В 98% случаев они сразу работали корректно. Были исключения, но там проблемы были в разводке платы и деталях а не симуляторе. Тот же мой VAC 2.0 ПОЛНОСТЬЮ совпал по результатам тестов в железе с результатами тестов в симуляторе.  Эта схема это простейший ВК в AB классе к которому подключили ОУ для усиления напряжения. Нет ни единой причины этой схеме работать некорректно или плохо. Единственные 2 варианта почему будет работать плохо/не работать, это либо накосячено при сборке или детали обвязки неисправны, либо сам ОУ палëный. Качество работы этой схемы очень сильно будет зависеть от качества ОУ и симулятор тут не при чëм. И опять же, этой схеме уже больше 30 лет и еë собирали сотни человек! Если собрано на нормальных деталях, эта схема будет работать как надо и выдаст качественный звук. 
    • У многих в голове "битые ячейки". Ясно сказано, что работает видео в помещении, опробовано десятки раз. Весь снятый материал в лесу и в поле пошёл в корзину и также опробовано не один раз. Приобретена новая карта за 1К. Видео ещё хуже, чем с тех "чудо флешек". https://disk.yandex.ru/i/Ww52T3leg99VxA
    • Сорри, вопрос звучит не однозначно. Меня интересовало - нужен ли вынос наружу головок или не нужен, а не их расположение на передней панели относительно друг друга.
    • Когда то я тоже был от неё в ужасе, но быстро прошло. К тому же это одно из лучших технических решений, если не лучшее.
    • Совершенно верно. Смысл сближения +/- шин в том чтобы получить эти контуры максимально симметрично расположенными относительно чувствительных к помехам точек монтажа. Однако при этом сами контуры увеличиваются по площади и меняют плоскость расположения на менее выгодную по помехам по сравнению с "классикой" (полигон земли под шинами). Поэтому, лично я предпочитаю трассировать прямые и возвратные проводники  друг над другом, чтобы минимизировать излучение изначально.
    • Почитайте Часть вопросов отпадет.
×
×
  • Создать...