学习利用Verilog的crc校验码生成
关于crc校验码的原理,就不详细的说了,感觉心里明白就可,比赛前再看看。
求法大概这样:
给定一个生成多项式g(x)=xn1+xn2+… …+1,这里最高幂次假设是m。
假设g(x) = x4 + x3 + 1,则对应代码为G = 11001。
要发送的信息为A
假设A = 1011001,接着将A左移m位(即在A右侧添m个零)得到B
然后用B模二除G,所得的余数就是校验字段crc校验码。
模2除法的原理
通过上面的计算过程可以看出,做模2除法,其实就是按位异或运算^,把握住这一点,再通过对B不断移位与G做异或,就可以得到最后的结果。
这是肥子同学提供给我参考的代码,他用了去年老师讲的思路,每一次给din_temp左移一位,然后判断最高位是不是1,(如果是0就说明被除数位数不够,需要再移一位)是1的话就进行模二除法(也就是与G按G的位数按位异或)。
(啰嗦的话)
前几天刚看完台剧想见你,太好看了也,王诠胜也太符合在下的审美了。剧情一点都不狗血,本来还想“爱情悬疑剧”能拍出个啥,没想到第一天晚上就被反派诡异的笑容吓得睡不着觉。最后陈韵如真正的死因不仅不牵强,而且竟然让人有些共鸣?
看完我一直在想自己的这段感情,抛开所有所有的不谈,我真的快乐吗?我是不是被一些次要次要的东西迷惑了眼睛,所以觉得真正重要的东西反而可无可有呢。我从心里,我身上的每一个细胞都知道这个人是很好的人,这样继续下去未尝不是很好的归宿。可是我还太年轻了啊,在内心并不确定的情况下,怎么肯就这么安顿下来呢。
"NOT THAT DESPERATE YET. "
两个月前我认为的幸福跟现在理解的就已经大相径庭了。谁知道再几个月后,再几年后我又会怎么想呢。
每次回想这个过程,我都十分感激他为我做的一切一切。我也相信换了其他人一定不会比他做得更好。温柔、善良也正是每个温暖的归宿必要的条件。可我就是知道,我不会跟他走下去了。是我不好对不起他。可是再想想,我这样的人,这么坏的人,干嘛要去祸害他呢,让他走又何尝不是救了他呢。hhh
再啰嗦一下,本来以为队友是学弟所以不会很厉害,结果人家不但做完了而且比我做的还快。果然,前几年划水划的太多,竟然让我以为所有人都跟我一样水。划水是进步的最大阻力。幸亏这次下定决心好好做,就算不会也要做下去吧,别辜负了这么百年难遇的好队友。愿意干活的就是好队友了。(这么一比较,感觉之前每一次组的队都是些什么垃圾啊。)