一种时钟恢复器和时钟恢复方法
技术领域
本发明涉及移动模拟电视信号接收解码技术领域,特别涉及一种时钟恢复器和时钟恢复方法。
背景技术
模拟电视标准作为一个成熟的技术标准已经存在相当长的时间,并且得到了广泛的应用。模拟电视接收设备需要实时接收并处理来自各个电视台模拟信号发射机传出的电视信号,实现模拟电视节目的同步播放。传统的模拟电视接收设备缺乏单一的处理芯片,需要调谐器,解调器,解码器等多个模拟处理模块,体积大,功耗大,因而主要应用于家庭消费电器,也就是常见的家用彩电。
随着CMOS技术的飞速发展,使得模拟电视接收单一芯片的解决方案成为可能,解决方案由原来单一的模拟电路衍化为模拟或数模混合的解决方案,减小了体积,降低了功耗,从而使得模拟电视得以应用于手机等移动便携设备。
现有技术中常见的数模混合方式接收模拟电视信号的装置可参考图1所示。滤波器102、低噪声放大器103、零中频转换器104为模拟处理器件,它们将电视台发射的模拟信号通过天线101接收到本地并转换成基带信号供后续模块进行处理。模数转换器105将模拟信号转换成数字信号,随后的解调器106、声音解码器109、图像解码器110以及时钟恢复器108均为数字处理器件。其中时钟恢复器108从解调器106输出的复合视频广播信号(CVBS)信号中提取出时钟频率信息,对该时钟频率信息进行处理后得到恢复的发射台时钟。恢复出的发射台时钟信号分别输出至模数转换器105、解调器106、声音解码器109和图像解码器110,使得上述数字处理器件可以采用和发射台同步的时钟,从而使得图像能正常解码并显示。
CVBS为解调器106输出的数据信号。如图2所示的CVBS的图像内容信号中,每隔一段固定的时间会有行同步信号,行同步信号具有宽度及高度(电平)固定的特点。如果恢复出的发射台时钟与实际的发射台时钟一致,那么由恢复出的发射台时钟所产生的行指示信号会与CVBS中的行同步信号位置保持对齐;反之,如果恢复出的发射台时钟与实际的电视台时钟存在相位差,那么由恢复出的发射台时钟所产生的行指示信号会与CVBS中的行同步信号位置相背离,如果恢复出的发射台时钟慢于实际的发射台时钟,则所述行指示信号滞后于CVBS中的行同步信号位置;如果恢复出的发射台时钟快于实际的发射台时钟,则所述行指示信号比CVBS中的行同步信号位置提前。
图1所示现有技术的数模混合方式接收模拟电视信号的装置中的时钟恢复器108的内部结构如图3所示。监相器301对输入的CVBS以及来自数字频率振荡器303的恢复出的发射台时钟进行相位监测,其输出的相位差代表了恢复出的发射台时钟所产生的行指示信号与CVBS的行同步信号的位置差。该相位差经过回路滤波器302进行滤波后,送给数字频率振荡器303。数字频率振荡器303根据来自本地时钟发生器107的本地时钟以及来自回路滤波器302的相位差恢复出发射台时钟,恢复出的发射台时钟经分路后,一路作为输出信号输出,另一路发送到监相器301。恢复出的发射台时钟的产生的过程是一个逐步收敛的过程,如图4所示,从开始时恢复出的发射台时钟与实际的发射台时钟频率相差较大,振幅逐渐缩小,到接近实际的发射台时钟频率并在其附近上下调整,当这个调整在一定范围之内,则认为恢复出的时钟和实际的发射台时钟频率是锁定的。
移动设备由于多径效应、多普勒(doppler)效应、信噪比(SNR)的变化等多种因素的影响常会出现恢复出的发射台时钟与实际的发射台时钟失锁的情况,即恢复出的发射台时钟没有在实际的发射台时钟频率附近上下调整,此时,恢复出的发射台时钟与实际的发射台时钟频率相差较大,需要重新锁定,即需要重复上述恢复出的发射台时钟的产生的过程,所需时间较长,影响电视图像的观赏效果。
发明内容
本发明提供了一种时钟恢复器和时钟恢复方法,能够快速恢复时钟锁定。
本发明实施例提出一种时钟恢复器,包括监相器(301)、回路滤波器(302)和数字频率振荡器(303);所述时钟恢复器还包括一个同步判断器(501);其中,
同步判断器(501),用于根据监相器(301)输出的相位差,确定恢复出的发射台时钟与实际的发射台时钟失锁时,向监相器(301)发送失锁指示信号;
监相器(301),用于接收该时钟恢复器外部输入的复合视频广播信号CVBS以及数字频率振荡器(303)反馈的恢复出的发射台时钟,计算所述CVBS的行同步信号的位置以及所述恢复出的发射台时钟所产生的行指示信号的相位差,将所述相位差输出经回路滤波器(302)传输至数字频率振荡器(303),以得到恢复出的发射台时钟,并将所述相位差输出至同步判断器(501);并用于在收到所述失锁指示信号后,确定该时钟恢复器外部输入的处于稳定状态的CVBS,将根据当前的恢复出的发射台时钟所产生的行指示信号设置为与所确定的CVBS最末行的行同步信号的位置、或者与所确定的各行CVBS行同步信号的平均位置对齐。
较佳地,所述同步判断器(501)包括求和单元和比较单元;
所述求和单元,用于将来自监相器(301)的当前场的各行CVBS对应的相位差的绝对值累加求和,将累加所得和值输出至比较单元;
所述比较单元,用于将所述和值与预先设置的第一阈值进行比较,如果连续N1场该和值均大于或等于第一阈值,则向监相器(301)发送失锁指示信号,N1为预先设定的自然数。
较佳地,所述同步判断器(501)包括:正向判断单元、负向判断单元和指示单元;
所述正向判断单元用于判断连续N2行内是否有多于m1行的相位差大于预先设置的正向阈值,并将判断结果输出至指示单元;
所述负向判断单元用于判断连续N2行内是否有多于m2行的相位差小于预先设置的负向阈值,并将判断结果输出至指示单元;所述正向阈值大于0,负向阈值小于0,N2、m1、m2均为预先设定的自然数,且N2>m1+m2;
指示单元用于当来自正向判断单元和负向判断单元的判断结果均为是时,向监相器(301)发送失锁指示信号。
较佳地,所述同步判断器(501)进一步用于在确定恢复出的发射台时钟与实际的发射台时钟失锁时,向回路滤波器(302)发送失锁指示信号;
所述回路滤波器(302)在收到失锁指示信号后,将自身的积分环路清零。
较佳地,所述监相器(301)包括相位差计算模块、输出模块和设置模块;其中,
相位差生成模块,用于接收该时钟恢复器外部输入的CVBS以及数字频率振荡器(303)反馈的恢复出的发射台时钟,计算所述CVBS的行同步信号的位置以及所述恢复出的发射台时钟所产生的行指示信号的相位差;
输出模块,用于将所述相位差输出至同步判断器(501)以及回路滤波器(302);
设置模块,用于在收到所述失锁指示信号后,确定该时钟恢复器外部输入的CVBS处于稳定状态,将根据当前的恢复出的发射台时钟所产生的行指示信号设置为与所确定的CVBS最末行的行同步信号的位置、或者与所确定的各行CVBS行同步信号的平均位置对齐。
较佳地,所述设置模块包括:计数器、缓存器、位置差计算单元、第一判断单元、第二判断单元和行指示信号设置单元,
位置差计算单元,用于在收到所述失锁指示信号后,记录CVBS中当前行以及上一行的行同步信号的位置,并计算所记录的这两行的行同步信号的位置差;
第一判断单元,用于判断所述位置差计算单元计算得到的位置差是否小于预先设定的第二阈值,若是,将所述当前行CVBS和上一行CVBS的行同步信号的位置存储至缓存器,将所述计数器的计数值加1,否则,将所述计数器清0,清空缓存器;
第二判断单元,用于判断所述计数器的计数值是否达到预先设定的第三阈值,若是,则指示位置差计算单元停止记录行同步信号的位置和计算位置差,并向相位差设置单元发送缓存器存储的各行同步信号的位置;
行指示信号设置单元,用于根据接收到的各行同步信号的位置,将根据当前的恢复出的发射台时钟所产生的行指示信号设置为接收到的最末行的行同步信号的位置、或者与接收到的行同步信号的平均位置对齐。
本发明实施例还提出一种时钟恢复方法,时钟恢复器执行如下步骤:
A、计算当前接收到的CVBS的同步信号的位置与当前的恢复出的发射台时钟产生的当前行指示信号相位差,根据所述相位差得到恢复出的发射台时钟;
B、根据所述相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定,若是,返回步骤A;否则,执行步骤C;
C、执行步骤A,并确定时钟恢复器外部输入的处于稳定状态的CVBS,直到确定该时钟恢复器外部输入的处于稳定状态的CVBS后,执行步骤D;
D、将根据当前的恢复出的发射台时钟所产生的行指示信号设置为与所确定的CVBS最末行的行同步信号的位置、或者与所确定的各行CVBS行同步信号的平均位置对齐,返回步骤A。
较佳地,所述根据所述相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定包括:
将当前场的各行CVBS对应的相位差的绝对值累加求和;
将求得的和与预先设置的第一阈值进行比较,并记录比较结果;
如果连续N1场所述比较结果均大于或等于第一阈值,则认为恢复出的发射台时钟与实际的发射台时钟失去锁定;如果连续N1场所述比较结果不全是大于或等于第一阈值,则认为恢复出的发射台时钟与实际的发射台时钟保持锁定;N1为预先设定的自然数。
较佳地,所述根据所述相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定包括:
判断连续N2行内,是否有多于m1行的相位差大于预先设置的正向阈值,并且多于m2行的相位差小于预先设置的负向阈值,若是,则恢复出的发射台时钟与实际的发射台时钟失去锁定;否则,恢复出的发射台时钟与实际的发射台时钟保持锁定;所述正向阈值大于0,负向阈值小于0,N2、m1、m2均为预先设定的自然数,且N2>m1+m2。
较佳地,执行步骤D时或执行步骤D前,进一步包括:将时钟恢复器内的积分环路清零。
较佳地,该方法还包括:设置计数器,并设置缓存器;
所述确定时钟恢复器外部输入的处于稳定状态的CVBS包括:
步骤C1:计算当前行CVBS和上一行CVBS的行同步信号的位置差;
步骤C2:判断所述位置差是否小于预先设定的第二阈值,如果是,将所述当前行CVBS和上一行CVBS的行同步信号的位置存储至所述缓存器,将所述计数器的计数值加1,并执行步骤C3;如果不是,清空缓存器,将计数器清0,返回步骤C1;
C3:判断计数器的计数值是否达到预先设定的第三阈值,如果是,缓存器存储的各行同步信号的位置所属的CVBS行即为确定的处于稳定状态的CVBS;否则,返回步骤C1。
从以上技术方案可以看出,在时钟恢复器中增加一个同步判断器,用于接收监相器输出的相位差,根据相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定,如果发现时钟失锁,向监相器发送失锁指示信号;所述监相器在收到失锁指示信号后,将行指示信号强行设为与CVBS的行同步信号的位置对齐,即相当于强行更正时钟失锁时监相器输出的错误的相位差,消除了该错误相位差对重新锁定的误导,从而缩短重新锁定所需时间。
另外,如果回路滤波器中有含有历史信息的积分环路,那么在失锁的时候,积分环路中会累积大量错误信息,使时钟重新恢复锁定需要较长时间。根据本发明方案,回路滤波器可以根据失锁指示信号将积分环路清零,使之重新开始,避免受到以前错误信息的误导,加快同步速度。
附图说明
图1为现有技术中的一种数模混合方式接收模拟电视信号的装置示意图;
图2为时钟失锁时行指示信号与CVBS的行同步信号位置背离的示意图;
图3为图1所示装置中的时钟恢复器108的内部结构示意图;
图4为恢复出的发射台时钟逐步收敛过程的示意图;
图5为本发明实施例提出的时钟恢复器的内部模块框图;
图6为本发明实施例提出的时钟恢复方法的处理流程图。
具体实施方式
图5所示为本发明实施例提出的时钟恢复器的内部模块框图。与图3相比,该时钟恢复器108中除了监相器301、回路滤波器302和数字频率振荡器303之外,还包括一个同步判断器501。同步判断器501用于接收监相器301输出的相位差,根据相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定,若是,则不进行任何操作,否则,向监相器301发送失锁指示信号。
有多种方法可用于判断时钟是否保持锁定,以下列举两种具体的实施方式:
方式一:同步判断器501将一场图像内每一行的相位差的绝对值相加求和,将所得和与预先设置的第一阈值进行比较,如果连续N1场该和值均大于或等于第一阈值,则认为时钟失锁;如果不满足上述条件,则认为时钟保持锁定。其中,N1为预先设定的自然数。
具体地,同步判断器501包括求和单元和比较单元;
所述求和单元可以看作是一个累加器,用于将来自监相器301的当前行的相位差的绝对值累加求和,若当前行是当前场的最后一行时,将累加所得和值输出至比较单元。所述和值就是一场图像的所有行的相位差绝对值之和。然后将和值归零,对下一场图像的每一行相位差绝对值进行累加。
当恢复出的发射台时钟和实际的发射台时钟保持锁定时,每一行的相位差的取值是在一个小范围内变化。通过统计较长一段时间内的单场的行相位差绝对值之和,可以得到一个平均值。如果连续若干场的行相位差绝对值之和均远大于该平均值,则可以认为时钟失锁。因此可以根据该平均值设定所述第一阈值。例如,将所述平均值乘以一个大于或等于1的调整因子,将所得结果作为第一阈值。
所述比较单元用于将所述和值与预先设置的第一阈值进行比较,如果连续N1场该和值均大于或等于第一阈值,则向监相器301发送失锁指示信号,N1为预先设定的自然数。由于随机误差可能导致计算出的个别场的相位差绝对值之和大于第一阈值,设置N1的目的就是为了排除这种随机误差的影响。
方法二,同步判断器501判断在连续N2行内是否出现如下情况:有多于m1行出现相位差大于正向阈值,且有多于m2行出现相位差小于负向阈值,那么认为失锁。所述正向阈值大于0,负向阈值小于0。其中N2、m1、m2均为预先设定的自然数,且N2>m1+m2。
时钟锁定情况下,每一行的相位差的取值是在一个小范围内变化,通过统计较长时间的各行相位差,可以得到相位差取值的一个分布图。设置一个概率M(例如,95%),根据该分布图可以得到一个正向阈值和一个负向阈值,相位差小于所述正向阈值且大于所述负向阈值的概率大于或等于所述概率M。
同步判断器501可以将失锁指示信号反馈给监相器301,监相器301在收到该失锁指示信号后,将根据当前的恢复出的发射台时钟所产生的行指示信号强行与所确定的CVBS最末行的行同步信号的位置、或者与所确定的各行CVBS行同步信号的平均位置对齐,然后以当前外部输入的CVBS的行同步信号的位置与对齐后的行指示信号的相位差起点去锁定发射台时钟。
另外,如果回路滤波器302中有含有历史信息的积分环路,那么在失锁的时候,积分环路中会累积大量错误信息,需要长时间才能调整回来。在这种情况下,同步判断器501可以同时将失锁指示信号反馈给回路滤波器302,回路滤波器302在收到失锁指示信号后,将回路滤波器302中的积分环路清零,使之重新开始,避免受到以前错误信息的误导,加快同步速度。
在监相器301将根据当前的恢复出的发射台时钟所产生的行指示信号设置为与所确定的CVBS最末行的行同步信号的位置、或者与所确定的各行CVBS行同步信号的平均位置对齐的时候,如果CVBS本身不准确,则CVBS的行同步信号的位置存在偏差,那么强行设置的本地行指示信号也会存在偏差,以此为起点锁定发射台时钟有可能使时钟重新锁定的时间延长。因此,在对齐前,需要确定的CVBS最末行的行同步信号的位置、或者与所确定的各行CVBS行同步信号的平均位置。
所述监相器(301)包括相位差计算模块、输出模块、设置模块;为达到上述目的,所述设置模块包括:计数器、缓存器、位置差计算单元、第一判断单元、第二判断单元和行指示信号设置单元,
位置差计算单元,用于在收到所述失锁指示信号后,记录CVBS中当前行以及上一行的行同步信号的位置,并计算所记录的这两行的行同步信号的位置差;
第一判断单元,用于判断所述位置差计算单元计算得到的位置差是否小于预先设定的第二阈值,若是,将所述当前行CVBS和上一行CVBS的行同步信号的位置存储至缓存器,将所述计数器的计数值加1,否则,将所述计数器清0,清空缓存器;
第二判断单元,用于判断所述计数器的计数值是否达到预先设定的第三阈值,若是,则指示位置差计算单元停止记录行同步信号的位置和计算位置差,并向相位差设置单元发送缓存器存储的各行同步信号的位置;
行指示信号设置单元,用于根据接收到的各行同步信号的位置,将根据当前的恢复出的发射台时钟所产生的行指示信号设置为接收到的最末行的行同步信号的位置、或者与接收到的行同步信号的平均位置对齐。
如果CVBS稳定,则相邻两行的行同步信号的位置应当基本保持一致,其位置差约等于0。可以根据实际需要设定一略大于0的数作为第二阈值。第二阈值越小,则CVBS稳定性的要求越高,强行设置相位差后越快实现时钟锁定,但进行强行设置相位差的操作的几率越小;第二阈值越大,则CVBS稳定性的要求越低,进行强行设置相位差的操作的几率高,但强行设置相位差后后可能导致实现时钟锁定所需的时间越长。
设置所述第三阈值的作用是,确保CVBS保持稳定已达到足够长的时间。当CVBS不稳定时,也可能暂时出现相邻两行的行同步信号位置差几乎为0的情况。通过设置合适的第三阈值,可以避免将这种情况误认为CVBS已达到稳定。
本发明实施例提出的一种时钟恢复方法的处理流程如图6所示,包括如下步骤:
步骤601:计算当前接收到的CVBS的同步信号的位置与当前的恢复出的发射台时钟产生的当前行指示信号相位差,根据所述相位差得到恢复出的发射台时钟。
步骤601的具体实现方法与现有技术得到恢复出的发射台时钟的方法近似,此处不再赘述。
步骤602:根据所述相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定,若是,返回步骤601;否则,执行步骤603。
步骤603:执行步骤601,并确定时钟恢复器外部输入的处于稳定状态的CVBS,直到确定该时钟恢复器外部输入的处于稳定状态的CVBS后,执行步骤604。
这里,从判断出时钟失锁至确定该时钟恢复器外部输入的处于稳定状态的CVBS前,不执行步骤602。
步骤604:将根据当前的恢复出的发射台时钟所产生的行指示信号设置为与所确定的CVBS最末行的行同步信号的位置、或者与所确定的各行CVBS行同步信号的平均位置对齐,并将时钟恢复器内的积分环路清零,返回步骤601。
较佳地,步骤602所述根据相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定包括如下子步骤:
将当前行的相位差的绝对值累加求和,若当前行是当前场的最后一行时,将累加所得和值与预先设置的第一阈值进行比较,然后将和值归零;
如果连续N1场所述比较结果均大于或等于第一阈值,则恢复出的发射台时钟与实际的发射台时钟失去锁定;如果连续N1场所述比较结果不全是大于或等于第一阈值,则恢复出的发射台时钟与实际的发射台时钟保持锁定;N1为预先设定的自然数。
或者,步骤602所述根据相位差判断恢复出的发射台时钟是否与实际的发射台时钟保持锁定包括:
判断连续N2行内,是否有多于m1行的相位差大于预先设置的正向阈值,并且多于m2行的相位差小于预先设置的负向阈值,若是,则恢复出的发射台时钟与实际的发射台时钟失去锁定;否则,恢复出的发射台时钟与实际的发射台时钟保持锁定;所述正向阈值大于0,负向阈值小于0,N2、m1、m2均为预先设定的自然数,且N2>m1+m2。
步骤603中,所述确定时钟恢复器外部输入的处于稳定状态的CVBS包括:
步骤603-1:计算当前行CVBS和上一行CVBS的行同步信号的位置差;
步骤603-2:判断所述位置差是否小于预先设定的第二阈值,如果是,将所述当前行CVBS和上一行CVBS的行同步信号的位置存储至所述缓存器,将所述计数器的计数值加1,并执行步骤603-3;如果不是,清空缓存器,将计数器清0,返回步骤603-1;
603-3:判断计数器的计数值是否达到预先设定的第三阈值,如果是,缓存器存储的各行同步信号的位置所属的CVBS行即为确定的处于稳定状态的CVBS;否则,返回步骤603-1。
以上所述仅为本发明的较佳例而已,并不用以限制本发明,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明保护的范围之内。