JP4224749B2 - COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM - Google Patents
COMMUNICATION DEVICE, COMMUNICATION METHOD, AND RECORDING MEDIUM Download PDFInfo
- 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
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】
請求項3に記載の通信方法は、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データを検出する検出ステップと、検出ステップの処理で検出された、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出した、同期データと同値である単位データの数をカウントするカウントステップと、カウントステップの処理でカウントされた、連続して検出された同期データと同値である単位データの数が、所定の数となったとき、検出された単位データのうちの1つの単位データのストリーム上の配置位置を、パケットの先頭とし、ストリームの同期を確立する同期確立ステップと、ストリームの同期が確立されている状態において、パケットからタイムスタンプを読み出し、読み出したタイムスタンプに基づいて、パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理ステップとを含むことを特徴とする。
【0034】
請求項4に記載の記録媒体は、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データを検出する検出ステップと、検出ステップの処理で検出された、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出した、同期データと同値である単位データの数をカウントするカウントステップと、カウントステップの処理でカウントされた、連続して検出された同期データと同値である単位データの数が、所定の数となったとき、検出された単位データのうちの1つの単位データのストリーム上の配置位置を、パケットの先頭とし、ストリームの同期を確立する同期確立ステップと、ストリームの同期が確立されている状態において、パケットからタイムスタンプを読み出し、読み出したタイムスタンプに基づいて、パケットに設定された識別子毎に所定の同期情報を算出する同期情報処理ステップとを含むことを特徴とする。
【0035】
請求項1に記載の通信装置、請求項3に記載の通信方法、および請求項4に記載の記録媒体のプログラムにおいては、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データが検出され、検出された、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データが検出され、検出された単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出された、同期データと同値である単位データの数がカウントされ、カウントされた、連続して検出された同期データと同値である単位データの数が、所定の数となったとき、検出された単位データのうちの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に記載の通信装置、請求項3に記載の通信方法、および請求項4に記載の記録媒体のプログラムによれば、所定のタイムスタンプが付加されているストリームを構成するパケットの先頭に組み込まれた同期データと同値である、ストリームに配置された単位データを検出し、検出した、同期データと同値である単位データのストリーム上の配置位置から、パケットの大きさ毎に、ストリームに配置された単位データを検出し、検出した単位データのうち、同期データと同値、タイムスタンプと同値、および同期データと同値の単位データが連続して検出されたとき、連続して検出した、同期データと同値である単位データの数をカウントするようにしたので、カウントした、連続して検出した同期データと同値である単位データの数が、所定の数となったとき、検出した単位データのうちの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
[0003]
The
[0004]
The
[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
[0006]
The
[0007]
The
[0008]
Next, the generation (adjustment) processing of the system clock C2 on the decoding side will be further described with reference to FIGS. The
[0009]
As shown in FIG. 2, the time
[0010]
The
[0011]
Returning to FIG. 3, the
[0012]
By the way, when a satellite is used as the transmission method in satellite broadcasting as the
[0013]
[Problems to be solved by the invention]
However, when an ATM (Asynchronous Transfer Mode) network is used as the
[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
[0016]
The data having delay fluctuation transmitted through the
[0017]
The
[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
[0021]
The
[0022]
The synchronization data creation unit 72-1 includes a
[0023]
The
[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
[0026]
The system clock recovery unit 102-1 includes a
[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
[0028]
However, in the above-described data transmission system, it is necessary to provide the synchronization
[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
[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]
[0034]
[0035]
The communication device according to
[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
[0037]
The
[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
[0044]
The ATM cell transmitted via the
[0045]
FIG. 11 illustrates a configuration example of the
[0046]
The PCR
[0047]
The synchronous
[0048]
The synchronous
[0049]
The memory 215 appropriately stores data necessary for calculating the synchronization information supplied from the synchronization
[0050]
The MPEG /
[0051]
The
[0052]
Returning to FIG. 11, the
[0053]
Next, the operation of the TS
[0054]
In step S1, the TS
[0055]
Next, in step S3, the TS
[0056]
In step S5, the TS
[0057]
In step S7, the TS
[0058]
As described above, frame synchronization is established.
[0059]
Next, in step S8, the TS
[0060]
If it is determined in step S10 that the data read in step S9 is not 47h, the TS
[0061]
In step S10, when the TS
[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
[0063]
In step S21, the TS
[0064]
FIG. 16B shows
[0065]
Next, in step S24, the TS
[0066]
In step S26, the TS
[0067]
In the case of
[0068]
Next, in step S28, the TS
[0069]
If it is determined in step S26 that the read data is 47h, the process proceeds to step S29, and the TS
[0070]
Next, in step S30, the TS
[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
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
[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
[0074]
In a state where frame synchronization of the MPEG transport stream packet is established by the TS
[0075]
Next, in step S52, the synchronous
Offset value O = PCR value E1 (= reference clock value B) −count value N1 (1)
[0076]
In step S <b> 53, the synchronous
[0077]
Next, in step S54, the synchronous
[0078]
In step S55, the synchronization
[0079]
If it is determined in step S54 that no PCR packet has been detected before the count value N of the
[0080]
In step S56, the synchronous
[0081]
When the PCR packet (the third PCR packet in this example) is detected in step S56, the synchronization
[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
[0084]
Next, in step S58, the synchronization
[0085]
The synchronization
[0086]
Next, in step S60, the synchronization
[0087]
As the synchronous
[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
[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
[0100]
FIG. 24 illustrates a configuration example of the
[0101]
The
[0102]
Similar to the TS
[0103]
When frame synchronization is established by the processing shown in the flowchart of FIG. 14, the TS
[0104]
Corresponding to
[0105]
The PCR
[0106]
The
[0107]
Next, the operation of the
[0108]
Next, in step S82, the
[0109]
In step S86, the
[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
Average value of ΔE = (ΔE1 + ΔE2 + ΔE3 + ΔE4 + ΔE5 + ΔE6 + ΔE7) / 7 (3)
[0111]
Next, in step S89, the
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
[0113]
In step S72, the
[0114]
In step S74, the
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
[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
[0117]
Next, in step S77, the
[0118]
Thereafter, returning to step S74, the
[0119]
The PCR rewriting process in the receiving
[0120]
As described above, since the synchronization information is written in the
[0121]
Next, another configuration example of the
[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
[0123]
FIG. 34 is a block diagram illustrating a configuration of an embodiment of a computer 501 that functions as the
[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
[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
4 is a block diagram illustrating a configuration example of a
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
12 is a diagram illustrating a configuration example of a
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
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
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のカウント手段によりカウントされた、連続して検出された前記同期データと異なる値である前記単位データの数が、所定の数となったとき、前記同期データと同値である、前記ストリームに配置された単位データを再び検出する
ことを特徴とする請求項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.
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)
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 |
-
1999
- 1999-11-24 JP JP33235099A patent/JP4224749B2/en not_active Expired - Fee Related
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 |