[再生システムの構成例]
図1は、本技術を適用した再生装置1を含む再生システムの構成例を示す図である。
この再生システムは、再生装置1と表示装置3がHDMI(High Definition Multimedia Interface)ケーブルなどで接続されることによって構成される。再生装置1には、BD-ROMなどの、BD規格の光ディスクである光ディスク2が装着される。
光ディスク2には、視点の数が2つの3D画像を表示するために必要なストリームが記録されている。ストリームを光ディスク2に記録するための符号化の方式として、例えば、H.264 AVC(Advanced Video Coding)/MVC(Multi-view Video coding)が採用される。
再生装置1は、光ディスク2に記録されているストリームの3D再生に対応したプレーヤである。再生装置1は、光ディスク2に記録されているストリームを再生し、再生して得られた3D画像をテレビジョン受像機などよりなる表示装置3に表示させる。音声についても同様に再生装置1により再生され、表示装置3に設けられるスピーカなどから出力される。なお、再生装置1は、従来のBDプレーヤと同様に2D再生にも対応している。
[H.264 AVC/MVC Profile]
H.264 AVC/MVCでは、Base view videoと呼ばれる画像ストリームと、Dependent view videoと呼ばれる画像ストリームとが定義されている。以下、適宜、H.264 AVC/MVCを単にMVCという。
図2は、撮影の例を示す図である。
図2に示すように、同じ被写体を対象として、L画像(左視点)用のカメラとR(右視点)画像用のカメラによって撮影が行われる。L画像用のカメラとR画像用のカメラによって撮影された映像のエレメンタリストリームがMVCエンコーダに入力される。
図3は、MVCエンコーダの構成例を示すブロック図である。
図3に示すように、MVCエンコーダは、H.264/AVCエンコーダ11、H.264/AVCデコーダ12、Dependent view videoエンコーダ13、およびマルチプレクサ14から構成される。
L画像用のカメラにより撮影されたL画像のストリームはH.264/AVCエンコーダ11に入力される。また、R画像用のカメラにより撮影されたR画像のストリームはDependent view videoエンコーダ13に入力される。
H.264/AVCエンコーダ11は、L画像のストリームを、例えばH.264 AVC/High Profileビデオストリームとして符号化する。H.264/AVCエンコーダ11は、符号化して得られたAVCビデオストリームを、Base view videoストリームとしてH.264/AVCデコーダ12とマルチプレクサ14に出力する。
H.264/AVCデコーダ12は、H.264/AVCエンコーダ11から供給されたAVCビデオストリームをデコードし、デコードして得られたL画像のストリームをDependent view videoエンコーダ13に出力する。
Dependent view videoエンコーダ13は、H.264/AVCデコーダ12から供給されたL画像のストリームと、外部から入力されたR画像のストリームをエンコードし、Dependent view videoストリームを出力する。
Base view videoには、他のストリームを参照画像とする予測符号化が許されていないが、図4に示すように、Dependent view videoには、Base view videoを参照画像とする予測符号化が許されている。例えばL画像をBase view videoとするとともにR画像をDependent view videoとして符号化を行った場合、その結果得られるDependent view videoストリームのデータ量は、Base view videoストリームのデータ量に比較して少なくなる。
なお、H.264/AVCでの符号化であるから、Base view videoについて時間方向の予測は行われている。また、Dependent view videoについても、view間の予測とともに、時間方向の予測が行われている。Dependent view videoをデコードするには、エンコード時に参照先とした、対応するBase view videoのデコードが先に終了している必要がある。
Dependent view videoエンコーダ13は、このようなview間の予測も用いて符号化して得られたDependent view videoストリームをマルチプレクサ14に出力する。
マルチプレクサ14は、H.264/AVCエンコーダ11から供給されたBase view videoストリームと、Dependent view videoエンコーダ13から供給されたDependent view videoストリームとを、例えばMPEG2 TSとして多重化する。Base view videoストリームとDependent view videoストリームは1本のMPEG2 TSに多重化されることもあるし、別々のMPEG2 TSに含まれることもある。
マルチプレクサ14は、生成したTS(MPEG2 TS)を出力する。マルチプレクサ14から出力されたTSは、他の管理データとともに記録装置において光ディスク2に記録され、再生装置1に提供される。
この例においては、L画像をBase view video、R画像をDependent view videoとしてMVC方式で符号化するものとしたが、反対に、R画像をBase view video、L画像をDependent view videoとして符号化するようにしてもよい。以下、L画像をBase view video、R画像をDependent view videoとして符号化した場合について説明する。
再生装置1は、ユーザによる指示などに応じて3D再生を行う場合、Base view videoストリームとDependent view videoストリームを光ディスク2から読み出して再生する。
また、再生装置1は、2D再生を行う場合、Base view videoストリームだけを光ディスク2から読み出して再生する。Base view videoストリームはH.264/AVCで符号化されているAVCビデオストリームであるから、BDのフォーマットに対応したプレーヤであれば、そのBase view videoストリームを再生し、2D画像を表示させることが可能になる。
[TSの構成例]
図5は、光ディスク2に記録されているTSの構成例を示す図である。
図5のMain TSにはBase view video、Dependent view video、Primary audio、Base PG、Dependent PG、Base IG、Dependent IGのそれぞれのストリームが多重化されている。
このように、Dependent view videoストリームが、Base view videoストリームとともに1本のTSであるMain TSに含まれていることもある。
Main TSは、少なくともBase view videoストリームを含むTSである。これに対して、Sub TSは、Base view videoストリーム以外のストリームを含み、再生時にMain TSとともに用いられるTSである。光ディスク2には、Main TSの他に、Sub TSも適宜記録される。
ビデオと同様に3Dでの表示が可能になるように、字幕などのPG(Presentation Graphics)、メニュー画面などのIG(Interactive Graphics)についても、Base viewとDependent viewのそれぞれのストリームが用意されている。
図6は、光ディスク2に記録されているTSの他の構成例を示す図である。
図6のMain TSにはBase view video、Primary audio、Base PG、Dependent PG、Base IG、Dependent IGのそれぞれのストリームが多重化されている。
一方、Sub TSにはDependent view videoストリームが含まれている。このように、Dependent view videoストリームが、Base view videoストリームとは別のTSに含まれていることもある。
図6に示すようにBase view videoストリームとDependent view videoストリームがそれぞれ別のTSに含まれている場合、それぞれのTSファイルは、インターリーブされて光ディスク2に記録される。
図7は、Base view videoストリーム(L videoストリーム)を含むTSファイルとDependent view videoストリーム(R videoストリーム)を含むTSファイルの光ディスク2における配置の例を示す図である。
図7に示すように、L videoストリームを含むTSファイルとR videoストリームを含むTSファイルは、所定のデータ単位毎に交互に並ぶようにインターリーブ配置され、光ディスク2に記録される。1つのTSファイルに属し、光ディスク2上に連続配置されるソースパケットの集まりをチャンクという。
図7において、「R」の文字と数字を付して示すそれぞれのブロックはR videoのチャンクを表し、「L」の文字と数字を付して示すそれぞれのブロックはL videoのチャンクを表す。
3D再生時、例えば、R[0],L[0],R[1],L[1],R[2],L[2],R[3],L[3],R[4],L[4],R[5],L[5],・・・の順に光ディスク2から読み出され、L[0],R[0],L[1],R[1],L[2],R[2],L[3],R[3],L[4],R[4],L[5],R[5],・・・の順にデコードされる。上述したように、R videoをデコードするには、エンコード時に参照したL videoが先にデコードされている必要がある。同じ数字が付されているR videoのチャンクとL videoのチャンクは、同じ時間の再生に必要なデータであり、3D再生時にセットで用いられる。
すなわち、説明を簡単にするため、コンテンツの再生時間全体を3等分する場合を考える。コンテンツの再生時間全体を3等分する時刻を、再生の開始時刻を0として、時系列順に、t1,t2と表すと、再生の開始時刻から時刻t1までの再生時間に必要な分のL videoのデータが、チャンクL[0]として分割される。
また、時刻t1からt2までの再生時間に必要な分のL videoのデータが、チャンクL[1]として分割され、時刻t2から再生の終了時刻までの再生時間に必要な分のL videoのデータが、チャンクL[2]として分割される。
R videoストリームについても同様に、再生の開始時刻から時刻t1までの再生時間に必要な分のR videoのデータが、チャンクR[0]として分割される。
また、時刻t1からt2までの再生時間に必要な分のR videoのデータが、チャンクR[1]として分割され、時刻t2から再生の終了時刻までの再生時間に必要な分のR videoのデータが、チャンクR[2]として分割される。
このようにして分割して得られた各チャンクは、同じ数字が付されたチャンク同士が、R videoのチャンク、L videoのチャンクの順になるように配置され、光ディスク2に記録される。なお、図5に示すように、L videoストリームとR videoストリームがともに1本のTSに含まれている場合、そのTSファイルはインターリーブされずに光ディスク2に記録される。
[AVストリームの管理構造]
図8は、再生装置1によるAVストリームの管理構造の例を示す図である。
AVストリームの管理は、図8に示すようにPlayListとClipの2つのレイヤを用いて行われる。AVストリームは、光ディスク2ではなく、再生装置1のローカルストレージに記録されていることもある。Clipは、ビデオデータやオーディオデータが多重化されることによって得られたTSであるAVストリームと、対応するClip Information(そのAVストリームに関する属性情報を含むClip Information)とから構成される。
AVストリームは時間軸上に展開され、各アクセスポイントは、主に、タイムスタンプでPlayListにおいて指定される。Clip Informationは、AVストリーム中のデコードを開始すべきアドレスを見つけるためなどに使用される。
PlayListはAVストリームの再生区間の集まりである。AVストリーム中の1つの再生区間はPlayItemと呼ばれる。PlayItemは、時間軸上の再生区間のIN点とOUT点のペアで表される。PlayListは1つまたは複数のPlayItemにより構成される。
図8の左から1番目のPlayListは2つのPlayItemから構成され、その2つのPlayItemにより、左側のClipに含まれるAVストリームの前半部分と後半部分がそれぞれ参照されている。
左から2番目のPlayListは1つのPlayItemから構成され、それにより、右側のClipに含まれるAVストリーム全体が参照されている。
左から3番目のPlayListは2つのPlayItemから構成され、その2つのPlayItemにより、左側のClipに含まれるAVストリームのある部分と、右側のClipに含まれるAVストリームのある部分がそれぞれ参照されている。
例えば、左から1番目のPlayListに含まれる左側のPlayItemが再生対象としてディスクナビゲーションプログラムにより指定された場合、そのPlayItemが参照する、左側のClipに含まれるAVストリームの前半部分の再生が行われる。このように、PlayListは、AVストリームの再生を制御するための再生制御情報として用いられる。
PlayListの中で、1つ以上のPlayItemの並びによって作られる再生パスをメインパス(Main Path)という。
また、PlayListの中で、Main Pathに並行して、1つ以上のSubPlayItemの並びによって構成される再生パスをサブパス(Sub Path)という。
図9は、Main PathとSub Pathの構造を示す図である。
PlayListは、1つのMain Pathと1つ以上のSub Pathを持つことができる。上述したL videoストリームは、Main Pathを構成するPlayItemにより参照される。また、R videoストリームは、Sub Path(後述するExtension()内のSub Path)を構成するSubPlayItemにより参照される。
図9のPlayListは、3つのPlayItemの並びにより構成される1つのMain Pathと、3つのSub Pathを有している。Main Pathを構成するPlayItemには、先頭から順にそれぞれIDが設定される。Sub PathにもそれぞれIDが設定される。
図9の例においては、Subpath_id=0のSub Pathには1つのSubPlayItemが含まれ、Subpath_id=1のSub Pathには2つのSubPlayItemが含まれる。また、Subpath_id=2のSub Pathには1つのSubPlayItemが含まれる。
あるPlayItemが参照するAVストリームと、そのPlayItemと時間帯が重複する再生区間を指定するSubPlayItemが参照するAVストリームは同期して再生される。PlayList、PlayItem、SubPlayItemを用いたAVストリームの管理については、例えば、特開2008−252740号公報、特開2005−348314号公報に記載されている。
[ディレクトリ構造]
図10は、光ディスク2に記録されるファイルの管理構造の例を示す図である。
図10に示すように、ファイルはディレクトリ構造により階層的に管理される。光ディスク2上には1つのrootディレクトリが作成される。rootディレクトリの下が、1つの記録再生システムで管理される範囲となる。
rootディレクトリの下にはBDMVディレクトリが置かれる。BDMVディレクトリの直下に、「Index.bdmv」の名前が設定されたファイルであるIndexファイルと、「MovieObject.bdmv」の名前が設定されたファイルであるMovieObjectファイルが格納される。
BDMVディレクトリの下には、PLAYLISTディレクトリ、CLIPINFディレクトリ、STREAMディレクトリ等が設けられる。
PLAYLISTディレクトリには、PlayListを記述したファイルであるPlayListファイルが格納される。各PlayListファイルには、5桁の数字と拡張子「.mpls」を組み合わせた名前が設定される。図10に示すPlayListファイルには「00000.mpls」のファイル名が設定されている。
CLIPINFディレクトリにはClip Informationを記述したファイルであるClip Informationファイルが格納される。各Clip Informationファイルには、5桁の数字と拡張子「.clpi」を組み合わせた名前が設定される。
図10の2つのClip Informationファイルには、それぞれ、「00001.clpi」、「00002.clpi」のファイル名が設定されている。以下、適宜、Clip Informationファイルをclpiファイルという。
「00001.clpi」のclpiファイルは、対応するL videoストリームに関する情報が記述されたファイルであり、「00002.clpi」のclpiファイルは、対応するR videoストリームに関する情報が記述されたファイルである。
STREAMディレクトリにはストリームファイルが格納される。各ストリームファイルには、5桁の数字と拡張子「.m2ts」を組み合わせた名前、もしくは、5桁の数字と拡張子「.ilvt」を組み合わせた名前が設定される。以下、適宜、拡張子「.m2ts」が設定されたファイルをm2tsファイルといい、拡張子「.ilvt」が設定されたファイルをilvtファイルという。
「00001.m2ts」のm2tsファイルはL videoストリームのファイルであり、「00002.m2ts」のm2tsファイルはR videoストリームのファイルである。
「00001.ilvt」のilvtファイルは、L videoストリームのm2tsファイルとR videoストリームのm2tsファイルがインターリーブされている場合に、それらのストリームを管理し、3D再生を行うためのファイルである。従って、L videoストリームとR videoストリームが1本のTSに含まれ、それらのm2tsファイルがインターリーブされていない場合、ilvtファイルは光ディスク2に記録されない。
図10に示すものの他に、BDMVディレクトリの下には、オーディオストリームのファイルを格納するディレクトリなども設けられる。
図10の例においては、L videoに関するClipを構成するm2tsファイルのファイル名は「00001.m2ts」、clpiファイルのファイル名は「00001.clpi」である。また、R videoに関するClipを構成するm2tsファイルのファイル名は「00002.m2ts」、clpiファイルのファイル名は「00002.clpi」である。1つのClipを構成するm2tsファイルのファイル名とclpiファイルのファイル名には同じ数字が含まれる。
ilvtファイルのファイル名には、L videoに関するClipを構成するm2tsファイルのファイル名とclpiファイルのファイル名にそれぞれ含まれる5桁の数字と同じ、「00001」が含まれる。これにより、L videoに関するClipを構成するclpiファイルのファイル名から、3D再生を行うときに指定するilvtファイルのファイル名を特定することが可能になる。
[各データのシンタクス]
図11は、PlayListファイルのシンタクスを示す図である。
説明の便宜上、図11の左側には行数を表す数字と「:」を示している。行数を表す数字と「:」はPlayListを構成するものではない。なお、ここでは、PlayListの主な記述について説明するものとし、詳細な説明は省略する。詳細については、例えばBlu-ray Disc Read Only Format part3に記載されている。
1行目のyyyyy.mplsは、このPlayListファイルのファイル名を表す。
2行目乃至5行目に示すように、PlayListファイルには、大きく分けて、AppInfoPlayList()、PlayList()、PlayListMark()、ExtensionData()のフィールドから構成される。4行目のPlayListMark()には、チャプタジャンプなどを指令するユーザ操作、またはコマンドなどによるジャンプ先であるマークに関する情報が記述される。
7行目乃至11行目がAppInfoPlayList()のフィールドである。AppInfoPlayList()には、9行目に示すように、PlayList中にMVC再生(3D再生)に関する情報が含まれるか否かを表す1ビットのフラグであるMVC_flagが含まれる。なお、PlayListの中に含まれるのではなく、ビデオストリームなどのストリームの中にMVC_flagが含まれるようにしてもよい。
図12は、MVC_flagの意味を示す図である。
図12に示すように、MVC_flagの値が0であることは、PlayList中に3D再生に関する情報が含まれていないことを表す。すなわち、MVC_flag=0が設定されたPlayListが記録されている光ディスクは3D再生に非対応のディスクということになる。
MVC_flagの値が1であることは、PlayList中に3D再生に関する情報が含まれていることを表す。
AppInfoPlayList()には、MVC_flagの他に、ランダム再生を行うためのPlayListであるかなどの、PlayListの種類に関する情報が含まれる。
12行目乃至25行目がPlayList()のフィールドである。13行目のnumber_of_PlayItemsは、PlayListの中にあるPlayItemの数を表す。図9の例の場合、PlayItemの数は3である。PlayItem_idの値は、PlayListの中でPlayItem()が現れる順に0から割り振られる。15行目乃至19行目のfor文では、PlayItemの数だけPlayItem()が参照される。
14行目のnumber_of_SubPathsは、PlayList()の中にあるSub Pathの数を表す。図9の例の場合、Sub Pathの数は3である。SubPath_idの値は、PlayList()の中でSubPath()が現れる順に0から割り振られる。20行目乃至24行目のfor文では、Sub Pathの数だけSubPath()が参照される。
26行目乃至33行目が、PlayList()に含まれるPlayItem()の記述になる。27行目のClip_Information_file_nameは、PlayItemが参照するAVストリームを含むClipのclpiファイルの名前を表す。
28行目のMVC_file_typeは、MVC_flagの値が1であるときに有効な値を持つ2ビットのデータであり、L videoストリームとR videoストリームのそれぞれの供給元のファイルのタイプを表す。
図13は、MVC_file_typeの意味を示す図である。
図13に示すように、MVC_file_typeの値が0であることは、L videoストリームとR videoストリームが1本のTSに含まれており、そのTSを管理するm2tsファイルが、Clip_Information_file_nameにより示されることを表す。
上述したように、あるClipを構成するm2tsファイルのファイル名とclpiファイルのファイル名には同じ数字が含まれる。Clip_Information_file_nameは、そのファイル名が設定されたclpiファイルと同じClipを構成する、対応するm2tsファイルのファイル名も示すことになる。
MVC_file_typeの値が1であることは、Clip_Information_file_nameが示すL videoストリームのm2tsファイル(第1のTSファイル)と、R videoストリームのm2tsファイル(第2のTSファイル)が、光ディスク2上でインターリーブされていることを表す。この場合、L videoストリームとR videoストリームはそれぞれ異なるTSに含まれることになる。
MVC_file_typeの値が2であることは、Clip_Information_file_nameが示すL videoストリームのm2tsファイルと、R videoストリームのm2tsファイルの両方、または片方が、再生装置1内のローカルストレージに記録されていることを表す。
MVC_file_typeの値の3はリザーブ値である。
図11の説明に戻り、30行目のIN_timeはPlayItemの再生区間の開始位置を表し、31行目のOUT_timeは終了位置を表す。
32行目のSTN_table()には、PlayItemが参照するAVストリームの情報が含まれる。例えば、PlayItemが参照するAVストリームの情報として、ストリーム番号(ID)、L videoストリームを構成するトランスポートパケットのPIDが含まれる。
34行目乃至40行目が、PlayList()に含まれるSubPath()の記述になる。34行目乃至40行目のSubPath()には、PlayItemが参照するAVストリームとともに再生される、R video以外のビデオデータに関する情報やオーディオデータに関する情報が含まれる。
35行目のSubPath_typeは、Sub Pathの種類を表す8ビットのデータである。
図14は、SubPath_typeの意味を示す図である。
図14に示すように、2から7の値によってSubPathの種類が表される。例えば、SubPath_type=2は、スライドショー(Browsable slideshow)再生時に用いられるオーディオデータのSubPathであることを表し、SubPath_type=3は、インタラクティブメニューの表示時のデータのSubPathであることを表す。
図11の36行目のnumber_of_SubPlayItemsは、1つのSub Path()の中にあるSubPlayItemの数(エントリー数)を示す8ビットのデータである。例えば、図9のSubPath_id=0のSubPlayItemのnumber_of_SubPlayItemsは1であり、SubPath_id=1のSubPlayItemのnumber_of_SubPlayItemsは2である。37行目乃至39行目のfor文では、SubPlayItemの数だけ、SubPlayItem()が参照される。
41行目乃至45行目が、SubPath()に含まれるSubPlayItem()の記述になる。42行目のClip_Information_file_nameは、SubPlayItemが参照するClipのclpiファイルの名前を表す。
43行目のSubPlayItem_IN_timeはSubPlayItemの再生区間の開始位置を表し、44行目のSubPlayItem_OUT_timeは終了位置を表す。
46行目乃至49行目が、拡張フィールドであるExtensionData()になる。
MVC_flagの値が1であるとき、ExtensionData()の中に、SubPath_entries_extension()とSTN_table_extension()が記述される。SubPath_entries_extension()とSTN_table_extension()には、PlayItemが参照するL videoストリームとともに3D再生に用いられる、R videoストリームに関する情報が含まれる。
R videoストリームはSubPathが参照するストリームとして管理されるが、このように、R videoストリームに関する情報はSubPath()(図11の34行目)のフィールドには記述されずに、ExtensionData()のフィールドに記述される。
R videoストリームに関する情報をSubPath()のフィールドに記述しておいた場合、その記述を3D再生に非対応のプレーヤが読み込んだときに不具合が生じるおそれがある。R videoストリームに関する情報をExtensionData()として記述しておき、その記述については、3D再生に対応したプレーヤが、3D再生を行うときにだけ読み込むようにしておくことにより、そのような不具合が生じるのを防ぐことが可能になる。
図15は、ExtensionData()に含まれるSubPath_entries_extension()のシンタクスの例を示す図である。
number_of_SubPath_extensionsは、SubPath_extensionの数、すなわち、SubPath_entries_extension()の中に現れるSubPath_extension()の数を表す16ビットのデータである。number_of_SubPath_extensionsに続くfor文では、SubPathの数だけ、SubPath_extension()が参照される。
ここで、R videoストリームを参照するSubPathにも、図11の34行目のSubPath()に情報が記述される、R video以外のビデオデータやオーディオデータを参照する通常のSubPathと同様にIDが割り振られる。
図15のfor文に示すように、R videoストリームを参照するSubPathのIDは、図11の14行目のnumber_of_SubPathsの値と同じ値から開始され、SubPath_extension()が参照される毎に1ずつインクリメントされる。例えば、図9に示すように通常のSubPathの数が3であり、number_of_SubPaths=3である場合、number_of_SubPath_extensionsが2であるとすると、1つ目のSubPathのIDには3が割り振られ、2つ目のSubPathのIDには4が割り振られる。
図16は、図15のSubPath_extension()のシンタクスの例を示す図である。
lengthは、lengthのフィールドの直後からSubPath_extension()の最後までのバイト数を示す32ビットのデータである。
SubPath_type_extensionは、SubPath_typeを拡張させたものであり、SubPath_extension()に情報が記述されるSubPathの種類を表す8ビットのデータである。
図17は、SubPath_type_extensionの意味を示す図である。
図17に示すように、SubPath_type_extensionの値の0から7は、それぞれ、図14のSubPath_typeの0から7の意味と同じ意味を表す。
SubPath_type_extensionの値の8は、SubPath_type_extension=8が設定されたSubPathがR videoストリームを参照するSubPathであることを表す。また、参照するR videoストリームのm2tsファイルが、PlayItemが参照するL videoストリームのm2tsファイルとは別のファイルであることを表す。
図16の説明に戻り、number_of_SubPlayItemsは、SubPath_extension()の中にあるSubPlayItemの数を示す8ビットのデータである。number_of_SubPlayItemsに続くfor文では、SubPlayItemの数だけ、SubPlayItem()が参照される。
SubPath_extension()の中のSubPlayItem()の記述は、図11の41行目から45行目に示すSubPlayItem()の記述と同じ記述である。
すなわち、SubPath_extension()の中のSubPlayItem()には、SubPlayItemが参照するR videoストリームと同じClipに含まれるclpiファイルのファイル名を示すClip_Information_file_nameが含まれる。また、再生区間の開始位置を表すSubPlayItem_IN_timeと、終了位置を表すSubPlayItem_OUT_timeが含まれる。
図18は、ExtensionData()に含まれるSTN_table_extension()のシンタクスの例を示す図である。
上述したように、STN_table(図11の32行目)には、PlayItemが参照するL videoストリームを構成するトランスポートパケットのPIDが含まれる。これに対して、STN_table_extension()には、SubPath(SubPath_extension)が参照するR videoストリームを構成するトランスポートパケットのPIDが含まれる。
図18に示すように、STN_table_extension()には、STN_table_extension()の長さを表すlengthに続いて、R videoストリームに関する情報として、stream_entry()と、R videoストリームの属性情報であるstream_attributes()が含まれる。
図19は、stream_entry()のシンタクスの例を示す図である。
図19に示すように、stream_entry()には、stream_entry()の長さを表すlengthに続いて、8ビットの情報であるtypeが含まれる。
例えば、typeの値が1であることは、R videoストリームが、PlayItemが参照するL videoストリームとともに1本のTSに含まれることを表す。また、typeの値が2であることは、R videoストリームが、PlayItemが参照するL videoストリームとは別のTSに含まれることを少なくとも表す。
typeの値が1である場合、ref_to_stream_PID_of_mainClipが参照される。ref_to_stream_PID_of_mainClipは、L videoストリームとともに1本のTSに含まれる、R videoストリームを構成するトランスポートパケットのPIDを表す。
typeの値が2である場合、ref_to_SubPath_id、ref_to_subClip_entry_id、ref_to_stream_PID_of_subClipが参照される。3つの情報のうちのref_to_SubPath_idは、R videoストリームを参照するSubPath(SubPath_extension)のIDを表す。また、ref_to_stream_PID_of_subClipは、ref_to_SubPath_idにより識別されるSubPathが参照するR videoストリームを構成するトランスポートパケットのPIDを表す。
図20は、R videoストリームを参照する、SubPath_type_extention=8が設定されたSubPathと、そのSubPathがPlayListにおいて関連付けられている、L videoストリームを参照するMainPathの関係を示す図である。
上述したように、各PlayItem()には、PlayItemの再生区間の開始位置を表すIN_timeと終了位置を表すOUT_timeが含まれる(図11の30行目、31行目)。
また、上述したように、SubPath_extension()の中のSubPlayItem()には、R videoストリームを参照するSubPathを構成するそれぞれのSubPlayItemについて、再生区間の開始位置を表すSubPlayItem_IN_timeと、終了位置を表すSubPlayItem_OUT_timeが含まれる。
図20に示すように、PlayItemの開始位置、終了位置と、そのPlayItemが参照するL videoストリームに関連付けられたR videoストリームを参照するSubPlayItemの開始位置、終了位置は、それぞれ同じ位置になる。
例えば、PlayItem_id=0が割り振られたPlayItemのIN_timeとOUT_timeは、それぞれ、PlayItem_id=0が割り振られたPlayItemに関連付けられたSubPlayItem#0のSubPlayItem_IN_time、SubPlayItem_OUT_timeと一致する。
以上のように、PlayListには、拡張フィールドであるExtensionData()の中に、SubPathに関する情報が記述されるフィールドであるSubPath()がSubPath_extension()として定義され、また、ストリーム番号(STream Number)に関する情報が記述されるフィールドであるSTN_table()がSTN_table_extension()として定義されている。
[再生装置1の構成例]
図21は、再生装置1の構成例を示すブロック図である。
コントローラ31は、予め用意されている制御プログラムを実行し、再生装置1の全体の動作を制御する。
ディスクドライブ32は、コントローラ31による制御に従って光ディスク2からデータを読み出し、読み出したデータを、コントローラ31、メモリ33、またはデコード部36に出力する。
メモリ33は、コントローラ31が各種の処理を実行する上において必要なデータなどを適宜記憶する。
ローカルストレージ34は例えばHDD(Hard Disk Drive)により構成される。ローカルストレージ34には、サーバ22からダウンロードされたR videoストリームなどが記録される。ローカルストレージ34に記録されているストリームもデコード部36に適宜供給される。
インターネットインタフェース35は、コントローラ31からの制御に従ってネットワーク21を介してサーバ22と通信を行い、サーバ22からダウンロードしたデータをローカルストレージ34に供給する。
サーバ22からは、光ディスク2に記録されているデータをアップデートさせるデータがダウンロードされる。後述するように、ダウンロードしたR videoストリームを光ディスク2に記録されているL videoストリームと併せて用いることでコンテンツの3D再生を行うことも可能とされている。
デコード部36は、ディスクドライブ32、またはローカルストレージ34から供給されたストリームをデコードし、得られたビデオ信号を表示装置3に出力する。オーディオ信号も所定の経路を介して表示装置3に出力される。
操作入力部37は、ボタン、キー、タッチパネル、マウスなどの入力デバイスや、所定のリモートコマンダから送信される赤外線などの信号を受信する受信部により構成される。操作入力部37はユーザの操作を検出し、検出した操作の内容を表す信号をコントローラ31に供給する。
図22は、デコード部36の構成例を示す図である。
分離部51は、ディスクドライブ32から供給されたデータを、コントローラ31による制御に従って、Main TSのデータとSub TSのデータに分離する。
分離部51は、分離したMain TSのデータをリードバッファ52に出力して記憶させ、Sub TSのデータをリードバッファ55に出力して記憶させる。また、分離部51は、ローカルストレージ34から供給されたSub TSのデータをリードバッファ55に出力して記憶させる。
PIDフィルタ53は、リードバッファ52に記憶されているデータから構成されるMain TSのトランスポートパケットをPIDに基づいて振り分ける。コントローラ31からは、PlayListのSTN_table()(図11の32行目)に基づいて特定された、L videoストリームを構成するトランスポートパケットのPIDと、STN_table_extension()のref_to_stream_PID_of_mainClip(図19)に基づいて特定された、R videoストリームを構成するトランスポートパケットのPIDが指定される。
PIDフィルタ53は、L videoストリームのトランスポートパケットをリードバッファ52から読み出し、ESバッファ54に出力して記憶させる。ESバッファ54には、L videoのES(Elementary Stream)が記憶される。
また、PIDフィルタ53は、L videoストリームとともにR videoストリームがMain TSに多重化されている場合、R videoストリームのトランスポートパケットをPIDに基づいて抽出し、スイッチ57に出力する。
PIDフィルタ56は、Sub TSに含まれるR videoストリームのトランスポートパケットをリードバッファ55から読み出し、スイッチ57に出力する。コントローラ31からは、STN_table_extension()のref_to_stream_PID_of_subClip(図19)に基づいて特定された、R videoストリームを構成するトランスポートパケットのPIDが指定される。
ここでは、L video、R videoストリームの処理について説明しているが、図5を参照して説明したように、PGやIGなどのグラフィックスのデータがMain TSに多重化されていることがある。同様に、Sub TSにも、PGやIGなどのグラフィックスのデータが多重化されていることがある。
PIDフィルタ53とPIDフィルタ56は、適宜、それらのデータをもPIDに基づいて振り分け、所定の出力先に出力する。図22のPIDフィルタ53とPIDフィルタ56のブロック内に示す出力先の端子(丸)には、グラフィックのデータをデコードするデコーダなどが接続される。
スイッチ57は、PIDフィルタ53から供給された、Main TSに含まれていたR videoストリームのトランスポートパケットをESバッファ58に出力して記憶させる。また、スイッチ57は、PIDフィルタ56から供給された、Sub TSに含まれていたR videoストリームのトランスポートパケットをESバッファ58に出力して記憶させる。ESバッファ58には、R videoのESが記憶される。
スイッチ59は、ESバッファ54に記憶されているL videoのパケットと、ESバッファ58に記憶されているR videoのパケットのうちの、デコードの対象になるパケットをデコーダ60に出力する。DTS(Decoding Time Stamp)などの時刻情報がL videoとR videoのPESパケットに設定されており、その時刻情報に基づいてバッファからの読み出しが行われる。
デコーダ60は、スイッチ59から供給されたパケットをデコードし、デコードすることによって得られたL video、またはR videoのビデオ信号を出力する。
[PlayListファイルの具体例1]
図23は、PlayListファイルの具体例を示す図である。
図23には、図11等に示す情報のうちの一部の情報を示している。後述するPlayListファイルの具体例についても同様である。
図23のPlayListファイルは、L videoストリームとR videoストリームがそれぞれ別のTSに含まれ、それらのTSファイルがインターリーブされて光ディスク2に記録されている場合の3D再生を制御するPlayListファイルである。
すなわち、図23のAppInfoPlayList()に示すようにMVC_flag=1であり、かつ、PlayItem()に示すようにMVC_file_type=1である。
PlayItem()のClip_Information_file_nameは「00001」である。この記述から、L videoのClipを構成するclpiファイルが特定される。また、PlayItem()のIN_timeとOUT_timeから、PlayItemの再生区間の開始位置と終了位置がそれぞれ特定され、STN_table()から、L videoストリームを構成するトランスポートパケットのPIDが特定される。
ExtensionData()には、R videoストリームを参照するSubPathに関する情報が記述される。この例においては、通常のSubPathの数が0(number_of_SubPaths(図11の14行目)の値が0)とされており、R videoストリームを参照するSubPathには、SubPath_id=0が割り当てられる。SubPath_extension()中には、R videoストリームを参照するSubPathであることを表すSubPath_type_extension=8が設定される。
ExtensionData()のSubPlayItem()のClip_Information_file_nameは「00002」である。
この記述から、R videoのClipを構成するclpiファイルが特定される。また、SubPlayItem()のSubPlayItem_IN_timeとSubPlayItem_OUT_timeから、SubPlayItemの再生区間の開始位置と終了位置がそれぞれ特定される。
STN_table_extension()から、R videoストリームを参照するSubPathのIDが0であること(ref_to_SubPath_id=0)と、R videoストリームを構成するトランスポートパケットのPID(ref_to_R_video_PID)が特定される。この例の場合、STN_table_extension()のtypeの値は2となる。
図24は、clpiファイルのシンタクスを示す図である。
図24Aは「00001.clpi」のclpiファイルの例を示す図である。
number_of_source_packets1は、「00001.m2ts」のm2tsファイルに含まれるソースパケットの数を表す。
EP_mapには、「00001.m2ts」のm2tsファイルに含まれるTSに設定されたエントリーポイント(EP)の位置情報が含まれる。
chunk_map()には、「00001.m2ts」のm2tsファイルの各チャンクの位置情報が含まれる。各チャンクの位置は、例えばSource Packet Number(SPN)により表される。chunk_map()の具体例については後述する。
図24Bは「00002.clpi」のclpiファイルの例を示す図である。
「00002.clpi」のclpiファイルにも、「00001.clpi」のclpiファイルと同様に、「00002.m2ts」のm2tsファイルに含まれるソースパケットの数を表すnumber_of_source_packets2、EP_map、およびchunk_map()が含まれる。
図25は、ファイル管理の概念を示す図である。
図25に示すように、インターリーブされて光ディスク2に記録されているファイルの管理は、物理レイヤ、ファイルシステムレイヤ、アプリケーションレイヤの3層構造の形で行われる。図23のPlayListファイル、図24のclpiファイルは、コンテンツの再生を管理するアプリケーションが扱うアプリケーションレイヤの情報になる。
物理レイヤは、L videoストリームのm2tsファイルとR videoストリームのm2tsファイルがインターリーブされて記録されている光ディスク2のレイヤとなる。
ファイルシステムレイヤにおいては、アプリケーションが指定したストリームファイル(m2tsファイル、ilvtファイル)と、各ストリームファイルを構成するエクステントの光ディスク2上の位置が対応付けられる。ファイルシステムは例えばUDF file systemである。
エクステントは、特定のファイルにより管理されるデータ全体のうち、連続して光ディスク2上に配置されるデータのそれぞれの集まりをいう。
すなわち、図25の例の場合、「00001.m2ts」のm2tsファイルにおいては、L[0],L[1]がそれぞれエクステントとなる。「00001.m2ts」のm2tsファイルが読み出しファイルとしてアプリケーションにより指定された場合、L[0],L[1]のそれぞれの光ディスク2上の位置がUDF file systemにより特定され、ディスクドライブ32により読み出される。
「00002.m2ts」のm2tsファイルにおいては、R[0],R[1]がそれぞれエクステントとなる。「00002.m2ts」のm2tsファイルが読み出しファイルとしてアプリケーションにより指定された場合、R[0],R[1]のそれぞれの光ディスク2上の位置がUDF file systemにより特定され、ディスクドライブ32により読み出される。
「00001.ilvt」のilvtファイルにおいては、R[0],L[0],R[1],L[1]全体が1つのエクステントとなる。「00001.ilvt」のilvtファイルが読み出しファイルとしてアプリケーションにより指定された場合、R[0],L[0],R[1],L[1]の光ディスク2上の位置がUDF file systemにより特定され、ディスクドライブ32により読み出される。
[動作例1]
ここで、図26のフローチャートを参照して、図23のPlayListファイルに従って行われる3D再生の処理について説明する。
MVC_flag=1である場合、コントローラ31(コントローラ31において実行される、コンテンツの再生を管理するアプリケーション)は、操作部37に対して行われたユーザによる操作に応じて3D再生を開始する。
ステップS1において、コントローラ31は、STN_table()の記述から、L videoストリームを構成する、Main TSのトランスポートパケットのPIDを特定する。
ステップS2において、コントローラ31は、STN_table_extension()の記述から、R videoストリームを参照するSubPathのSubPath_idの値であるref_to_SubPath_id=0を特定し、また、R videoストリームを構成する、Sub TSのトランスポートパケットのPIDを特定する。
ステップS3において、コントローラ31は、PlayItem()の中のClip_Information_file_nameから、L videoストリームを含むMain TSのm2tsファイルに対応するclpiファイルのファイル名を「00001.clpi」として特定する。
ステップS4において、コントローラ31は、SubPath_entries_extension()の中でSubPath_id=0を持つ、SubPath_type=8が設定されたSubPathのSubPlayItem()の中のClip_Information_file_nameから、R videoストリームを含むm2tsファイルに対応するclpiファイルのファイル名を「00002.clpi」として特定する。
ステップS5において、コントローラ31は、L videoのClipを構成するファイルのファイル名に含まれる数字(00001)と同じ5文字をファイル名に含み、拡張子がilvtである「00001.ilvt」のilvtファイルを特定する。上述したように、ilvtファイルのファイル名には、L videoのClipを構成するm2tsファイル、clpiファイルの名前に含まれる数字と同じ数字が含まれる。
ステップS6において、コントローラ31は、ステップS3で特定した「00001.ilvt」を読み出しファイルとし、UDF file systemを通して、ディスクドライブ32に光ディスク2から読み出させる。「00001.ilvt」のilvtファイルのデータとしてディスクドライブ32により読み出されたL videoストリームとR videoストリームのデータは、デコード部36の分離部51に供給される。
なお、ランダムアクセスなどが指定されたことにより、EP_mapに含まれる所定のEPからデコードを開始する場合、読み出しファイルのデータのうちの、そのEP以降のデータが読み出される。EP_mapには、各EPの位置を指定するソースパケットの番号などの位置情報が含まれる。
ステップS7において、コントローラ31は、分離部51を制御し、「00001.clpi」のclpiファイルのchunk_map()と「00002.clpi」のclpiファイルのchunk_map()に基づいて、光ディスク2から読み出されたデータを、L videoとR videoのデータに分離させる。
分離部51により分離されたL videoストリームのデータはリードバッファ52に出力され、R videoストリームのデータはリードバッファ55に出力される。chunk_map()を使って行われるデータの分離については後述する。
リードバッファ52に記憶されたL videoストリームのデータは、そのトランスポートパケットがステップS1において特定されたPIDに基づいてPIDフィルタ53により抽出され、ESバッファ54、スイッチ59を介してデコーダ60に供給される。リードバッファ55に記憶されたR videoストリームのデータは、そのトランスポートパケットがステップS2において特定されたPIDに基づいてPIDフィルタ56により抽出され、スイッチ57、ESバッファ58、およびスイッチ59を介してデコーダ60に供給される。
ステップS8において、デコーダ60は、スイッチ59から順次供給されるパケットをデコードする(再生する)。
L videoストリームとR videoストリームがそれぞれ別のTSに含まれ、それらのTSファイルがインターリーブされて光ディスク2に記録されている場合の3D再生は以上のようにして行われる。
[chunk_map()を使ったデータの分離]
図27は、chunk_map()のシンタクスの例を示す図である。
number_of_chunksは、参照するチャンクの数を表す。number_of_chunks以降には、ここで指定される数だけチャンクの情報が記述される。
SPN_chunk_start[i]は、例えば先頭のチャンクの開始位置を基準として、その基準の位置から各チャンクの開始位置までのSPN(Source Packet Number)(長さ)を表す。各チャンクの開始位置のSPNが、先頭のチャンクのものから順に記述される。
図28は、chunk_map()を含む、clpiファイルの具体例を示す図である。
図28Aは「00001.clpi」のclpiファイルを示す図であり、number_of_source_packetsは「number_of_source_packets1」とされている。また、chunk_map()のnumber_of_chunksはn+1であり、SPN_chunk_start[i]は0,a1,a2,…,anである。
SPN_chunk_start[i]の1番目の値0は、図29の中段に示すように、「00001.m2ts」のm2tsファイルの先頭のチャンクの開始位置を基準として、その基準の位置から、1番目のチャンクであるL[0]の開始位置までのSPNが0であることを表す。
2番目の値a1は、基準の位置から、2番目のチャンクであるL[1]の開始位置までのSPNがa1であることを表す。
3番目の値a2は、基準の位置から、3番目のチャンクであるL[2]の開始位置までのSPNがa2であることを表す。
n+1番目の値anは、基準の位置から、最後のチャンクであるL[n]の開始位置までのSPNがanであることを表す。
図28Bは「00002.clpi」のclpiファイルを示す図であり、number_of_source_packetsは「number_of_source_packets2」とされている。また、chunk_map()のnumber_of_chunksはn+1であり、SPN_chunk_start[i]は0,b1,b2,…,bnである。
SPN_chunk_start[i]の1番目の値0は、図29の上段に示すように、「00002.m2ts」のm2tsファイルの先頭のチャンクの開始位置を基準として、その基準の位置から、1番目のチャンクであるR[0]の開始位置までのSPNが0であることを表す。
2番目の値b1は、基準の位置から、2番目のチャンクであるR[1]の開始位置までのSPNがb1であることを表す。
3番目の値b2は、基準の位置から、3番目のチャンクであるR[2]の開始位置までのSPNがb2であることを表す。
n+1番目の値bnは、基準の位置から、最後のチャンクであるR[n]の開始位置までのSPNがbnであることを表す。
分離部51は、光ディスク2から読み出されたデータが供給された場合、図29の下段に示すように、2つのchunk_map()の記述に基づいて、供給されたデータの先頭からb1に相当するSPN分のデータをR[0]として分離する。「00001.ilvt」のilvtファイルが読み出しファイルとして指定された場合、分離部51には、R[0],L[0],R[1],L[1],・・・,R[n],L[n]の順に各データが供給される。
また、分離部51は、R[0]の終わりの位置からa1に相当するSPN分のデータをL[0]として分離し、L[0]の終わりの位置からb2-b1に相当するSPN分のデータをR[1]として分離する。分離部51は、R[1]の終わりの位置からa2-a1に相当するSPN分のデータをL[1]として分離する。
同様にして、分離部51は、L[n-1]の終わりの位置から、「00002.clpi」のclpiファイルに記述されるnumber_of_source_packets2の値からbnの値を減算した値に相当するSPN分のデータをR[n]として分離する。分離部51は、R[n]の終わりの位置から、「00001.clpi」のclpiファイルに記述されるnumber_of_source_packets1の値からanの値を減算した値に相当するSPN分のデータをL[n]として分離する。
このように、分離部51によるデータの分離は、chunk_map()に記述される各チャンクの長さの情報を用いて行われる。
なお、1以外の値がMVC_file_typeに設定されているとき、chunk_map()はオプショナル(あっても無くても良い)となる。1以外の値がMVC_file_typeに設定されたPlayListを読み込んだプレーヤは、chunk_map()がPlayList中にある場合には、そのchunk_map()を無視しなければならない。
MVC_file_type=1のとき、L videoストリームとR videoストリームの対応する2つのストリームは、それぞれ同じ数のチャンクに分割される。インターリーブされるR[i],L[i]について、添え字iの値が同じL videoストリームのチャンクとL videoストリームのチャンクは、同じ再生時間を持つ。
図30は、clpiファイルに記述されるEP_map()のシンタクスを示す図である。
EP_map()はランダムアクセスなどを行うときのデコード開始位置を特定するために参照される。number_of_EP_entriesはEP(エントリポイント)の数を表す。
number_of_EP_entries以降の記述が各EPについて用意される。PTS_EP_start[i]はEPのPTSを表し、SPN_EP_start[i]はEPのSPNを表す。このように、EP_mapには、各エントリポイントについてのPTSとSPNが対応付けて登録される。EPが指定されたとき、指定されたEPのPTS_EP_start[i]とSPN_EP_start[i]に基づいて読み出し開始アドレスが特定され、ファイルの読み出しが行われる。
[PlayListファイルの具体例2]
図31Aは、PlayListファイルの他の具体例を示す図である。
図31AのPlayListは、L videoストリームとR videoストリームが同じTSに含まれる場合の3D再生を制御するPlayListである。すなわち、L videoストリームのm2tsファイルとR videoストリームのm2tsファイルは、光ディスク2上でインターリーブされていない。
この場合、図31AのAppInfoPlayList()に示すようにMVC_flag=1であり、かつ、PlayItem()に示すようにMVC_file_type=0である。
PlayItem()のClip_Information_file_nameは「00001」である。この記述から、L videoのClipを構成するclpiファイルが特定される。また、PlayItem()のIN_timeとOUT_timeから、PlayItemの再生区間の開始位置と終了位置がそれぞれ特定され、STN_table()から、L videoストリームを構成するトランスポートパケットのPIDが特定される。
ExtensionData()のSTN_table_extension()から、R videoストリームを構成するトランスポートパケットのPIDが特定される。この例の場合、STN_table_extension()のtypeの値は1となる。
図31Bは、「00001.clpi」のclpiファイルのシンタクスを示す図である。
図31Bに示すように、「00001.clpi」のclpiファイルにはEP_mapが含まれる。1以外の値がMVC_file_typeに設定されており、この例においては、clpiファイルにchunk_map()が含まれていない。
図32は、図31のファイルに基づいて行われるファイル管理の概念を示す図である。
図32に示すように、L videoストリームとR videoストリームを含む1本のTSは、「00001.m2ts」のm2tsファイルによって管理される。
「00001.m2ts」のm2tsファイルが読み出しファイルとしてアプリケーションにより指定された場合、「00001.m2ts」のm2tsファイルの記録位置がUDF file systemにより特定され、ディスクドライブ32により読み出される。読み出された「00001.m2ts」のm2tsファイルに含まれるL videoストリームとR videoストリームを構成するそれぞれのトランスポートパケットは、PIDに基づいて、それぞれ分離される。
[動作例2]
図33のフローチャートを参照して、図31のPlayListファイルに従って行われる3D再生の処理について説明する。
ステップS21において、コントローラ31は、STN_table()の記述から、L videoストリームを構成する、Main TSのトランスポートパケットのPIDを特定する。
ステップS22において、コントローラ31は、STN_table_extension()の記述から、R videoストリームを構成する、Main TSのトランスポートパケットのPIDを特定する。
ステップS23において、コントローラ31は、PlayItem()の中のClip_Information_file_nameから、L videoストリームとR videoストリームを含むm2tsファイルに対応するclpiファイルのファイル名を「00001.clpi」として特定する。MVC_flag=1であり、かつ、MVC_file_type=0であることにより、1本のMain TSにL videoストリームとR videoストリームが含まれていることは特定されている。
ステップS24において、コントローラ31は、「00001.m2ts」を読み出しファイルとし、UDF file systemを通して、ディスクドライブ32に光ディスク2から読み出させる。ディスクドライブ32により読み出された、「00001.m2ts」のm2tsファイルのデータは、分離部51を介してリードバッファ52に供給され、記憶される。
リードバッファ52に記憶されたデータの中から、ステップS21において特定されたPIDに基づいて、L videoストリームのトランスポートパケットがPIDフィルタ53により抽出される。抽出されたトランスポートパケットのデータは、ESバッファ54、スイッチ59を介してデコーダ60に供給される。
また、リードバッファ52に記憶されたデータの中から、ステップS22において特定されたPIDに基づいて、R videoストリームのトランスポートパケットがPIDフィルタ53により抽出される。抽出されたトランスポートパケットのデータは、スイッチ57、ESバッファ58、スイッチ59を介してデコーダ60に供給される。
ステップS25において、デコーダ60は、スイッチ59から順次供給されるパケットをデコードする(再生する)。
L videoストリームとR videoストリームが同じTSに含まれる場合の3D再生は以上のようにして行われる。
[PlayListファイルの具体例3]
図34は、PlayListファイルのさらに他の具体例を示す図である。
図34のPlayListファイルは、L videoストリームを含むTSが光ディスク2に記録され、R videoストリームを含むTSがローカルストレージ34に記録されている場合の3D再生を制御するPlayListである。例えば、サーバ22からR videoストリームがダウンロードされたとき、光ディスク2に記録されているPlayListはR videoストリームに関する情報を追加するようにして更新され、ローカルストレージ34に記録してコントローラ31により管理される。
図34のAppInfoPlayList()に示すようにMVC_flag=1であり、かつ、PlayItem()に示すようにMVC_file_type=2である。
PlayItem()のClip_Information_file_nameは「00001」である。この記述から、L videoのClipを構成するclpiファイルが特定される。また、PlayItem()のIN_timeとOUT_timeから、PlayItemの再生区間の開始位置と終了位置がそれぞれ特定され、STN_table()から、L videoストリームを構成するトランスポートパケットのPIDが特定される。
ExtensionData()には、R videoストリームを参照するSubPathに関する情報が記述される。この例においても、通常のSubPathの数が0(number_of_SubPaths(図11の14行目)の値が0)とされており、R videoストリームを参照するSubPathには、SubPath_id=0が割り当てられる。図34に示すように、SubPath_extension()中には、R videoストリームを参照するSubPathであることを表すSubPath_type_extension=8が設定される。
ExtensionData()のSubPlayItem()のClip_Information_file_nameは「00003」である。
この記述から、R videoのClipを構成するclpiファイルが特定される。「00003.clpi」のclpiファイルも、対応するR videoストリームのファイルである「00003.m2ts」のm2tsファイルとともにサーバ22からダウンロードされ、ローカルストレージ34に記憶されている。
また、ExtensionData()のSubPlayItem()のSubPlayItem_IN_timeとSubPlayItem_OUT_timeから、SubPlayItemの再生区間の開始位置と終了位置がそれぞれ特定される。STN_table_extension()から、R videoストリームを参照するSubPathのIDが0であること(ref_to_SubPath_id=0)と、R videoストリームを構成するトランスポートパケットのPID(ref_to_R_video_PID)が特定される。この例の場合、STN_table_extension()のtypeの値は2となる。
図35は、clpiファイルのシンタクスを示す図である。
図35Aは「00001.clpi」のclpiファイルの例を示す図である。図35Aに示すように、「00001.clpi」のclpiファイルにはEP_mapが含まれる。図35Bは「00003.clpi」のclpiファイルの例を示す図である。図35Bに示すように、「00003.clpi」のclpiファイルにもEP_mapが含まれる。
例えば、「00001.clpi」のclpiファイルに含まれるEP_mapと「00003.clpi」のclpiファイルに含まれるEP_mapには、コンテンツの先頭の時刻t0を基準としてそれぞれ同じ時刻に設定されたEPの情報が含まれる。「00001.clpi」のclpiファイルに含まれるEP_mapを使用して再生が開始されるL videoストリームの位置と、「00003.clpi」のclpiファイルに含まれるEP_mapを使用して再生が開始されるR videoストリームの位置は、時刻t0を基準とした時間軸上では同じ時刻の位置になる。
図36は、図34と図35のファイルを用いて行われるファイル管理の概念を示す図である。
図36に示すように、光ディスク2に記録されたL videoストリームを含むTSは、「00001.m2ts」のm2tsファイルによって管理される。また、ローカルストレージ34に記録されたR videoストリームを含むTSは、「00003.m2ts」のm2tsファイルによって管理される。
BDにおいては、BDに記録されたデータとローカルストレージに記録されたデータは、BDに記録されたデータを管理する例えばUDF file systemと、ローカルストレージに記録されたデータを管理するファイルシステムとをマージした仮想的なファイルシステムによって管理される。ローカルストレージを内蔵したプレーヤは、そのような仮想的なファイルシステムを生成し、BDに記録されたデータとローカルストレージに記録されたデータを管理する。
読み出し対象とするファイルがアプリケーションにより指定された場合、そのファイルがBDに記録されているのか、またはローカルストレージに記録されているのかと、記録メディア上の記録位置を示すアドレスが仮想ファイルシステムにより特定され、特定された記録メディアの、特定されたアドレスからファイルが読み出される。
例えば、「00001.m2ts」のm2tsファイルがアプリケーションにより指定された場合、「00001.m2ts」のm2tsファイルが光ディスク2の所定の位置に記録されていることが仮想ファイルシステムにより特定され、ディスクドライブ32により読み出される。
また、「00003.m2ts」のm2tsファイルがアプリケーションにより指定された場合、「00003.m2ts」のm2tsファイルがローカルストレージ34の所定の位置に記録されていることが仮想ファイルシステムにより特定され、読み出される。
[動作例3]
図37のフローチャートを参照して、図34のPlayListファイルに従って行われる3D再生の処理について説明する。
ステップS41において、コントローラ31は、STN_table()の記述から、L videoストリームを構成する、Main TSのトランスポートパケットのPIDを特定する。
ステップS42において、コントローラ31は、STN_table_extension()の記述から、R videoストリームを参照するSubPathのSubPath_idの値であるref_to_SubPath_id=0を特定し、また、R videoストリームを構成するトランスポートパケットのPIDを特定する。
ステップS43において、コントローラ31は、PlayItem()の中のClip_Information_file_nameから、L videoストリームを含むMain TSのm2tsファイルに対応するclpiファイルのファイル名を「00001.clpi」として特定する。
ステップS44において、コントローラ31は、SubPath_entries_extension()の中でSubPath_id=0を持つ、SubPath_type=8が設定されたSubPathのSubPlayItem()の中のClip_Information_file_nameから、R videoストリームを含むm2tsファイルに対応するclpiファイルのファイル名を「00003.clpi」として特定する。
ステップS45において、コントローラ31は、「00001.m2ts」を読み出しファイルとし、仮想ファイルシステムを通して、ディスクドライブ32に光ディスク2から読み出させる。
ステップS46において、コントローラ31は、「00003.m2ts」を読み出しファイルとし、仮想ファイルシステムを通して、ローカルストレージ34から読み出す。
ディスクドライブ32により読み出された「00001.m2ts」のm2tsファイルのデータは、分離部51を介してリードバッファ52に供給され、記憶される。リードバッファ52に記憶されたL videoストリームのデータは、そのトランスポートパケットがステップS41において特定されたPIDに基づいてPIDフィルタ53により抽出され、ESバッファ54、スイッチ59を介してデコーダ60に供給される。
一方、ローカルストレージ34から読み出された「00003.m2ts」のm2tsファイルのデータは、分離部51を介してリードバッファ55に供給され、記憶される。リードバッファ55に記憶されたR videoストリームのデータは、そのトランスポートパケットがステップS42において特定されたPIDに基づいてPIDフィルタ56により抽出され、スイッチ57、ESバッファ58、およびスイッチ59を介してデコーダ60に供給される。
ステップS47において、デコーダ60は、スイッチ59から順次供給されるパケットをデコードする(再生する)。
L videoストリームを含むTSが光ディスク2に記録され、R videoストリームを含むTSがローカルストレージ34に記録されている場合の3D再生は以上のようにして行われる。
[2D再生を行う場合の動作]
以上のようなPlayListファイルに従って、光ディスク2に記録されているコンテンツを2D再生する場合の動作について説明する。
ここでは、L videoストリームとR videoストリームがそれぞれ別のTSに含まれ、それらのm2tsファイルがインターリーブされて光ディスク2に記録されているものとする。光ディスク2上のデータの配置は図25に示す配置になる。2D再生は、図23のPlayListファイルに従って行われる。
この場合、2D再生を行うプレーヤは、2D再生と関係のある記述だけをPlayListファイルから読み込んで処理を行う。
図23のPlayListファイルの記述うちの、読み込みの対象になる記述を図38に下線を付して示す。図38に示すように、R videoストリームの再生時に参照される情報であるExtensionData()の記述は読み込まれない。
また、図24Aのclpiファイルの記述うちの、読み込みの対象になる記述を図39Aに下線を付して示す。図39Aに示すように、R videoストリームの再生時に参照される情報であるchunk_map()は読み込まれない。また、図39Bに示すように、「00002.clpi」のclpiファイルはその全体が読み込まれない。
一連の処理について説明すると、2D再生を行う再生装置1は、PlayItem()の中のClip_Information_file_nameから、L videoストリームを含むm2tsファイルに対応するclpiファイルのファイル名を「00001.clpi」として特定する。また、再生装置1は、STN_table()の記述から、L videoストリームを構成するトランスポートパケットのPIDを特定する。
再生装置1は、UDF file systemを通して、「00001.m2ts」のm2tsファイルを光ディスク2から読み出し、以降、L videoストリームを読み出したときと同様の処理を行う。すなわち、リードバッファ52に一時的に記憶されたL videoストリームのデータは、PIDフィルタ53、ESバッファ54、スイッチ59を介してデコーダ60に供給され、再生される。再生装置1から出力されるデータはL videoストリームのデータだけであるから、表示装置3においては、L videoストリームのデータに基づいて2D画像が表示される。
このように、図23等を参照して説明したPlayListファイルは、3D再生に対応した再生装置において2D再生を行う場合にも、あるいは、3D再生に非対応の再生装置において2D再生を行う場合にも、利用可能なファイルとなる。これにより、3D再生に対応した再生装置用のものと、3D再生に非対応の再生装置用のものとをそれぞれ用意する必要がなく、PlayListファイルやそれを記録した光ディスク2の互換性を確保することが可能になる。
[記録装置の構成例]
図40は、ソフト製作処理部101の構成例を示すブロック図である。
ビデオエンコーダ111は、図3のMVCエンコーダと同様の構成を有している。ビデオエンコーダ111は、複数の映像データをH.264 AVC/MVCでエンコードすることによってL videoストリームとR videoストリームを生成し、バッファ112に出力する。
オーディオエンコーダ113は、入力されたオーディオストリームをエンコードし、得られたデータをバッファ114に出力する。オーディオエンコーダ113には、L videoストリーム、R videoストリームとともにディスクに記録させるオーディオストリームが入力される。
データエンコーダ115は、PlayListファイルなどの、ビデオ、オーディオ以外の上述した各種のデータをエンコードし、エンコードして得られたデータをバッファ116に出力する。例えば、データエンコーダ115は、上述したSubPath_entries_extension(図15)やSTN_table_extension(図18)やMVC_flag(図12)やMVC_file_type(図13)を設定し、図11を参照して説明したようなPlayListファイルを生成する。
多重化部117は、それぞれのバッファに記憶されたビデオデータ、オーディオデータ、および、ストリーム以外のデータを同期信号と共に多重化し、誤り訂正符号化部118に出力する。
誤り訂正符号化部118は、エラー訂正用のコードを多重化部117により多重化されたデータに付加する。
変調部119は、誤り訂正符号化部118から供給されたデータに対して変調を施し、出力する。変調部119の出力は、再生装置1において再生可能な光ディスク2に記録されるソフトウエアとなる。
このような構成を有するソフト製作処理部101が記録装置に設けられる。
図41は、ソフト製作処理部101を含む構成の例を示す図である。
図41に示す構成の一部が記録装置内に設けられることもある。
ソフト製作処理部101により生成された記録信号はプリマスタリング処理部131においてマスタリング処理が施され、光ディスク2に記録すべきフォーマットの信号が生成される。生成された信号は原盤記録部133に供給される。
記録用原盤製作部132においては、ガラスなどよりなる原盤が用意され、その上に、フォトレジストなどよりなる記録材料が塗布される。これにより、記録用原盤が製作される。
原盤記録部133において、プリマスタリング処理部131から供給された記録信号に対応してレーザビームが変調され、原盤上のフォトレジストに照射される。これにより、原盤上のフォトレジストが記録信号に対応して露光される。その後、この原盤を現像し、原盤上にピットを出現させることが行われる。
金属原盤製作部134において、原盤に電鋳等の処理が施され、ガラス原盤上のピットを転写した金属原盤が製作される。この金属原盤から、さらに金属スタンパが製作され、これが成形用金型とされる。
成形処理部135において、成形用金型に、インジェクションなどによりPMMA(アクリル)またはPC(ポリカーボネート)などの材料を注入し、固定化させることが行われる。
あるいは、金属スタンパ上に2P(紫外線硬化樹脂)などを塗布した後、紫外線を照射して硬化させることが行われる。これにより、金属スタンパ上のピットを、樹脂よりなるレプリカ上に転写することができる。
成膜処理部136において、レプリカ上に、反射膜が蒸着あるいはスパッタリングなどにより形成される。あるいはまた、レプリカ上に、反射膜がスピンコートにより形成される。
後加工処理部137において、このディスクに対して内外径の加工が施され、2枚のディスクを張り合わせるなどの必要な処置が施される。このようにして、再生装置1によって再生可能なデータが記録された上述した光ディスク2が完成する。
[コンピュータの構成例]
上述した一連の処理は、ハードウエアにより実行することもできるし、ソフトウエアにより実行することもできる。一連の処理をソフトウエアにより実行する場合には、そのソフトウエアを構成するプログラムが、専用のハードウエアに組み込まれているコンピュータ、または汎用のパーソナルコンピュータなどに、プログラム記録媒体からインストールされる。
図42は、上述した一連の処理をプログラムにより実行するコンピュータのハードウエアの構成例を示すブロック図である。
CPU(Central Processing Unit)151、ROM(Read Only Memory)152、RAM(Random Access Memory)153は、バス154により相互に接続されている。
バス154には、さらに、入出力インタフェース155が接続されている。入出力インタフェース155には、キーボード、マウスなどよりなる入力部156、ディスプレイ、スピーカなどよりなる出力部157が接続される。また、入出力インタフェース155には、ハードディスクや不揮発性のメモリなどよりなる記憶部158、ネットワークインタフェースなどよりなる通信部159、リムーバブルメディア161を駆動するドライブ160が接続される。
以上のように構成されるコンピュータでは、CPU151が、例えば、記憶部158に記憶されているプログラムを入出力インタフェース155及びバス154を介してRAM153にロードして実行することにより、上述した一連の処理が行われる。
CPU151が実行するプログラムは、例えばリムーバブルメディア161に記録して、あるいは、ローカルエリアネットワーク、インターネット、デジタル放送といった、有線または無線の伝送媒体を介して提供され、記憶部158にインストールされる。
なお、コンピュータが実行するプログラムは、本明細書で説明する順序に沿って時系列に処理が行われるプログラムであっても良いし、並列に、あるいは呼び出しが行われたとき等の必要なタイミングで処理が行われるプログラムであっても良い。
本技術の実施の形態は、上述した実施の形態に限定されるものではなく、本技術の要旨を逸脱しない範囲において種々の変更が可能である。