我正在尝试整理这个将10位值转换为6位的函数。当我使用更高分辨率的ADC时,我还需要能够定义输入的比特长度:
BYTE ioGetADC (void)
{
BYTE r;
ConvertADC(); // Start Conversion
while(BusyADC()); // Wait for completion
{
r = ( (ReadADC())/16); // Read result and convert to 0-63 (returns 10bit right hand justified)
}
return r;
}
在Joachim的回答基础上,如何:
uint32_t dropBits(uint32_t x, uint8_t bitsIn, uint8_t bitsOut)
{
return x / (1 << (bitsOut - bitsIn));
}
因此,例如,如果我们调用dropBits(1023, 10, 6)
将10位整数的最大值缩放为6位,它将返回1023 / (1 << 4)
,即1023 / 16
,即63,6位值的最大值。
当然,我们可能会试图帮助编译器,因为分母是二的幂:
return x >> (bitsOut - bitsIn);
这删除了除法运算符,而是直接用移位来执行。
请注意,这只能丢弃位,不能将值缩放为更多位。
您需要的除数是输入和输出位之间的差,提升到2的幂。