回复【10楼】cowboy
这个是否可以这样计算?
设 a 为 1~65535,且a的二进制数为:
0 0 0 0 0 1 x x x x x x x x x x
\___ ___/ \___ ___/
v v
前面n个0 i取5位二进制数,不足5位后面补0
则a的分贝值可表示为:
90-6*n+log_tab
n和i可以轻松以移位求得。而对数表如下:
unsigned char log_tab[32]={0,0,0,0,1,1,1,1,1,2,2,2,2,2,3,3,3,3,3,4,4,4,4,4,4,5,5,5,5,5,5,5,};
式中常90为log(32768)*20,系数6为log(2)*20
这个是否可以这样计算?
设 a 为 1~65535,且a的二进制数为:
0 0 0 0 0 1 x x x x x x x x x x
\___ ___/ \___ ___/
v v
前面n个0 i取5位二进制数,不足5位后面补0
则a的分贝值可表示为:
90-6*n+log_tab
n和i可以轻松以移位求得。而对数表如下:
unsigned char log_tab[32]={0,0,0,0,1,1,1,1,1,2,2,2,2,2,3,3,3,3,3,4,4,4,4,4,4,5,5,5,5,5,5,5,};
式中常90为log(32768)*20,系数6为log(2)*20
-----------------------------------------------------------------------
好牛X,完全看不明白。。。
言归正传:
CPU是不支持对数的,所以如果对数运算能转换成移位和四则运算就最好,否则示符运算的密度,
如果隅尔求对数,或几秒才求一次,可用mach.h上的办法,或用展开式法,来写算法。
否则,一定要用查表法,才能提速。
一定要设法减少运算量,即对整个算式查表。
一周热门 更多>