PT2262编码模块的FPGA实现
1赞PT2262编码模块的FPGA实现
毕业设计的一个小部分,设计中用的是现成的PT2262芯片,连射频电路都搭好的那种傻 瓜模块。为了说明PT2262的编码原理,就做了一个仿真实验。
无线收发部分使用的是PT2262和PT2272这 一对无线收发编码模块,在发射端所使用的是PT2262,它是DIP-20封装。各个管脚的功能如表1所示。
名称 |
管脚 |
说明 |
A0-A11 |
1-8、10-13 |
地址管脚 |
D0-D5 |
7-8、10-13 |
数据输入端,有一个为“1”即有编码发出 |
Vcc |
18 |
电源正端(+) |
Vss |
9 |
电源负端(-) |
TE |
14 |
编码启动端,用于多数据编码发射,低电平有效 |
OSC1 |
16 |
振荡电阻输入端,与OSC2所 接电阻决定振荡频率 |
OSC2 |
15 |
振荡电阻振荡器输出端 |
Dout |
17 |
编码输出端 |
表1 PT2262引脚功能表
由PT2262搭建的无线发射模块的电路图如图1所示。P1为电源,我们可以外接9V的电池组或者其他直流电源供电,上电后,闭合S1开 关,则指示灯LED就亮。在PT2262的电路联接中可以看到,作为地址管脚的A0-A7被统一接地,在接收模块PT2272中我们也 是统一接地,这样就保持了相同的收发模块地址,才能实现二者的正常通信。当然了,这里的地址端口的接法是可以有3的8次方即6561种接法的,因为一共8个地址管脚,每个都可以有三种接法:接正、接负或者悬空。但是有一点是必须注意的,那就是需要使用的对应收发 模块的地址必须保持一致。
表2 发 送数据编码表
由表2可以看出,通过PT2262的 内部编码把每1bit的原始码元对应编码成为1Byte新 码元。也就是说,地址码A0~A7以及数据 码A0~A3一共12bit的原始码元编码成12Byte的新码元发送出 去。而编码后的1bit码元的周期为4T(T为 震荡周期),相应的1Byte的码元周期就 是32T。为了更好的理解PT2262的编 码方式,本人利用VerilogHDL进行编程,通过ModelSim仿 真的一个波形如图2所示(由于空间所限,这里只给出部分仿真波形)。
图2 PT2262编码仿真波形
波形的信号从上到下依次为:clk(主时钟信号,即振荡周期)、rst_n(复位信号,低电平有效)、clock4(主 时钟的4分频信号,它的一个周期对应着编码后的1bit码 元的持续周期)、add(地址信号,在仿真激励中设置为00001z10,z代表相应管脚悬空)、data(数据信号,在仿真激 励中设置为0001)、clock(主时钟 的32分频信号,它的一个时钟周期对应着一个原始数据发送的时间)、dout(编码输出)、en(输出使能信号,高电平有 效,表示编码完成开始输出)。
由于数据是从数据地址码的低位开始进行编码发送的,所以第一个发送的数据是“0”,它对 应的dout编码就是开始的10001000, 紧随其后的11101110则代表地址码的次低位“1”, 依次类推下一位传输码元“z”(代表悬空)的编码为10001110,其它的码元编码过程与此 类似。当12bit码元编码结束后,dout将 维持128个振荡周期的低电平,然后重复发送12bit原 始码元,一共要完成四次的重复发送。