Итак, я пытаюсь написать функцию, которая преобразует 7-битный код Грея в соответствующий 7-битный двоичный код.
Вот как конвертировать -
- Биты значения серого ---- бит MS > (G6) G5 G4 G3 G2 G1 G0 *
Биты двоичного значения -- бит MS > (B6) B5 B4 B3 B2 B1 B0 *
B6 = G6 // биты MS всегда одинаковы
- B5 = B6 ^ G5 // Исключительное ИЛИ между битами для построения 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;
}
Мне нужно найти способ доступа к требуемым конкретным битам для каждого запуска цикла... мне нужно как-то получить доступ к битам, как я мог бы с массивами...
Любые идеи/указатели? Спасибо :)