[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

JP4224749B2 - COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM - Google Patents

COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM Download PDF

Info

Publication number
JP4224749B2
JP4224749B2 JP33235099A JP33235099A JP4224749B2 JP 4224749 B2 JP4224749 B2 JP 4224749B2 JP 33235099 A JP33235099 A JP 33235099A JP 33235099 A JP33235099 A JP 33235099A JP 4224749 B2 JP4224749 B2 JP 4224749B2
Authority
JP
Japan
Prior art keywords
data
synchronization
packet
unit
stream
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP33235099A
Other languages
Japanese (ja)
Other versions
JP2001156760A (en
Inventor
洋一 松村
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sony Corp
Original Assignee
Sony Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sony Corp filed Critical Sony Corp
Priority to JP33235099A priority Critical patent/JP4224749B2/en
Publication of JP2001156760A publication Critical patent/JP2001156760A/en
Application granted granted Critical
Publication of JP4224749B2 publication Critical patent/JP4224749B2/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Landscapes

  • Television Systems (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Time-Division Multiplex Systems (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Synchronisation In Digital Transmission Systems (AREA)

Description

【0001】
【発明の属する技術分野】
本発明は、通信装置および方法、並びに記録媒体に関し、特に、ATM通信技術などを用いてデジタル化されたオーディオデータやビデオデータを送受信することができるようにした通信装置および方法、並びに媒体に関する。
【0002】
【従来の技術】
図1は、従来のデータ伝送システムの構成例を表している。なお、エンコード側とデコード側のそれぞれが接続するネットワーク3は、デジタルCS放送における伝送方法と同様に、衛星が利用されているものとする。すなわち、ネットワーク3を介して伝送されるデータには、一定間隔の遅延が発生するものとする。
【0003】
エンコーダ1は、伝送すべきデータとしての、例えばビデオデータおよびオーディオデータをMPEG-2方式に従ってエンコードし、システムエンコーダ2に出力する。システムエンコーダ2は、入力されたビデオデータおよびオーディオデータをパケット化し、トランスポートストリームパケットを生成するとともに、必要に応じて他のトランスポートストリームと多重化して、ネットワーク3上に出力する。
【0004】
システムエンコーダ2はまた、生成したトランスポートストリームパケットのヘッダに、タイムスタンプであるPCR(Program Clock Reference)を、図2に示すように組み込む(以下、PCRがヘッダに組み込まれたトランスポートストリームパケットをPCRパケットと称する)。このPCRは、エンコード側から、トランスポートストリームが出力されるタイミングでカウントされた、システムエンコーダ2におけるシステムクロックC1(MPEG-2方式の場合、周波数が27MHzのクロック)のカウント値である。なお、PCRは、MPEG-2規格により、0.1秒間に少なくとも1つ、エンコード側から出力されるように、トランスポートストリームに組み込まれている。
【0005】
図1に戻り、エンコード側から出力されたトランスポートストリームパケット(PCRパケットを含む)は、ネットワーク3を介して、デコード側に到着し、そのシステムデコーダ4に入力される。なお、ネットワーク3を介して伝送されてきたトランスポートストリームは、一定間隔の遅延を有しているので、PCR(PCRパケット)は、エンコード側から送出された間隔と同じ間隔(その差が、MPEG-2規格の+/-500ns以内)でデコード側に到着する。
【0006】
システムデコーダ4は、入力されたトランスポートストリームパケットをデパケット化し、その結果得られたオーディオストリームまたはビデオストリームを、デコーダ5に出力する。システムデコーダ4はまた、図2に示すように、PCRパケットからPCRを取り出し、そのPCRと、PCRを取り出したタイミングでカウントした、デコード側のシステムクロックC2(27MHzのクロック)のカウント値と比較し、その比較結果に基づいて、システムクロックC2の速度を調整し、デコーダ5に供給する。
【0007】
デコーダ5は、システムデコーダ4から供給されたオーディオデータまたはビデオデータを、システムデコーダ4から供給されたシステムクロックC2に同期して、デコード処理をする。
【0008】
次に、デコード側におけるシステムクロックC2の生成(調整)処理を、図3と図4を参照してさらに説明する。システムデコーダ4は、図3に示すように構成されている。システムデコーダ4に供給されたトランスポートストリームパケットは、システムデコーダ4のシステムデコード部11およびタイムスタンプ取出回路12に供給される。
【0009】
タイムスタンプ取出回路12は、図2に示したように、PCRパケットに組み込まれたPCRを取り出し、PLL回路13に出力する。PLL回路13は、例えば図4に示すように構成されており、その減算器21には、タイムスタンプ取出回路12により取り出されたPCR、およびそのPCRが入力されたタイミングでカウントされたカウンタ24のカウント値(D/Aコンバータ兼VCO23から出力されるクロックのカウント値)が入力される。減算器21は、タイムスタンプ取出回路12からのPCRと、カウンタ24からのカウント値との差を算出し、ローパスフィルタ(以下、LPFと略称する)22に出力する。LPF22は、入力された減算器21からの演算結果を時間的に平滑し、D/Aコンバータ兼VCO(電圧制御発振器)23に出力する。D/Aコンバータ兼VCO23は、LPF22より入力されたデジタル信号をアナログ信号に変換し、そのアナログ信号を制御電圧として、その制御電圧に対応する周波数のシステムクロックC2を発生する。D/Aコンバータ兼VCO23は、発生したシステムクロックC2をカウンタ24およびデコーダ5に出力する。
【0010】
カウンタ24は、D/Aコンバータ兼VCO23からのシステムクロックC2をカウントし、そのカウント値を、その時点におけるシステムクロックC2の周波数と位相を表す信号として、減算器21に供給する。すなわち、このPLL回路13において、トランスポートストリームパケットに組み込まれたPCRと、そのPCRが取り出されるタイミング(PCRパケットがデコード側に到着するタイミング)でカウントされたシステムクロックC2のカウント値の差がなくなるように、システムクロックC2の速度が調整される。その結果、エンコード側のシステムクロックC1と同期する、デコード側のシステムクロックC2が生成される。
【0011】
図3に戻り、システムデコード部11は、入力されたトランスポートストリームパケットをデパケット化し、その結果得られたオーディオストリームおよびビデオストリームを、デコーダ5に出力する。
【0012】
ところで、ネットワーク3として、衛星放送における伝送方法と同様に、衛星が利用されている場合、エンコード側から伝送されたトランスポートストリームパケットには、固定遅延が付加される。つまり、エンコード側から伝送されたトランスポートストリームパケットは、一定時間分だけ遅れて、または速まって、デコード側に到着する。この場合、遅れる時間または速まる時間は、一定であるので、トランスポートストリームパケット(PCRパケットを含む)のデコード側への到着間隔は、エンコード側からの出力間隔と同じとなる。そのため、この場合においては、図3と図4を参照して説明した方法を利用することで、デコード側のシステムクロックC2は、エンコード側のシステムクロックC1と同期するように生成される。
【0013】
【発明が解決しようとする課題】
しかしながら、ネットワーク3として、ATM(Asynchronous Transfer Mode)ネットワークが利用される場合、エンコード側から伝送されるトランスポートストリームパケットには、一定間隔の遅延ではなく、例えば、1ms乃至2msの範囲でゆれる遅延(以下、遅延ゆらぎと称する)が付加される。この場合、上述したデータ伝送システムでは、その遅延ゆらぎが吸収されず、結局、遅延の大きさが、MPEG-2規格の+/-500nsの範囲を大きく超えてしまい、データが適切に再生されない。
【0014】
そこで、デコード側において、遅延ゆらぎをある程度低減させた後にシステムクロックを生成するようにしたアダプティブクロック法などの同期方法が提案されている。
【0015】
図5は、アダプティブクロック法を適用したデコード側の装置のアダプティブクロック部51の構成例を表している。なお、ネットワーク50を介して伝送されてくるデータには、遅延ゆらぎが発生しているものとする。
【0016】
ネットワーク50を介して伝送されてきた、遅延ゆらぎを有するデータは、アダプディブクロック部51のFIFO52に入力される。FIFO52は、入力されたデータを一時保持するとともに、制御部53から供給される所定の読み出しクロックに対応してデータを出力する。FIFO52はまた、自分自身のデータ占有率をLPF54に出力する。LPF54は、FIFO52のデータ占有率を平滑し、それを制御部53に出力する。
【0017】
制御部53は、LPF54から供給されるデータ(平滑されたFIFO52のデータ占有率)が、所定の値になるように、FIFO52に出力する読み出しクロックの速度を制御する。すなわち、アダプティブクロック法においては、制御部53により制御されるクロックがデコード側のシステムクロックとされる。
【0018】
このように、このアダプティブクロック方式においては、受信されたデータのみに基づいて、デコード側のシステムクロックが生成されるので、装置の構成を簡単にすることができる。しかしながら、この例では、ジッタ成分をアナログ的にシェイビングしているだけなので、長い時間でみればジッタ成分は残っており、遅延ゆらぎは十分に吸収されない課題がある。
【0019】
また、エンコード側に、図6に示されるような構成を有する送信装置61、およびデコード側に、図7に示すような構成を有する受信装置62からなるデータ伝送システムも提案されている。これは、例えば、各テレビジョン放送局または番組作成会社において、それぞれのクロックに同期した複数のプログラムを伝送するためのシステムである。
【0020】
送信装置61には、図6に示すように、PLL回路71とN個の同期データ作成部72−1乃至72−N(以下、ここに区別する必要がない場合、単に、同期データ作成部72と記述する。他の部分についても同様である)が設けられている。PLL回路71には、ネットワーク63のネットワーククロックである8KHzのクロックが供給される。PLL回路71は、図8に示すように構成されている位相比較器91が設けられている。位相比較器91のVCO92は、位相比較部94から供給される信号に基づいて所定の位相の27MHzを発生し、それを分周器93に出力するとともに、同期データ作成部72−1乃至72−Nのそれぞれにも出力する。
【0021】
分周器93は、VCO92から入力された27MHzのクロックを、1/3375に分周し、8KHzのクロックを生成し、それを位相比較部94に出力する。位相比較部94は、ネットワーク63からの8KHzのクロックと、分周器93からの8KHzのクロックの位相を比較し、比較結果をVCO92に出力する。
【0022】
同期データ作成部72−1は、PLL回路81、ラッチ回路82、およびクロック83などから構成されている。同期データ作成部72−1のPLL回路81には、例えば、所定のクロックに同期して作成されたデータに含まれているタイムスタンプが供給される。PLL回路81は、基本的に、図4に示したPLL回路13と同様の構成を有している。すなわち、PLL回路81は、入力されたタイムスタンプに基づて所定のクロックを発生し、ラッチ回路82に出力する。
【0023】
ラッチ回路82は、PLL回路81からのクロックとクロック83からのクロックに従ってラッチ処理を実行する。そのラッチ処理の処理結果により再生されたデータが同期データとされ、所定のトランスポートストリームパケットに組み込まれる。
【0024】
同期データ作成部72−2乃至72−Nも、同期データ作成部72−1と同様の構成を有しているので、その図示と詳細な説明は省略するが、それぞれ異なるクロックに同期して作成されたデータに含まれるタイムスタンプが入力され、そのクロックに対応した同期データを作成する。
【0025】
受信装置62には、図7に示すように、PLL回路101とN個のシステムクロック再生部102−1乃至102−Nが設けられている。PLL回路101には、ネットワーク63のネットワーククロックである8KHzのクロックが供給される。PLL回路101は、送信装置61のPLL回路71と同様に、入力される8KHzのクロックに対応する27MHzのクロックを発生し、システムクロック再生部102−1乃至102−Nのそれぞれに出力する。
【0026】
システムクロック再生部102−1は、クロック110およびPLL回路111などから構成されている。システムクロック再生部102−1のクロック110には、PLL回路101から供給されたクロックが入力され、クロック110は、それを1/27000000に分周し、PLL回路111に出力する。PLL回路111には、クロック110からのクロックの他、送信装置61の同期データ作成部72−1により作成された同期データが供給される。そこでPLL回路111は、入力されたクロックおよび同期データに基づいて、システムクロックを再生する。
【0027】
システムクロック再生部102−2乃至102−Nも、システムクロック再生部102−1と同様の構成を有しているので、その図示は省略するが、それらは、それぞれ対応する、送信装置61の同期データ作成部72から供給される同期データを利用してシステムクロックを再生する。このように再生されたシステムクロックは、それぞれのデータのエンコード時のクロックに同期しているので、そのクロックに従って、データをそれぞれデコードすることにより、データは適切に再生される。
【0028】
しかしながら、上述したデータ伝送システムにおいては、エンコード時のクロック毎に、同期データ作成部72およびシステムクロック再生部102を備える必要があり、装置の構成が複雑、かつ、大型化してしまう課題があった。
【0029】
本発明はこのような問題に盤みてなされたものであり、遅延ゆらぎを、容易に、かつ、確実に吸収し、また装置を複雑、かつ、大型化することなく、複数のプログラムに対応するデータを送受信することができるようにしたものである。
【0030】
請求項1に記載の通信装置は、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データを検出する検出手段と、検出手段により検出された、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出した、同期データと同値である単位データの数をカウントする第1のカウント手段と、第1のカウント手段によりカウントされた、連続して検出された同期データと同値である単位データの数が、所定の数となったとき、検出された単位データのうちの1つの単位データのストリーム上の配置位置を、パケットの先頭とし、ストリームの同期を確立する同期確立手段と、ストリームの同期が確立されている状態において、パケットからタイムスタンプを読み出し、読み出したタイムスタンプに基づいて、パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理手段とを備えることを特徴とする。
【0031】
同期確立手段により、パケットの先頭とされた単位データの、同期確立手段により同期が確立されたストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、連続して検出した、同期データと異なる値である単位データの数をカウントする第2のカウント手段をさらに設けることができ、検出手段は、第2のカウント手段によりカウントされた、連続して検出された同期データと異なる値である単位データの数が、所定の数となったとき、同期データと同値である、ストリームに配置された単位データを再び検出することができる。
【0033】
請求項に記載の通信方法は、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データを検出する検出ステップと、検出ステップの処理で検出された、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出した、同期データと同値である単位データの数をカウントするカウントステップと、カウントステップの処理でカウントされた、連続して検出された同期データと同値である単位データの数が、所定の数となったとき、検出された単位データのうちの1つの単位データのストリーム上の配置位置を、パケットの先頭とし、ストリームの同期を確立する同期確立ステップと、ストリームの同期が確立されている状態において、パケットからタイムスタンプを読み出し、読み出したタイムスタンプに基づいて、パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理ステップとを含むことを特徴とする。
【0034】
請求項に記載の記録媒体は、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データを検出する検出ステップと、検出ステップの処理で検出された、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出した、同期データと同値である単位データの数をカウントするカウントステップと、カウントステップの処理でカウントされた、連続して検出された同期データと同値である単位データの数が、所定の数となったとき、検出された単位データのうちの1つの単位データのストリーム上の配置位置を、パケットの先頭とし、ストリームの同期を確立する同期確立ステップと、ストリームの同期が確立されている状態において、パケットからタイムスタンプを読み出し、読み出したタイムスタンプに基づいて、パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理ステップとを含むことを特徴とする。
【0035】
請求項1に記載の通信装置、請求項に記載の通信方法、および請求項に記載の記録媒体のプログラムにおいては、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データが検出され、検出された、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データが検出され、検出された単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出された、同期データと同値である単位データの数がカウントされ、カウントされた、連続して検出された同期データと同値である単位データの数が、所定の数となったとき、検出された単位データのうちの1つの単位データのストリーム上の配置位置を、パケットの先頭とし、ストリームの同期が確立され、ストリームの同期が確立されている状態において、パケットからタイムスタンプが読み出され、読み出されたタイムスタンプに基づいて、パケットに設定された識別子毎に所定の同期情報が算出される
【0036】
【発明の実施の形態】
図9は、本発明を適用したデータ伝送システムの構成例を表している。このシステムにおいては、MPEG-2方式に準拠したMPEGトランスポートストリームが、ATMネットワークであるネットワーク202を介して送受信される。すなわち、ネットワーク202を介して伝送されるデータには、遅延ゆらぎが発生する。
【0037】
送信装置201には、それぞれにエンコードされた複数のプログラムが多重化されているMPEGトランスポートストリームパケットが入力される。なお、このMPEGトランスポートストリームパケットには、PCRが少なくとも0.1秒以内の間隔で受信装置203に到着するようにPCRパケットが組み込まれている。
【0038】
MPEGトランスポートストリームパケットは、図10に示すように、ヘッダ部、アダプテーションフィールド部、およびペイロード部等からなる、188バイトの固定パケットである。ヘッダ部には、同期バイト(8ビット)、誤り表示(1ビット)、ユニット開始表示(1ビット)、トランスポートパケットプライオリティ(1ビット)、PID(Packet Identification)(13ビット)、スクランブル制御(2ビット)、アダプテーションフィール制御(2ビット)、巡回カウンタ(4ビット)が含まれる。なお、同期バイトは、47hとされている。
【0039】
アダプテーションフィールド部には、アダプテーションフィールド長さ(8ビット)、不連続表示(1ビット)、ランダムアクセス表示(1ビット)、ストリーム優先表示(1ビット)、フラグ(5ビット)、プログラムクロックリファレンスベース(33ビット)、リザーブ(6ビット)、およびプログラムクロックリファレンス拡張(9ビット)が含まれる。なお、フラグには、PCRフラグ(1ビット)をはじめ5種類のフラグが存在する。
【0040】
ペイロード部には、データが含まれる。
【0041】
MPEGトランスポートストリームパケットは、以上のようなデータ構造を有するが、図10に示すように、ヘッダ部のアダプテーションフィールド制御が”10”または”11”とされ、かつ、アダプテーションフィールド部のアダプテーションフィールド長さが00h以外の値で、さらにPCRフラグに”1”が立っている場合(以下、このようなデータ設定をPCRパケット条件と記述する)、そのMPEGトランスポートストリームパケットは、PCRパケットであり、そのアダプテーションフィールド部のプログラムクロックリファレンスベースの値およびプログラムロックリファレンス拡張の値の組み合わせが、PCR値を表す。
【0042】
プログラムクロックリファレンスベースには、0乃至299の値が順に設定され(カウントされ)、プログラムクロックリファレンスベースの値が299から0の値に戻る(リセット)されるタイミングで、プログラムクロックリファレンス拡張の値が1だけインクリメントされる。すなわち、プログラムクロックリファレンスベースおよびプログラムクロックリファレンス拡張の合計42ビットにより、MPEG-2方式における27MHzのシステムクロックを単位として、24時間分の時間がカウントされる。
【0043】
図9に戻り、送信装置201に入力されたMPEGトランスポートストリームパケット(PCRパケットを含む)は、そこで、ATMセルに変換され、ネットワーク202上に伝送されるが、PCRパケットには、そのPCR値に基づいて作成された所定の同期情報(後述)が書き込まれる。
【0044】
ネットワーク202を介して伝送されてきたATMセルは、受信装置203に到着し、そこで、MPEGトランスポートストリームに変換されるが、PCRパケットに含まれるPCR値は、PCRパケットに書き込まれた同期情報に基づいて修正される。PCR値が修正されたPCRパケットを含むMPEGトランスポートストリームパケットは、図示せぬデコーダに供給され、そこでデコードされる。
【0045】
図11は、送信装置201の構成例を表している。MPEGトランスポートストリームパケット同期部(以下、TSパケット同期部と略称する)211には、送信装置201に供給されたMPEGトランスポートストリームパケットが入力される。TSパケット同期部211は、入力されたMPEGトランスポートストリームパケットの先頭を検出し、フレーム同期を確立するとともに、フレーム同期を確立した後、MEPGトランスポートストリームパケットを、PCRパケット検出部212に出力する。
【0046】
PCRパケット検出部212は、TSパケット同期部211から入力されたMPEGトランスポートストリームパケット(フレーム同期が取られているMPEGトランスポートストリームパケット)のヘッダ部およびアダプテーションフィールド部を参照して、PCRパケット条件が設定されているか否かを判定し、PCRパケット条件が設定されていると判定した場合、すなわち、そのMPEGトランスポートストリームパケットがPCRパケットである場合、そのことを示す信号(以下、PCRパケット検出信号と称する)を同期情報処理部213に出力する。なお、PCRパケット検出部212は、入力されたMPEGトランスポートストリームパケット自身には、何ら処理を施さずに、同期情報処理部213に出力する。
【0047】
同期情報処理部213には、PCRパケット検出部212から、MPEGトランスポートストリームパケットおよびPCRパケット検出信号、並びにカウンタ214から、カウント値が、それぞれ入力される。
【0048】
同期情報処理部213は、PCRパケット検出部212からのPCRパケット検出信号により特定される、PCRパケット検出部212からのMPEGトランスポートストリームパケット(PCRパケット)からPCRを読み出し、読み出したPCRに基づいて、所定の同期情報(詳細は後述する)を算出する。同期情報処理部213は、算出した同期情報をそのPCRパケットに書き込み、MPEG/ATM変換部216に出力する。
【0049】
メモリ215は、同期情報処理部213から供給される、同期情報を算出する上において必要なデータを適宜記憶する。なお、この例の場合、同期情報処理部213による同期情報算出処理は、プログラム毎(MEPGトランスポートストリームパケットに設定されたPID毎)に行われるので、メモリ215は、同期情報処理部213から供給されるデータを各プログラム毎に記憶する。
【0050】
MPEG/ATM変換部216は、MPEGトランスポートストリームパケットをATMセルに変換してネットワーク202へ送信する。MPEG/ATM変換部216はまた、ネットワーク202から順次送信されてくるATMセルを受信し、受信したATMセルに基づいてネットワーク202のネットワーククロックに同期した8KHzのクロックを生成し、PLL回路217に出力する。
【0051】
PLL回路217は、例えば、図6のPLL回路71と同様に、図12に示すような位相比較器250を有している。VCO251は、位相比較部252から供給される信号に基づいて所定の位相の27MHzを発生し、カウンタ214および分周器253に出力する。分周器253は、VCO251から入力された27MHzのクロックを、1/3375に分周し、8KHzのクロックを生成し、位相比較部252に出力する。位相比較部252は、MPEG/ATM変換部216からの8KHzのクロックの位相と、分周器253からの8KHzからのクロックの位相を比較し、その比較結果をVCO251に出力する。すなわち、カウンタ214に出力される27MHzのクロックは、ネットワーク202のネットワーククロックと同期するように、その位相が調整される。
【0052】
図11に戻り、カウンタ214は、PLL回路217からの27MHzのクロックを1/3240000で分周して、カウントするとともに、そのカウント値Nを同期情報処理部213に出力する。すなわち、このカウンタ214は、ネットワーク202のネットワーククロックに同期したクロックをカウントする。
【0053】
次に、送信装置201のTSパケット同期部211の動作を、図13のフローチャートを参照して説明する。
【0054】
ステップS1において、TSパケット同期部211は、入力されたMPEGトランスポートストリームパケットのデータを1バイトごと読み取り、読み取った値が、同期バイトと等しい47h(図10)であると判定するまで待機する。読み取った1バイトの値が47hであると判定したとき、TSパケット同期部211は、ステップS2に進み、47hを読み取った回数をカウントするカウンタiの値を1に初期設定する。
【0055】
次に、ステップS3において、TSパケット同期部211は、ステップS1で読み取った47hから188バイト分離れたデータ(188バイト後のデータ)を読み取り、ステップS4において、それが47hであるか否かを判定する。ステップS4において、ステップS3で読み取ったデータが47hではないと判定した場合、TSパケット同期部211は、ステップS1に戻り、それ以降の処理を実行する。一方、ステップS4において、読み取ったデータが47hであると判定した場合、TSパケット同期部211は、ステップS5に進む。
【0056】
ステップS5において、TSパケット同期部211は、カウンタiの値が5であるか否かを判定し、その値が5ではないと判定した場合、ステップS6に進み、カウンタiの値を1だけインクリメントし、ステップS3に戻り、それ以降の処理を実行する。ステップS5で、カウンタiの値が5とであると判定された場合、すなわち、入力されたMPEGトランスポートストリームパケットのデータから、188バイト毎に、5回連続して47hが読み取られた場合、ステップS7に進む。
【0057】
ステップS7において、TSパケット同期部211は、5回目に検出した47hを同期バイトとし、すなわち、MPEGトランスポートストリームパケットの先頭データとし、フレーム同期を確立する。なお、ステップS7で、フレーム同期が確立される前に送信装置201に入力されたデータは、PCRパケット検出部212には供給されず、捨てられる。
【0058】
以上のようにして、フレーム同期が確立される。
【0059】
次に、ステップS8において、TSパケット同期部211は、カウンタiの値を1に初期設定し、ステップS9に進み、同期バイトとした47hから188バイト分離れたデータを読み取り、ステップS10において、それが47hであるか否かを判定する。
【0060】
ステップS10において、ステップS9で読み取られたデータが47hではないと判定した場合、TSパケット同期部211は、ステップS11に進み、カウンタiの値が3であるか否かを判定し、その値が3はないと判定した場合、ステップS12に進み、カウンタiの値を1だけインクリメントし、ステップS9に戻り、それ以降の処理を実行する。一方、ステップS11で、カウンタiの値が3であると判定された場合、ステップS1に戻り、それ以降の処理が実行される。すなわち、ステップS9において読み取られたデータが3回連続して47hではないと判定された場合、MPEGトランスポートストリームパケットのフレーム同期が取られていないと判断され、ステップS1に戻り、同期確立のための処理が、はじめから行われる。なお、同期を確立するための処理がはじめから再度行われる前に入力された、同期が取られていないと予想される、3×188バイト分のデータは、PCRパケット検出部212に供給されることになる。
【0061】
ステップS10において、TSパケット同期部211は、ステップS9で読み取ったデータが47hであると判定した場合、ステップS9に戻り、それ以降の処理を実行する。
【0062】
図14のフローチャートを参照して、同期を確立するための他の方法について説明する。なお、この例の場合、TSパケット同期部211は、図15に示すように、188個のメモリ領域i(=1,2,・・,188)からなる47hカウント部を内蔵しているものとする。なお、初期状態において、47hカウント部の各メモリ領域iには、値0が設定されている。
【0063】
ステップS21において、TSパケット同期部211は、入力されたMPEGトランスポートストリームパケットを1バイトごと読み出し、47hを検出するまで待機し、47hを検出すると、ステップS22に進み、カウンタiの値を1だけインクリメントし、ステップS23において、カウンタiの値で特定されるメモリ領域i(=1)の値を、1だけインクリメントする。
【0064】
図16(B)には、ステップS21で47hが検出された位置から188バイト毎に区分されたデータ1乃至データ5が示され、図16(A)には、各データを構成するバイトと、それに対応する47hカウント部のメモリ領域iの値が示されている。データ1の先頭データ(47h)に対応する、メモリ領域1の値は、1が設定されている。なお、図16中、xxhは、47h以外のデータを示している。
【0065】
次に、ステップS24において、TSパケット同期部211は、ステップS21で、検出した47hの次の1バイト分のデータを読みとり、ステップS25において、カウンタiの値を1だけインクリメントする。
【0066】
ステップS26において、TSパケット同期部211は、ステップS24で読み取ったデータが47hであるか否かを判定し、47hではないと判定した場合、ステップS27に進む。
【0067】
図16のデータ1の場合、47hの次の1バイトのデータは、47hではないので(図中、”xxh”で示されているデータであるので)、ステップS27に進み、TSパケット同期部211は、メモリ領域2に0を設定する。
【0068】
次に、ステップS28において、TSパケット同期部211は、カウンタiの値が189であるか否かを判定し、その値が189ではないと判定した場合、ステップS24に戻り、それ以降の処理を実行する。
【0069】
ステップS26において、読み取られたデータが47hであると判定された場合、ステップS29に進み、TSパケット同期部211は、カウンタiの値で特定されるメモリ領域iの値を1だけインクリメントする。データ1の先頭バイトからkバイト離れたデータは、47hであるので、メモリ領域kの値は、1だけインクリメントされる。
【0070】
次に、ステップS30において、TSパケット同期部211は、ステップS29で、その値を1だけインクリメントしたメモリ領域iの値が5であるか否を判定し、その値が5ではないと判定した場合、ステップS28に戻り、それ以降の処理を実行する。
【0071】
ステップS28において、カウンタiの値が189であると判定された場合、ステップS22に戻り、TSパケット同期部211は、それ以降の処理を実行する
ステップS30において、メモリ領域iの値が5であると判定された場合、ステップS31に進み、TSパケット同期部211は、カウンタi=5のとき、ステップS24で読み取った47hを同期バイトとし、MPEGトランスポートストリームのフレーム同期を確立する。図16の例では、データ5の先頭データからkバイト離れた47hが読み出されているとき、メモリ領域kの値が5となるので、そのとき読み出されたデータ5の47hが同期バイトとされ、フレーム同期が確立される。
【0072】
ステップS32乃至ステップS36の処理は、図13のステップS8乃至ステップS12における場合と同様であるので、その説明は省略する。
【0073】
次に、同期情報を算出する場合の同期情報処理部213の処理手順を、図17のフローチャートを参照して説明する。なお、この処理は、MPEGトランスポートストリームに設定されたPID毎(最大8192個のプログラム分のPID毎)に実行されるが、この例の場合、1つのPIDに対応して実行される同期情報算出処理を例として説明する。
【0074】
TSパケット同期部211により、MPEGトランスポートストリームパケットのフレーム同期が確立されている状態において、ステップS51において、PCRパケット検出部212が、例えば、図18(A)に示すように、時刻P1において、フレーム同期確立後、送信装置201に入力された最初のPCRパケット(第1番目のPCRパケット)を検出し、PCRパケット検出信号を同期情報処理部213に出力する。同期情報処理部213は、PCRパケットが検出されたことを示すフラグをメモリ215に設定する。
【0075】
次に、ステップS52において、同期情報処理部213は、オフセット値Oを算出する。具体的には、はじめに、同期情報処理部213は、第1番目のPCRパケットのPCR値E1(図18(C))を取得し、それを基準クロック値B(図18(B))とする。なお、このとき、同期情報処理部213は、カウンタ214に対して、図18(B)に示すように、カウント値Nが基準クロック値Bとなるタイミング(時刻t0(図18(A))でカウント値Nのリセットを指令する。次に、同期情報処理部213は、ステップS51でPCRパケット検出信号が入力されたときの、カウンタ214から供給されたカウント値N1(図18(B))を参照点として保持し、それを基準クロック値Bとともに、下記の式(1)に代入し、オフセット値Oを算出する。
オフセット値O=PCR値E1(=基準クロック値B)−カウント値N1・・(1)
【0076】
ステップS53において、同期情報処理部213は、基準クロック値Bおよびオフセット値Oのそれぞれをメモリ215に記憶させる。
【0077】
次に、ステップS54において、同期情報処理部213は、カウンタ214からのカウント値Nが3240000を示すまでに、PCRパケット検出信号が、PCRパケット検出部212から入力されたか否かを判定し、それまでにPCRパケット検出信号が入力されたと判定した場合、ステップS55に進む。この例の場合、図18(A),(B)に示すように、ステップS52でカウンタ214のカウント値Nがリセットされてから(時刻t0)、3240000クロックのカウントが完了するとき(時刻t1(図18(A))までに、第2番目のPCRパケットが検出されるので、ステップS55に進む。なお、PCRパケットが入力されていないとき、同期情報処理部213は、PCRパケットが検出されたことを示すフラグを取り消す。
【0078】
ステップS55において、同期情報処理部213は、PCRパケット(この場合、第2番目のPCRパケット)のヘッダ部の同期バイトを47hから−128に変更する。なお、ここでの処理の意味は、後述する。
【0079】
ステップS54において、カウンタ214のカウント値Nが3240000になるまでの間にPCRパケットが検出されなかったと判定した場合、同期情報処理部213は、カウンタ214に対して、カウント値N=3240000となるタイミングで、カウント値Nのリセットを指令し、その後、ステップS56に進む。
【0080】
ステップS56において、同期情報処理部213は、PCRパケットが検出されるまで(PCRパケット検出信号が入力されるまで)待機する。なお、この例の場合、カウンタ214においては、1/3240000に分周された27MHzのクロックがカウントされているので、3240000クロック分のカウントが完了するのに、0.12秒(=3240000/27000000)を要する。すなわち、MPEG-2方式によれば、PCRパケットは、少なくとも0.1秒に1つの割合で伝送されるようになされているので、ステップS54でカウント値Nの値がリセットされてから(例えば、図18(A)の時刻t1)、3240000クロックのカウントが完了する(例えば、図18(A)の時刻t2)までの間には、必ず1つのPCRパケット(この例の場合、第3番目のPCRパケット)が検出される。
【0081】
ステップS56において、PCRパケット(この例の場合、第3番目のPCRパケット)が検出されたとき、同期情報処理部213は、ステップS57に進み、第3番目のPCRパケットに書き込む同期情報を算出する。具体的には、同期情報処理部213は、到着した第3番目のPCRパケットのPCR値E3(図18(C))を取得する。次に、同期情報処理部213は、第3番目のPCRパケットが検出されたときのカウンタ値N3(図18(B))を保持する。さらに、同期情報処理部213は、PCR値E1、PCR値E3、カウント値N3、および基準クロック値Bを、下記の式(2)に代入し、同期情報を算出する。
【0082】
同期情報=((PCR値E3−PCR値E1)−(カウント値N3−基準クロック値B))×3240000÷(カウント値N3−基準クロック値B))・・(2)
【0083】
すなわち、この同期情報は、(カウント値N3−基準クロック値B)分のクロックがカウントされる間に生じる、PCR値E3(システムエンコーダのシステムクロックのカウント値)とカウント値N3(ネットワーク202のネットワーククロックと同期するPLL回路217により発生されたクロックのカウント値)との差(α)から、第3番目のPCRパケットが、カウント値Nが3240000となる時点(時刻t1)に送信装置201に到着されるものとした場合のPCR値Eとカウンタ値N(=3240000)との差(β)を表すものでる。
【0084】
次に、ステップS58において、同期情報処理部213は、第3番目のPCRパケットに、ステップS57で算出した同期情報を書き込む。具体的には、同期情報処理部213は、第3番目のPCRパケットのヘッダ部の同期バイト(47h)を、算出した同期情報に変更する。
【0085】
同期情報処理部213は、ステップS55またはステップS58で同期バイトを変更した後、ステップS59に進み、その値から39hを差し引く。このように、39hの値を差し引くことより、例えば、同期情報が含まれていないPCRパケットの同期バイト(ステップS55で、−128に変更された同期バイト)は、47hとなる。このことより、受信装置102において、図13または図14のフローチャートで説明した同期処理により、MPEGトランスポートストリームパケットの同期が確立されるようになる。
【0086】
次に、ステップS60において、同期情報処理部213は、3240000(クロック)に、ステップS57で算出した同期情報を加算して、それを新たな基準クロック値Bとし、またステップS52で算出したオフセット値Oに同期情報を加算して、それを新たなオフセット値Oして、メモリ215に上書きする。すなわち、次のPCRパケットが入力されたとき、この変更された基準クロック値Bおよびオフセット値Oに基づいて、同期情報が算出される。
【0087】
以上のような処理を同期情報処理部213が実行することより、メモリ215には、基準クロック値B(42ビット)、オフセット値O(42ビット)、およびフラグ(1ビット)が、プログラムのPIDに対応して記憶される。
【0088】
また、以上においては、図18に示したように、時刻t0と時刻t1(図18(A))との間に、第2番目のPCRパケットが検出される(送信装置201に入力される)場合を例として説明したが、例えば、図19に示すように、その間に、第3番目のPCRパケットが入力されるような場合であっても同様に処理される。すなわち、この場合、第2番目のPCRパケットと第3番目のPCRパケットのヘッダ部の同期バイトの値は47h(−128から39hが差し引かれた47h)が設定され、そして第4番目のPCRパケットには、ステップS57における処理で算出される同期情報が、その同期バイトに書き込まれる。
【0089】
以上においては、1のPIDに対応して(1のプログラムに対応して)、同期情報が算出される場合を例として説明したが、図20に示すように、複数のプログラム(2つのプログラム)に対応する場合も同様に、上述した方法で、それぞれの同期情報が算出され、所定のPCRパケットに書き込まれる。
【0090】
図20(A)は、図18(B)と同じ図であり、図20(B)は、他のプログラムに対しての同期情報作成処理を説明するタイミングチャートである。図20(B)の場合、カウント値N10からオフセット値O1だけ離れた地点が基準クロック値Bとされ、上述した同期情報作成処理が行われる。なお、この場合のオフセット値Oおよび基準クロックBは、メモリ215に、プログラムのPIDに対応して記憶される。
【0091】
次に、同期情報の情報量について説明する。MPEG-2規格によれば、システムクロックとして用いられる27MHzのクロック(例えば、システムエンコーダのシステムクロックや送信装置201のPLL回路217により生成されるクロック(以下、クロックSと称する))には、それぞれ+/-30ppm(parts per million )の偏差が許容されている。すなわち、システムエンコーダのクロックおよびクロックSの周波数は、(27MHz−810(=27×106×30×10-6)Hz)乃至(27MHz+810Hz)の範囲で変動する。
【0092】
つまり、両者の周波数のずれは、図21に示すように、システムエンコーダのシステムクロックの周波数が27MHz+810Hz(図21(A))で、かつ、クロックSの周波数が27MHz−810Hz(図21(C))であるとき、また逆に、図22に示すように、システムエンコーダのシステムクロックの周波数が27MHz−810Hz(図22(A))で、かつ、クロックSの周波数が27MHz+810Hzであるとき(図22(C))に最大となる。
【0093】
そこで、図21の場合における各クロックの1秒間にカウントされるクロック数を求めると、想定する真の27 MHzの場合、27×106個であるのに対して(図21(B))、図21(A)のシステムエンコーダの場合は、(27×106+810)個となり、図21(C)のクロックSの場合は、(27×106−810)個となる。また、同様に図22の場合における各クロックの1秒間にカウントされるクロック数を求めると、図22(A)のシステムエンコーダのシステムクロック場合、(27×106−810)個となり、図22(C)のクロックSの場合、(27×106+810)個となる。すなわち、両者の周波数のずれが最大となるときの、1秒間でカウントされるクロック数の差は、1620個となる。
(27×106+810)−(27×106−810)=1620
【0094】
ところで、上述した同期情報も、システムエンコーダのシステムクロックとクロックSのずれ(PCRパケットの送信装置201への到着間隔の間でカウントされるクロック数の差)を示すものであるが、同期情報は、クロックSのカウント値NをPCRの時間軸に対応させることで算出されている。すなわち、同期情報の最大値も、PCRの時間軸に対応させて求める必要がある。また、同期情報は、この例の場合、0.12(=324000/27000000)秒間に、少なくとも1つ以上、MPEGトランスポートストリームパケットに組み込まれているので、同期情報は、最大0.12秒間のずれ(0.12秒間にカウントされるクロック数の差)を示すことができる必要がある。つまり、同期情報は、図21の状態のとき、プラス側で最大となり、その値は、下記に示すように、195となる。
((1+30ppm)/(1-30ppm)-1)×27MHz×0.12s=195
【0095】
上記式は、図21(C)のクロックSの周期(1/(27MHz−810Hz))(時間)を、図21(A)のシステムエンコーダのシステムクロックの周期(1/(27MHz+810Hz))で正規化し(PCRの時間軸に対応させ)、正規化されたそのクロックSの時間(PCRの時間軸に対応するクロックSの時間)と、PCRの時間(1単位)との差を求め、求めたその差に基づいて、0.12秒間に発生する両者のクロックのずれをクロック数で示したものである。
【0096】
一方、図22の状態のとき、同期情報は、マイナス側で最大となり、その値は、下記に示すように、-195となる。
((1-30ppm)/(1+30ppm)-1)×27MHz×0.12s=-195
すなわち、以上のことから、同期情報は、下記に示す範囲の値を取り得る。
-195<=同期情報=<195
【0097】
このことより、同期情報を表すには、9ビットが必要となるが(バイト単位で容量を確保するものとすると、2バイトが必要となるが)、1ビット分削除し、8ビットで示しても、+/-1クロック分の誤差が発生するだけで、MPEG-2方式のジッタの規格を越えない。MPEG-2方式におけるジッタの規格は、+/-500nsであり、それをクロック数に変換すると、+/-13.5(=+/-500nsec×27MHz)クロックである。すなわち、+/-1クロック分の誤差は、その範囲内であり、結局、同期情報は、8ビット(1バイト(-128乃至128))で示すことができる。
【0098】
この例の場合、同期情報は、−125乃至125のうちのいずれかの値とし、その他の値には、図23に示すような意味付けを行って利用する。例えば、−128は、同期情報が設定されていないことを意味する。すなわち、ステップS52で同期バイトが−128とされたが、これは、そのTSパケットには、同期情報が書き込まれないとを示すためである。
【0099】
−127は、例えばPCRパケットに大きなジッタが発生し、入力されたPCRパケットの間隔が大きく、同期情報の値が−125乃至125の範囲外とされるような場合などの、送信装置201において何らかのエラーが発生したことを意味する。−126、126、および127は、リザーブの値である。
【0100】
図24は、受信装置203の構成例を表している。ATM/MPEG変換部301は、ネットワーク202を介して伝送されてきた、送信装置201からのATMセルをMPEGトランスポートストリームパケットに変換し、TSパケット同期部304に出力する。ATM/MPEG変換部301はまた、受信したATMセルに基づいてネットワーク202のネットワーククロックに同期した8KHzのクロックを生成し、PLL回路302に出力する。PLL回路302は、図11のPLL回路217と同様の構成(位相比較回路を有している)を有するので、その詳細な説明は省略するが、ATM/MPEG変換部301から供給されたクロックと同期した、27MHzのクロックを生成し、カウンタ303に出力する。
【0101】
カウンタ303は、PLL回路302からの27MHzのクロックを1/3240000で分周し、それをカウントするとともに、そのカウント値MをPCR書換部306に出力する。
【0102】
TSパケット同期部304は、図11のTSパケット同期部211と同様に、図13または図14に示したフローチャートの処理に従って、ATM/MPEG変換部301からのMPEGトランスポートストリームパケットの同期を確立し、PCRパケット検出部305に出力する。
【0103】
なお、図14のフローチャートに示した処理により、フレーム同期を確立する場合、TSパケット同期部304は、47hカウント部(図15)を利用するが、同期情報が書き込まれたPCRパケットが入力されたとき、47hカウント部のメモリ領域iの値をリセットしないようにすることもできる。図25を参照して、具体的に説明する。
【0104】
データ11およびデータ12のデータに対応して、メモリ領域kの値が2とされている状態において、データ13の先頭データからkバイト離れた、4Ah乃至44hのいずれかの値が読み取られたとき、メモリ領域kの値は0にリセットされない(値2が保持される)。これは、4Ah乃至44hのいずれかの値を、同期情報が含まれるPCRパケットの先頭データであるとし、フレーム同期が取られているとしたためのである。なお、図25中、xxhは、47h、4Ah乃至44h以外のデータを示している。
【0105】
PCRパケット検出部305は、入力されたMPEGトランスポートストリームパケットのヘッダ部およびアダプテーションフィールド部を参照し、PCRパケット条件が設定されているか否かを判定し、PCRパケット条件が設定されていると判定した場合、PCRパケット検出信号をPCR書換部306に出力する。
【0106】
PCR書換部306は、入力されるPCRパケット(同期情報が書き込まれている)から同期情報を読み出すなどの処理を行い、新たなPCR値Dを算出し、PCR値DをPCRパケットに書き込む(書き換える)。なお、PCR書換部306における処理の詳細は、後述する。メモリ307は、PCR書換部306が、PCR値Dを算出するのに必要なデータを記憶している。
【0107】
次に、PCRパケットのPCR値を書き換える場合のPCR書換部306の動作を、図26のフローチャートを参照して説明する。TSパケット同期部304において、MPEGトランスポートストリームパケットの同期が取られている状態において、ステップS71において、PCR書換部306は、オフセット値Dを決定する。この処理の詳細は、図27のフローチャートに示されている。すなわち、ステップS81において、PCR書換部306は、フレーム同期確立後、最初に入力されるPCRパケットのPCR値Eを取得し、それを基準クロック値Bとし、そのPCRパケットが入力されたときのカウンタ303からのカウンタ値Mから、その基準クロック値Bを減算し、オフセット値Wを算出する。PCR書換部306は、基準クロック値Bおよびオフセット値Wを、メモリ307に記憶させる。
【0108】
次に、ステップS82において、PCR書換部306は、カウンタjの値に1を設定し、ステップS83において、次に入力されたPCRパケットのPCR値Eを読み取り、基準クロック値Bとの差ΔEを算出する。次に、ステップS84において、PCR書換部306は、ΔEが所定のリミット値Lより大きいか否かを判定し、大きくないと判定した場合、ステップS85に進み、それをメモリ307に記憶させる。一方、ステップS84において、ΔEがリミット値Lより大きいと判定された場合、ステップS83に戻る。
【0109】
ステップS86において、PCR書換部306は、カウンタjの値が7になったか否かを判定し、その値が7ではないと判定した場合、ステップS87に進み、カウンタjの値を1だけインクリメントして、ステップS83に戻り、次に入力されてくるPCRパケットに対して、それ以降の処理を実行する。
【0110】
ステップS86において、カウンタjの値が7であると判定された場合、すなわち、図28に示すように、7つのΔE1乃至ΔE7が算出され、それらがメモリ307に記憶されたとき、ステップS88に進み、PCR書換部306は、式(3)に示すように、ΔEの合計値を7で割り、ΔEの平均値を算出し、メモリ307に記憶させる。
ΔEの平均値=(ΔE1+ΔE2+ΔE3+ΔE4+ΔE5+ΔE6+ΔE7)/7 ・・・(3)
【0111】
次に、ステップS89において、PCR書換部306は、式(4)に従い、オフセット値Wに、ΔEの平均値を加算して、オフセット値Dを算出する(図28)。
オフセット値D=オフセット値W+ΔEの平均値 ・・・(4)
【0112】
このように、オフセット値Dが算出されたとき、処理は終了され、図26のステップS72に進む。なお、オフセット値Dが算出されたタイミング(図29の例では、時刻t10)で、PCR書換部306は、オフセット値Dが算出されたことを示す所定のフラグ(1ビット)をメモリ307にセットする。また、PCR書換部306は、同じタイミングで、カウンタ303に対して、カウント値Mのリセットを指令する。
【0113】
ステップS72において、PCR書換部306は、同期情報が書き込まれたPCRパケットが入力されるまで待機し、それが入力されたとき、ステップS73に進み、カウンタ303が、ステップS71でリセットされてから、3240000クロック分のカウントを完了したか否かを判定し、そのカウントを完了していないと判定した場合、ステップS74に進む。ここでの第1番目のPCRパケットは、送信装置201の説明において示された第1番目のPCRパケットとは、別のパケットである。
【0114】
ステップS74において、PCR書換部306は、PCR値Dを算出する。図29を参照して説明するが、ステップS71でカウント値Mがリセットされてから、340000クロック分のカウントが完了するまでに、同期情報が書き込まれたPCRパケット(第1番目のPCRパケット)が入力されたものとする。そこで、PCR書換部306は、到着した第1番目のPCRパケットの同期情報を取得する。次に、PCR書換部306は、第1番目のPCRパケットが入力されたときの、カウンタ303からのカウンタ値M1(図29(B))を保持する。そして、PCR書換部306は、カウント値M1、オフセット値D、同期情報、および基準クロック値Bを、式(5)に代入して、PCR値Dを算出する。
PCR値D=(カウント値N1+オフセット値D+同期情報×(カウント値N1−基準クロックB)/3240000 ・・・(5)
【0115】
次に、ステップS75において、PCR書換部306は、第1番目のPCRパケットのPCR値E1を、算出したPCR値Dに書き換え、図示せぬデコーダに出力する。その後処理は終了する。
【0116】
ステップS73において、3240000クロック分のカウントが完了していたと判定された場合、すなわち、図30に示すように、3240000クロック分のカウントが完了してから、第1番目のPCRパケット(同期情報が書き込まれているPCRパケット)が入力されたとき、ステップS76に進み、基準クロック値Bが変更される。具体的には、PCR書換部306は、第1番目のPCRパケットから同期情報を読み出し、それに3240000を加算し、その加算結果を新たな基準クロック値Bとしてメモリ307に上書きする。これにより、基準クロック値Bが変更される。
【0117】
次に、ステップS77において、PCR書換部306は、オフセット値Dを変更する。具体的には、PCR書換部306は、メモリ307からオフセット値Dを読み出し、それに第1番目のPCRパケットの同期情報を加算し、その加算結果を、新たなオフセット値Dとして、メモリ307に上書きする。これにより、オフセット値Dが変更される。
【0118】
その後、ステップS74に戻り、PCR書換部306は、変更された基準クロック値Bおよびオフセット値Dに基づいて、PCR値Dを算出する。
【0119】
以上において説明した、受信装置203におけるPCR書き換え処理は、プログラムごと(例えば、チャンネル)に行われる。すなわち、複数のプログラムに対して同様の処理が行われる。
【0120】
以上のように、送信装置201において同期情報が書き込まれ、ネットワーク202を介して受信装置203に伝送された後、受信装置203において、同期情報に基づいてPCRが書き換えられるようにしたので、複数のプログラム(例えば、8192通りのPID)に対応して、遅延ゆらぎが抑制される。
【0121】
次に、受信装置203の他の構成例を、図31に示す。なお、図中、図24における場合と対応する部分については、同一の符号を付してある。すなわち、ATM/MPEG変換部301とTSパケット同期部304の間に、図5に示したアダプティブクロック部51が設けられている。これにより、アダプティブクロック部51によりある程度ゆらぎが吸収されたMPEGトランスポートストリームパケットにより、PCR値Dが算出される。その結果、受信装置203からMPEGトランスポートストリームパケット(PCRパケットを含む)の供給を受ける、図32に示すようなデコーダ400において、図33に示すように、VBVバッファ401の破綻を防止することができる。
【0122】
デコーダ400において、入力されるMPEGトランスポートストリームパケットに遅延ゆらぎが発生していない場合は、VBVバッファ401のデータ占有量の軌跡は、図33中、点線Aで示されるようになり、オーバフロまたはアンダーフロしない。しかしながら、MPEGトランスポートストリームパケットが遅れて到着するような場合、データ占有量の軌跡は、実線Bで示されるように、アンダーフロになる可能性がある。また、早く到着するような場合、その軌跡は、実線Cに示されるように、オーバーフロになる可能性がある。
【0123】
図34は、上述のような送信装置201または受信装置203として機能するコンピュータ501の一実施の形態の構成を示すブロック図である。CPU(Central Processing Unit)511にはバス515を介して入出力インタフェース516が接続されており、CPU511は、入出力インタフェース516を介して、ユーザから、キーボード、マウスなどよりなる入力部518から指令が入力されると、例えば、ROM(Read Only Memory)512、ハードディスク514、またはドライブ520に装着される磁気ディスク531、光ディスク532、光磁気ディスク533、若しくは半導体メモリ534などの記録媒体に格納されているプログラムを、RAM(Random Access Memory)513にロードして実行する。これにより、上述した各種の処理(例えば、図13,図14,図17,図26,図27のフローチャートにより示される処理)が行われる。さらに、CPU511は、その処理結果を、例えば、入出力インタフェース516を介して、LCD(Liquid Crystal Display)などよりなる表示部517に必要に応じて出力する。なお、プログラムは、ハードディスク514やROM512に予め記憶しておき、コンピュータ501と一体的にユーザに提供したり、磁気ディスク531、光ディスク532、光磁気ディスク533,半導体メモリ534等のパッケージメディアとして提供したり、衛星、ネットワーク等から通信部519を介してハードディスク514に提供することができる。
【0124】
なお、本明細書において、記録媒体により提供されるプログラムを記述するステップは、記載された順序に沿って時系列的に行われる処理はもちろん、必ずしも時系列的に処理されなくとも、並列的あるいは個別に実行される処理をも含むものである。
【0125】
また、本明細書において、システムとは、複数の装置により構成される装置全体を表すものである。
【0126】
【発明の効果】
請求項1に記載の通信装置、請求項に記載の通信方法、および請求項に記載の記録媒体のプログラムによれば、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データを検出し、検出した、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出した、同期データと同値である単位データの数をカウントするようにしたので、カウントした、連続して検出した同期データと同値である単位データの数が、所定の数となったとき、検出した単位データのうちの1つの単位データのストリーム上の配置位置を、パケットの先頭として、ストリームの同期を確立し、ストリームの同期が確立されている状態において、パケットからタイムスタンプを読み出し、読み出したタイムスタンプに基づいて、パケットに設定された識別子毎に所定の同期情報を算出することができる。
【図面の簡単な説明】
【図1】従来のデータ伝送システムの構成例を示すブロック図である。
【図2】 PCRを説明する図である。
【図3】図1のシステムデコーダ4の構成例を示すブロック図である。
【図4】図3のPLL回路13の構成例を示すブロック図である。
【図5】アダプティブクロック部の構成例を示すブロック図である。
【図6】送信装置61の構成例を示すブロック図である。
【図7】受信装置62の構成例を示すブロック図である。
【図8】位相比較器91の構成例を示すブロック図である。
【図9】 本発明を適用したデータ伝送システムの構成例を示す図である。
【図10】 MPEGトランスポートストリームパケットのデータ構造を説明する図である。
【図11】図9の送信装置201の構成例を示す図である。
【図12】位相比較器250の構成例を示す図である。
【図13】同期確立処理を説明するフローチャートである。
【図14】同期確立処理を説明する他のフローチャートである。
【図15】 47hカウント部を示す図である。
【図16】同期確立処理を説明する図である。
【図17】同期情報作成処理を説明するフローチャートである。
【図18】同期情報作成処理を説明するタイミングチャートである。
【図19】同期情報作成処理を説明するタイミングチャートである。
【図20】同期情報作成処理を説明する他のタイミングチャートである。
【図21】同期情報のデータ量を説明する図である。
【図22】同期情報のデータ量を説明する他の図である。
【図23】 同期情報の値の意味を説明する図である。
【図24】受信装置203の構成例を示す図である。
【図25】同期確立処理を説明する図である。
【図26】 PCR書換処理を説明するフローチャートである。
【図27】 オフセット値の算出処理を説明するフローチャートである。
【図28】オフセット値の算出処理を説明する図である。
【図29】 PCR書き換え処理を説明するタイミングチャートである。
【図30】 PCR書き換え処理を説明する他のタイミングチャートである。
【図31】受信装置203の他の構成例を示すブロック図である。
【図32】デコーダ400の構成例を示すブロック図である。
【図33】 VBVバッファのデータ量の軌跡を示す図である。
【図34】コンピュータ501の構成例を示すブロック図である。
【符号の説明】
201 送信装置, 202 ネットワーク, 203 受信装置, 211 TSパケット同期部, 212 PCRパケット検出部, 213 同期情報処理部, 214 カウンタ, 215 メモリ, 216 MPEG/ATM変換部, 217 PLL回路, 301 ATM/MPEG変換部, 302 PLL回路, 303 カウンタ, 304 TSパケット同期部, 305 PCRパケット検出部, 306 PCR書換部, 307 メモリ
[0001]
BACKGROUND OF THE INVENTION
The present invention relates to a communication apparatus and method, and a recording medium, and more particularly to a communication apparatus and method, and a medium that can transmit and receive audio data and video data digitized using ATM communication technology.
[0002]
[Prior art]
FIG. 1 shows a configuration example of a conventional data transmission system. It is assumed that the network 3 to which each of the encoding side and the decoding side is connected uses a satellite as in the transmission method in digital CS broadcasting. That is, it is assumed that a delay of a constant interval occurs in data transmitted via the network 3.
[0003]
The encoder 1 encodes, for example, video data and audio data as data to be transmitted according to the MPEG-2 system, and outputs the encoded data to the system encoder 2. The system encoder 2 packetizes the input video data and audio data, generates a transport stream packet, multiplexes it with another transport stream as necessary, and outputs it to the network 3.
[0004]
The system encoder 2 also incorporates a PCR (Program Clock Reference), which is a time stamp, in the header of the generated transport stream packet as shown in FIG. 2 (hereinafter, a transport stream packet in which PCR is incorporated in the header). Called PCR packet). This PCR is a count value of the system clock C1 (the clock having a frequency of 27 MHz in the case of the MPEG-2 system) in the system encoder 2 counted at the timing when the transport stream is output from the encode side. The PCR is incorporated in the transport stream so that at least one PCR is output from the encoding side in 0.1 seconds according to the MPEG-2 standard.
[0005]
Returning to FIG. 1, the transport stream packet (including the PCR packet) output from the encoding side arrives at the decoding side via the network 3 and is input to the system decoder 4. Since the transport stream transmitted via the network 3 has a delay of a constant interval, the PCR (PCR packet) is the same interval as that sent from the encoding side (the difference is MPEG Arrives at the decoding side within +/- 500ns of -2 standard).
[0006]
The system decoder 4 depackets the input transport stream packet, and outputs the resulting audio stream or video stream to the decoder 5. As shown in FIG. 2, the system decoder 4 also extracts the PCR from the PCR packet, and compares the PCR with the count value of the decoding-side system clock C2 (27 MHz clock) counted at the timing when the PCR is extracted. Based on the comparison result, the speed of the system clock C2 is adjusted and supplied to the decoder 5.
[0007]
The decoder 5 decodes the audio data or video data supplied from the system decoder 4 in synchronization with the system clock C2 supplied from the system decoder 4.
[0008]
Next, the generation (adjustment) processing of the system clock C2 on the decoding side will be further described with reference to FIGS. The system decoder 4 is configured as shown in FIG. The transport stream packet supplied to the system decoder 4 is supplied to the system decoding unit 11 and the time stamp extraction circuit 12 of the system decoder 4.
[0009]
As shown in FIG. 2, the time stamp extracting circuit 12 extracts the PCR incorporated in the PCR packet and outputs it to the PLL circuit 13. For example, the PLL circuit 13 is configured as shown in FIG. 4. The subtracter 21 includes a PCR extracted by the time stamp extraction circuit 12 and a counter 24 counted at the timing when the PCR is input. A count value (clock count value output from the D / A converter / VCO 23) is input. The subtractor 21 calculates the difference between the PCR from the time stamp extraction circuit 12 and the count value from the counter 24 and outputs the difference to a low-pass filter (hereinafter abbreviated as LPF) 22. The LPF 22 temporally smoothes the input calculation result from the subtracter 21 and outputs the result to a D / A converter / VCO (voltage controlled oscillator) 23. The D / A converter / VCO 23 converts the digital signal input from the LPF 22 into an analog signal, and uses the analog signal as a control voltage to generate a system clock C2 having a frequency corresponding to the control voltage. The D / A converter / VCO 23 outputs the generated system clock C2 to the counter 24 and the decoder 5.
[0010]
The counter 24 counts the system clock C2 from the D / A converter / VCO 23 and supplies the count value to the subtractor 21 as a signal representing the frequency and phase of the system clock C2 at that time. That is, in the PLL circuit 13, there is no difference between the PCR incorporated in the transport stream packet and the count value of the system clock C2 counted at the timing when the PCR is taken out (timing when the PCR packet arrives at the decoding side). As described above, the speed of the system clock C2 is adjusted. As a result, a decoding-side system clock C2 that is synchronized with the encoding-side system clock C1 is generated.
[0011]
Returning to FIG. 3, the system decoding unit 11 depackets the input transport stream packet, and outputs the resulting audio stream and video stream to the decoder 5.
[0012]
By the way, when a satellite is used as the transmission method in satellite broadcasting as the network 3, a fixed delay is added to the transport stream packet transmitted from the encoding side. That is, the transport stream packet transmitted from the encoding side arrives at the decoding side after being delayed or accelerated by a fixed time. In this case, since the lag time or the accelerating time is constant, the arrival interval of transport stream packets (including PCR packets) on the decoding side is the same as the output interval from the encoding side. Therefore, in this case, the decoding-side system clock C2 is generated in synchronization with the encoding-side system clock C1 by using the method described with reference to FIGS.
[0013]
[Problems to be solved by the invention]
However, when an ATM (Asynchronous Transfer Mode) network is used as the network 3, the transport stream packet transmitted from the encoding side does not have a fixed interval delay, but has a delay (for example, in the range of 1 ms to 2 ms). (Hereinafter referred to as delay fluctuation). In this case, in the above-described data transmission system, the delay fluctuation is not absorbed, and eventually, the magnitude of the delay greatly exceeds the range of +/− 500 ns of the MPEG-2 standard, and the data is not reproduced properly.
[0014]
Therefore, a synchronization method such as an adaptive clock method has been proposed in which the system clock is generated after delay fluctuation is reduced to some extent on the decoding side.
[0015]
FIG. 5 shows a configuration example of the adaptive clock unit 51 of the decoding-side apparatus to which the adaptive clock method is applied. It is assumed that delay fluctuation has occurred in the data transmitted via the network 50.
[0016]
The data having delay fluctuation transmitted through the network 50 is input to the FIFO 52 of the adaptive clock unit 51. The FIFO 52 temporarily holds input data and outputs data corresponding to a predetermined read clock supplied from the control unit 53. The FIFO 52 also outputs its own data occupancy rate to the LPF 54. The LPF 54 smoothes the data occupation rate of the FIFO 52 and outputs it to the control unit 53.
[0017]
The control unit 53 controls the speed of the read clock output to the FIFO 52 so that the data supplied from the LPF 54 (the data occupation rate of the smoothed FIFO 52) becomes a predetermined value. That is, in the adaptive clock method, the clock controlled by the control unit 53 is the system clock on the decoding side.
[0018]
Thus, in this adaptive clock system, the system clock on the decoding side is generated based only on the received data, so that the configuration of the apparatus can be simplified. However, in this example, since the jitter component is only shaved in an analog manner, the jitter component remains in a long time, and there is a problem that the delay fluctuation is not sufficiently absorbed.
[0019]
In addition, a data transmission system has been proposed that includes a transmitting device 61 having a configuration as shown in FIG. 6 on the encoding side and a receiving device 62 having a configuration as shown in FIG. 7 on the decoding side. This is, for example, a system for transmitting a plurality of programs synchronized with respective clocks in each television broadcasting station or program creation company.
[0020]
As shown in FIG. 6, the transmission device 61 includes a PLL circuit 71 and N synchronization data creation units 72-1 to 72-N (hereinafter, if it is not necessary to distinguish between them, the synchronization data creation unit 72 is simply used. The same applies to other parts). The PLL circuit 71 is supplied with an 8 kHz clock that is the network clock of the network 63. The PLL circuit 71 is provided with a phase comparator 91 configured as shown in FIG. The VCO 92 of the phase comparator 91 generates 27 MHz of a predetermined phase based on the signal supplied from the phase comparator 94, outputs it to the frequency divider 93, and also generates synchronization data generators 72-1 to 72-. Also output to each of N.
[0021]
The frequency divider 93 divides the 27 MHz clock input from the VCO 92 by 1/3375, generates an 8 KHz clock, and outputs it to the phase comparator 94. The phase comparison unit 94 compares the phase of the 8 KHz clock from the network 63 with the phase of the 8 KHz clock from the frequency divider 93 and outputs the comparison result to the VCO 92.
[0022]
The synchronization data creation unit 72-1 includes a PLL circuit 81, a latch circuit 82, a clock 83, and the like. For example, a time stamp included in data created in synchronization with a predetermined clock is supplied to the PLL circuit 81 of the synchronous data creation unit 72-1. The PLL circuit 81 basically has the same configuration as the PLL circuit 13 shown in FIG. That is, the PLL circuit 81 generates a predetermined clock based on the input time stamp and outputs it to the latch circuit 82.
[0023]
The latch circuit 82 executes a latch process according to the clock from the PLL circuit 81 and the clock from the clock 83. Data reproduced based on the processing result of the latch processing is used as synchronization data, and is incorporated into a predetermined transport stream packet.
[0024]
Since the synchronization data creation units 72-2 to 72-N have the same configuration as the synchronization data creation unit 72-1, the illustration and detailed description thereof are omitted, but they are created in synchronization with different clocks. The time stamp included in the received data is input, and synchronous data corresponding to the clock is created.
[0025]
As shown in FIG. 7, the receiving device 62 includes a PLL circuit 101 and N system clock recovery units 102-1 to 102-N. The PLL circuit 101 is supplied with an 8 kHz clock that is the network clock of the network 63. Similar to the PLL circuit 71 of the transmission device 61, the PLL circuit 101 generates a 27 MHz clock corresponding to the input 8 KHz clock, and outputs it to each of the system clock recovery units 102-1 to 102-N.
[0026]
The system clock recovery unit 102-1 includes a clock 110, a PLL circuit 111, and the like. The clock supplied from the PLL circuit 101 is input to the clock 110 of the system clock recovery unit 102-1, and the clock 110 divides it by 1/27000000 and outputs it to the PLL circuit 111. In addition to the clock from the clock 110, the PLL circuit 111 is supplied with the synchronization data created by the synchronization data creation unit 72-1 of the transmission device 61. Therefore, the PLL circuit 111 regenerates the system clock based on the input clock and synchronization data.
[0027]
Since the system clock recovery units 102-2 to 102-N also have the same configuration as the system clock recovery unit 102-1, illustration thereof is omitted, but they correspond to the synchronization of the transmission device 61, respectively. The system clock is regenerated using the synchronization data supplied from the data creation unit 72. Since the system clock reproduced in this way is synchronized with the clock at the time of encoding each data, the data is appropriately reproduced by decoding the data according to the clock.
[0028]
However, in the above-described data transmission system, it is necessary to provide the synchronization data creation unit 72 and the system clock reproduction unit 102 for each clock at the time of encoding, and there is a problem that the configuration of the apparatus is complicated and the size is increased. .
[0029]
The present invention has been made in view of such problems, and can easily and reliably absorb delay fluctuations, and data corresponding to a plurality of programs without complicating and increasing the size of the apparatus. Can be sent and received.
[0030]
The communication device according to claim 1 is: Predetermined time stamp is added A detection unit that detects unit data arranged in the stream that has the same value as the synchronization data incorporated at the head of the packet constituting the stream, and a unit data stream that has the same value as the synchronization data detected by the detection unit. For each packet size, unit data arranged in the stream is detected for each packet size, and among the detected unit data, When unit data with the same value as the sync data, the same value as the time stamp, and the same value as the sync data is detected continuously, First count means for counting the number of unit data having the same value as the synchronization data detected continuously, and unit data having the same value as the synchronization data detected continuously by the first count means Synchronization establishment means for establishing the synchronization of the stream with the arrangement position on the stream of one unit data of the detected unit data as the head of the packet when the number of data reaches a predetermined number Synchronous information processing means for reading a time stamp from the packet in a state where the synchronization of the stream is established, and calculating predetermined synchronization information for each identifier set in the packet based on the read time stamp It is characterized by providing.
[0031]
The unit data placed in the stream is detected for each size of the packet from the placement position of the unit data set at the head of the packet by the synchronization establishment means on the stream where the synchronization is established by the synchronization establishment means. A second counting unit that counts the number of unit data having different values from the synchronous data detected continuously among the unit data, and the detecting unit is counted by the second counting unit. In addition, when the number of unit data having a value different from the synchronous data detected continuously reaches a predetermined number, the unit data arranged in the stream having the same value as the synchronous data can be detected again. .
[0033]
Claim 3 The communication method described in Predetermined time stamp is added A detection step for detecting unit data arranged in the stream having the same value as the synchronization data incorporated at the head of the packet constituting the stream, and a unit data having the same value as the synchronization data detected in the processing of the detection step. Unit data arranged in the stream is detected for each packet size from the arrangement position on the stream, and among the detected unit data, When unit data with the same value as the sync data, the same value as the time stamp, and the same value as the sync data is detected continuously, A count step for counting the number of unit data having the same value as the synchronous data detected continuously, and the number of unit data having the same value as the synchronous data detected continuously, which is counted in the processing of the count step, A synchronization establishing step for establishing synchronization of the stream with the arrangement position on the stream of one unit data of the detected unit data as the head of the packet when the predetermined number is reached; A synchronization information processing step of reading a time stamp from the packet in a state where the synchronization of the stream is established, and calculating predetermined synchronization information for each identifier set in the packet based on the read time stamp; It is characterized by including.
[0034]
Claim 4 The recording medium described in Predetermined time stamp is added A detection step for detecting unit data arranged in the stream having the same value as the synchronization data incorporated at the head of the packet constituting the stream, and a unit data having the same value as the synchronization data detected in the processing of the detection step. Unit data arranged in the stream is detected for each packet size from the arrangement position on the stream, and among the detected unit data, When unit data with the same value as the sync data, the same value as the time stamp, and the same value as the sync data is detected continuously, A count step for counting the number of unit data having the same value as the synchronous data detected continuously, and the number of unit data having the same value as the synchronous data detected continuously, which is counted in the processing of the count step, A synchronization establishing step for establishing synchronization of the stream with the arrangement position on the stream of one unit data of the detected unit data as the head of the packet when the predetermined number is reached; A synchronization information processing step of reading a time stamp from the packet in a state where the synchronization of the stream is established, and calculating predetermined synchronization information for each identifier set in the packet based on the read time stamp; It is characterized by including.
[0035]
The communication device according to claim 1, 3 Communication method according to claim 1 and claim 4 In the recording medium program described in Predetermined time stamp is added The unit data arranged in the stream having the same value as the synchronous data incorporated at the head of the packet constituting the stream is detected, and the packet from the arrangement position on the stream of the detected unit data having the same value as the synchronous data is detected. For each size, unit data arranged in the stream is detected, and among the detected unit data, When unit data with the same value as the sync data, the same value as the time stamp, and the same value as the sync data is detected continuously, When the number of unit data with the same value as the synchronous data detected continuously is counted, and when the number of unit data with the same value as the synchronous data detected continuously reaches the predetermined number The synchronization position of the stream is established with the arrangement position of one of the detected unit data on the stream as the head of the packet. In a state where the synchronization of the stream is established, a time stamp is read from the packet, and predetermined synchronization information is calculated for each identifier set in the packet based on the read time stamp. .
[0036]
DETAILED DESCRIPTION OF THE INVENTION
FIG. 9 shows a configuration example of a data transmission system to which the present invention is applied. In this system, an MPEG transport stream compliant with the MPEG-2 system is transmitted / received via a network 202 which is an ATM network. That is, delay fluctuation occurs in data transmitted via the network 202.
[0037]
The transmission apparatus 201 receives an MPEG transport stream packet in which a plurality of encoded programs are multiplexed. The MPEG transport stream packet includes a PCR packet so that the PCR arrives at the receiving device 203 at intervals of at least 0.1 seconds.
[0038]
As shown in FIG. 10, the MPEG transport stream packet is a 188-byte fixed packet composed of a header portion, an adaptation field portion, a payload portion, and the like. The header part includes a synchronization byte (8 bits), error indication (1 bit), unit start indication (1 bit), transport packet priority (1 bit), PID (Packet Identification) (13 bits), scramble control (2 Bit), adaptation feel control (2 bits), and cyclic counter (4 bits). The synchronization byte is 47h.
[0039]
The adaptation field section includes an adaptation field length (8 bits), discontinuous display (1 bit), random access display (1 bit), stream priority display (1 bit), flag (5 bits), program clock reference base ( 33 bits), reserve (6 bits), and program clock reference extension (9 bits). There are five types of flags including a PCR flag (1 bit).
[0040]
The payload part includes data.
[0041]
The MPEG transport stream packet has the data structure as described above. As shown in FIG. 10, the adaptation field control of the header part is set to “10” or “11”, and the adaptation field length of the adaptation field part. When the value is other than 00h and “1” is set in the PCR flag (hereinafter, such data setting is described as a PCR packet condition), the MPEG transport stream packet is a PCR packet, A combination of the value of the program clock reference base and the value of the program lock reference extension in the adaptation field portion represents the PCR value.
[0042]
A value from 0 to 299 is sequentially set (counted) in the program clock reference base, and the value of the program clock reference extension is set at a timing when the value of the program clock reference base returns from 299 to a value of 0 (reset). Incremented by one. That is, a total of 42 bits of the program clock reference base and the program clock reference extension counts 24 hours in units of 27 MHz system clock in the MPEG-2 system.
[0043]
Returning to FIG. 9, the MPEG transport stream packet (including the PCR packet) input to the transmission apparatus 201 is converted into an ATM cell and transmitted on the network 202. The PCR packet includes the PCR value. The predetermined synchronization information (described later) created based on the above is written.
[0044]
The ATM cell transmitted via the network 202 arrives at the receiving device 203, where it is converted into an MPEG transport stream. The PCR value included in the PCR packet is added to the synchronization information written in the PCR packet. Modified based on. The MPEG transport stream packet including the PCR packet whose PCR value is corrected is supplied to a decoder (not shown) and decoded there.
[0045]
FIG. 11 illustrates a configuration example of the transmission apparatus 201. An MPEG transport stream packet supplied to the transmission apparatus 201 is input to an MPEG transport stream packet synchronization unit (hereinafter abbreviated as a TS packet synchronization unit) 211. The TS packet synchronization unit 211 detects the head of the input MPEG transport stream packet, establishes frame synchronization, and after establishing frame synchronization, outputs the MEPG transport stream packet to the PCR packet detection unit 212. .
[0046]
The PCR packet detection unit 212 refers to the header part and the adaptation field part of the MPEG transport stream packet (MPEG transport stream packet in which frame synchronization is taken) input from the TS packet synchronization unit 211, and the PCR packet condition Is determined, and if it is determined that the PCR packet condition is set, that is, if the MPEG transport stream packet is a PCR packet, a signal indicating that (hereinafter referred to as PCR packet detection) (Referred to as a signal) is output to the synchronous information processing unit 213. The PCR packet detection unit 212 outputs the input MPEG transport stream packet itself to the synchronous information processing unit 213 without performing any processing.
[0047]
The synchronous information processing unit 213 receives the MPEG transport stream packet and the PCR packet detection signal from the PCR packet detection unit 212 and the count value from the counter 214.
[0048]
The synchronous information processing unit 213 reads the PCR from the MPEG transport stream packet (PCR packet) from the PCR packet detection unit 212 specified by the PCR packet detection signal from the PCR packet detection unit 212, and based on the read PCR. Predetermined synchronization information (details will be described later) is calculated. The synchronization information processing unit 213 writes the calculated synchronization information in the PCR packet and outputs it to the MPEG / ATM conversion unit 216.
[0049]
The memory 215 appropriately stores data necessary for calculating the synchronization information supplied from the synchronization information processing unit 213. In the case of this example, the synchronization information calculation processing by the synchronization information processing unit 213 is performed for each program (for each PID set in the MEPG transport stream packet), so the memory 215 is supplied from the synchronization information processing unit 213. Stored data is stored for each program.
[0050]
The MPEG / ATM conversion unit 216 converts the MPEG transport stream packet into an ATM cell and transmits it to the network 202. The MPEG / ATM conversion unit 216 also receives ATM cells sequentially transmitted from the network 202, generates an 8 KHz clock synchronized with the network clock of the network 202 based on the received ATM cells, and outputs the generated clock to the PLL circuit 217. To do.
[0051]
The PLL circuit 217 includes a phase comparator 250 as shown in FIG. 12, for example, similarly to the PLL circuit 71 of FIG. The VCO 251 generates 27 MHz of a predetermined phase based on the signal supplied from the phase comparison unit 252 and outputs it to the counter 214 and the frequency divider 253. The frequency divider 253 divides the 27 MHz clock input from the VCO 251 by 1/3375, generates an 8 KHz clock, and outputs it to the phase comparator 252. The phase comparison unit 252 compares the phase of the 8 kHz clock from the MPEG / ATM conversion unit 216 with the phase of the 8 kHz clock from the frequency divider 253, and outputs the comparison result to the VCO 251. That is, the phase of the 27 MHz clock output to the counter 214 is adjusted so as to be synchronized with the network clock of the network 202.
[0052]
Returning to FIG. 11, the counter 214 divides the 27 MHz clock from the PLL circuit 217 by 1/3240000, counts it, and outputs the count value N to the synchronous information processing unit 213. That is, the counter 214 counts a clock synchronized with the network clock of the network 202.
[0053]
Next, the operation of the TS packet synchronization unit 211 of the transmission apparatus 201 will be described with reference to the flowchart of FIG.
[0054]
In step S1, the TS packet synchronization unit 211 reads the data of the input MPEG transport stream packet for each byte, and waits until it is determined that the read value is 47h (FIG. 10) equal to the synchronization byte. When it is determined that the read 1-byte value is 47h, the TS packet synchronization unit 211 proceeds to step S2 and initializes the value of the counter i that counts the number of times of reading 47h to 1.
[0055]
Next, in step S3, the TS packet synchronization unit 211 reads data (data after 188 bytes) that is 188 bytes apart from 47h read in step S1, and in step S4 determines whether or not it is 47h. judge. If it is determined in step S4 that the data read in step S3 is not 47h, the TS packet synchronization unit 211 returns to step S1 and executes the subsequent processing. On the other hand, if it is determined in step S4 that the read data is 47h, the TS packet synchronization unit 211 proceeds to step S5.
[0056]
In step S5, the TS packet synchronization unit 211 determines whether or not the value of the counter i is 5. If it is determined that the value is not 5, the process proceeds to step S6 and increments the value of the counter i by 1. Then, the process returns to step S3, and the subsequent processing is executed. When it is determined in step S5 that the value of the counter i is 5, that is, when 47h is read 5 times continuously every 188 bytes from the data of the input MPEG transport stream packet, Proceed to step S7.
[0057]
In step S7, the TS packet synchronization unit 211 establishes frame synchronization by using 47h detected at the fifth time as the synchronization byte, that is, using the head data of the MPEG transport stream packet. In step S7, data input to the transmission apparatus 201 before frame synchronization is established is not supplied to the PCR packet detection unit 212 but is discarded.
[0058]
As described above, frame synchronization is established.
[0059]
Next, in step S8, the TS packet synchronization unit 211 initializes the value of the counter i to 1, and proceeds to step S9 to read the data separated by 188 bytes from 47h as the synchronization byte, and in step S10, Is 47h.
[0060]
If it is determined in step S10 that the data read in step S9 is not 47h, the TS packet synchronization unit 211 proceeds to step S11, determines whether the value of the counter i is 3, and the value is If it is determined that there is no 3, the process proceeds to step S12, the value of the counter i is incremented by 1, the process returns to step S9, and the subsequent processing is executed. On the other hand, when it is determined in step S11 that the value of the counter i is 3, the process returns to step S1 and the subsequent processing is executed. That is, if it is determined that the data read in step S9 is not 47h three consecutive times, it is determined that the frame transport of the MPEG transport stream packet is not taken, and the process returns to step S1 to establish synchronization. This process is performed from the beginning. Note that 3 × 188 bytes of data that is input before the process for establishing synchronization is performed again from the beginning and is expected to be not synchronized is supplied to the PCR packet detection unit 212. It will be.
[0061]
In step S10, when the TS packet synchronization unit 211 determines that the data read in step S9 is 47h, the TS packet synchronization unit 211 returns to step S9 and executes the subsequent processing.
[0062]
With reference to the flowchart of FIG. 14, another method for establishing synchronization will be described. In this example, as shown in FIG. 15, the TS packet synchronization unit 211 includes a 47h count unit including 188 memory areas i (= 1, 2,..., 188). To do. In the initial state, a value of 0 is set in each memory area i of the 47h count unit.
[0063]
In step S21, the TS packet synchronization unit 211 reads the input MPEG transport stream packet byte by byte, waits until 47h is detected, and if 47h is detected, proceeds to step S22 and sets the value of the counter i to 1. In step S23, the value of the memory area i (= 1) specified by the value of the counter i is incremented by one.
[0064]
FIG. 16B shows data 1 to data 5 divided into 188 bytes from the position where 47h is detected in step S21, and FIG. 16A shows the bytes constituting each data, The corresponding value of the memory area i of the 47h count unit is shown. The value of the memory area 1 corresponding to the top data (47h) of data 1 is set to 1. In FIG. 16, xxh indicates data other than 47h.
[0065]
Next, in step S24, the TS packet synchronization unit 211 reads the data for the next 1 byte after 47h detected in step S21, and increments the value of the counter i by 1 in step S25.
[0066]
In step S26, the TS packet synchronization unit 211 determines whether the data read in step S24 is 47h. If it is determined that the data is not 47h, the process proceeds to step S27.
[0067]
In the case of data 1 in FIG. 16, the next 1-byte data after 47h is not 47h (because it is data indicated by “xxh” in the figure), so the process proceeds to step S27 and the TS packet synchronizer 211 Sets 0 in the memory area 2.
[0068]
Next, in step S28, the TS packet synchronization unit 211 determines whether or not the value of the counter i is 189, and when it is determined that the value is not 189, the process returns to step S24, and the subsequent processing is performed. Execute.
[0069]
If it is determined in step S26 that the read data is 47h, the process proceeds to step S29, and the TS packet synchronization unit 211 increments the value of the memory area i specified by the value of the counter i by 1. Since the data separated by k bytes from the first byte of data 1 is 47h, the value of the memory area k is incremented by one.
[0070]
Next, in step S30, the TS packet synchronization unit 211 determines in step S29 whether the value of the memory area i obtained by incrementing the value by 1 is 5, and determines that the value is not 5. Returning to step S28, the subsequent processing is executed.
[0071]
If it is determined in step S28 that the value of the counter i is 189, the process returns to step S22, and the TS packet synchronization unit 211 executes the subsequent processing.
If it is determined in step S30 that the value of the memory area i is 5, the process proceeds to step S31, and when the counter i = 5, the TS packet synchronization unit 211 sets 47h read in step S24 as a synchronization byte, and MPEG Establish frame synchronization of the transport stream. In the example of FIG. 16, when 47h, which is k bytes away from the head data of data 5, is read, the value of the memory area k is 5, so that 47h of the read data 5 is the sync byte. Frame synchronization is established.
[0072]
Since the processing from step S32 to step S36 is the same as that in step S8 to step S12 in FIG. 13, the description thereof is omitted.
[0073]
Next, the processing procedure of the synchronization information processing unit 213 when calculating the synchronization information will be described with reference to the flowchart of FIG. This process is executed for each PID set for the MPEG transport stream (for each PID of up to 8192 programs). In this example, the synchronization information is executed corresponding to one PID. The calculation process will be described as an example.
[0074]
In a state where frame synchronization of the MPEG transport stream packet is established by the TS packet synchronization unit 211, in step S51, the PCR packet detection unit 212, for example, at time P1, as shown in FIG. After frame synchronization is established, the first PCR packet (first PCR packet) input to the transmission apparatus 201 is detected, and a PCR packet detection signal is output to the synchronization information processing unit 213. The synchronous information processing unit 213 sets a flag indicating that a PCR packet has been detected in the memory 215.
[0075]
Next, in step S52, the synchronous information processing unit 213 calculates an offset value O. Specifically, first, the synchronous information processing unit 213 acquires the PCR value E1 (FIG. 18C) of the first PCR packet and uses it as the reference clock value B (FIG. 18B). . At this time, the synchronous information processing unit 213 gives the counter 214 the timing (time t0 (FIG. 18A)) when the count value N becomes the reference clock value B as shown in FIG. Command the reset of the count value N. Next, the synchronous information processing unit 213 uses the count value N1 (FIG. 18B) supplied from the counter 214 when the PCR packet detection signal is input in step S51. It holds as a reference point and substitutes it into the following equation (1) together with the standard clock value B to calculate the offset value O.
Offset value O = PCR value E1 (= reference clock value B) −count value N1 (1)
[0076]
In step S <b> 53, the synchronous information processing unit 213 stores the reference clock value B and the offset value O in the memory 215.
[0077]
Next, in step S54, the synchronous information processing unit 213 determines whether or not the PCR packet detection signal is input from the PCR packet detection unit 212 until the count value N from the counter 214 indicates 3240000. If it is determined that the PCR packet detection signal has been input before, the process proceeds to step S55. In this example, as shown in FIGS. 18A and 18B, after the count value N of the counter 214 is reset in step S52 (time t0), when the count of 324,000 clocks is completed (time t1 ( 18 (A)), the second PCR packet is detected, so the process proceeds to step S55, and when no PCR packet is input, the synchronous information processing unit 213 detects the PCR packet. Cancel the flag indicating that.
[0078]
In step S55, the synchronization information processing unit 213 changes the synchronization byte of the header portion of the PCR packet (in this case, the second PCR packet) from 47h to -128. The meaning of the processing here will be described later.
[0079]
If it is determined in step S54 that no PCR packet has been detected before the count value N of the counter 214 reaches 3240000, the synchronous information processing unit 213 determines the count value N = 3240000 for the counter 214. Thus, the reset of the count value N is commanded, and then the process proceeds to step S56.
[0080]
In step S56, the synchronous information processing unit 213 waits until a PCR packet is detected (until a PCR packet detection signal is input). In this example, since the counter 214 counts 27 MHz clocks divided by 1/3240000, the counting for 324,000 clocks is completed for 0.12 seconds (= 3240000/27000000). ). That is, according to the MPEG-2 system, the PCR packet is transmitted at a rate of at least one per 0.1 second, so that the count value N is reset in step S54 (for example, FIG. 18). (A) (time t1) Until 320000 clock counts are completed (for example, time t2 in FIG. 18A), there is always one PCR packet (in this example, the third PCR packet). ) Is detected.
[0081]
When the PCR packet (the third PCR packet in this example) is detected in step S56, the synchronization information processing unit 213 proceeds to step S57 and calculates the synchronization information to be written in the third PCR packet. . Specifically, the synchronous information processing unit 213 acquires the PCR value E3 (FIG. 18C) of the third PCR packet that has arrived. Next, the synchronous information processing unit 213 holds the counter value N3 (FIG. 18B) when the third PCR packet is detected. Furthermore, the synchronization information processing unit 213 calculates the synchronization information by substituting the PCR value E1, the PCR value E3, the count value N3, and the reference clock value B into the following equation (2).
[0082]
Synchronization information = ((PCR value E3−PCR value E1) − (count value N3−reference clock value B)) × 3240000 ÷ (count value N3−reference clock value B)) (2)
[0083]
In other words, this synchronization information includes the PCR value E3 (the count value of the system clock of the system encoder) and the count value N3 (the network 202 of the network 202) that are generated while the clocks of (count value N3−reference clock value B) are counted. From the difference (α) from the difference (α) from the clock count value generated by the PLL circuit 217 synchronized with the clock), the third PCR packet arrives at the transmission device 201 at the time point (time t1) when the count value N becomes 3240000. Represents the difference (β) between the PCR value E and the counter value N (= 3240000).
[0084]
Next, in step S58, the synchronization information processing unit 213 writes the synchronization information calculated in step S57 into the third PCR packet. Specifically, the synchronization information processing unit 213 changes the synchronization byte (47h) in the header portion of the third PCR packet to the calculated synchronization information.
[0085]
The synchronization information processing unit 213 changes the synchronization byte in step S55 or step S58, and then proceeds to step S59 to subtract 39h from the value. Thus, by subtracting the value of 39h, for example, the synchronization byte of the PCR packet that does not include the synchronization information (the synchronization byte changed to −128 in step S55) becomes 47h. As a result, in the receiving apparatus 102, synchronization of the MPEG transport stream packet is established by the synchronization processing described with reference to the flowchart of FIG. 13 or FIG.
[0086]
Next, in step S60, the synchronization information processing unit 213 adds the synchronization information calculated in step S57 to 320000 (clock) to obtain the new reference clock value B, and the offset value calculated in step S52. The synchronization information is added to O, and the new offset value O is overwritten on the memory 215. That is, when the next PCR packet is input, synchronization information is calculated based on the changed reference clock value B and offset value O.
[0087]
As the synchronous information processing unit 213 executes the above processing, the reference clock value B (42 bits), the offset value O (42 bits), and the flag (1 bit) are stored in the memory 215 in the program PID. Is stored in correspondence with.
[0088]
In the above, as shown in FIG. 18, the second PCR packet is detected between time t0 and time t1 (FIG. 18A) (input to transmitting apparatus 201). Although the case has been described as an example, for example, as shown in FIG. 19, the same processing is performed even when the third PCR packet is input during that time. That is, in this case, the value of the synchronization byte in the header part of the second PCR packet and the third PCR packet is set to 47h (47h obtained by subtracting -128 to 39h), and the fourth PCR packet is set. The synchronization information calculated in the process in step S57 is written in the synchronization byte.
[0089]
In the above, the case where the synchronization information is calculated corresponding to one PID (corresponding to one program) has been described as an example. However, as shown in FIG. 20, a plurality of programs (two programs) Similarly, the synchronization information is calculated by the method described above and written in a predetermined PCR packet.
[0090]
FIG. 20 (A) is the same as FIG. 18 (B), and FIG. 20 (B) is a timing chart for explaining the synchronization information creation processing for other programs. In the case of FIG. 20B, a point separated from the count value N10 by the offset value O1 is set as the reference clock value B, and the above-described synchronization information generation process is performed. In this case, the offset value O and the reference clock B are stored in the memory 215 corresponding to the PID of the program.
[0091]
Next, the amount of synchronization information will be described. According to the MPEG-2 standard, a 27 MHz clock (for example, a system clock of the system encoder or a clock generated by the PLL circuit 217 of the transmission device 201 (hereinafter referred to as clock S)) used as the system clock is respectively +/- 30ppm (parts per million) deviation is allowed. That is, the frequency of the clock and the clock S of the system encoder is (27 MHz−810 (= 27 × 10 6 × 30 × 10 -6 ) Hz) to (27MHz + 810Hz).
[0092]
That is, as shown in FIG. 21, the frequency difference between the two is that the system encoder system clock frequency is 27 MHz + 810 Hz (FIG. 21A) and the clock S frequency is 27 MHz-810 Hz (FIG. 21C). ), And conversely, as shown in FIG. 22, when the frequency of the system clock of the system encoder is 27 MHz-810 Hz (FIG. 22A) and the frequency of the clock S is 27 MHz + 810 Hz (FIG. 22). (C)) is the maximum.
[0093]
Accordingly, when the number of clocks counted per second of each clock in the case of FIG. 21 is obtained, 27 × 10 in the case of the assumed true 27 MHz. 6 In the case of the system encoder shown in FIG. 21A (FIG. 21B), (27 × 10) 6 +810), and in the case of the clock S in FIG. 6 -810). Similarly, when the number of clocks counted in one second of each clock in the case of FIG. 22 is obtained, in the case of the system clock of the system encoder of FIG. 22A, (27 × 10 6 −810), and in the case of the clock S in FIG. 6 +810). That is, the difference in the number of clocks counted in one second when the frequency shift between the two becomes the maximum is 1620.
(27 × 10 6 +810) − (27 × 10 6 −810) = 1620
[0094]
By the way, the above-described synchronization information also indicates the difference between the system clock of the system encoder and the clock S (difference in the number of clocks counted between the arrival intervals of the PCR packets to the transmission device 201). The count value N of the clock S is calculated by associating it with the time axis of PCR. That is, the maximum value of the synchronization information needs to be obtained in correspondence with the PCR time axis. In this example, since at least one synchronization information is incorporated in the MPEG transport stream packet in 0.12 (= 324000/27000000) seconds, the synchronization information is shifted by a maximum of 0.12 seconds (0.12 seconds). (The difference in the number of clocks counted). That is, the synchronization information is maximum on the plus side in the state of FIG. 21, and its value is 195 as shown below.
((1 + 30ppm) / (1-30ppm) -1) × 27MHz × 0.12s = 195
[0095]
In the above formula, the period of the clock S in FIG. 21C (1 / (27 MHz−810 Hz)) (time) is normalized by the period of the system encoder system clock in FIG. 21A (1 / (27 MHz + 810 Hz)). (Corresponding to the PCR time axis), and the difference between the normalized time of the clock S (time of the clock S corresponding to the PCR time axis) and the PCR time (1 unit) was obtained. Based on the difference, the difference between the two clocks occurring in 0.12 seconds is shown by the number of clocks.
[0096]
On the other hand, in the state of FIG. 22, the synchronization information is maximum on the minus side, and its value is −195 as shown below.
((1-30ppm) / (1 + 30ppm) -1) × 27MHz × 0.12s = -195
That is, from the above, the synchronization information can take values in the following ranges.
-195 <= synchronization information = <195
[0097]
Therefore, 9 bits are required to represent the synchronization information (2 bytes are required if capacity is secured in byte units), but 1 bit is deleted and shown as 8 bits. However, only an error of +/- 1 clock occurs, and does not exceed the MPEG-2 standard for jitter. The standard of jitter in the MPEG-2 system is +/− 500 ns, and when converted into the number of clocks, it is +/− 13.5 (= + / − 500 nsec × 27 MHz) clock. That is, the error for +/- 1 clock is within the range, and the synchronization information can be represented by 8 bits (1 byte (-128 to 128)) after all.
[0098]
In the case of this example, the synchronization information is one of values from −125 to 125, and the other values are used with meanings as shown in FIG. For example, -128 means that synchronization information is not set. That is, the synchronization byte is set to -128 in step S52, because this indicates that the synchronization information is not written in the TS packet.
[0099]
-127 is something that occurs in the transmission apparatus 201 when, for example, a large jitter occurs in the PCR packet, the interval between the input PCR packets is large, and the value of the synchronization information is outside the range of -125 to 125. Means that an error has occurred. -126, 126, and 127 are reserve values.
[0100]
FIG. 24 illustrates a configuration example of the reception device 203. The ATM / MPEG conversion unit 301 converts the ATM cell transmitted from the transmission device 201 via the network 202 into an MPEG transport stream packet and outputs the MPEG transport stream packet to the TS packet synchronization unit 304. The ATM / MPEG conversion unit 301 also generates an 8 KHz clock synchronized with the network clock of the network 202 based on the received ATM cell, and outputs the generated clock to the PLL circuit 302. Since the PLL circuit 302 has the same configuration (having a phase comparison circuit) as the PLL circuit 217 of FIG. 11, the detailed description thereof is omitted, but the clock supplied from the ATM / MPEG conversion unit 301 A synchronized 27 MHz clock is generated and output to the counter 303.
[0101]
The counter 303 divides the 27 MHz clock from the PLL circuit 302 by 1/3240000, counts it, and outputs the count value M to the PCR rewriting unit 306.
[0102]
Similar to the TS packet synchronization unit 211 of FIG. 11, the TS packet synchronization unit 304 establishes synchronization of the MPEG transport stream packet from the ATM / MPEG conversion unit 301 according to the processing of the flowchart shown in FIG. 13 or FIG. And output to the PCR packet detection unit 305.
[0103]
When frame synchronization is established by the processing shown in the flowchart of FIG. 14, the TS packet synchronization unit 304 uses the 47h count unit (FIG. 15), but a PCR packet in which synchronization information is written is input. At this time, the value of the memory area i of the 47h count unit may not be reset. A specific description will be given with reference to FIG.
[0104]
Corresponding to data 11 and data 12, when any value of 4Ah to 44h, which is separated by k bytes from the top data of data 13, in a state where the value of memory area k is 2, The value of the memory area k is not reset to 0 (value 2 is held). This is because the value of 4Ah to 44h is assumed to be the head data of the PCR packet including the synchronization information, and the frame synchronization is taken. In FIG. 25, xxh indicates data other than 47h, 4Ah to 44h.
[0105]
The PCR packet detection unit 305 refers to the header part and the adaptation field part of the input MPEG transport stream packet, determines whether the PCR packet condition is set, and determines that the PCR packet condition is set. If it does, the PCR packet detection signal is output to the PCR rewriting unit 306.
[0106]
The PCR rewriting unit 306 performs processing such as reading synchronization information from the input PCR packet (where synchronization information is written), calculates a new PCR value D, and writes (rewrites) the PCR value D to the PCR packet. ). Details of processing in the PCR rewriting unit 306 will be described later. The memory 307 stores data necessary for the PCR rewriting unit 306 to calculate the PCR value D.
[0107]
Next, the operation of the PCR rewriting unit 306 when rewriting the PCR value of the PCR packet will be described with reference to the flowchart of FIG. In the state where the MPEG packet stream is synchronized in the TS packet synchronization unit 304, the PCR rewriting unit 306 determines the offset value D in step S71. Details of this processing are shown in the flowchart of FIG. That is, in step S81, the PCR rewriting unit 306 acquires the PCR value E of the PCR packet input first after frame synchronization is established, sets it as the reference clock value B, and the counter when the PCR packet is input. The reference clock value B is subtracted from the counter value M from 303 to calculate the offset value W. The PCR rewriting unit 306 stores the reference clock value B and the offset value W in the memory 307.
[0108]
Next, in step S82, the PCR rewriting unit 306 sets 1 to the value of the counter j. In step S83, the PCR rewriting unit 306 reads the PCR value E of the next input PCR packet, and calculates the difference ΔE from the reference clock value B. calculate. Next, in step S84, the PCR rewriting unit 306 determines whether or not ΔE is greater than a predetermined limit value L. If it is determined that ΔE is not larger, the process proceeds to step S85 and stores it in the memory 307. On the other hand, if it is determined in step S84 that ΔE is greater than the limit value L, the process returns to step S83.
[0109]
In step S86, the PCR rewriting unit 306 determines whether or not the value of the counter j has become 7, and if it is determined that the value is not 7, the process proceeds to step S87 and increments the value of the counter j by 1. Then, the process returns to step S83, and the subsequent processing is executed for the next input PCR packet.
[0110]
When it is determined in step S86 that the value of the counter j is 7, that is, as shown in FIG. 28, when seven ΔE1 to ΔE7 are calculated and stored in the memory 307, the process proceeds to step S88. The PCR rewriting unit 306 divides the total value of ΔE by 7 to calculate the average value of ΔE and stores it in the memory 307 as shown in the equation (3).
Average value of ΔE = (ΔE1 + ΔE2 + ΔE3 + ΔE4 + ΔE5 + ΔE6 + ΔE7) / 7 (3)
[0111]
Next, in step S89, the PCR rewriting unit 306 calculates the offset value D by adding the average value of ΔE to the offset value W according to the equation (4) (FIG. 28).
Offset value D = average value of offset value W + ΔE (4)
[0112]
Thus, when the offset value D is calculated, the process is terminated, and the process proceeds to step S72 in FIG. At the timing when the offset value D is calculated (time t10 in the example of FIG. 29), the PCR rewriting unit 306 sets a predetermined flag (1 bit) indicating that the offset value D has been calculated in the memory 307. To do. Further, the PCR rewriting unit 306 instructs the counter 303 to reset the count value M at the same timing.
[0113]
In step S72, the PCR rewriting unit 306 waits until the PCR packet in which the synchronization information is written is input. When the PCR packet is input, the process proceeds to step S73, and the counter 303 is reset in step S71. It is determined whether or not the counting for 3240000 clocks has been completed. If it is determined that the counting has not been completed, the process proceeds to step S74. The first PCR packet here is a packet different from the first PCR packet shown in the description of the transmitting apparatus 201.
[0114]
In step S74, the PCR rewriting unit 306 calculates the PCR value D. As will be described with reference to FIG. 29, the PCR packet (first PCR packet) in which the synchronization information is written after the count value M is reset in step S71 until the count of 340000 clocks is completed. It is assumed that it has been entered. Therefore, the PCR rewriting unit 306 acquires the synchronization information of the first PCR packet that has arrived. Next, the PCR rewriting unit 306 holds the counter value M1 (FIG. 29B) from the counter 303 when the first PCR packet is input. Then, the PCR rewriting unit 306 calculates the PCR value D by substituting the count value M1, the offset value D, the synchronization information, and the reference clock value B into Equation (5).
PCR value D = (count value N1 + offset value D + synchronization information × (count value N1−reference clock B) / 3240000 (5)
[0115]
Next, in step S75, the PCR rewriting unit 306 rewrites the PCR value E1 of the first PCR packet with the calculated PCR value D and outputs it to a decoder (not shown). Thereafter, the process ends.
[0116]
If it is determined in step S73 that the counting for 324,000 clocks has been completed, that is, as shown in FIG. 30, the first PCR packet (synchronization information is written) after the counting for 324,000 clocks is completed. When the received (PCR packet) is input, the process proceeds to step S76, and the reference clock value B is changed. Specifically, the PCR rewriting unit 306 reads the synchronization information from the first PCR packet, adds 3240000 thereto, and overwrites the memory 307 with the addition result as a new reference clock value B. Thereby, the reference clock value B is changed.
[0117]
Next, in step S77, the PCR rewriting unit 306 changes the offset value D. Specifically, the PCR rewriting unit 306 reads the offset value D from the memory 307, adds the synchronization information of the first PCR packet thereto, and overwrites the memory 307 with the addition result as a new offset value D. To do. Thereby, the offset value D is changed.
[0118]
Thereafter, returning to step S74, the PCR rewriting unit 306 calculates the PCR value D based on the changed reference clock value B and offset value D.
[0119]
The PCR rewriting process in the receiving apparatus 203 described above is performed for each program (for example, channel). That is, similar processing is performed on a plurality of programs.
[0120]
As described above, since the synchronization information is written in the transmission device 201 and transmitted to the reception device 203 via the network 202, the PCR is rewritten based on the synchronization information in the reception device 203. Corresponding to a program (for example, 8192 kinds of PID), delay fluctuation is suppressed.
[0121]
Next, another configuration example of the reception device 203 is illustrated in FIG. In the figure, parts corresponding to those in FIG. 24 are denoted by the same reference numerals. That is, the adaptive clock unit 51 shown in FIG. 5 is provided between the ATM / MPEG conversion unit 301 and the TS packet synchronization unit 304. Thereby, the PCR value D is calculated from the MPEG transport stream packet in which the fluctuation is absorbed to some extent by the adaptive clock unit 51. As a result, in the decoder 400 as shown in FIG. 32 that receives the supply of the MPEG transport stream packet (including the PCR packet) from the receiving device 203, the failure of the VBV buffer 401 can be prevented as shown in FIG. it can.
[0122]
In the decoder 400, when there is no delay fluctuation in the input MPEG transport stream packet, the locus of the data occupation amount of the VBV buffer 401 becomes as shown by a dotted line A in FIG. Do not flow. However, when the MPEG transport stream packet arrives late, the trajectory of the data occupation amount may become underflow as indicated by the solid line B. In addition, when arriving early, the trajectory may overflow as shown by the solid line C.
[0123]
FIG. 34 is a block diagram illustrating a configuration of an embodiment of a computer 501 that functions as the transmission device 201 or the reception device 203 as described above. An input / output interface 516 is connected to a CPU (Central Processing Unit) 511 via a bus 515, and the CPU 511 receives a command from an input unit 518 such as a keyboard and a mouse via the input / output interface 516. When input, it is stored in a recording medium such as a ROM (Read Only Memory) 512, a hard disk 514, or a magnetic disk 531, an optical disk 532, a magneto-optical disk 533, or a semiconductor memory 534 mounted in the drive 520. The program is loaded into a RAM (Random Access Memory) 513 and executed. Thereby, the various processes described above (for example, the processes shown by the flowcharts of FIGS. 13, 14, 17, 26, and 27) are performed. Further, the CPU 511 outputs the processing result to a display unit 517 such as an LCD (Liquid Crystal Display) via the input / output interface 516 as necessary. The program is stored in advance in the hard disk 514 or ROM 512 and provided to the user integrally with the computer 501 or as a package medium such as the magnetic disk 531, the optical disk 532, the magneto-optical disk 533, and the semiconductor memory 534. Or can be provided to the hard disk 514 via the communication unit 519 from a satellite, a network, or the like.
[0124]
In the present specification, the step of describing the program provided by the recording medium is not limited to the processing performed in chronological order according to the described order, but is not necessarily performed in chronological order. It also includes processes that are executed individually.
[0125]
Further, in this specification, the system represents the entire apparatus constituted by a plurality of apparatuses.
[0126]
【The invention's effect】
The communication device according to claim 1, 3 Communication method according to claim 1 and claim 4 According to the recording medium program described in Predetermined time stamp is added The unit data arranged in the stream, which is the same value as the synchronization data incorporated at the head of the packet constituting the stream, is detected, and from the arrangement position on the stream of the detected unit data equivalent to the synchronization data, the packet data For each size, unit data placed in the stream is detected, and among the detected unit data, When unit data with the same value as the sync data, the same value as the time stamp, and the same value as the sync data is detected continuously, Since the number of unit data having the same value as the synchronous data detected continuously is counted, the number of the unit data having the same value as the synchronous data detected continuously is a predetermined number. The synchronization of the stream is established with the arrangement position of one of the detected unit data on the stream as the head of the packet. In the state where the synchronization of the stream is established, the time stamp is read from the packet, and predetermined synchronization information is calculated for each identifier set in the packet based on the read time stamp. can do.
[Brief description of the drawings]
FIG. 1 is a block diagram illustrating a configuration example of a conventional data transmission system.
FIG. 2 is a diagram for explaining PCR.
3 is a block diagram showing a configuration example of a system decoder 4 in FIG.
4 is a block diagram illustrating a configuration example of a PLL circuit 13 in FIG. 3;
FIG. 5 is a block diagram illustrating a configuration example of an adaptive clock unit.
6 is a block diagram illustrating a configuration example of a transmission device 61. FIG.
7 is a block diagram illustrating a configuration example of a receiving device 62. FIG.
8 is a block diagram showing a configuration example of a phase comparator 91. FIG.
FIG. 9 is a diagram illustrating a configuration example of a data transmission system to which the present invention is applied.
FIG. 10 is a diagram illustrating a data structure of an MPEG transport stream packet.
11 is a diagram illustrating a configuration example of a transmission device 201 in FIG. 9;
12 is a diagram illustrating a configuration example of a phase comparator 250. FIG.
FIG. 13 is a flowchart illustrating synchronization establishment processing.
FIG. 14 is another flowchart for explaining synchronization establishment processing;
FIG. 15 is a diagram illustrating a 47h count unit.
FIG. 16 is a diagram for explaining synchronization establishment processing;
FIG. 17 is a flowchart illustrating a synchronization information creation process.
FIG. 18 is a timing chart for explaining synchronization information creation processing;
FIG. 19 is a timing chart illustrating synchronization information creation processing.
FIG. 20 is another timing chart illustrating the synchronization information creation process.
FIG. 21 is a diagram for explaining the data amount of synchronization information;
FIG. 22 is another diagram illustrating the data amount of the synchronization information.
FIG. 23 is a diagram illustrating the meaning of the value of synchronization information.
24 is a diagram illustrating a configuration example of a reception device 203. FIG.
FIG. 25 is a diagram for explaining synchronization establishment processing;
FIG. 26 is a flowchart illustrating a PCR rewriting process.
FIG. 27 is a flowchart illustrating an offset value calculation process.
FIG. 28 is a diagram illustrating offset value calculation processing.
FIG. 29 is a timing chart illustrating a PCR rewriting process.
FIG. 30 is another timing chart for explaining the PCR rewriting process.
31 is a block diagram illustrating another configuration example of the reception device 203. FIG.
32 is a block diagram illustrating a configuration example of a decoder 400. FIG.
FIG. 33 is a diagram illustrating a trajectory of a data amount of a VBV buffer.
34 is a block diagram illustrating a configuration example of a computer 501. FIG.
[Explanation of symbols]
201 Transmission Device, 202 Network, 203 Reception Device, 211 TS Packet Synchronization Unit, 212 PCR Packet Detection Unit, 213 Synchronization Information Processing Unit, 214 Counter, 215 Memory, 216 MPEG / ATM Conversion Unit, 217 PLL Circuit, 301 ATM / MPEG Conversion unit, 302 PLL circuit, 303 counter, 304 TS packet synchronization unit, 305 PCR packet detection unit, 306 PCR rewrite unit, 307 Memory

Claims (4)

所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、前記ストリームに配置された単位データを検出する検出手段と、
前記検出手段により検出された、前記同期データと同値である前記単位データの前記ストリーム上の配置位置から、前記パケットの大きさ毎に、前記ストリームに配置された単位データを検出し、検出した前記単位データのうち、前記同期データと同値、前記タイムスタンプと同値、および前記同期データと同値の単位データが連続して検出されたとき、連続して検出した、前記同期データと同値である前記単位データの数をカウントする第1のカウント手段と、
前記第1のカウント手段によりカウントされた、連続して検出された前記同期データと同値である前記単位データの数が、所定の数となったとき、検出された前記単位データのうちの1つの前記単位データの前記ストリーム上の配置位置を、前記パケットの先頭とし、前記ストリームの同期を確立する同期確立手段と
前記ストリームの同期が確立されている状態において、前記パケットから前記タイムスタンプを読み出し、読み出した前記タイムスタンプに基づいて、前記パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理手段と
を備えることを特徴とする通信装置。
Detection means for detecting unit data arranged in the stream, which is the same value as the synchronization data incorporated at the head of the packet constituting the stream to which the predetermined time stamp is added ;
The unit data arranged in the stream is detected for each size of the packet from the arrangement position on the stream of the unit data, which is the same value as the synchronization data, detected by the detection unit, and the detected unit data is detected. Among the unit data, when the unit data having the same value as the synchronization data, the same value as the time stamp, and the unit data having the same value as the synchronization data are continuously detected, the unit having the same value as the synchronization data detected continuously First counting means for counting the number of data;
One of the detected unit data is counted when the number of the unit data counted by the first counting means and having the same value as the synchronous data continuously detected becomes a predetermined number. Synchronization establishment means for establishing the arrangement position of the unit data on the stream as the head of the packet and establishing synchronization of the stream ;
Synchronous information processing means for reading out the time stamp from the packet and calculating predetermined synchronization information for each identifier set in the packet based on the read time stamp in a state where the synchronization of the stream is established communication device, characterized in that it comprises and.
前記同期確立手段により、前記パケットの先頭とされた前記単位データの、前記同期確立手段により同期が確立された前記ストリーム上の配置位置から、前記パケットの大きさ毎に、前記ストリームに配置された単位データを検出し、検出した前記単位データのうち、連続して検出した、前記同期データと異なる値である前記単位データの数をカウントする第2のカウント手段
をさらに備え、
前記検出手段は、前記第2のカウント手段によりカウントされた、連続して検出された前記同期データと異なる値である前記単位データの数が、所定の数となったとき、前記同期データと同値である、前記ストリームに配置された単位データを再び検出する
ことを特徴とする請求項1に記載の通信装置。
The unit data set at the head of the packet by the synchronization establishing unit is arranged in the stream for each size of the packet from the arrangement position on the stream where the synchronization is established by the synchronization establishing unit. A second counting means for detecting unit data and counting the number of unit data that is continuously detected from the detected unit data and having a value different from the synchronous data;
The detection means has the same value as the synchronization data when the number of unit data, which is counted by the second count means and is different from the continuously detected synchronization data, reaches a predetermined number. The communication apparatus according to claim 1, wherein unit data arranged in the stream is detected again.
所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、前記ストリームに配置された単位データを検出する検出ステップと、
前記検出ステップの処理で検出された、前記同期データと同値である前記単位データの前記ストリーム上の配置位置から、前記パケットの大きさ毎に、前記ストリームに配置された単位データを検出し、検出した前記単位データのうち、前記同期データと同値、前記タイムスタンプと同値、および前記同期データと同値の単位データが連続して検出されたとき、連続して検出した、前記同期データと同値である前記単位データの数をカウントするカウントステップと、
前記カウントステップの処理でカウントされた、連続して検出された前記同期データと同値である前記単位データの数が、所定の数となったとき、検出された前記単位データのうちの1つの前記単位データの前記ストリーム上の配置位置を、前記パケットの先頭とし、前記ストリームの同期を確立する同期確立ステップと
前記ストリームの同期が確立されている状態において、前記パケットから前記タイムスタンプを読み出し、読み出した前記タイムスタンプに基づいて、前記パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理ステップと
を含むことを特徴とする通信方法。
A detection step of detecting unit data arranged in the stream, which is the same value as the synchronization data incorporated in the head of the packet constituting the stream to which the predetermined time stamp is added ;
The unit data arranged in the stream is detected for each size of the packet from the arrangement position on the stream of the unit data having the same value as the synchronization data detected in the detection step, and detected. Among the unit data, the same value as the synchronous data, the same value as the time stamp, and the same value as the synchronous data when the unit data of the same value as the synchronous data are detected continuously. A counting step for counting the number of unit data;
When the number of the unit data that is counted in the process of the counting step and has the same value as the synchronous data detected continuously becomes a predetermined number, one of the detected unit data A synchronization establishment step of establishing the synchronization of the stream with the arrangement position of the unit data on the stream as the head of the packet ;
A synchronization information processing step of reading the time stamp from the packet and calculating predetermined synchronization information for each identifier set in the packet based on the read time stamp in a state where the synchronization of the stream is established communication method which comprises and.
所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、前記ストリームに配置された単位データを検出する検出ステップと、
前記検出ステップの処理で検出された、前記同期データと同値である前記単位データの前記ストリーム上の配置位置から、前記パケットの大きさ毎に、前記ストリームに配置された単位データを検出し、検出した前記単位データのうち、前記同期データと同値、前記タイムスタンプと同値、および前記同期データと同値の単位データが連続して検出されたとき、連続して検出した、前記同期データと同値である前記単位データの数をカウントするカウントステップと、
前記カウントステップの処理でカウントされた、連続して検出された前記同期データと同値である前記単位データの数が、所定の数となったとき、検出された前記単位データのうちの1つの前記単位データの前記ストリーム上の配置位置を、前記パケットの先頭とし、前記ストリームの同期を確立する同期確立ステップと
前記ストリームの同期が確立されている状態において、前記パケットから前記タイムスタンプを読み出し、読み出した前記タイムスタンプに基づいて、前記パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理ステップと
を含むことを特徴とする処理をコンピュータに実行させるプログラムが記録されている記録媒体。
A detection step of detecting unit data arranged in the stream, which is the same value as the synchronization data incorporated in the head of the packet constituting the stream to which the predetermined time stamp is added ;
The unit data arranged in the stream is detected for each size of the packet from the arrangement position on the stream of the unit data having the same value as the synchronization data detected in the detection step, and detected. Among the unit data, the same value as the synchronous data, the same value as the time stamp, and the same value as the synchronous data when the unit data of the same value as the synchronous data are detected continuously. A counting step for counting the number of unit data;
When the number of the unit data that is counted in the process of the counting step and has the same value as the synchronous data detected continuously becomes a predetermined number, one of the detected unit data A synchronization establishment step of establishing the synchronization of the stream with the arrangement position of the unit data on the stream as the head of the packet ;
A synchronization information processing step of reading the time stamp from the packet and calculating predetermined synchronization information for each identifier set in the packet based on the read time stamp in a state where the synchronization of the stream is established recording medium having a program recorded to execute a process characterized in computers to include and.
JP33235099A 1999-11-24 1999-11-24 COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM Expired - Fee Related JP4224749B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP33235099A JP4224749B2 (en) 1999-11-24 1999-11-24 COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP33235099A JP4224749B2 (en) 1999-11-24 1999-11-24 COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM

Publications (2)

Publication Number Publication Date
JP2001156760A JP2001156760A (en) 2001-06-08
JP4224749B2 true JP4224749B2 (en) 2009-02-18

Family

ID=18253989

Family Applications (1)

Application Number Title Priority Date Filing Date
JP33235099A Expired - Fee Related JP4224749B2 (en) 1999-11-24 1999-11-24 COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM

Country Status (1)

Country Link
JP (1) JP4224749B2 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3736396B2 (en) * 2001-07-25 2006-01-18 日本電信電話株式会社 Stream transmitting apparatus and receiving apparatus
JP4092705B2 (en) * 2005-09-02 2008-05-28 日本電信電話株式会社 Stream transmitting apparatus, receiving apparatus, and transmission / reception method
US8473638B2 (en) * 2008-05-02 2013-06-25 James Aweya Method and apparatus for time and frequency transfer in communication networks
JP5133818B2 (en) * 2008-09-03 2013-01-30 株式会社日立国際電気 Signal reproduction device

Also Published As

Publication number Publication date
JP2001156760A (en) 2001-06-08

Similar Documents

Publication Publication Date Title
EP1089482A1 (en) Communication device, communication method, and recorded medium
EP2506570B1 (en) Method and system for playing video information, and video information content
US6493832B1 (en) Communication apparatus which handles a time stamp
JP4193297B2 (en) COMMUNICATION DEVICE AND METHOD, COMMUNICATION SYSTEM, AND RECORDING MEDIUM
US7756233B2 (en) Data receiving device and data receiving method
US6377588B1 (en) Method and apparatus for reducing jitter of a program clock reference in a transport stream of MPEG over ATM, and MPEG decoder
JP3045715B2 (en) Transmission system, transmitting device, recording / reproducing device, and recording device
JP5041844B2 (en) PCR correction circuit
JP3810918B2 (en) Multimedia data relay apparatus and method
JP4081936B2 (en) COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM
JP4224749B2 (en) COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM
US7558868B2 (en) Information processing device and method, recording medium, and program
JP4158075B2 (en) COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM
JP3419607B2 (en) Clock recovery device
JP6259227B2 (en) Clock reproduction control device and video signal receiving device
JP4092705B2 (en) Stream transmitting apparatus, receiving apparatus, and transmission / reception method
JP2002152273A (en) Delay fluctuation absorbing method and packet arrangement adjustment device
JP3736396B2 (en) Stream transmitting apparatus and receiving apparatus
JP4874272B2 (en) Video signal processing apparatus and video signal processing method
JP2002374220A (en) Stream transmission reception system, and stream transmitter and receiver
JP2001016210A (en) Communication equipment and method, and medium
JP2007274536A (en) Receiver and transmission/reception method
JPH11234308A (en) Method for reducing program clock reference jitter of mpeg over atm, reducing device and mpeg decoding device
JP2000187940A (en) Recording/reproducing device and recorder
JP2000341684A (en) Device and method for receiving signal and reproducing video signal

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20060301

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20080327

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20080724

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20080922

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20081030

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20081112

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20111205

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20111205

Year of fee payment: 3

LAPS Cancellation because of no payment of annual fees