This repository contains a Python, and a C implementation of the Hamming(7,4) code, which is used for error detection and correction in binary data. The project provides functions to encode binary strings using Hamming codes, detect and correct single-bit errors, and convert between binary strings and bytes. A special feature of this implementation is the automatic handling of padding to ensure data integrity during encoding and decoding, without having bother with the padding length to decode the data.
- Hamming(7,4) Encoding: Encode 4-bit binary data into 7-bit Hamming code.
- Error Detection and Correction: Detect and correct single-bit errors in the encoded data.
- Binary String Conversion: Convert between binary strings and byte data.
- Automatic Padding Management: Automatically handle padding to ensure data integrity.
- Python 3.x (For the python implementation)
Clone the repository to your local machine:
git clone https://github.com/Silenttttttt/hamming-code-error-correction.git
cd hamming-code-error-correction
Run python hamming.py
to see an example of the encoding and decoding:
The script includes an example that encodes the string "Hello world!" into a binary string, introduces an error, and then decodes and corrects the error to retrieve the original message.
In digital communication, data often needs to be aligned to specific bit lengths. The automatic padding feature in this implementation ensures that the binary data is correctly aligned for Hamming(7,4) encoding. Here's how it works:
-
Padding Calculation: The algorithm calculates the number of padding bits required to make the length of the binary data a multiple of 4. This is necessary because Hamming(7,4) encoding operates on 4-bit blocks.
-
Padding Addition: The calculated padding bits (zeros) are appended to the binary data. This ensures that the data can be divided into complete 4-bit blocks for encoding.
-
Padding Information Encoding: The number of padding bits added is encoded as a 4-bit binary string, with the rightmost bit set to
1
as a marker. The preceding 3 bits represent the padding length. -
Padding Removal: During decoding, the padding information is extracted from the encoded data. The algorithm uses this information to remove the padding bits, restoring the original data length.
This automatic padding management ensures that the data integrity is maintained throughout the encoding and decoding process, allowing for accurate error detection and correction.
generate_hamming_code(data_bits: str) -> str
: Generates a Hamming(7,4) code from 4 data bits.detect_and_correct_error(hamming_code: str) -> str
: Detects and corrects a single-bit error in a Hamming(7,4) code.encode_binary_string(data_bits: str) -> str
: Encodes a binary string using Hamming(7,4) encoding.decode_binary_string(encoded_string: str) -> str
: Decodes a binary string encoded with Hamming(7,4) and corrects errors.bytes_to_binary_string(byte_data: bytes) -> str
: Converts bytes to an 8-bit binary string.binary_string_to_bytes(binary_str: str) -> bytes
: Converts a binary string back to bytes.
Contributions are welcome! Please feel free to submit a pull request or open an issue.
This project is licensed under the MIT License - see the LICENSE file for details.
- The big man Hamming