【无标题】


crc16校验示例,原理还没弄懂,先应用再说

#include <stdio.h>
#include <stdint.h>

// CRC16多项式
#define CRC16_POLYNOMIAL 0x8005

// 计算CRC16校验码
uint16_t calculate_crc16(const uint8_t *data, size_t length) {
    uint16_t crc = 0xFFFF;

    for (size_t i = 0; i < length; ++i) {
        crc ^= (uint16_t)data[i];
        for (int j = 0; j < 8; ++j) {
            if (crc & 0x0001) {
                crc = (crc >> 1) ^ CRC16_POLYNOMIAL;
            } else {
                crc >>= 1;
            }
        }
    }

    return crc;
}

int main() {
    // 示例数据
    uint8_t data[] = "Hello, CRC16!";
    size_t data_length = sizeof(data) - 1; // 减1是为了排除字符串结束符

    // 计算CRC16校验码
    uint16_t crc = calculate_crc16(data, data_length);

    // 打印CRC16校验码
    printf("CRC16 Checksum: 0x%04X\n", crc);

    return 0;
}

在这里插入代码片
#include <iostream>
#include <cstdint>

// CRC16查表法
static const uint16_t crc16_table[] = {
    0x0000, 0x1021, 0x2042, 0x3063, 0x4084, 0x50A5, 0x60C6, 0x70E7,
    0x8108, 0x9129, 0xA14A, 0xB16B, 0xC18C, 0xD1AD, 0xE1CE, 0xF1EF
};

// 计算CRC16校验值
uint16_t calculateCRC16(const uint8_t* data, size_t length) {
    uint16_t crc = 0;
    for (size_t i = 0; i < length; ++i) {
        crc = (crc << 4) ^ crc16_table[((crc >> 12) ^ (data[i] >> 4)) & 0x0F];
        crc = (crc << 4) ^ crc16_table[((crc >> 12) ^ (data[i] & 0x0F)) & 0x0F];
    }
    return crc;
}

int main() {
    // 示例数据
    uint8_t data[] = {0x01, 0x02, 0x03, 0x04, 0x05};
    size_t dataLength = sizeof(data) / sizeof(data[0]);

    // 计算CRC16校验值
    uint16_t crc16 = calculateCRC16(data, dataLength);

    // 输出CRC16校验值
    std::cout << "CRC16校验值: 0x" << std::hex << crc16 << std::endl;

    return 0;
}


RS译码
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值