私は最近、多くのさまざまなデバイスでかなりのDIYホームオートメーション(RF; 433MHz)を行っています。それは基本的に、いくつかの本当にひどいリモートコントロールを備えたプールロボットです。
BladeRF SDRとGNU Radioを使用していくつかのデータを収集しました。「その他3」列は基本的にアクションですが、「その他1」はいくつかのシリアルのようで、「その他2」は複数を使用している場合のロボットを定義しますそこ)。カウントがどのような目的に適しているかはわかりませんが、おそらく範囲が広くなりすぎたときにロボットがそれを知るためです(情報が不足していますか?)。バイトとその意味を絞り込みましたが、データの正しいCRC(チェックサム)を計算できません。
古い-以下の更新をご覧ください!!
ここにいくつかのサンプルデータがあります:
<other1 > <other2> <other3> <count > <crc >
10110100 00111110 10001111 11001000 00000001 11110111 01011110
10110100 00111110 10001111 11001000 00000001 11111000 01010011
10110100 00111110 10001111 11001000 00000001 11111001 01010100
10110100 00111110 10001111 11001000 00000001 11111010 01010001
10110100 00111110 10001111 11001000 00000001 11111011 01010010
10110100 00111110 10001111 11001000 00000001 11111100 01010111
10110100 00111110 10001111 11001000 00000001 11111101 01011000
10110100 00111110 10001111 11001000 00000001 11111110 01010101
10110100 00111110 10001111 11001000 00000001 11111111 01010110
10110100 00111110 10001111 11001000 00000001 00000000 01100111
10110100 00111110 10001111 11001000 00000001 00000001 01101000
10110100 00111110 10001111 11001000 00000001 00000010 01100101
10110100 00111110 10001111 11001000 00000001 00000011 01100110
10110100 00111110 10001111 11001000 00000001 00000101 01100100
10110100 00111110 10001111 11001000 00000001 00000111 01100010
added data:
10110100 00111110 10001111 11001000 00000010 00000110 01100100
10110100 00111110 10001111 11101010 00000010 01100101 10011010
10110100 00111110 10001111 11101010 00000001 01100100 10011100
10110100 00111110 10001111 11101010 00000001 01100011 10011101
10110100 00111110 10001111 11101010 00000001 01100110 10011010
変更する必要のある各要求と送信されるいくつかのコマンドの数があります。たとえば、「その他3」列は00000001ではなく00000010を読み取ることができます。
誰かが私にどこを見ればよいかについてのヒントを教えてくれるととても助かります。バイト間のXORやモジュロの計算など、さまざまな手法を試しました。残念ながら、CRCアルゴリズムのブルートフォースツールも試しましたが、残念ながらまだ成功していません。
編集:私はデータをExcelに入れていくつかの機能を追加しました(基本的に各4ビットを上からのものと比較します-最後の送信)。CRCが1度同じままであることを認識したので、それを行いました。これは、アクションとカウントの両方が1ずつ増加した場合に当てはまります。
更新:
他にももっと詳細な仕様を見つけました。何時間も検索した後、ネット上の同じベンダーから出て、それが出てきたので、CRCは実際には同等です。また、gnuラジオキャプチャフローグラフを微調整し、いくつかの新しいデータを収集しました。上記のデータを無視して、こちらをご覧ください。
other 1> other 2 > other 3> other 4 > parity
10110100 001111101000111111101010 00000001 011110101001 0101
10110100 001111101000111111101010 00000001 011110111001 0110
10110100 001111101000111111101010 00000001 011111001001 0011
10110100 001111101000111111101010 00000001 011111011001 0100
10110100 001111101000111111101010 00000010 011111101001 0100
10110100 001111101000111111101010 00000010 011111111001 0011
10110100 001111101000111111101010 00000010 100000001001 0011
10110100 001111101000111111101010 00000010 100000011001 0100
10110100 001111101000111111101010 00000001 100000101001 0100
10110100 001111101000111111101010 00000001 100000111001 0011
10110100 001111101000111111101010 00000001 100001001001 0110
10110100 001111101000111111101010 00000001 100001011001 0101
10110100 001111101000111111101010 00000010 100001101001 0101
10110100 001111101000111111101010 00000010 100001111001 0110
10110100 001111101000111111101010 00000010 100010001001 1011
10110100 001111101000111111101010 00000010 100010011001 1100
10110100 001111101000111111101010 00000001 100010101001 1100
10110100 001111101000111111101010 00000001 100010111001 1011
10110100 001111101000111111101010 00000001 100011001001 1110
10110100 001111101000111111101010 00000001 100011011001 1101
そして、ファンシーエクセルとして再びここにあります:
誰かがそのパリティを計算する方法を知っていますか?データなどを分割して通常のパリティ計算を試してみましたが、残念ながらまだ成功していません。