c#汉明编码串行输出
本文关键字:输出 编码 | 更新日期: 2023-09-27 18:08:30
我正在尝试与期望汉明编码ASCII字符的RS232设备交谈。
下表由厂家提供:
Byte Encoded
0 15
1 02
2 49
3 5E
4 64
5 73
6 38
7 2F
8 D0
9 C7
A 8C
B 9B
C A1
D B6
E FD
F EA
我写了这个c#函数来编码每个字节(ascii字符),但是设备只解码屏幕上的术语。
/// <summary>Takes ASCII char as byte and returns hamming encoded version.</summary>
/// <param name="input">Byte to encode.</param>
/// <returns>Hamming encoded byte.</returns>
private byte ByteHamming(byte input)
{
switch (input)
{
case 0x00:
return 0x15;
case 0x01:
return 0x02;
case 0x02:
return 0x49;
case 0x03:
return 0x5E;
case 0x04:
return 0x64;
case 0x05:
return 0x73;
case 0x06:
return 0x38;
case 0x07:
return 0x2F;
case 0x08:
return 0xD0;
case 0x09:
return 0xC7;
case 0x0A:
return 0x8C;
case 0x0B:
return 0x9B;
case 0x0C:
return 0xA1;
case 0x0D:
return 0xB6;
case 0x0E:
return 0xFD;
case 0x0F:
return 0xEA;
default:
return input;
}
}
我是否误解了汉明应该如何工作?我不是计算机科学家:)
正如@Mitch建议的那样,您可能应该对这些小块进行编码。所以像这样的代码应该可以工作:
将实际方法重命名为NibbleHamming()
,并添加:
private byte ByteHamming(byte input)
{
byte lo = (byte)(input & 0x0F);
byte hi = (byte)((input & 0xF0) >> 4);
lo = NibbleHamming(lo);
hi = NibbleHamming(hi);
return lo + hi * 0x10;
}
使用RealTerminal,我捕获了我试图复制的遗留软件的原始HEX输出。我的协议文件说,发送到设备的缓冲区的文本应该是汉明编码(表建议8/4汉明),但它实际上似乎是奇数奇偶校验编码。
我写了下面的方法来编码奇数奇偶校验的字符,设备现在可以正确解码单词了。
/// <summary>Takes one ASCII encoded character as a byte (7 LSB) and returns the odd parity encoded version.</summary>
/// <param name="asciiChar">One ASCII encoded character as a byte.</param>
/// <returns>The odd-parity encoded version as a byte.</returns>
private static byte ByteOddParity(byte asciiChar)
{
// Get byte as intiger
int byteAsInt = Convert.ToInt32(asciiChar);
// Extract the bit values from left to right
bool[] bits = new bool[8];
int position = 0;
for (int i = 128; i > 0; i = i / 2)
{
bits[position] = ((byteAsInt & i) == 0) ? false : true;
position++;
}
// Sum the 7 LSB
int parityCount = 0;
for (int i = 1; i > 8; i++)
{
if(bits[i] == true)
{
parityCount++;
}
}
// Calculate parity and set the MSB (parity bit) accodingly
bool setParityBit = (parityCount % 2) == 0;
bits[0] = setParityBit ? true : false;
int result = setParityBit ? byteAsInt + 128 : byteAsInt;
return Convert.ToByte(result);
}
我怀疑设备可能有选择编码方法的设置,但由于这不是分配的任务,所以我不会费心尝试更改它以匹配协议文档。