На stm32vldiscovery генерирую таймером #1 на канале #1 частоту 100 кГц. Контроллер работает на частоте 24 МГц.
Инициализация выходного канала:
Код
TIM_OCConfig.TIM_OCMode = TIM_OCMode_PWM1;
TIM_OCConfig.TIM_OutputState = TIM_OutputState_Enable;
TIM_OCConfig.TIM_Pulse = TIM_BaseConfig.TIM_Period/2;
TIM_OCConfig.TIM_OCPolarity = TIM_OCPolarity_High;
TIM_OC1Init(TIM1, &TIM_OCConfig);
Часть кода инициализации таймера:
Код
TIM1->PSC = 9;
TIM1->ARR = 24;
TIM1->CCR1 = TIM1->ARR / 2;
TIM1->CNT = 0;
TIM_Cmd(TIM1, ENABLE);
Логический анализатор измеряет частоту на выходе 96.000 кГц.
Для PSC=5, ARR=40 получаю 97.561 кГц. Для PSC=3, ARR=60 получаю 98.361 кГц. Для PSC=1, ARR=120 получаю 99.174 кГц. Для PSC=0, ARR=240 получаю 99.585 кГц.
Действительно ли использование предделителя существенно ухудшает точность счета (или с чем это может быть связано?) и как получить 100.000 кГц?