找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 3044|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

發(fā)一個(gè)任意數(shù)分頻的程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:499649 發(fā)表于 2019-3-28 09:35 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
本帖最后由 Mystery0724 于 2019-3-28 09:39 編輯

  1. module divide(
  2.                                         clk,
  3.                                         rst_n,
  4.                                         clkout);

  5. input         clk,rst_n;
  6. output        clkout;   

  7. parameter        WIDTH        = 3;         
  8. parameter        N = 5;            

  9. reg         [WIDTH-1:0]        cnt_p,cnt_n;   //cnt_p為上升沿觸發(fā)時(shí)的計(jì)數(shù)器,cnt_n為下降沿觸發(fā)時(shí)的計(jì)數(shù)器
  10. reg        clk_p,clk_n;     //clk_p為上升沿觸發(fā)時(shí)分頻時(shí)鐘,clk_n為下降沿觸發(fā)時(shí)分頻時(shí)鐘

  11. //上升沿觸發(fā)時(shí)計(jì)數(shù)器的控制
  12. always @ (posedge clk or negedge rst_n )         
  13. begin
  14.         if(!rst_n)
  15.                 cnt_p<=0;
  16.         else if (cnt_p==(N-1))
  17.                 cnt_p<=0;
  18.         else cnt_p<=cnt_p+1;            
  19. end
  20.                
  21. always @ (posedge clk or negedge rst_n)
  22. begin
  23.         if(!rst_n)
  24.                 clk_p<=0;
  25.         else if (cnt_p<(N>>1))          //N>>1表示右移一位,相當(dāng)于除以2去掉余數(shù)
  26.                 clk_p<=0;
  27.         else
  28.                 clk_p<=1;               //得到的分頻時(shí)鐘正周期比負(fù)周期多一個(gè)clk時(shí)鐘
  29. end

  30.           //下降沿觸發(fā)時(shí)計(jì)數(shù)器的控制               
  31. always @ (negedge clk or negedge rst_n)
  32.         begin
  33.                 if(!rst_n)
  34.                         cnt_n<=0;
  35.                 else if (cnt_n==(N-1))
  36.                         cnt_n<=0;
  37.                 else cnt_n<=cnt_n+1;
  38.         end

  39.           //下降沿觸發(fā)的分頻時(shí)鐘輸出,和clk_p相差半個(gè)時(shí)鐘
  40. always @ (negedge clk)
  41.         begin
  42.                 if(!rst_n)
  43.                         clk_n<=0;
  44.                 else if (cnt_n<(N>>1))  
  45.                         clk_n<=0;
  46.                 else
  47.                         clk_n<=1;                //得到的分頻時(shí)鐘正周期比負(fù)周期多一個(gè)clk時(shí)鐘
  48.         end

  49.           assign clkout = (N==1)?clk:(N[0])?(clk_p&clk_n):clk_p;      //條件判斷表達(dá)式
  50.                                                                                                                                                                           //當(dāng)N=1時(shí),直接輸出clk
  51.                                                                                                                                                                           //當(dāng)N為偶數(shù)也就是N的最低位為0,N(0)=0,輸出clk_p
  52.                                                                                                                                                                           //當(dāng)N為奇數(shù)也就是N最低位為1,N(0)=1,輸出clk_p&clk_n。正周期多所以是相與
  53. endmodule
復(fù)制代碼


評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:478456 發(fā)表于 2019-7-25 15:06 | 只看該作者
記號(hào)一下
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表