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

標題: 一個超聲波測距模塊,仿真testbench里Trig怎么處理? 求幫助 [打印本頁]

作者: TKNO1    時間: 2019-5-1 17:41
標題: 一個超聲波測距模塊,仿真testbench里Trig怎么處理? 求幫助
有那個大佬幫忙說一下仿真testbench里Trig怎么處理

新建文本文檔.pdf

5.69 KB, 下載次數: 3


作者: TKNO1    時間: 2019-5-1 17:45
module         SRF_Control(sys_clk,sys_rst_n,echo,Distance,Trig);//《基于FPGA的數字系統設計與研究》
                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      




歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 国产伊人精品 | 午夜电影福利 | 一本一道久久a久久精品蜜桃 | 欧美中文字幕一区二区三区亚洲 | 久久久久国产一区二区三区四区 | 亚洲天堂免费在线 | 91在线视频观看免费 | 成人午夜高清 | 日韩精品一区二区三区免费观看 | 国产乱码精品一区二区三区中文 | 欧美成人a∨高清免费观看 老司机午夜性大片 | 久久久久久国产精品免费免费 | 成人在线视频一区二区三区 | 日韩在线视频精品 | 亚洲一区二区三区四区五区中文 | av免费看片 | 午夜羞羞 | 国产一区二区激情视频 | 日本一本视频 | 一级全黄少妇性色生活免费看 | 精品熟人一区二区三区四区 | 精品久久久久一区二区国产 | 午夜国产一级片 | 国产美女在线观看 | 涩涩视频网站在线观看 | 久久久天堂 | 北条麻妃国产九九九精品小说 | 亚洲午夜视频 | 欧美日韩精品免费 | 爽爽免费视频 | 国产大学生情侣呻吟视频 | 国产一区在线免费观看 | 四虎影院在线播放 | 少妇一级淫片aaaaaaaaa | 国产91 在线播放 | 一级全黄少妇性色生活免费看 | 三级免费网 | 国产精品av久久久久久毛片 | 日韩一区不卡 | 国产美女一区 | 一区二区三区欧美在线 |