所以我想写一个函数,将7位格雷码转换为相应的7位二进制代码。格雷码到二进制代码转换
下面是如何转换 -
- 灰度值位---- MS位>(G6)G5 G4 G3 G2 G1 G0 *
二进制值位 - MS位>(B6 )B5 B4 B3 B2 B1 B0 *
B6 = G6 // MS比特总是相同
- B5 B6 =^G5 //异 'OR' 的位一起构建7位二进制值
- B4 = B5^G4
- B3 = B4^G3
- B2 = B3^G2
- B1 = B2^G1
- B0 = B1^G0
,这里是我的功能所以远
unsigned short Gray_to_Bin(unsigned short Gray)
{
unsigned short Bin;
unsigned short i;
unsigned short mask;
mask = 0x40; // Initial mask
Bin = 0;
Gray &= 0x7f; // Mask bit 7 (Index Bit)
Bin = Gray & mask; // Set B6 = G6
for (i=0; i<6; i++) // Set B5, B4, ..., B0
{
// Code needed here!!
}
return Bin;
}
我需要到f ind一种方法来访问每个运行循环所需的特定位...需要像我可以以某种方式访问位...
任何想法/指针?谢谢:)
那么,代码不是阵列形式 - 进来的灰色代码将像0101 1100.我不认为你可以像访问一个数组中的每个数字短代码? (请原谅我的无知,我对此很陌生:P)。 谢谢! – 2011-03-15 08:17:50