日本a√视频在线,久久青青亚洲国产,亚洲一区欧美二区,免费g片在线观看网站

        <style id="k3y6c"><u id="k3y6c"></u></style>
        <s id="k3y6c"></s>
        <mark id="k3y6c"></mark>
          
          

          <mark id="k3y6c"></mark>

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 正交解碼及在旋轉(zhuǎn)編碼器中的應(yīng)用

          正交解碼及在旋轉(zhuǎn)編碼器中的應(yīng)用

          作者: 時(shí)間:2024-01-25 來(lái)源:電子森林 收藏

          module quad(clk, quadA, quadB, count);
          input clk, quadA, quadB;
          output [7:0] count; 
          reg quadA_delayed, quadB_delayed;
          always @(posedge clk) quadA_delayed <= quadA;
          always @(posedge clk) quadB_delayed <= quadB; 
          wire count_enable = quadA ^ quadA_delayed ^ quadB ^ quadB_delayed;
          wire count_direction = quadA ^ quadB_delayed; 
          reg [7:0] count;
          always @(posedge clk)begin
            if(count_enable)
            begin
              if(count_direction) count<=count+1; 
              else count<=count-1;
            end
           end 
           endmodule

          實(shí)際的電路

          module quad(clk, quadA, quadB, count);
          input clk, quadA, quadB;output [7:0] count; 
          reg [2:0] quadA_delayed, quadB_delayed;
          always @(posedge clk) quadA_delayed <= {quadA_delayed[1:0], quadA};
          always @(posedge clk) quadB_delayed <= {quadB_delayed[1:0], quadB}; 
          wire count_enable = quadA_delayed[1] ^ quadA_delayed[2] ^ quadB_delayed[1] ^ quadB_delayed[2];
          wire count_direction = quadA_delayed[1] ^ quadB_delayed[2]; 
          reg [7:0] count;
          always @(posedge clk)begin
            if(count_enable)
            begin
              if(count_direction) count<=count+1; else count<=count-1;
            end
           end 
            endmodule


          評(píng)論


          相關(guān)推薦

          技術(shù)專(zhuān)區(qū)

          關(guān)閉