0

在一个似乎运行良好的程序中,我有以下声明:

#include <stdio.h>
#include "system.h"

signed char input[4]; /* The 4 most recent input values */

char get_q7( void );
void put_q7( char );
void firFixed(signed char input[4]);

const int c0 = (0.0299 * 128 + 0.5); /* Converting from float to Q7 is multiplying by 2^n i.e. 128 = 2^7 since we use Q7 and round to the nearest integer*/
const int c1 = (0.4701 * 128 + 0.5);
const int c2 = (0.4701 * 128 + 0.5);
const int c3 = (0.0299 * 128 + 0.5);
const int half = (0.5000 * 128 + 0.5);

enum { Q7_BITS = 7 };

void firFixed(signed char input[4])
{
    int sum = c0*input[0] + c1*input[1] + c2*input[2] + c3*input[3];
    signed char output = (signed char)((sum + half) >> Q7_BITS);
    put_q7(output);
}

int main(void)
{   
    int a;
    while(1)
    {    
     for (a = 3 ; a > 0 ; a--)
    {
      input[a] = input[a-1];
    }      
     input[0]=get_q7();           
     firFixed(input);
    }
    return 0;
}

但我不明白如何声明一个小数,就像int用常量一样。它应该是 Q7 表示法,但为什么要这样做,编译器如何接受小数的 int?它会只取分数的整数部分吗?如果是,为什么不需要强制转换?

4

2 回答 2

3

当浮点值转换为整数时,它会被截断。这意味着简单地删除小数点后的所有数字。例如12.34变成1212.99 变成12。没有进行四舍五入。

这就是该+ 0.5部分在初始化中所做的。这只是一种通过舍入将浮点值转换为整数的方法。例如,0.0299 * 128is which is 3.8272which truncated will be 3. 但随着+ 0.5it's 4.3272which 被截断变成4,这是 的四舍五入值3.8272

但是可能仍然存在问题,您可能想阅读每个计算机科学家应该了解的关于浮点运算的知识以了解更多信息。

于 2013-10-07T11:54:57.233 回答
1

只有在类型提升的情况下才需要强制转换,而不是在类型截断的情况下。

于 2013-10-07T11:55:30.490 回答