Wincc CRC校验

如何用vb实现CRC(循环码)校验?
 

最佳答案

STEP7编写的不好找,VB编写的网上多的是,呵呵!
 Function CRC16(data() As Byte) As String
       Dim CRC16Lo As Byte, CRC16Hi As Byte      'CRC寄存器
       Dim CL As Byte, CH As Byte                '多项式码&HA001
       Dim SaveHi As Byte, SaveLo As Byte
       Dim i As Integer
       Dim Flag As Integer
       CRC16Lo = &HFF
       CRC16Hi = &HFF
       CL = &H1
       CH = &HA0
       For i = 0 To UBound(data) - 1
         CRC16Lo = CRC16Lo Xor data(i) '每一个数据与CRC寄存器进行异或
         For Flag = 0 To 7
           SaveHi = CRC16Hi
           SaveLo = CRC16Lo
           CRC16Hi = CRC16Hi \ 2            '高位右移一位
           CRC16Lo = CRC16Lo \ 2            '低位右移一位
           If ((SaveHi And &H1) = &H1) Then '如果高位字节最后一位为1
             CRC16Lo = CRC16Lo Or &H80      '则低位字节右移后前面补1
           End If                           '否则自动补0
           If ((SaveLo And &H1) = &H1) Then '如果LSB为1,则与多项式码进行异或
             CRC16Hi = CRC16Hi Xor CH
             CRC16Lo = CRC16Lo Xor CL
           End If
           'Debug.Print Str(i) & ":", CRC16Lo, CRC16Hi
         Next Flag
         'Debug.Print CRC16Lo, CRC16Hi
       Next i
       Dim ReturnData(1) As Byte
       ReturnData(0) = CRC16Lo              'CRC低位
       ReturnData(1) = CRC16Hi              'CRC高位
       CRC16 = CStr(Hex(CRC16Hi)) & CStr(Hex(CRC16Lo))
 End Function
 -------------------------
 调用方法如下:
 Dim data(7) As Byte
 data(0) = &H5
 data(1) = &H1
 data(2) = &H0
 data(3) = &H0
 data(4) = &H2
 data(5) = &H3
 data(6) = &H1
 MsgBox CRC16(data)

提问者对于答案的评价:
正确。能否解释一下A001是什么意思?生成多项式应该是18005阿?
 (crc-16)

原创文章,作者:more0621,如若转载,请注明出处:https://www.zhaoplc.com/plc276124.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2019年6月11日 下午12:08
下一篇 2019年6月11日 下午12:09

相关推荐

  • 有没有wincc中的VB或C脚本函数

    里面的好多函数按F1也搞不懂,如果有个手册就好了,在下载中心找那N久,没得收获,没得办法,提个问题啊。 最佳答案 VBS和C基础可以上网搜索,很多相关教材。 WinCC自…

    SIMATIC WinCC 2019年6月11日
  • wincc怎么制作表格

    请教下,我想在wincc界面制作一个表格,显示比如说学生成绩单那种的表格,可以修改数据,没有现成的编辑器吗?我现在的做法是用输入输出域拼成一个表格,还有更好的做法吗?谢谢 最佳答案…

    SIMATIC WinCC 2019年6月11日
  • WinCC错误码7002、7006

    你好,请教一个问题,WinCC中使用过程中遇到一个情况。原来安装WinCC的系统是英文系统,运行正常,后安装汉化包,投用一段时间(2天)WinCC画面上就变暗了,ping一下是通的…

    SIMATIC WinCC 2019年6月11日
  • winCC服务器冗余

    WinCC6.2服务器冗余需要什么软件硬件条件?具体的设置步骤是怎样的?哪里有参考文档? 最佳答案 1、wincc实现服务器授权,在服务器端除了基本的WINCC的RC或者RT的基本…

    SIMATIC WinCC 2019年6月11日
  • wincc 历史曲线 时间轴

    我想查询 12月1日 0点0分0秒 到 12月31日23点59分59秒,设置的是从开始到结束时间,但每次都是显示从11月30日8点到1月1日…

    SIMATIC WinCC 2021年7月5日
  • WinCC是否有增加点数的授权?

    我司原有一个电厂项目,项目配置是1024点的WinCC V6.0服务器冗余项目,已用去了1010点,现业主增加了一台锅炉,需挂在原WinCC V6.0冗余服务下…

    SIMATIC WinCC 2019年6月11日
  • 求教,这语句什么意思

    dim lastlast=HMIRuntime.DataSet("last").Value 最佳答案 DataSet对象可用于保存各种类型的对象或变量…

    SIMATIC WinCC 2019年6月10日
  • wincc 如何 让plc实现关机命令

    SMART PLC 如何实现C脚本,或者其他方法让wincc 自动关机 钻石用户推荐最佳答案 C脚本:ExitWinCC();直接退出WinCC运行系…

    SIMATIC WinCC 2021年7月5日
  • 求助:WinCC中如何实现对本地图片的动态显示?

    场景:有一产品缺陷视觉检测装置,工业摄像机拍摄的图片经处理后保存在本地硬盘。流程:拍照——下位机检测——存到上位机——WinCC中显示问题:如何在WinCC中动态显示产品图片?即在…

    SIMATIC WinCC 2017年6月13日
  • wincc C语言动作无效

    一个编译无误的项目程序,c语言等动作都正常。昨天安装了300的PLCSIM仿真,然后卸载了wincc6.0的智能工具又安装回去,再编译WINCC项目就不行了,仿真时鼠标点击,C语言…

    SIMATIC WinCC 2019年6月11日