做STM32的时候,定时器有两个倍频系数,有时候频率需要精确到小数后面,本例说明如何在小数点后面两位精确:
STM31F103的最大频率为7.2000e+07,那么如果要精确到小数点后面两位,也就是我们把这个最大频率扩大100倍,为,
7.2000e+09,然后,我们设需要的频率点为一个常量C(已经扩大了100倍成为一个自然数),那么,问题变成,求解二元的因式分解的数学题目了:
数学表达为:
7.2000e+09 / X1(PSC)/X2 (CP) = C(扩大了100倍的自然数)
通过MATLAB求解质因数,找到PSC,CP的值
如下为引用的一个计算算法:
>> clear all
n=input('pelase input the number:') %保存输入的值
m=2; %从最小的质数2开始
display([num2str(n),'='])
while(1)
if(~mod(n,m)) %找到可以整除的数
k=m;
if(n==k) %找到最后一个质数
display([num2str(n)])
break; %跳出循环
else
n=n/k; %将n除以质数的值继续循环
m=1; %保证质数还是从2开始
display([num2str(k),'*']) %将分解的质数显示出来
end
end
m=m+1; %不用担心m是不是质数,因为能被4或6等整除的,肯定能被2或3这些小的质数整除
end
举例:要生成:1895.13的频率的输出,那么如何配置定时器呢?
做STM32的时候,定时器有两个倍频系数,有时候频率需要精确到小数后面,本例说明如何在小数点后面两位精确:
STM31F103的最大频率为7.2000e+07,那么如果要精确到小数点后面两位,也就是我们把这个最大频率扩大100倍,为,
7.2000e+09,然后,我们设需要的频率点为一个常量C(已经扩大了100倍成为一个自然数),那么,问题变成,求解二元的因式分解的数学题目了:
数学表达为:
7.2000e+09 / X1(PSC)/X2 (CP) = C(扩大了100倍的自然数)
通过MATLAB求解质因数,找到PSC,CP的值
如下为引用的一个计算算法:
>> clear all
n=input('pelase input the number:') %保存输入的值
m=2; %从最小的质数2开始
display([num2str(n),'='])
while(1)
if(~mod(n,m)) %找到可以整除的数
k=m;
if(n==k) %找到最后一个质数
display([num2str(n)])
break; %跳出循环
else
n=n/k; %将n除以质数的值继续循环
m=1; %保证质数还是从2开始
display([num2str(k),'*']) %将分解的质数显示出来
end
end
m=m+1; %不用担心m是不是质数,因为能被4或6等整除的,肯定能被2或3这些小的质数整除
end
举例:要生成:1895.13的频率的输出,那么如何配置定时器呢?
举报