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

网站建设外包工作室百度关键词价格

网站建设外包工作室,百度关键词价格,武汉互联网公司排行榜,设计网站需要哪些流程6、有限状态机状态机,只要C代码写过2年的人,估计无人不识君,稍微复杂的逻辑都可以借助状态机来简化问题。为了方便,我们使用前面用过的一个例子,来说明状态机的应用,也就是说我们前面已经有意无意的用过状态…

6、有限状态机

状态机,只要C代码写过2年的人,估计无人不识君,稍微复杂的逻辑都可以借助状态机来简化问题。

为了方便,我们使用前面用过的一个例子,来说明状态机的应用,也就是说我们前面已经有意无意的用过状态机了。

我们以SPI的Slave接口,为例,来说明状态机的使用


为了简化问题
1、我们没有把信号同步到本地时钟
2、把其他信号同步到SCK
3、我们把SPI暂时按照单向来分析

下面,我们分析SPI通讯
1、nCS高电平时候,总线是空闲的
2、nCS低电平时传输数据
3、满了8个bit,凑够了一个字节,要保存当前已经收到的字节,并准备收下一个;

nCS高电平的时候,我们称之为idel态(IDEL)
接受0~7逐个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(nCS==1'b1)
                next_state = IDEL;
            else
                next_state = BIT_RECV;
        BIT_RECV:
            if(nCS==1'b0)
            bgein
                if(bitcnt<4'h8)
                    next_state = BIT_RECV;
                else
                    next_state = BYTE_SAVE;
            end
            else
                next_state = IDEL;
        BYTE_SAVE:
            if(nCS==1'b0)
                next_state = BIT_RECV;
            else
                next_state = IDEL;
        defalut:
            next_state = IDEL;
        endcase
    end


    always @(posdge SCK)
        if(nCS)
            bitcnt=0;
        else
            state = next_state


    always @(posdge SCK)
        case(state)
        BIT_RECV:
            begin
                bitcnt <= bitcnt+4'h1;
                shift_in <= {shift_in[6:0], MOSI};
            end
        BYTE_SAVE:
            begin
                bitcnt <= 4'h0;
                data <= deshift_in;
            end
        endcase
   
我用了所谓的三段式,来描述这个状态机,用了3个always语句
第一个always用来描述状态转移的条件
第二个always用来描述状态转移
第三个always用来描述状态机的输出,也就是状态机实际要干的活


与前面帖子(同步和异步设计)中的SPI代码相比,是不是冗长了很多。
冗长,并不代表着脱裤子放屁,自找麻烦。您难道没有反显,代码很容易读懂了吗?

没错,这就是空间换时间的策略,我们写更长的代码来增强可分析性。

状态机的代码撰写一般不复杂,复杂的是状态机的构建过程,这个过程中,我们要分析
实际遇到的各个情况,同时把状态机进行优化,某些状态进行合并,某些状态去掉。
  
有人问,为何某些状态要去掉?
这要说下FSM的来头了,有限状态机,是有限的状态机。
自然界实际的状态机,往往起状态的数量,是非常大的,直接建模使用简直是劳民伤财。
而且,现实的往往是无限的状态机,这根本无法用于工程实现,所以有限状态机就横空出世了。

正如,软件算法中的DAG(Directed Acyclic Graph)有向无环图,比纯粹的图有实用价值。
二叉树,比多叉树,也更容易实现。

越说,软件和FPGA越近了。可谓是天下大势,分久必合,合久必分。

http://www.shuangfujiaoyu.com/news/40562.html

相关文章:

  • 旅行社做网站如何优化seo技巧
  • 网站建设程序员做什么举例一个成功的网络营销案例
  • mui做的h5网站案例企业推广的渠道有哪些
  • 河南官网网站建设seo工作内容和薪资
  • 做效果图网站比较经典的营销案例
  • 网站请人做的 域名自己注册的 知道网站后台 怎么挂自己的服务器各平台推广费用
  • wordpress 标签页面seo优化推广流程
  • 品牌工厂网站建设大型网站建站公司
  • 网站做营销推广的公司网站网络营销公司
  • 网站推广应注意哪些事项长春seo整站优化
  • 网页浏览器大全百度官方优化指南
  • 个人网站备案备注新媒体seo指的是什么
  • dw软件做的网站怎么发到网上推广赚钱的软件
  • 微信微网站平台百度搜索关键词怎么刷上去
  • 南宁共建站杭州推广系统
  • 衢州网站建设哪家好网站安全检测平台
  • cf刷枪网站怎么做的微营销推广软件
  • 做网站需要什么材料东营seo整站优化
  • 阳江市住房和城乡建设局网站专业放心关键词优化参考价格
  • 哪家做的濮阳网站建设网络培训班
  • 做网站以前出名的公司腾讯云建站
  • 淘宝上面的网站建设是靠谱龙岗网络公司
  • 专门做搞笑视频的网站友情链接交易
  • 免费网站入口2021五合一网站建设
  • wordpress录入表单写数据库优化网站价格
  • 珠宝类网站建设百度关键词推广
  • 厦门首屈一指的网站建设公司南京百度快速排名优化
  • 用dw6做网站首页seo的培训班
  • 公司网站设计好河北关键词排名推广
  • 小程序导航网站开发网络营销考试答案