Calculate two's complement checksum of hexadecimal string

Crake picture Crake · Oct 17, 2012 · Viewed 12.7k times · Source

I have a string "0AAE0000463130004144430000" and I need to calculate the two's complement checksum of the hex bytes that make up the string.

The formula for the example string above is

  1. Sum the values: 0A + AE + 00 + 00 + 46 + 31 + 30 + 00 + 41 + 44 + 43 + 00 + 00 = 27 (discard the overflow)
  2. Subtract the result from 0x100 = 0xD9

D9 is the correct checksum for this example, but I am having trouble getting the two digit hex values parsed out of the string in C#. My current code is below:

string output = "0AAE0000463130004144430000";
long checksum = 0;
char[] outputBytes = output.TrimStart(':').ToCharArray();

foreach (var outputByte in outputBytes)
{
    checksum += Convert.ToInt32(outputByte);
    checksum = checksum & 0xFF;
}

checksum = 256 - checksum;

However, this is summing the ASCII values as far as I can tell, and doing it for each individual character.

Answer

L.B picture L.B · Oct 17, 2012

You can use SoapHexBinary class in System.Runtime.Remoting.Metadata.W3cXsd2001.

soapHexBinary.Value property will return you a byte array

string hexString = "0AAE0000463130004144430000";
byte[] buf = SoapHexBinary.Parse(hexString).Value;

int chkSum = buf.Aggregate(0, (s, b) => s += b) & 0xff;
chkSum = (0x100 - chkSum) & 0xff;

var str = chkSum.ToString("X2"); // <-- D9