c-转换为6位



我正在尝试整理这个将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的幂。

相关内容

  • 没有找到相关文章

最新更新