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;
        }
    }

我是否误解了汉明应该如何工作?我不是计算机科学家:)

c#汉明编码串行输出

正如@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);
    }

我怀疑设备可能有选择编码方法的设置,但由于这不是分配的任务,所以我不会费心尝试更改它以匹配协议文档。