私はbashでCRC16チェックサムを実装しようとしています。既存のC++コードから移植しています。私はもうすぐそこにいますが、私は別の答えを得ています。
C++コードとbashスクリプトのチェックサムが異なる理由がよくわかりません。
別の目は大きな助けになるでしょう。
C++コードは次のとおりです。
uint16_t Encoder::checksum(std::string thestring)
{
uint8_t d, e, f;
uint16_t c, r, crccalc;
c = 0xffff;
for (unsigned int i = 0; i < thestring.length(); i++)
{
d = thestring[i];
e = c ^ d;
f = e ^ (e << 4);
r = (c >> 8) ^ (f << 8) ^ (f << 3) ^ (f >> 4);
c = r;
}
c ^= 0xffff;
crccalc = c;
return crccalc;
}
そして、これが私のbashコードです:
function calc_crc16()
{
string=$1
while read -d "" -n 1 ; do astring+=( "$reply" ) ; done <<< "$string"
cnt=${#astring[@]}
c=0xffff
for ((x=0;x<$cnt;x++)); do
char=${astring[$x]}
e=$(($c ^ $char))
s=$(($e << 4))
f=$(($e ^ $s))
t1=$(($c >> 8))
t2=$(($f << 8))
t3=$(($f << 3))
t4=$(($f >> 4))
r1=$(($t1 ^ $t2 ^ $t3 ^ $t4))
c=$r1
done
c=$c ^ 0xffff
echo "checksum = $c"
}
それはintのサイズと関係があるのでしょうか?bashでそれについてできることはあまりないと思います。
実際の番号を取得していますが、正しく機能することがわかっているC++と一致しません。誰かが私が物事を台無しにしているかもしれない何かを見ますか?