比特率是数字信号的传输速率,它用单位时间内传输的二进制代码的有效位(bit)数来表示,其单位为每秒比特数bit/s(bps)、每秒千比特数(Kbps)或每秒兆比特数(Mbps)来表示(此处K和M分别为1000和1000000,而不是涉及计算机存储器容量时的1024和1048576)。 波特率指数据信号对载波的调制速率,它用单位时间内载波调制状态改变次数来表示,其单位为波特(Baud)。
波特率与比特率的关系为:比特率=波特率X单个调制状态对应的二进制位数
两相调制(单个调制状态对应1个二进制位)的比特率等于波特率; 四相调制(单个调制状态对应2个二进制位)的比特率为波特率的两倍; 八相调制(单个调制状态对应3个二进制位)的比特率为波特率的三倍; 对于串行通信来说,或者说是对于普通的数字电路来说,都是两相调制(单个调制状态对应1个二进制位),因此波特率=比特率(通常叫波特率)。 如果系统时钟是1.8432MHz,那16分频就得到115200Hz reg
[3:0] BaudDivCnt;
always @(posedge clk) BaudDivCnt <= BaudDivCnt + 1;
wire BaudTick = (BaudDivCnt==15); |
但通常系统的时钟不是刚刚好是波特率的整数倍,如果不采用DCM对系统进行倍频的话,可以采用下面程序进行处理,设系统时钟为2MHz=2000000Hz
两个频率很接近,可以采用下面程序产生我们要的波特率。 // 10 bits for the accumulator ([9:0]), and one extra bit for the accumulator carry-out ([10])reg
[10:0] acc; // 11 bits total!
always @(posedge clk)
acc <= acc[9:0] + 59;
// use only 10 bits from the previous result, but save the full 11 bits
wire BaudTick = acc[10]; // so that the 11th bit is the carry-out
|
当系统时钟为2MHz的时候,计算得到的波特率的值为115234,与115200只有0.03%的误差。 |