python计算CRC16等 智能电能表数据通信协议DL/T 645 - 2007;本部分实现了该协议的部分功能。...temper=('00'+temper).upper()[-2:] h=h+temper ##返回减0x33后的数据 return h ''' 计算16进制字符串的CRC16...校验 @Source 2013-5-10 11:00 ''' def CRC16(s): h='0' for i in range(len(s)/2): h=hex(int...) if len(h)<=1: h='00'+h return h.upper()[-2:] ##68AAAAAAAAAAAA681300DF16 ##print CRC16
crccreatearray是直接返回生成crc的数组,calcrc是校验数组是否符合crc16,返回0表示符合,1表示不符合 class crc16: auchCRCHi = [ 0x00, 0xC1...crchi == array[lenarray-2] and crclo== array[lenarray-1] : return 0 else: return 1 test = crc16
二 CRC16源码解析:1 函数实现#include #include #include #define CRC_POLY_...const unsigned char *input_str, size_t num_bytes ); * * The function crc_16() calculates the 16 bits CRC16...return crc;} /* crc_16 *//* * static void init_crc16_tab( void ); * * For optimal performance uses the CRC16
使用Qt接口对数据进行CRC16校验与基于zlib算法进行解压缩。...CRC16校验 data:输入数据 len:输入数据长度 standard:实现标准 输出:CRC16校验和 quint16 qChecksum(const char *data,
CRC-16 码采用的生成多项式为 G(x) = x16 + x15 + x2 +1 module crc_16( clk,rst,x,crc_reg,crc_...
参考:https://blog.csdn.net/niepangu/article/details/45499383
文章目录 一、配置机器1 二、配置机器2 三、创建集群 1.数据验证 2.在哪个服务器上写数据:CRC16 3.集群和Python交互 ---- 一、配置机器1 172.16.179.130为当前ubuntu...7002 写⼊数据 set name itheima ⾃动跳到了7003服务器,并写⼊数据成功 在7003可以获取数据,如果写入数据又重定向到7000(负载均衡) 2.在哪个服务器上写数据:CRC16...redis cluster 默认分配了 16384 个slot,当我们 set⼀个key 时,会⽤CRC16算法来取模得到所属的slot,然后将这个key 分到哈 希槽区间的节点上,具体算法就是:CRC16...才会启动⼀个对应的 salve 节点,充 当 master 需要注意的是:必须要3个或以上的主节点,否则在创建集群时会失败,并且当存 活的主节点数⼩于总节点数的⼀半时,整个集群就⽆法提供服务了 3.集群和Python...redis_cluster.py,示例码如下 from rediscluster import * if __name__ == '__main__': try: # 构建所有的节点,Redis会使⽤CRC16
crc校验 crc校验常用的有CRC16和CRC32,在通信中用的比较多(modbus协议等),这里不详细介绍其原理了。 crc校验不同多项式,计算结果是不一样的。...{ unsigned int i; unsigned short j,tmp,CRC16; CRC16=0xffff; for ( i = 0; i < len; i++ )...{ CRC16 = *ptr ^ CRC16; for ( j = 0; j < 8; j++ ) { tmp=CRC16 & 0x0001;...CRC16 =CRC16 >>1; if (tmp) CRC16=CRC16 ^ 0xa001; } *ptr++; } return...= 0) cout<<"check file crc16 fault! please add crc16 later!"
而一般电气、自动化仪表的crc16校验,多项式码选用16进制A001。...Go 语言实现如下: // 传入数据内容,返回 crc校验码 func Crc16Check(data []byte) []byte { var crc16 uint16 = 0xFFFF...for j := 0; j < 8; j++ { if crc16&0x0001 > 0 { crc16...= (crc16 >> 1) ^ 0xA001 } else { crc16 >>= 1...packet[0] = byte(crc16 >> 8) return packet }
172.16.179.130、172.16.179.131,这⾥的IP在使⽤时要改为实际值 参考阅读 redis集群搭建 http://www.cnblogs.com/wuxl360/p/5920330.html [Python...在哪个服务器上写数据:CRC16 redis cluster在设计的时候,就考虑到了去中⼼化,去中间件,也就是说,集群中 的每个节点都是平等的关系,都是对等的,每个节点都保存各⾃的数据和整个集 群的状态...redis cluster 默认分配了 16384 个slot,当我们 set⼀个key 时,会⽤CRC16算法来取模得到所属的slot,然后将这个key 分到哈 希槽区间的节点上,具体算法就是:CRC16...挂掉之后,才会启动⼀个对应的 salve 节点,充 当 master 需要注意的是:必须要3个或以上的主节点,否则在创建集群时会失败,并且当存 活的主节点数⼩于总节点数的⼀半时,整个集群就⽆法提供服务了 与Python...redis_cluster.py,示例码如下 from rediscluster import * if __name__ == '__main__': try: # 构建所有的节点,Redis会使⽤CRC16
前言 这一节说明一下数据传输中常用的CRC校验 所谓CRC校验,说白了就是对数据做下计算,然后把计算结果放到最后面 平时用的最多的算是CRC16 直接上菜 计算CRC /** * @brief...calculate CRC * @param *modbusdata: Source data address * @param length: data length * @param * @retval CRC16...* @param *modbusdata: Read data address * @param length: Read data length * @param * @retval 1:CRC16...说明: 1.最后两位 F7 和 BE就是经过CRC16计算之后的数据;高位在前,低位在后 2.整个数据发给另一个设备以后,另一个设备用同样的方式计算 01 00 55 aa 的CRC16值 ...扩展 大部分设备的CRC16计算方式,这个地方是 0xffff, 但是也有0的情况 ?
参考:https://www.cnblogs.com/skullboyer/p/8342167.html 一、CRC16校验码的使用 现选择最常用的CRC-16校验,说明它的使用方法。 ...二、CRC16校验码计算方法 常用查表法和计算法。...------------------------------------------------- unsigned int CRC16; #define SEED 0xFFFF //initialization...for CRC16 #define GP 0xA001 //generating polynomial //for standard CRC16 //(remainder of division...) //to start a new CRC, set CRC16 = SEED //then for each byte call Calc_CRC(byte, &CRC16); //CRC16 will
month/:day/:title/ #permalink_defaults: permalink: posts/:abbrlink/ abbrlink: alg: crc32 #support crc16...default) and hex 下面解释说明一下: 首先指定Hexo文章永久链接的格式,接下来两个是abbrlink插件的设置: alg -- Algorithm (currently support crc16...and crc32, which crc16 is default) rep -- Represent (the generated link could be presented in hex or...dec value) 这两个设置的示例如下: crc16 & hex https://post.zz173.com/posts/66c8.html crc16 & dec https://post.zz173
查找设备);另一个是能不能显示任意消息(消息通知) BLE 抓包 那先来简单抓个包看看吧,BLE 的空口抓包方案我已经做过总结,可以直接参考我的语雀文档: 这里我推荐 Sniffle 这个项目,可以用 python...所以这堆数据的头部我们已经可以看出来了,218 就是 0xDA,i10 是传进来的参数 56 也就是 0x38 后面的内容是传进来的字节数组,再往后有一个 CRC 校验 跟进 CRC 函数,看一下是做的何种校验方式,可以看到明显是 CRC16...,但是是何种 CRC16 呢 打开一个在线 CRC 计算的网站(http://www.ip33.com/crc.html),可以看到一堆 CRC16 的函数,对于 CRC 算法还没有深入了解,我决定先试一试...0xda、0x38 是开头固定的,后面跟 data 的长度 和 data 长度右移 8,再跟上 data,组成要发送的 BLE 指令 最后对 BLE 指令进行 CRC16-IBM 计算,得到两个字节的 CRC16...to_bytes(1,byteorder='big') + (len(data) >> 8 ).to_bytes(1,byteorder='big') ble_data = head + data # 定义CRC16
Redis集群的执行流程分析 哈希槽说明 Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value时,redis 先对 key 使用 crc16 算法算出一个结果...当你往Redis Cluster中加入一个Key时,会根据crc16(key) mod 16384计算这个key应该分布到哪个hash slot中,一个hash slot中会有很多key和value。...通俗来说 Redis 集群有16384个哈希槽,每个key通过CRC16校验后对16384取模来决定放置哪个槽.集群的每个节点负责一部分hash槽,举个例子,比如当前集群有3个节点,那么: 节点 A...执行流程分析 假如redis集群里面能存放90个key,那么redis集群把90key平分到3个主机 redis对每个主机里面30个存储位置都编号,当应用连接到主机1上面时,应该发送一个写的命令 主机使用crc16...算出槽号 如果槽号在1-30 可以直接操作主机1 如果槽号在31-60那么redis会转发到主机2 如果应该再发一个命令set age 22 那么主机2使用crc16再算槽号再转发
二、示例代码 以下C语言代码演示如何获取一段数据的CRC校验值: #include #include // CRC校验函数 uint16_t crc16(uint8...return crc; } // 封装的CRC校验函数调用 uint16_t calculateCRC(uint8_t *data, int length) { return crc16...crc = calculateCRC(message, length); printf("CRC: 0x%04X\n", crc); return 0; } 在上面代码中,crc16...calculateCRC 函数是对 crc16 的封装,用于调用CRC校验函数并返回校验结果。...3.1 发送方(封装校验值) #include #include // CRC校验函数 uint16_t crc16(uint8_t *data, int length
Addr Fun Data start reg hi Data start reg lo Data #of regs hi Data #of regs lo CRC16 hi CRC16 lo 06H...Addr Fun DO start reg hi DO start reg lo DO #of regs hi DO #of regs lo CRC16 hi CRC16 lo 11H 01H 00H...Addr Fun Byte count Data CRC16 hi CRC16 lo 11H 01H 01H 2AH XXH XXH 数据 0 0 0 0 0 0 DO2 DO1 MSB...Addr Fun Byte count Data1 hi Data1 Lo Data 2 hi Data2 lo Data3 hi Data3 lo CRC16 hi CRC16 lo 11H 03H...Addr Fun CRC16 hi CRC16 lo 11H 11H XXH XXH 图示 2-21报告从机标识—-查询 响应 图2 – 22所示正常响应格式,数据内容对应每台控制器的类型。
local datatable={}; for i=1,RevLen do datatable[i] = data:byte(i); end log.info("CRC16...=", CRC16(datatable,RevLen)); --计算CRC function CRC16(modbusdata,length) local i=0;local j=0;local...function CRC16Flage(modbusdata,length) local Receive_CRC = 0;local calculation = 1; Receive_CRC = CRC16
CRC16在使用一条DAT线路的情况下,CRC16用于块传输模式下的有效负载保护。CRC校验和是一个16位的值,计算方法如下:第一个位是相应块的第一个数据位。...在单数据线模式和宽总线模式下应使用相同的CRC16方法在宽总线模式下,CRC16在每条线路上分别完成。...CRC16例子512字节的0xFF data-->CRC16=0x7FA1错误条件 CRC与非法命令所有命令都由CRC (cvclic redundancy check)位保护。
集群架构 ---- redis总共16384个槽 均分给每个主节点(图二中红色部分) 主节点的物理上限为16384个(主节点最少分一个hash槽) 2. crc16算法 算法结果就是槽的取值范围...对集群模式下的所有key进行crc16计算,计算的结果始 终在0-16384之间 对客户端的key进行crc16计算时同一个key经过多次crc16计 算结果始终一致 对客户端的不同的key...进行crc16计算,计算的结果可能会出 现一致 动态增加节点的时候涉及到hash槽的分配 3.集群搭建 判断一个是集群中的节点是否可用,是集群中的所用主节点选举过程,如果半数以上的节点认为当前节点挂掉
领取专属 10元无门槛券
手把手带您无忧上云