当前位置: 首页 > news >正文

中国建设银行公积金网缴网站长辛店网站建设

中国建设银行公积金网缴网站,长辛店网站建设,百度推广公司电话,现如今网站开发用什么框架6、有限状态机状态机#xff0c;只要C代码写过2年的人#xff0c;估计无人不识君#xff0c;稍微复杂的逻辑都可以借助状态机来简化问题。为了方便#xff0c;我们使用前面用过的一个例子#xff0c;来说明状态机的应用#xff0c;也就是说我们前面已经有意无意的用过状态…6、有限状态机状态机只要C代码写过2年的人估计无人不识君稍微复杂的逻辑都可以借助状态机来简化问题。为了方便我们使用前面用过的一个例子来说明状态机的应用也就是说我们前面已经有意无意的用过状态机了。我们以SPI的Slave接口为例来说明状态机的使用为了简化问题1、我们没有把信号同步到本地时钟2、把其他信号同步到SCK3、我们把SPI暂时按照单向来分析下面我们分析SPI通讯1、nCS高电平时候总线是空闲的2、nCS低电平时传输数据3、满了8个bit凑够了一个字节要保存当前已经收到的字节并准备收下一个nCS高电平的时候我们称之为idel态IDEL接受07逐个bit的时候称之为bit接受态BIT_RECV收满一个字节称之为字节转存态BYTE_SAVE model SlaveSPI(input nCS, input SCK, input MOSI, output MISO); parameter IDEL 0,           BIT_RECV 1,           BIT_SAVE 2;     reg[3:0]    bitcnt;     reg[7:0]    shift_in;   //写入     reg[7:0]    shift_out;  //读出     reg[7:0]    data;     reg[1:0]    state;     reg[1:0]    next_state;     always (*)     begin         case(state)         IDEL:             if(nCS1b1)                 next_state IDEL;             else                 next_state BIT_RECV;         BIT_RECV:             if(nCS1b0)             bgein                 if(bitcnt4h8)                     next_state BIT_RECV;                 else                     next_state BYTE_SAVE;             end             else                 next_state IDEL;         BYTE_SAVE:             if(nCS1b0)                 next_state BIT_RECV;             else                 next_state IDEL;         defalut:             next_state IDEL;         endcase     end     always (posdge SCK)         if(nCS)             bitcnt0;         else             state next_state     always (posdge SCK)         case(state)         BIT_RECV:             begin                 bitcnt bitcnt4h1;                 shift_in {shift_in[6:0], MOSI};             end         BYTE_SAVE:             begin                 bitcnt 4h0;                 data deshift_in;             end         endcase     我用了所谓的三段式来描述这个状态机用了3个always语句 第一个always用来描述状态转移的条件 第二个always用来描述状态转移 第三个always用来描述状态机的输出也就是状态机实际要干的活 与前面帖子(同步和异步设计)中的SPI代码相比是不是冗长了很多。 冗长并不代表着脱裤子放屁自找麻烦。您难道没有反显代码很容易读懂了吗 没错这就是空间换时间的策略我们写更长的代码来增强可分析性。 状态机的代码撰写一般不复杂复杂的是状态机的构建过程这个过程中我们要分析 实际遇到的各个情况同时把状态机进行优化某些状态进行合并某些状态去掉。    有人问为何某些状态要去掉 这要说下FSM的来头了有限状态机是有限的状态机。 自然界实际的状态机往往起状态的数量是非常大的直接建模使用简直是劳民伤财。 而且现实的往往是无限的状态机这根本无法用于工程实现所以有限状态机就横空出世了。 正如软件算法中的DAGDirected Acyclic Graph有向无环图比纯粹的图有实用价值。 二叉树比多叉树也更容易实现。 越说软件和FPGA越近了。可谓是天下大势分久必合合久必分。
http://www.w-s-a.com/news/909799/

相关文章:

  • 广东网站建设咨询电话好牌子网
  • 公司怎样制作网站南阳网站关键词
  • 营销型网站建设与网盟完整php网站开发
  • 网站做微信链接怎么做的石桥铺网站建设公司
  • 济南mip网站建设公司做图书馆网站模板
  • app 门户网站网站项目框架
  • 做网站视频网站备案 新闻审批号
  • 织梦网站怎么居中视频网站开发与制作
  • 网站上海备案佛山网站seo哪家好
  • 品牌形象网站有哪些珠海市区工商年报在哪个网站做
  • 注册域名不建设网站seo外包服务方案
  • 如何进行外贸网站建设wordpress文章输入密码可见
  • 政务网站建设索引常州做网站信息
  • 南宁做网站找哪家好wordpress 更改首页
  • 一个人在家做网站建设品牌策划流程
  • 小网站广告投放wordpress页面添加js
  • 仿制别人的竞价网站做竞价犯法吗wordpress添加版块
  • wordpress主题 站长互联网站备案表
  • 广州品牌策划公司排行南宁seo网络推广公司
  • 营销型网站图片肯德基网站开发
  • 网站的外链是什么wordpress开启菜单
  • 文字字体是什么网站西安博达网站建设
  • 北京南昌网站建设网站查看空间商
  • 网站建设人员职责分布乐清市网站建设设计
  • 网站建设etw网站建设陕西
  • 网站文章页内链结构不好可以改吗wordpress英文模板下载
  • 北京天通苑 做网站哈尔滨快速网站排名
  • 网站开发负责人是什么职位试剂网站建设
  • 什么是展示型网站wordpress链接视频
  • 佳木斯城乡建设局网站过年做哪个网站能致富