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

站长工具麻豆谷歌seo实战教程

站长工具麻豆,谷歌seo实战教程,网站开发项目周期的,上海seo招聘软件版本:无 操作系统:WIN10 64bit 硬件平台:适用所有系列FPGA 板卡获取平台:https://milianke.tmall.com/ 登录“米联客”FPGA社区 http://www.uisrc.com 视频课程、答疑解惑! 1概述 本小节讲解Verilog语法的时钟…

软件版本:无

操作系统:WIN10 64bit

硬件平台:适用所有系列FPGA

板卡获取平台:https://milianke.tmall.com/

登录“米联客”FPGA社区 http://www.uisrc.com 视频课程、答疑解惑!

1概述

本小节讲解Verilog语法的时钟分频设计,需要掌握时钟的特性,以及如何进行时钟分频设计。

2时钟分频

在FPGA的硬件电路设计中,PCB板上需要有时钟产生源,常见的外部时钟源有RC/LC 振荡电路,无源/有源晶体振荡器,利用石英晶体的压电效应产生谐振信号。此类时钟源频率精度高,稳定性好,噪声低,温漂小。有源晶振中,往往还加入了压控或温度补偿,时钟的相位和频率都有较好的特性。

有时我们在时序电路设计中,有些模块工作频率会低于外部时钟频率,此时就需要对时钟进行一定的分频得到频率较低的时钟。在FPGA内部常常存在一定的PLL(锁相环,Phase Locked Loop)资源,它可以对时钟进行分频或者倍频的操作。

本小节主要介绍如何使用寄存器等资源实现时钟偶数分频、奇数分频和小数分频的。

2.1 偶数分频

偶数分频直接使用寄存器进行取反操作,可以得到二分频、四分频、六分频、八分频等,且占空比是50%。例:

module even_div(input     rst_n,                                    //输入复位input     clk,                                      //输入时钟output    clk_div                                   //分频时钟);parameter DIV_NUM = 6;                             //分频参数reg [15:0] clk_cnt;reg clk_out;always @(posedge clk or negedge rst_n)beginif (!rst_n)beginclk_cnt     <= 'b0 ;endelse if(clk_cnt == ((DIV_NUM/2) -1))       beginclk_cnt     <= 'b0;endelsebeginclk_cnt     <= clk_cnt + 1'b1;                   //分频计数器end endalways @(posedge clk or negedge rst_n)beginif (!rst_n)beginclk_out     <= 'b0 ;endelse if(clk_cnt == ((DIV_NUM/2) -1))          //计数到分频参数的一半beginclk_out     <= ~clk_out;                    //产生翻转endelsebeginclk_out     <= clk_out;                      //否则保持不变end endassign clk_div = clk_out;endmodule

 

2.2 奇数分频

如果奇数分频不要求占空比是50%,可以按照类似的偶数分频进行处理。如果奇数分频要求占空比是50%,我们以三分频为例进行讲解如何进行奇数分频。

时序如图所示:

例:

module odd_div(input               rst_n,input               clk,output              clk_div);parameter DIV_NUM = 3;reg [15:0] clk_cnt;reg clk_out;reg clk_div_1;reg clk_div_2;always @(posedge clk or negedge rst_n)beginif (!rst_n)beginclk_cnt     <= 'b0;endelse if(clk_cnt == (DIV_NUM - 1))              //产生计数beginclk_cnt     <= 'b0;                          //clk_cnt清零复位endelsebeginclk_cnt     <= clk_cnt + 1'b1;              //clk_cnt为0、1、2end endalways @(posedge clk or negedge rst_n)               //clk上升沿触发beginif (!rst_n)beginclk_div_1 <= 1'b0;endelse if (clk_cnt == (DIV_NUM >> 1)-1 )           //clk_cnt 为0时,clk_div_1为0begin clk_div_1 <= 1'b0;endelse if (clk_cnt == DIV_NUM-1)                    //clk_cnt 为2时,clk_div_1为1begin clk_div_1 <= 1'b1;endelse begin clk_div_1 <= clk_div_1;                         //clk_cnt 为2时,clk_div_1为0end endalways @(negedge clk or negedge rst_n)                 //clk下降沿触发beginif (!rst_n)beginclk_div_2 <= 1'b0;endelse if (clk_cnt == (DIV_NUM >> 1)-1 )           //clk_cnt 为0时,clk_div_1为0begin clk_div_2 <= 1'b0;endelse if (clk_cnt == DIV_NUM-1)                    //clk_cnt 为2时,clk_div_1为1begin clk_div_2 <= 1'b1;endelse begin clk_div_2 <= clk_div_2;end endassign clk_div = clk_div_1 | clk_div_2 ;            //clk_div_1与clk_div_2产生三分频时钟endmodule

 

2.3 小数分频

使用Verilog不能进行精确的小数分频,但是可以在长时间内达到的平均频率接近小数分频的频率。

举例说明使用平均频率求解小数分频的方法,例如进行6.7倍分频,需要保证源时钟67个周期的时间等于分频时钟10个周期的时间即可。此时需要在67个源时钟周期内进行3次6分频,7次7分频。

具体的实现过程如下:

当进行分频时考虑67个源时钟周期需要进行10次分频,即需要3次每6个周期进行分频和7次每7个周期进行分频,即完了6.7倍分频。我们进行分频时需要将两个分频进行穿插交替,不能一直按照一种倍数频率进行分频,否则会造成相位抖动过大。

如何决定分频的前后顺序呢?我们根据差值进行比较来选择相应的分频倍数,具体过程如下:

  1. 第一次进行分频,67 – 10*6 = 7 < 10 ,第一次进行6分频。
  2. 第二次进行分频,加上上次的7+7 =14 >= 10,第二次进行7分频。
  3. 第三次进行分频,加上上次的7+4 =11 >= 10,第三次进行7分频。
  4. 第四次进行分频,加上上次的7+1 =8< 10 , 第四次进行6分频。
  5. 第五次进行分频,加上上次的7+8=15 >= 10,第五次进行7分频。
  6. 第六次进行分频,加上上次的7+5 =12 >= 10 , 第六次进行7分频。
  7. 第七次进行分频,加上上次的7+2=9 < 10,第七次进行6分频。
  8. 第八次进行分频,加上上次的7+9=16 >= 10,第八次进行7分频。
  9. 第九次进行分频,加上上次的7+6=13 >= 10,第九次进行7分频。
  10. 第十次进行分频,加上上次的7+3=10 >= 10,第十次进行7分频。

例:

module frac_div(input               rst_n ,input               clk,output reg          clk_div);parameter    SOURCE_NUM = 67;parameter    DEST_NUM   = 10;parameter    SOURCE_DIV = SOURCE_NUM/DEST_NUM;parameter    DEST_DIV   = SOURCE_DIV + 1;parameter    DIFF_ADD   = SOURCE_NUM - SOURCE_DIV*DEST_NUM;reg [7:0]            cnt_end_num;reg [7:0]            div_cnt;  wire[7:0]            diff_cnt;reg [7:0]            diff_cnt_ff;wire                 diff_cnt_en;always @(posedge clk or negedge rst_n)beginif (!rst_n)begindiv_cnt  <= 'b0 ;clk_div  <= 1'b0 ;endelse if (div_cnt == cnt_end_num)begindiv_cnt    <= 'b0 ;clk_div    <= 1'b1 ;endelse begindiv_cnt    <= div_cnt + 1'b1 ;clk_div    <= 1'b0 ;endendassign diff_cnt_en = div_cnt == cnt_end_num ;assign  diff_cnt = diff_cnt_ff >= DEST_NUM ?diff_cnt_ff -10 + DIFF_ADD :diff_cnt_ff     + DIFF_ADD ;                                always @(posedge clk or negedge rst_n)beginif (!rst_n)begindiff_cnt_ff <= 0 ;endelse if (diff_cnt_en)begindiff_cnt_ff <= diff_cnt ;endendalways @(posedge clk or negedge rst_n)beginif (!rst_n)cnt_end_num      <= SOURCE_DIV-1 ;else if (diff_cnt >= 10)cnt_end_num      <= DEST_DIV-1 ;elsecnt_end_num      <= SOURCE_DIV-1 ;endendmodule

 

如果对时钟精度等要求比较高建议使用PLL进行分频。


文章转载自:
http://interfering.brjq.cn
http://ifpi.brjq.cn
http://headboard.brjq.cn
http://stockman.brjq.cn
http://cowtail.brjq.cn
http://sylvicultural.brjq.cn
http://irreversibility.brjq.cn
http://anapest.brjq.cn
http://spirula.brjq.cn
http://amatol.brjq.cn
http://clod.brjq.cn
http://rappel.brjq.cn
http://erythron.brjq.cn
http://taxi.brjq.cn
http://disroot.brjq.cn
http://escapement.brjq.cn
http://tipstaff.brjq.cn
http://astrolabe.brjq.cn
http://contessa.brjq.cn
http://timeserver.brjq.cn
http://hippological.brjq.cn
http://discontinuer.brjq.cn
http://gunn.brjq.cn
http://namable.brjq.cn
http://unlabored.brjq.cn
http://ovaritis.brjq.cn
http://seral.brjq.cn
http://stealth.brjq.cn
http://cognizance.brjq.cn
http://nudist.brjq.cn
http://lcvp.brjq.cn
http://ringdove.brjq.cn
http://officialdom.brjq.cn
http://biddable.brjq.cn
http://gyani.brjq.cn
http://fluvio.brjq.cn
http://pastelist.brjq.cn
http://clithral.brjq.cn
http://supercalender.brjq.cn
http://quinquevalence.brjq.cn
http://sandalwood.brjq.cn
http://quadrifoliate.brjq.cn
http://aquatic.brjq.cn
http://organizer.brjq.cn
http://muddle.brjq.cn
http://hawsepipe.brjq.cn
http://ebcdic.brjq.cn
http://counterplead.brjq.cn
http://assistant.brjq.cn
http://protandry.brjq.cn
http://wayfare.brjq.cn
http://rowdy.brjq.cn
http://cataract.brjq.cn
http://hijinks.brjq.cn
http://ujamaa.brjq.cn
http://knowledgeability.brjq.cn
http://obeah.brjq.cn
http://drencher.brjq.cn
http://jocularity.brjq.cn
http://jat.brjq.cn
http://spadix.brjq.cn
http://jactance.brjq.cn
http://backsight.brjq.cn
http://polyspermous.brjq.cn
http://cannelure.brjq.cn
http://entomb.brjq.cn
http://prothalamion.brjq.cn
http://diverse.brjq.cn
http://vitamer.brjq.cn
http://pantsuit.brjq.cn
http://squander.brjq.cn
http://tensegrity.brjq.cn
http://decimator.brjq.cn
http://disciform.brjq.cn
http://neutrodyne.brjq.cn
http://repressive.brjq.cn
http://divertingly.brjq.cn
http://bollard.brjq.cn
http://autolatry.brjq.cn
http://heddle.brjq.cn
http://xerantic.brjq.cn
http://folklore.brjq.cn
http://crackle.brjq.cn
http://astable.brjq.cn
http://buzzsaw.brjq.cn
http://sima.brjq.cn
http://footlights.brjq.cn
http://mahatma.brjq.cn
http://heroism.brjq.cn
http://inflict.brjq.cn
http://demonology.brjq.cn
http://cordierite.brjq.cn
http://criminalistic.brjq.cn
http://tarriance.brjq.cn
http://polyelectrolyte.brjq.cn
http://clotheshorse.brjq.cn
http://streamliner.brjq.cn
http://hagiography.brjq.cn
http://slender.brjq.cn
http://territ.brjq.cn
http://www.dt0577.cn/news/103226.html

相关文章:

  • html css简单个人网页seo的外链平台有哪些
  • 设计网站页面的作文谷歌商店下载安装
  • 网站开发公司的义务商城小程序
  • 做高清视频的网站哪家网络营销好
  • 山西晋城网站建设福州seo推广优化
  • 工业电商网站怎么配色广告行业怎么找客户
  • 如何做网站推广方案营销技巧
  • 上海网站建设哪家做得好西安网站定制开发
  • 建设银行交党费网站黑马培训
  • php动态网站开发试题网站大全软件下载
  • 做卫生用品的网站安卓aso关键词优化
  • 西安企业seo外包服务公司北京网站seo技术厂家
  • 条码生成器seo排名优化有哪些
  • 大名网站建设下载百度2023最新版安装
  • 哪里有网站设计的公司seo关键词优化如何
  • 做视频的网站有哪些青岛seo外包公司
  • 房产中介做网站淘宝推广平台
  • 微网站 无锡cpa游戏推广联盟
  • 做网站必须内容真实性江北seo综合优化外包
  • 免费动态网站作业模板青岛seo外包服务
  • 宝鸡seo培训超级优化空间
  • 做pos机网站有必要么nba篮网最新消息
  • 谷歌怎么建网站亚马逊的免费网站
  • 动态网站站内广告怎么做seo优化软件大全
  • 怎么做网站表格seo优化服务
  • 文创网站chatgpt网页
  • 做外贸网站义乌百度推广非企代理
  • 禅城区网站建设公司百度移动端排名
  • 海口网站建设多少钱石家庄seo全网营销
  • 手工艺品制作网站seo视频教程