久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1526|回復: 0
打印 上一主題 下一主題
收起左側

有那個大佬幫忙說一下仿真testbench里Trig信號怎么設置嗎?

[復制鏈接]
跳轉到指定樓層
樓主
ID:525536 發表于 2019-5-1 21:21 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
module  SRF_Control(sys_clk,sys_rst_n,echo,Distance,Trig):
                input                       sys_clk;
                input                       sys_rst_n;
                input                       echo;
                output[13:0]                Distance;
                output                      Trig;
      
      
      
      reg                         Trig;
                reg[31:0]                   Distance_r;
                assign                      Distance = Distance_r/2941;//calculate and output ultrasonic obstacle distance value
                reg[3:0]                    State;
                reg[31:0]                   Trig_cnt;
                reg[31:0]                   Timeout_cnt;
                reg[31:0]                   echo_cnt;
                reg                         echo_r;
               
                always@(posedge sys_clk or negedge sys_rst_n)
                begin
                         if(!sys_rst_n)
                                           echo_r <= 1'b0;
                         else
                                           echo_r <= echo;
                end

                always@(posedge sys_clk or negedge sys_rst_n)
                begin
                if(!sys_rst_n)
                         begin
                         State        <= 4'd0 ;
                         Trig          <= 1'b0;
                         Trig_cnt    <= 32'd0 ;
                         echo_cnt   <= 32'd0 ;
                         Distance_r <= 32'd0 ;
                         Timeout_cnt   <= 32'd0;
                         end
                else
                         begin
                         case(State)
                         4'd0:        begin
                                         Trig          <= 1'b0;
                                         Trig_cnt    <= 32'd0;
                                         echo_cnt   <= 32'd0;
                                         Timeout_cnt   <= 32'd0;
                                         State          <= 4'd1;
                                         end
                         4'd1:        begin
                                         Trig          <= 1'b1;
                                         if(Trig_cnt==32'd500000)begin
                                                         Trig_cnt <= 32'd0;
                                                         State <= 4'd2;
                                                         end
                                         else begin
                                                         Trig_cnt <= Trig_cnt+1;
                                                         State <= 4'd1;
                              end
              end
                        4'd2:         begin
                                         Trig    <= 1'b0;
                                         if(Trig_cnt == 32'd500)begin
                                                          Trig_cnt <= 32'd0;
                                                          State      <= 4'd3;
                                                          end
                                         else begin
                                                          Trig_cnt <= Trig_cnt+1;
                                                          State     <= 4'd2;
                                                          end
                                         end            
                        4'd3:         begin              
                                         if(!echo_r)      
                                                          State <= 4'd4;
                                         else            
                                                          State <= 4'd3;
                                         end
                        4'd4:         begin
                                         if(!echo_r)  State <= 4'd5;
                                         else if(Timeout_cnt == 32'd50000000)begin
                                                           Timeout_cnt <= 0;
                                                           State   <=   4'd0;  end
                                         else begin
                                                           Timeout_cnt <= Timeout_cnt+1;
                                                           State    <=   4'd4;  end
                                         end            
                        4'd5:         begin         
                                         if(!echo_r)  State    <=   4'd6;
                                         else begin  
                                                           echo_cnt <= echo_cnt+1;
                                                           State    <=   4'd5;
                                                end      
                                         end            
                        4'd6:         begin           
                                         Distance_r <= echo_cnt;
                                         if(Timeout_cnt == 32'd50000000) begin
                                                           Timeout_cnt <= 0;
                                                           State   <=   4'd0;   end
                                         else begin  Timeout_cnt <= Timeout_cnt+1;
                                                           State   <=   4'd6;   end
                                         State   <=   4'd0;
                                         end
                        default:     State   <=   4'd0;
                        endcase
                        end
               end
endmodule      
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产婷婷精品 | www.99久久.com | 色综合天天天天做夜夜夜夜做 | 久久99精品久久久久久 | 欧美乱大交xxxxx另类电影 | 国产精品视频久久久 | 午夜精品一区二区三区在线观看 | 涩涩鲁亚洲精品一区二区 | 成人99| 日韩免费一级 | 国产良家自拍 | av中文在线 | 福利影院在线看 | 欧美日韩在线观看一区 | 一区中文字幕 | 亚洲成人免费 | 免费国产精品久久久久久 | 一区二区三区四区视频 | 人人干视频在线 | 欧美日韩中文在线 | 欧美性成人 | www久久爱 | 亚洲中午字幕 | 久久久久久国产 | www中文字幕 | 久久婷婷香蕉热狠狠综合 | 国产精品亚洲视频 | 国产欧美日韩综合精品一区二区 | 一区二区三区四区视频 | 在线免费视频一区 | 激情五月综合网 | 中文字幕在线观看视频一区 | 日韩av免费在线观看 | 成人免费视频在线观看 | 亚洲一区二区三区国产 | www.黄色片视频 | 久久av.com | 欧美成年网站 | 国产一区二区 | 亚洲a视频| 国产精品视频久久久 |