JP2022076012A - 送信装置、受信装置、制御方法、プログラム、および送受信システム - Google Patents

送信装置、受信装置、制御方法、プログラム、および送受信システム Download PDF

Info

Publication number
JP2022076012A
JP2022076012A JP2022051318A JP2022051318A JP2022076012A JP 2022076012 A JP2022076012 A JP 2022076012A JP 2022051318 A JP2022051318 A JP 2022051318A JP 2022051318 A JP2022051318 A JP 2022051318A JP 2022076012 A JP2022076012 A JP 2022076012A
Authority
JP
Japan
Prior art keywords
data
unit
transmission
parameter
packet
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.)
Granted
Application number
JP2022051318A
Other languages
English (en)
Other versions
JP7326522B2 (ja
Inventor
直樹 吉持
Naoki Yoshimochi
雅俊 水野
Masatoshi Mizuno
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sony Semiconductor Solutions Corp
Original Assignee
Sony Semiconductor Solutions Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sony Semiconductor Solutions Corp filed Critical Sony Semiconductor Solutions Corp
Publication of JP2022076012A publication Critical patent/JP2022076012A/ja
Application granted granted Critical
Publication of JP7326522B2 publication Critical patent/JP7326522B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/12Systems in which the television signal is transmitted via one channel or a plurality of parallel channels, the bandwidth of each channel being less than the bandwidth of the television signal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L25/00Baseband systems
    • H04L25/02Details ; arrangements for supplying electrical power along data transmission lines
    • H04L25/14Channel dividing arrangements, i.e. in which a single bit stream is divided between several baseband channels and reassembled at the receiver
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/242Synchronization processes, e.g. processing of PCR [Program Clock References]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/14Handling requests for interconnection or transfer
    • G06F13/20Handling requests for interconnection or transfer for access to input/output bus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/14Digital output to display device ; Cooperation and interconnection of the display device with other functional units
    • G06F3/147Digital output to display device ; Cooperation and interconnection of the display device with other functional units using display panels
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G5/00Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
    • G09G5/003Details of a display terminal, the details relating to the control arrangement of the display terminal and to the interfaces thereto
    • G09G5/006Details of the interface to the display terminal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L25/00Baseband systems
    • H04L25/38Synchronous or start-stop systems, e.g. for Baudot code
    • H04L25/40Transmitting circuits; Receiving circuits
    • H04L25/49Transmitting circuits; Receiving circuits using code conversion at the transmitter; using predistortion; using insertion of idle bits for obtaining a desired frequency spectrum; using three or more amplitude levels ; Baseband coding techniques specific to data transmission systems
    • H04L25/4906Transmitting circuits; Receiving circuits using code conversion at the transmitter; using predistortion; using insertion of idle bits for obtaining a desired frequency spectrum; using three or more amplitude levels ; Baseband coding techniques specific to data transmission systems using binary codes
    • H04L25/4908Transmitting circuits; Receiving circuits using code conversion at the transmitter; using predistortion; using insertion of idle bits for obtaining a desired frequency spectrum; using three or more amplitude levels ; Baseband coding techniques specific to data transmission systems using binary codes using mBnB codes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L7/00Arrangements for synchronising receiver with transmitter
    • H04L7/0008Synchronisation information channels, e.g. clock distribution lines
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L7/00Arrangements for synchronising receiver with transmitter
    • H04L7/0016Arrangements for synchronising receiver with transmitter correction of synchronization errors
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L7/00Arrangements for synchronising receiver with transmitter
    • H04L7/04Speed or phase control by synchronisation signals
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/236Assembling of a multiplex stream, e.g. transport stream, by combining a video stream with other content or additional data, e.g. inserting a URL [Uniform Resource Locator] into a video stream, multiplexing software data into a video stream; Remultiplexing of multiplex streams; Insertion of stuffing bits into the multiplex stream, e.g. to obtain a constant bit-rate; Assembling of a packetised elementary stream
    • H04N21/23605Creation or processing of packetized elementary streams [PES]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/4302Content synchronisation processes, e.g. decoder synchronisation
    • H04N21/4305Synchronising client clock from received content stream, e.g. locking decoder clock with encoder clock, extraction of the PCR packets
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/434Disassembling of a multiplex stream, e.g. demultiplexing audio and video streams, extraction of additional data from a video stream; Remultiplexing of multiplex streams; Extraction or processing of SI; Disassembling of packetised elementary stream
    • H04N21/4343Extraction or processing of packetized elementary streams [PES]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N23/00Cameras or camera modules comprising electronic image sensors; Control thereof
    • H04N23/50Constructional details
    • H04N23/555Constructional details for picking-up images in sites, inaccessible due to their dimensions or hazardous conditions, e.g. endoscopes or borescopes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N23/00Cameras or camera modules comprising electronic image sensors; Control thereof
    • H04N23/60Control of cameras or camera modules
    • H04N23/66Remote control of cameras or camera parts, e.g. by remote control devices
    • H04N23/661Transmitting camera control signals through networks, e.g. control via the Internet
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N23/00Cameras or camera modules comprising electronic image sensors; Control thereof
    • H04N23/60Control of cameras or camera modules
    • H04N23/667Camera operation mode switching, e.g. between still and video, sport and normal or high- and low-resolution modes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/025Systems for the transmission of digital non-picture data, e.g. of text during the active part of a television frame
    • H04N7/035Circuits for the digital non-picture data signal, e.g. for slicing of the data signal, for regeneration of the data-clock signal, for error detection or correction of the data signal
    • H04N7/0352Circuits for the digital non-picture data signal, e.g. for slicing of the data signal, for regeneration of the data-clock signal, for error detection or correction of the data signal for regeneration of the clock signal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/025Systems for the transmission of digital non-picture data, e.g. of text during the active part of a television frame
    • H04N7/035Circuits for the digital non-picture data signal, e.g. for slicing of the data signal, for regeneration of the data-clock signal, for error detection or correction of the data signal
    • H04N7/0357Circuits for the digital non-picture data signal, e.g. for slicing of the data signal, for regeneration of the data-clock signal, for error detection or correction of the data signal for error detection or correction
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2370/00Aspects of data communication
    • G09G2370/10Use of a protocol of communication by packets in interfaces along the display data pipeline
    • GPHYSICS
    • G09EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
    • G09GARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
    • G09G2380/00Specific applications
    • G09G2380/08Biomedical applications
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N23/00Cameras or camera modules comprising electronic image sensors; Control thereof
    • H04N23/60Control of cameras or camera modules
    • H04N23/66Remote control of cameras or camera parts, e.g. by remote control devices

Landscapes

  • Engineering & Computer Science (AREA)
  • Signal Processing (AREA)
  • Multimedia (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Spectroscopy & Molecular Physics (AREA)
  • Human Computer Interaction (AREA)
  • Power Engineering (AREA)
  • Computer Hardware Design (AREA)
  • Communication Control (AREA)
  • Synchronisation In Digital Transmission Systems (AREA)
  • Detection And Prevention Of Errors In Transmission (AREA)

Abstract

Figure 2022076012000001
【課題】データの伝送効率を高めることができるようにする。
【解決手段】本技術の一側面の送信装置は、データストリームの送信に関するパラメータを変更する場合に、変更するパラメータの種類に応じて、レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御する。変更するパラメータがデータストリームの送信に用いるレーンの数を表すレーン情報である場合、および、パラメータがそれぞれのレーンの伝送レートの種類を表すレート情報である場合には、トレーニング処理を行った後に、変更後のパラメータに応じたデータストリームの送信が開始される。本技術は、チップ間のデータ伝送に適用することができる。
【選択図】図46

Description

本技術は、送信装置、受信装置、制御方法、プログラム、および送受信システムに関し、特に、データの伝送効率を高めることができるようにした送信装置、受信装置、制御方法、プログラム、および送受信システムに関する。
イメージセンサの高画質化、高フレームレート化に伴い、イメージセンサと、イメージセンサにより撮像された画像を処理するDSP(Digital Signal Processor)との間のインタフェースに求められるデータの伝送容量が高まってきている。
特許文献1には、画像データを格納するパケットを複数レーンに分配し、複数レーンを介して、イメージセンサからDSPにデータを伝送する伝送方式が記載されている。この伝送方式においては、1フレームの各ラインを構成する画像データがイメージセンサにおいて各パケットに格納され、DSPに伝送される。
特開2012-120159号公報
データ伝送のモードを変更する毎に、データ伝送を一度止め、受信側でのCDRによる再同期とレーン間のData Skew(データの受信タイミングのずれ)の補正のためのトレーニング処理を行うものとした場合、伝送効率が低下する。
例えば、トレーニング処理の間は画像データを伝送することができず、トレーニング処理に用いるためのいわば無効なデータを伝送する必要があり、そのような無効なデータを伝送する分だけ、伝送効率が低下することになる。
本技術はこのような状況に鑑みてなされたものであり、データの伝送効率を高めることができるようにするものである。
本技術の第1の側面の送信装置は、伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配する分配部と、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信する複数の信号処理部と、前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御する制御部と、を備え、前記制御部は、前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じた前記データストリームの送信を開始させる。
本技術の第2の側面の受信装置は、伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを複数の前記レーンを用いて並列に送信する送信装置から送信されてきた前記データストリームを受信する複数の信号処理部と、前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御する制御部と、を備え、前記制御部は、前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じて送信された前記データストリームの受信を開始させる。
本技術の第1の側面においては、前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じた前記データストリームの送信が開始される。
本技術の第2の側面においては、前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じて送信された前記データストリームの受信が開始される。
本技術によれば、データの伝送効率を高めることができる。
なお、ここに記載された効果は必ずしも限定されるものではなく、本開示中に記載されたいずれかの効果であってもよい。
伝送システムの第1の構成例を示す図である。 伝送システムの第2の構成例を示す図である。 伝送システムの第3の構成例を示す図である。 フレームフォーマットの例を示す図である。 送信部と受信部の構成例を示す図である。 ヘッダ構造を示す図である。 ヘッダ情報の内容と情報量を示す図である。 ビット配列の例を示す図である。 各画素の画素値が8ビットで表される場合のPixel to Byte変換の例を示す図である。 各画素の画素値が10ビットで表される場合のPixel to Byte変換の例を示す図である。 各画素の画素値が12ビットで表される場合のPixel to Byte変換の例を示す図である。 各画素の画素値が14ビットで表される場合のPixel to Byte変換の例を示す図である。 各画素の画素値が16ビットで表される場合のPixel to Byte変換の例を示す図である。 ペイロードデータの例を示す図である。 ペイロードデータの他の例を示す図である。 パリティが挿入されたペイロードデータの例を示す図である。 ペイロードデータにヘッダを付加した状態を示す図である。 ペイロードデータにヘッダとフッタを付加した状態を示す図である。 パリティが挿入されたペイロードデータにヘッダを付加した状態を示す図である。 パケットデータの割り当ての例を示す図である。 制御コードの例を示す図である。 K Characterの値を示す図である。 Pad Codeの挿入の例を示す図である。 制御コード挿入後のパケットデータの例を示す図である。 Data Skewの補正の例を示す図である。 撮像装置の処理について説明するフローチャートである。 図26のステップS2において行われるデータ送信処理について説明するフローチャートである。 図26のステップS3において行われるデータ受信処理について説明するフローチャートである。 レーン数を切り替える場合の制御シーケンスを示す図である。 フレームフォーマットの他の例を示す図である。 図30のフレームフォーマットの1パケットを拡大して示す図である。 ヘッダ情報の内容を示す図である。 Mode Changeのシーケンスの例を示す図である。 図33の1フレーム目を拡大して示す図である。 Training Sequenceにおいて用いられる制御コードの例を示す図である。 レジスタに設定されるパラメータの例を示す図である。 Mode Change with Standbyのシーケンスの例を示す図である。 イメージセンサの各レイヤ間で用いられる制御信号の例を示す図である。 送信部のリンクレイヤの状態遷移の例を示す図である。 送信部の物理レイヤの状態遷移の例を示す図である。 DSPの各レイヤ間で用いられる制御信号の例を示す図である。 受信部のリンクレイヤの状態遷移の例を示す図である。 受信部の物理レイヤの状態遷移の例を示す図である。 Mode Changeの例を示す図である。 簡易型Mode Changeの例を示す図である。 無効フレームの伝送がある簡易型Mode Changeのシーケンスの例を示す図である。 簡易型Mode Changeが用いられる場合の、送信部のリンクレイヤの状態遷移の例を示す図である。 簡易型Mode Change時の各部の処理について説明するシーケンス図である。 無効フレームの伝送がない簡易型Mode Changeのシーケンスの例を示す図である。 ヘッダに格納される情報の例を示す図である。 リザーブ領域の割り当ての例を示す図である。 Additional Informationの例を示す図である。 簡易型Mode Change時の各部の処理について説明するシーケンス図である。 リザーブ領域の割り当ての他の例を示す図である。 Additional Informationの例を示す図である。 簡易型Mode Change時の各部の処理について説明するシーケンス図である。 コンピュータの構成例を示すブロック図である。 内視鏡手術システムの概略的な構成の一例を示す図である。 図58に示すカメラヘッド及びCCUの機能構成の一例を示すブロック図である。
以下、本技術を実施するための形態について説明する。説明は以下の順序で行う。
1.データ伝送について
2.Mode Changeについて
(1)通常のMode Change
(2)Training Sequenceを省略したMode Change
(3)無効フレームの伝送がない簡易型Mode Change
3.変形例
4.応用例
<1.データ伝送について>
[伝送システムの構成例]
図1は、本技術の一実施形態に係る伝送システムの第1の構成例を示す図である。
図1の伝送システム1は、イメージセンサ11とDSP12から構成される。イメージセンサ11とDSP12はそれぞれ異なるLSI(Large Scale Integrated Circuit)により構成され、デジタルカメラや携帯電話機などの、撮像機能を有する同じ撮像装置内に設けられる。イメージセンサ11には撮像部21と1つの送信部22が設けられ、DSP12には1つの受信部31と画像処理部32が設けられている。
イメージセンサ11の撮像部21は、CMOS(Complementary Metal Oxide Semiconductor)などの撮像素子よりなり、レンズを介して受光した光の光電変換を行う。また、撮像部21は、光電変換によって得られた信号のA/D変換などを行い、1フレームの画像を構成する画素データを、1画素のデータずつ順に送信部22に出力する。
送信部22は、撮像部21から供給された各画素のデータを、例えば撮像部21から供給された順に複数の伝送路に割り当て、複数の伝送路を介して並列にDSP12に送信する。図1の例においては、8本の伝送路を用いて画素データの伝送が行われている。イメージセンサ11とDSP12の間の伝送路は有線の伝送路であってもよいし、無線の伝送路であってもよい。以下、適宜、イメージセンサ11とDSP12の間の伝送路をレーン(Lane)という。
DSP12の受信部31は、8本のレーンを介して送信部22から伝送されてきた画素データを受信し、各画素のデータを順に画像処理部32に出力する。
画像処理部32は、受信部31から供給された画素データに基づいて1フレームの画像を生成し、生成した画像を用いて各種の画像処理を行う。イメージセンサ11からDSP12に伝送される画像データはRAWデータであり、画像処理部32においては、画像データの圧縮、画像の表示、記録媒体に対する画像データの記録などの各種の処理が行われる。
図2は、伝送システム1の第2の構成例を示す図である。図2に示す構成のうち、図1に示す構成と同じ構成には同じ符号を付してある。重複する説明については適宜省略する。
図2の伝送システム1のイメージセンサ11には、撮像部21と、2つの送信部である送信部22-1,22-2が設けられ、DSP12には、2つの受信部である受信部31-1,31-2と、画像処理部32が設けられている。
撮像部21は、撮像を行うことによって得られた1フレームの画像を構成する画素データを、1画素のデータずつ、送信部22-1と送信部22-2に並列に出力する。例えば、撮像部21は、奇数ラインの画素のデータを送信部22-1に出力し、偶数ラインの画素のデータを送信部22-2に出力する。
送信部22-1は、撮像部21から供給された各画素のデータを、例えば撮像部21から供給された順に複数のレーンに割り当て、複数のレーンを介して並列にDSP12に送信する。送信部22-2も同様に、撮像部21から供給された各画素のデータを、例えば撮像部21から供給された順に複数のレーンに割り当て、複数のレーンを介して並列にDSP12に送信する。
図2の例においてもイメージセンサ11とDSP12の間は8本のレーンを介して接続されている。送信部22-1と送信部22-2は、それぞれ、4本のレーンを用いて画素データを伝送する。
DSP12の受信部31-1は、4本のレーンを介して送信部22-1から伝送されてきた画素データを受信し、各画素のデータを順に画像処理部32に出力する。受信部31-2も同様に、4本のレーンを介して送信部22-2から伝送されてきた画素データを受信し、各画素のデータを順に画像処理部32に出力する。
画像処理部32は、受信部31-1から供給された画素データと受信部31-2から供給された画素データに基づいて1フレームの画像を生成し、生成した画像を用いて各種の画像処理を行う。
図2に示すようにイメージセンサ11に2つの送信部を設け、それに対応させて2つの受信部をDSP12に設けることにより、撮像部21が出力する画素データのレートが高い場合であっても画素データをDSP12に伝送することが可能になる。
図3は、伝送システム1の第3の構成例を示す図である。図3に示す構成のうち、図1に示す構成と同じ構成には同じ符号を付してある。重複する説明については適宜省略する。
図3の伝送システム1においては、イメージセンサ11-1とイメージセンサ11-2の2つのイメージセンサが設けられている。イメージセンサ11-1には撮像部21-1と1つの送信部である送信部22-1が設けられ、イメージセンサ11-2には撮像部21-2と1つの送信部である送信部22-2が設けられる。DSP12には、図2の場合と同様に、2つの受信部である受信部31-1,31-2と、画像処理部32が設けられている。
イメージセンサ11-1の撮像部21-1は、撮像を行うことによって得られた1フレームの画像を構成する画素データを、1画素のデータずつ順に送信部22-1に出力する。
送信部22-1は、撮像部21-1から供給された各画素のデータを、例えば撮像部21-1から供給された順に複数のレーンに割り当て、複数のレーンを介して並列にDSP12に送信する。
イメージセンサ11-2の撮像部21-2は、撮像を行うことによって得られた1フレームの画像を構成する画素データを、1画素のデータずつ順に送信部22-2に出力する。
送信部22-2は、撮像部21-2から供給された各画素のデータを、例えば撮像部21-2から供給された順に複数のレーンに割り当て、複数のレーンを介して並列にDSP12に送信する。
図3の例においてもイメージセンサ側とDSP12の間は8本のレーンを介して接続されている。イメージセンサ11-1とイメージセンサ11-2にはそれぞれ4本のレーンが割り当てられ、送信部22-1と送信部22-2は、それぞれ、4本のレーンを用いて画素データを伝送する。
DSP12の受信部31-1は、4本のレーンを介してイメージセンサ11-1の送信部22-1から伝送されてきた画素データを受信し、各画素のデータを順に画像処理部32に出力する。受信部31-2も同様に、4本のレーンを介してイメージセンサ11-2の送信部22-2から伝送されてきた画素データを受信し、各画素のデータを順に画像処理部32に出力する。
画像処理部32は、受信部31-1から供給された画素データに基づいて1フレームの画像を生成するとともに、受信部31-2から供給された画素データに基づいて1フレームの画像を生成する。画像処理部32は、生成した画像を用いて各種の画像処理を行う。
図3に示すように2つのイメージセンサを設けることにより、例えば、イメージセンサ11-1により撮像された左目用の画像と、イメージセンサ11-2により撮像された右目用の画像からなる3D画像を1つのDSP12で処理することが可能になる。左目用の画像と右目用の画像には視差がある。
以上のように、伝送システム1のイメージセンサには、撮像された1フレームの画像データを伝送する送信部が1つまたは複数設けられる。一方、DSPには、イメージセンサの送信部に対応して、イメージセンサから伝送されてきたデータを受信する受信部が1つまたは複数設けられる。
以下、イメージセンサ11に1つの送信部が設けられ、DSP12に1つの受信部が設けられる図1の伝送システム1におけるデータ伝送について説明する。図2と図3の送信部22-1-受信部31-1間、送信部22-2-受信部31-2間においても同様にしてデータ伝送が行われる。
[フレームフォーマット]
図4は、イメージセンサ11-DSP12間で1フレームの画像データを伝送するのに用いられるフォーマットの例を示す図である。
有効画素領域A1は、撮像部21により撮像された1フレームの画像の有効画素の領域である。有効画素領域A1の左側には、垂直方向の画素数が有効画素領域A1の垂直方向の画素数と同じであるマージン領域A2が設定される。
有効画素領域A1の上側には、水平方向の画素数が、有効画素領域A1とマージン領域A2全体の水平方向の画素数と同じである前ダミー領域A3が設定される。図4の例においては、前ダミー領域A3にはEmbedded Dataが挿入されている。Embedded Dataは、シャッタスピード、絞り値、ゲインなどの、撮像部21による撮像に関する設定値の情報が含まれる。後ダミー領域A4にEmbedded Dataが挿入されることもある。
有効画素領域A1の下側には、水平方向の画素数が、有効画素領域A1とマージン領域A2全体の水平方向の画素数と同じである後ダミー領域A4が設定される。
有効画素領域A1、マージン領域A2、前ダミー領域A3、および後ダミー領域A4から画像データ領域A11が構成される。
画像データ領域A11を構成する各ラインの前にはヘッダが付加され、ヘッダの前にはStart Codeが付加される。また、画像データ領域A11を構成する各ラインの後ろにはフッタがオプションで付加され、フッタの後ろにはEnd Codeなどの後述する制御コードが付加される。フッタが付加されない場合、画像データ領域A11を構成する各ラインの後ろにEnd Codeなどの制御コードが付加される。
撮像部21により撮像された1フレームの画像をイメージセンサ11からDSP12に伝送する毎に、図4に示すフォーマットのデータ全体が伝送データとして伝送される。
図4の上側の帯は下側に示す伝送データの伝送に用いられるパケットの構造を示している。水平方向の画素の並びをラインとすると、パケットのペイロードには、画像データ領域A11の1ラインを構成する画素のデータが格納される。1フレームの画像データ全体の伝送は、画像データ領域A11の垂直方向の画素数以上の数のパケットを用いて行われることになる。
1ライン分の画素データが格納されたペイロードに、ヘッダとフッタが付加されることによって1パケットが構成される。後に詳述するように、ヘッダには、Frame Start, Frame End, Line Valid, Line Number, ECCなどの、ペイロードに格納されている画素データの付加的な情報が含まれる。各パケットには、制御コードであるStart CodeとEnd Codeが少なくとも付加される。
このように、1フレームの画像を構成する画素データをライン毎に伝送するフォーマットを採用することによって、ヘッダ等の付加的な情報やStart Code, End Codeなどの制御コードをライン毎のブランキング期間中に伝送することが可能になる。
[送信部22と受信部31の構成]
図5は、送信部22と受信部31の構成例を示す図である。
図5の左側に破線で囲んで示す構成が送信部22の構成であり、右側に破線で囲んで示す構成が受信部31の構成である。送信部22と受信部31は、それぞれ、リンクレイヤの構成と物理レイヤの構成からなる。実線L2より上側に示す構成がリンクレイヤの構成であり、実線L2より下側に示す構成が物理レイヤの構成である。
なお、実線L1の上に示す構成はアプリケーションレイヤの構成である。システム制御部51、フレームデータ入力部52、およびレジスタ53は撮像部21において実現される。システム制御部51は、送信部22のLINK-TXプロトコル管理部61と通信を行い、フレームフォーマットに関する情報を提供するなどして画像データの伝送を制御する。フレームデータ入力部52は、ユーザによる指示などに応じて撮像を行い、撮像を行うことによって得られた画像を構成する各画素のデータを送信部22のPixel to Byte変換部62に供給する。レジスタ53は、Pixel to Byte変換のビット数やLane数等の情報を記憶する。レジスタ53に記憶されている情報に従って画像データの送信処理が行われる。
また、アプリケーションレイヤの構成のうちのフレームデータ出力部141、レジスタ142、およびシステム制御部143は画像処理部32において実現される。フレームデータ出力部141は、受信部31から供給された各ラインの画素データに基づいて1フレームの画像を生成し、出力する。フレームデータ出力部141から出力された画像を用いて各種の処理が行われる。レジスタ142は、Byte to Pixel変換のビット数やLane数などの、画像データの受信に関する各種の設定値を記憶する。レジスタ142に記憶されている情報に従って画像データの受信処理が行われる。システム制御部143は、LINK-RXプロトコル管理部121と通信を行い、モードチェンジ等のシーケンスを制御する。
[送信部22のリンクレイヤの構成]
はじめに、送信部22のリンクレイヤの構成について説明する。
送信部22には、リンクレイヤの構成として、LINK-TXプロトコル管理部61、Pixel to Byte変換部62、ペイロードECC挿入部63、パケット生成部64、およびレーン分配部65が設けられる。LINK-TXプロトコル管理部61は、状態制御部71、ヘッダ生成部72、データ挿入部73、およびフッタ生成部74から構成される。
LINK-TXプロトコル管理部61の状態制御部71は、送信部22のリンクレイヤの状態を管理する。
ヘッダ生成部72は、1ライン分の画素データが格納されたペイロードに付加されるヘッダを生成し、パケット生成部64に出力する。
図6は、ヘッダ生成部72により生成されるヘッダの構造を示す図である。
上述したように、1パケット全体は、ヘッダと、1ライン分の画素データであるペイロードデータから構成される。パケットにはフッタが付加されることもある。ヘッダは、ヘッダ情報とHeader ECCから構成される。
ヘッダ情報には、Frame Start, Frame End, Line Valid, Line Number, Reservedが含まれる。各情報の内容と情報量を図7に示す。
Frame Startは、フレームの先頭を示す1ビットの情報である。図4の画像データ領域A11の1ライン目の画素データの伝送に用いられるパケットのヘッダのFrame Startには1の値が設定され、他のラインの画素データの伝送に用いられるパケットのヘッダのFrame Startには0の値が設定される。
Frame Endは、フレームの終端を示す1ビットの情報である。有効画素領域A1の終端ラインの画素データをペイロードに含むパケットのヘッダのFrame Endには1の値が設定され、他のラインの画素データの伝送に用いられるパケットのヘッダのFrame Endには0の値が設定される。
Frame StartとFrame Endが、フレームに関する情報であるフレーム情報となる。
Line Validは、ペイロードに格納されている画素データのラインが有効画素のラインであるのか否かを表す1ビットの情報である。有効画素領域A1内のラインの画素データの伝送に用いられるパケットのヘッダのLine Validには1の値が設定され、他のラインの画素データの伝送に用いられるパケットのヘッダのLine Validには0の値が設定される。
Line Numberは、ペイロードに格納されている画素データにより構成されるラインのライン番号を表す13ビットの情報である。
Line ValidとLine Numberが、ラインに関する情報であるライン情報となる。
Reservedは拡張用の32ビットの領域である。ヘッダ情報全体のデータ量は6バイトになる。
図6に示すように、ヘッダ情報に続けて配置されるHeader ECCには、6バイトのヘッダ情報に基づいて計算された2バイトの誤り検出符号であるCRC(Cyclic Redundancy Check)符号が含まれる。また、Header ECCには、CRC符号に続けて、ヘッダ情報とCRC符号の組である8バイトの情報と同じ情報が2つ含まれる。
すなわち、1つのパケットのヘッダには、同じヘッダ情報とCRC符号の組が3つ含まれる。ヘッダ全体のデータ量は、1組目のヘッダ情報とCRC符号の組の8バイトと、2組目のヘッダ情報とCRC符号の組の8バイトと、3組目のヘッダ情報とCRC符号の組の8バイトとの、あわせて24バイトになる。
図8は、ヘッダ情報とCRC符号の1つの組を構成する8バイトのビット配列の例を示す図である。
ヘッダを構成する8バイトのうちの1番目の1バイトであるバイトH7には、1ビット目から順に、Frame Start, Frame End, Line Validの各1ビットと、Line Numberの13ビットのうちの1~5ビット目が含まれる。また、2番目の1バイトであるバイトH6には、Line Numberの13ビットのうちの6~13ビット目が含まれる。
3番目の1バイトであるバイトH5から6番目の1バイトであるバイトH2がReservedとなる。7番目の1バイトであるバイトH1と8番目の1バイトであるバイトH0にはCRC符号の各ビットが含まれる。
図5の説明に戻り、ヘッダ生成部72は、システム制御部51による制御に従ってヘッダ情報を生成する。例えば、システム制御部51からは、フレームデータ入力部52が出力する画素データのライン番号を表す情報や、フレームの先頭、終端を表す情報が供給される。
また、ヘッダ生成部72は、ヘッダ情報を生成多項式に適用してCRC符号を計算する。ヘッダ情報に付加されるCRC符号の生成多項式は例えば下式(1)により表される。
Figure 2022076012000002
ヘッダ生成部72は、ヘッダ情報にCRC符号を付加することによってヘッダ情報とCRC符号の組を生成し、同じヘッダ情報とCRC符号の組を3組繰り返して配置することによってヘッダを生成する。ヘッダ生成部72は、生成したヘッダをパケット生成部64に出力する。
データ挿入部73は、スタッフィング(stuffing)に用いられるデータを生成し、Pixel to Byte変換部62とレーン分配部65に出力する。Pixel to Byte変換部62に供給されたスタッフィングデータであるペイロードスタッフィングデータは、Pixel to Byte変換後の画素データに付加され、ペイロードに格納される画素データのデータ量の調整に用いられる。また、レーン分配部65に供給されたスタッフィングデータであるレーンスタッフィングデータは、レーン割り当て後のデータに付加され、レーン間のデータ量の調整に用いられる。
フッタ生成部74は、システム制御部51による制御に応じて、適宜、ペイロードデータを生成多項式に適用して32ビットのCRC符号を計算し、計算により求めたCRC符号をフッタとしてパケット生成部64に出力する。フッタとして付加されるCRC符号の生成多項式は例えば下式(2)により表される。
Figure 2022076012000003
Pixel to Byte変換部62は、フレームデータ入力部52から供給された画素データを取得し、各画素のデータを1バイト単位のデータに変換するPixel to Byte変換を行う。例えば、撮像部21により撮像された画像の各画素の画素値(RGB)は、8ビット、10ビット、12ビット、14ビット、16ビットのうちのいずれかのビット数で表される。
図9は、各画素の画素値が8ビットで表される場合のPixel to Byte変換の例を示す図である。
Data[0]がLSBを表し、数字の最も大きいData[7]がMSBを表す。白抜き矢印で示すように、この場合、画素Nの画素値を表すData[7]~[0]の8ビットは、Data[7]~[0]からなるByte Nに変換される。各画素の画素値が8ビットで表される場合、Pixel to Byte変換後のバイト単位のデータの数は、画素の数と同じ数になる。
図10は、各画素の画素値が10ビットで表される場合のPixel to Byte変換の例を示す図である。
この場合、画素Nの画素値を表すData[9]~[0]の10ビットは、Data[9]~[2]からなるByte 1.25*Nに変換される。
画素N+1~N+3についても同様に、それぞれの画素値を表すData[9]~[0]の10ビットが、Data[9]~[2]からなるByte 1.25*N+1~Byte 1.25*N+3に変換される。また、画素N~N+3のそれぞれの下位のビットであるData[1]とData[0]が集められてByte 1.25*N+4に変換される。各画素の画素値が10ビットで表される場合、Pixel to Byte変換後のバイト単位のデータの数は、画素の数の1.25倍の数になる。
図11は、各画素の画素値が12ビットで表される場合のPixel to Byte変換の例を示す図である。
この場合、画素Nの画素値を表すData[11]~[0]の12ビットは、Data[11]~[4]からなるByte 1.5*Nに変換される。
画素N+1についても同様に、画素N+1の画素値を表すData[11]~[0]の12ビットが、Data[11]~[4]からなるByte 1.5*N+1に変換される。また、画素Nと画素N+1のそれぞれの下位のビットであるData[3]~[0]が集められてByte 1.5*N+2に変換される。各画素の画素値が12ビットで表される場合、Pixel to Byte変換後のバイト単位のデータの数は、画素の数の1.5倍の数になる。
図12は、各画素の画素値が14ビットで表される場合のPixel to Byte変換の例を示す図である。
この場合、画素Nの画素値を表すData[13]~[0]の14ビットは、Data[13]~[6]からなるByte 1.75*Nに変換される。
画素N+1~N+3についても同様に、それぞれの画素値を表すData[13]~[0]の14ビットが、Data[13]~[6]からなるByte 1.75*N+1~Byte 1.75*N+3に変換される。また、画素N~N+3のビットのうちの残ったビットが下位のビットから順に集められ、例えば、画素NのビットであるData[5]~[0]と、画素N+1のビットであるData[5],[4]がByte 1.75*N+4に変換される。
同様に、画素N+1のビットであるData[3]~[0]と、画素N+2のビットであるData[5]~[2]がByte 1.75*N+5に変換され、画素N+2のビットであるData[1],[0]と、画素N+3のビットであるData[5]~[0]がByte 1.75*N+6に変換される。各画素の画素値が14ビットで表される場合、Pixel to Byte変換後のバイト単位のデータの数は、画素の数の1.75倍の数になる。
図13は、各画素の画素値が16ビットで表される場合のPixel to Byte変換の例を示す図である。
この場合、画素Nの画素値を表すData[15]~[0]の16ビットは、Data[15]~[8]からなるByte 2*NとData[7]~[0]からなるByte 2*N+1に変換される。各画素の画素値が16ビットで表される場合、Pixel to Byte変換後のバイト単位のデータの数は、画素の数の2倍の数になる。
図5のPixel to Byte変換部62は、このようなPixel to Byte変換を例えばラインの左端の画素から順に各画素を対象として行う。また、Pixel to Byte変換部62は、Pixel to Byte変換によって得られたバイト単位の画素データに、データ挿入部73から供給されたペイロードスタッフィングデータを付加することによってペイロードデータを生成し、ペイロードECC挿入部63に出力する。
図14は、ペイロードデータの例を示す図である。
図14は、各画素の画素値が10ビットで表される場合のPixel to Byte変換によって得られた画素データを含むペイロードデータを示している。色を付していない1つのブロックが、Pixel to Byte変換後のバイト単位の画素データを表す。また、色を付している1つのブロックが、データ挿入部73により生成されたペイロードスタッフィングデータを表す。
Pixel to Byte変換後の画素データは、変換によって得られた順に、所定の数のグループにグループ化される。図14の例においては、各画素データがグループ0~15の16グループにグループ化されており、画素P0のMSBを含む画素データがグループ0に割り当てられ、画素P1のMSBを含む画素データがグループ1に割り当てられている。また、画素P2のMSBを含む画素データがグループ2に割り当てられ、画素P3のMSBを含む画素データがグループ3に割り当てられ、画素P0~P3のLSBを含む画素データがグループ4に割り当てられている。
画素P4のMSBを含む画素データ以降の画素データについても、グループ5以降の各グループに順に割り当てられる。ある画素データがグループ15に割り当てられたとき、それ以降の画素データは、グループ0以降の各グループに順に割り当てられる。なお、画素データを表すブロックのうち、3本の破線が内側に付されているブロックは、Pixel to Byte変換時に、画素N~N+3のLSBを含むようにして生成されたバイト単位の画素データを表す。
送信部22のリンクレイヤにおいては、このようにしてグループ化が行われた後、クロック信号によって規定される期間毎に、各グループにおいて同じ位置にある画素データを対象として処理が並行して行われる。すなわち、図14に示すように16のグループに画素データが割り当てられた場合、各列に並ぶ16の画素データを同じ期間内に処理するようにして画素データの処理が進められる。
上述したように、1つのパケットのペイロードには1ラインの画素データが含まれる。図14に示す画素データ全体が、1ラインを構成する画素データである。ここでは、図4の有効画素領域A1の画素データの処理について説明しているが、マージン領域A2等の他の領域の画素データについても有効画素領域A1の画素データとともに処理される。
1ライン分の画素データがグループ化された後、各グループのデータ長が同じ長さになるように、ペイロードスタッフィングデータが付加される。ペイロードスタッフィングデータは1バイトのデータである。
図14の例においては、グループ0の画素データにはペイロードスタッフィングデータが付加されず、破線で囲んで示すように、グループ1~15の各画素データには、終端にペイロードスタッフィングデータが1つずつ付加されている。画素データとスタッフィングデータからなるペイロードデータのデータ長(Byte)は下式(3)により表される。
Figure 2022076012000004
式(3)のLineLengthはラインの画素数を表し、BitPixは1画素の画素値を表すビット数を表す。PayloadStuffingはペイロードスタッフィングデータの数を表す。
図14に示すように画素データを16グループに割り当てるとした場合、ペイロードスタッフィングデータの数は下式(4)により表される。式(4)の%は剰余を表す。
Figure 2022076012000005
図15は、ペイロードデータの他の例を示す図である。
図15は、各画素の画素値が12ビットで表される場合のPixel to Byte変換によって得られた画素データを含むペイロードデータを示している。
図15の例においては、画素P0のMSBを含む画素データがグループ0に割り当てられ、画素P1のMSBを含む画素データがグループ1に割り当てられ、画素P0と画素P1のLSBを含む画素データがグループ2に割り当てられている。画素P2のMSBを含む画素データ以降の画素データについても、グループ3以降の各グループに順に割り当てられる。画素データを表すブロックのうち、1本の破線が内側に付されているブロックは、Pixel to Byte変換時に、画素Nと画素N+1のLSBを含むようにして生成されたバイト単位の画素データを表す。
図15の例においては、グループ0とグループ1の画素データにはペイロードスタッフィングデータが付加されず、グループ2~15の各画素データには、終端にペイロードスタッフィングデータが1つずつ付加されている。
このような構成を有するペイロードデータがPixel to Byte変換部62からペイロードECC挿入部63に供給される。
ペイロードECC挿入部63は、Pixel to Byte変換部62から供給されたペイロードデータに基づいて、ペイロードデータの誤り訂正に用いられる誤り訂正符号を計算し、計算により求めた誤り訂正符号であるパリティをペイロードデータに挿入する。誤り訂正符号として、例えばリードソロモン符号が用いられる。なお、誤り訂正符号の挿入はオプションであり、例えば、ペイロードECC挿入部63によるパリティの挿入と、フッタ生成部74によるフッタの付加はいずれか一方のみを行うことが可能とされる。
図16は、パリティが挿入されたペイロードデータの例を示す図である。
図16に示すペイロードデータは、図15を参照して説明した、各画素の画素値が12ビットで表される場合のPixel to Byte変換によって得られた画素データを含むペイロードデータである。斜線を付して示すブロックがパリティを表す。
図16の例においては、グループ0~15の各グループの先頭の画素データから順に14個選択され、選択された224個(224バイト)の画素データに基づいて2バイトのパリティが求められている。2バイトのパリティが、その計算に用いられた224個の画素データに続けてグループ0,1の15番目のデータとして挿入され、224個の画素データと2バイトのパリティから1つ目のBasic Blockが形成される。
このように、ペイロードECC挿入部63においては、基本的に、224個の画素データに基づいて2バイトのパリティが生成され、224個の画素データに続けて挿入される。
また、図16の例においては、1つ目のBasic Blockに続く224個の画素データが各グループから順に選択され、選択された224個の画素データに基づいて2バイトのパリティが求められている。2バイトのパリティが、その計算に用いられた224個の画素データに続けてグループ2,3の29番目のデータとして挿入され、224個の画素データと2バイトのパリティから2つ目のBasic Blockが形成される。
あるBasic Blockに続く画素データとペイロードスタッフィングデータの数である16×Mが224に満たない場合、残っている16×M個のブロック(画素データとペイロードスタッフィングデータ)に基づいて2バイトのパリティが求められる。また、求められた2バイトのパリティがペイロードスタッフィングデータに続けて挿入され、16×M個のブロックと2バイトのパリティからExtra Blockが形成される。
ペイロードECC挿入部63は、パリティを挿入したペイロードデータをパケット生成部64に出力する。パリティの挿入が行われない場合、Pixel to Byte変換部62からペイロードECC挿入部63に供給されたペイロードデータは、そのままパケット生成部64に出力される。
パケット生成部64は、ペイロードECC挿入部63から供給されたペイロードデータに、ヘッダ生成部72により生成されたヘッダを付加することによってパケットを生成する。フッタ生成部74によりフッタの生成が行われている場合、パケット生成部64は、ペイロードデータにフッタを付加することも行う。
図17は、ペイロードデータにヘッダを付加した状態を示す図である。
H7~H0の文字を付して示す24個のブロックは、ヘッダ情報、またはヘッダ情報のCRC符号である、バイト単位のヘッダデータを表す。図6を参照して説明したように1つのパケットのヘッダには、ヘッダ情報とCRC符号の組が3組含まれる。
例えばヘッダデータH7~H2はヘッダ情報(6バイト)であり、ヘッダデータH1,H0はCRC符号(2バイト)である。
図17の例においては、グループ0のペイロードデータには1つのヘッダデータH7が付加され、グループ1のペイロードデータには1つのヘッダデータH6が付加されている。グループ2のペイロードデータには1つのヘッダデータH5が付加され、グループ3のペイロードデータには1つのヘッダデータH4が付加されている。グループ4のペイロードデータには1つのヘッダデータH3が付加され、グループ5のペイロードデータには1つのヘッダデータH2が付加されている。グループ6のペイロードデータには1つのヘッダデータH1が付加され、グループ7のペイロードデータには1つのヘッダデータH0が付加されている。
また、図17の例においては、グループ8のペイロードデータには2つのヘッダデータH7が付加され、グループ9のペイロードデータには2つのヘッダデータH6が付加されている。グループ10のペイロードデータには2つのヘッダデータH5が付加され、グループ11のペイロードデータには2つのヘッダデータH4が付加されている。グループ12のペイロードデータには2つのヘッダデータH3が付加され、グループ13のペイロードデータには2つのヘッダデータH2が付加されている。グループ14のペイロードデータには2つのヘッダデータH1が付加され、グループ15のペイロードデータには2つのヘッダデータH0が付加されている。
図18は、ペイロードデータにヘッダとフッタを付加した状態を示す図である。
F3~F0の文字を付して示す4個のブロックは、フッタとして生成された4バイトのCRC符号であるフッタデータを表す。図18の例においては、フッタデータF3~F0が、グループ0からグループ3のそれぞれのペイロードデータに付加されている。
図19は、パリティが挿入されたペイロードデータにヘッダを付加した状態を示す図である。
図19の例においては、パリティが挿入された図16のペイロードデータに対して、図17、図18の場合と同様にヘッダデータH7~H0が付加されている。
パケット生成部64は、このようにして生成した1パケットを構成するデータであるパケットデータをレーン分配部65に出力する。レーン分配部65に対しては、ヘッダデータとペイロードデータからなるパケットデータ、ヘッダデータとペイロードデータとフッタデータからなるパケットデータ、または、ヘッダデータと、パリティが挿入されたペイロードデータからなるパケットデータが供給されることになる。図6のパケット構造は論理的なものであり、リンクレイヤ、物理レイヤにおいては、図6の構造を有するパケットのデータがバイト単位で処理される。
レーン分配部65は、パケット生成部64から供給されたパケットデータを、先頭のデータから順に、Lane0~7のうちのデータ伝送に用いる各レーンに割り当てる。
図20は、パケットデータの割り当ての例を示す図である。
ここでは、ヘッダデータとペイロードデータとフッタデータからなるパケットデータ(図18)の割り当てについて説明する。Lane0~7の8レーンを用いてデータ伝送を行う場合のパケットデータの割り当ての例を白抜き矢印#1の先に示す。
この場合、ヘッダデータH7~H0の3回繰り返しを構成するそれぞれのヘッダデータは、先頭のヘッダデータから順にLane0~7に割り当てられる。あるヘッダデータがLane7に割り当てられたとき、それ以降のヘッダデータは、Lane0以降の各レーンに順に割り当てられる。Lane0~7の各レーンには同じヘッダデータが3個ずつ割り当てられることになる。
また、ペイロードデータは、先頭のペイロードデータから順にLane0~7に割り当てられる。あるペイロードデータがLane7に割り当てられたとき、それ以降のペイロードデータは、Lane0以降の各レーンに順に割り当てられる。
フッタデータF3~F0は、先頭のフッタデータから順に各レーンに割り当てられる。図20の例においては、ペイロードデータを構成する最後のペイロードスタッフィングデータがLane7に割り当てられており、フッタデータF3~F0がLane0~3に1つずつ割り当てられている。
黒色を付して示すブロックはデータ挿入部73により生成されたレーンスタッフィングデータを表す。レーンスタッフィングデータは、1パケット分のパケットデータが各レーンに割り当てられた後、各レーンに割り当てられるデータ長が同じ長さになるように、データの数が少ないレーンに割り当てられる。レーンスタッフィングデータは1バイトのデータである。図20の例においては、データの割り当て数の少ないレーンであるLane4~7に対して、レーンスタッフィングデータが1つずつ割り当てられている。
パケットデータがヘッダデータとペイロードデータとフッタデータからなる場合のレーンスタッフィングデータの数は下式(5)により表される。
Figure 2022076012000006
式(5)のLaneNumはレーンの数を表し、PayloadLengthはペイロードデータ長(バイト)を表す。また、FooterLengthはフッタ長(バイト)を表す。
また、パケットデータが、ヘッダデータと、パリティが挿入されたペイロードデータからなる場合のレーンスタッフィングデータの数は下式(6)により表される。式(6)のParityLengthは、ペイロードに含まれるパリティの総バイト数を表す。
Figure 2022076012000007
Lane0~5の6レーンを用いてデータ伝送を行う場合のパケットデータの割り当ての例を白抜き矢印#2の先に示す。
この場合、ヘッダデータH7~H0の3回繰り返しを構成するそれぞれのヘッダデータは、先頭のヘッダデータから順にLane0~5に割り当てられる。あるヘッダデータがLane5に割り当てられたとき、それ以降のヘッダデータは、Lane0以降の各レーンに順に割り当てられる。Lane0~5の各レーンには4個ずつヘッダデータが割り当てられることになる。
また、ペイロードデータは、先頭のペイロードデータから順にLane0~5に割り当てられる。あるペイロードデータがLane5に割り当てられたとき、それ以降のペイロードデータは、Lane0以降の各レーンに順に割り当てられる。
フッタデータF3~F0は、先頭のフッタデータから順に各レーンに割り当てられる。図20の例においては、ペイロードデータを構成する最後のペイロードスタッフィングデータがLane1に割り当てられており、フッタデータF3~F0がLane2~5に1つずつ割り当てられている。Lane0~5のパケットデータの数が同じ数であるから、この場合、レーンスタッフィングデータは用いられない。
Lane0~3の4レーンを用いてデータ伝送を行う場合のパケットデータの割り当ての例を白抜き矢印#3の先に示す。
この場合、ヘッダデータH7~H0の3回繰り返しを構成するそれぞれのヘッダデータは、先頭のヘッダデータから順にLane0~3に割り当てられる。あるヘッダデータがLane3に割り当てられたとき、それ以降のヘッダデータは、Lane0以降の各レーンに順に割り当てられる。Lane0~3の各レーンには6個ずつヘッダデータが割り当てられることになる。
また、ペイロードデータは、先頭のペイロードデータから順にLane0~3に割り当てられる。あるペイロードデータがLane3に割り当てられたとき、それ以降のペイロードデータは、Lane0以降の各レーンに順に割り当てられる。
フッタデータF3~F0は、先頭のフッタデータから順に各レーンに割り当てられる。図20の例においては、ペイロードデータを構成する最後のペイロードスタッフィングデータがLane3に割り当てられており、フッタデータF3~F0がLane0~3に1つずつ割り当てられている。Lane0~3のパケットデータの数が同じ数であるから、この場合、レーンスタッフィングデータは用いられない。
レーン分配部65は、このようにして各レーンに割り当てたパケットデータを物理レイヤに出力する。以下、Lane0~7の8レーンを用いてデータを伝送する場合について主に説明するが、データ伝送に用いるレーンの数が他の数の場合であっても同様の処理が行われる。
[送信部22の物理レイヤの構成]
次に、送信部22の物理レイヤの構成について説明する。
送信部22には、物理レイヤの構成として、PHY-TX状態制御部81、クロック生成部82、信号処理部83-0乃至83-Nが設けられる。信号処理部83-0は、制御コード挿入部91、8B10Bシンボルエンコーダ92、同期部93、および送信部94から構成される。レーン分配部65から出力された、Lane0に割り当てられたパケットデータは信号処理部83-0に入力され、Lane1に割り当てられたパケットデータは信号処理部83-1に入力される。また、LaneNに割り当てられたパケットデータは信号処理部83-Nに入力される。
このように、送信部22の物理レイヤには、信号処理部83-0乃至83-Nがレーンの数と同じ数だけ設けられ、各レーンを用いて伝送するパケットデータの処理が、信号処理部83-0乃至83-Nのそれぞれにおいて並行して行われる。信号処理部83-0の構成について説明するが、信号処理部83-1乃至83-Nも同様の構成を有する。
PHY-TX状態制御部81は、信号処理部83-0乃至83-Nの各部を制御する。例えば、信号処理部83-0乃至83-Nにより行われる各処理のタイミングがPHY-TX状態制御部81により制御される。
クロック生成部82は、クロック信号を生成し、信号処理部83-0乃至83-Nのそれぞれの同期部93に出力する。
信号処理部83-0の制御コード挿入部91は、レーン分配部65から供給されたパケットデータに対して制御コードを付加する。制御コードは、予め用意された複数種類のシンボルの中から選択された1つのシンボルにより、または複数種類のシンボルの組み合わせにより表されるコードである。制御コード挿入部91により挿入される各シンボルは8ビットのデータである。後段の回路で8B10B変換が施されることによって、制御コード挿入部91により挿入された1シンボルは10ビットのデータになる。一方、受信部31においては後述するように受信データに対して10B8B変換が施されるが、受信データに含まれる10B8B変換前の各シンボルは10ビットのデータであり、10B8B変換後の各シンボルは8ビットのデータになる。
図21は、制御コード挿入部91により付加される制御コードの例を示す図である。
制御コードには、Idle Code, Start Code, End Code, Pad Code, Sync Code, Deskew Code, Standby Codeがある。
Idle Codeは、パケットデータの伝送時以外の期間に繰り返し送信されるシンボル群である。Idle Codeは、8B10B CodeであるD CharacterのD00.0(00000000)で表される。
Start Codeは、パケットの開始を示すシンボル群である。上述したように、Start Codeはパケットの前に付加される。Start Codeは、3種類のK Characterの組み合わせであるK28.5, K27.7, K28.2, K27.7の4シンボルで表される。それぞれのK Characterの値を図22に示す。
End Codeは、パケットの終了を示すシンボル群である。上述したように、End Codeはパケットの後ろに付加される。End Codeは、3種類のK Characterの組み合わせであるK28.5, K29.7, K30.7, K29.7の4シンボルで表される。
Pad Codeは、画素データ帯域とPHY伝送帯域の差を埋めるためにペイロードデータ中に挿入されるシンボル群である。画素データ帯域は、撮像部21から出力され、送信部22に入力される画素データの伝送レートであり、PHY伝送帯域は、送信部22から送信され、受信部31に入力される画素データの伝送レートである。Pad Codeは、4種類のK Characterの組み合わせであるK23.7, K28.4, K28.6, K28.3の4シンボルで表される。
図23は、Pad Codeの挿入の例を示す図である。
図23の上段は、Pad Code挿入前の、各レーンに割り当てられたペイロードデータを示し、下段は、Pad Code挿入後のペイロードデータを示す。図23の例においては、先頭から3番目の画素データと4番目の画素データの間、6番目の画素データと7番目の画素データの間、12番目の画素データと13番目の画素データの間にPad Codeが挿入されている。このように、Pad Codeは、Lane0~7の各レーンのペイロードデータの同じ位置に挿入される。
Lane0に割り当てられたペイロードデータに対するPad Codeの挿入は信号処理部83-0の制御コード挿入部91により行われる。他のレーンに割り当てられたペイロードデータに対するPad Codeの挿入も同様に、信号処理部83-1乃至83-Nにおいてそれぞれ同じタイミングで行われる。Pad Codeの数は、画素データ帯域とPHY伝送帯域の差と、クロック生成部82が生成するクロック信号の周波数などに基づいて決定される。
このように、Pad Codeは、画素データ帯域が狭く、PHY伝送帯域が広い場合に、双方の帯域の差を調整するために挿入される。例えば、Pad Codeが挿入されることによって、画素データ帯域とPHY伝送帯域の差が一定の範囲内に収まるように調整される。
図21の説明に戻り、Sync Codeは、送信部22-受信部31間のビット同期、シンボル同期を確保するために用いられるシンボル群である。Sync Codeは、K28.5, Any**の2シンボルで表される。Any**は、どの種類のシンボルが用いられてもよいことを表す。Sync Codeは、例えば送信部22-受信部31間でパケットデータの伝送が開始される前のトレーニングモード時に繰り返し送信される。
Deskew Codeは、レーン間のData Skew、すなわち、受信部31の各レーンで受信されるデータの受信タイミングのずれの補正に用いられるシンボル群である。Deskew Codeは、K28.5, Any**の2シンボルで表される。Deskew Codeを用いたレーン間のData Skewの補正については後述する。
Standby Codeは、送信部22の出力がHigh-Z(ハイインピーダンス)などの状態になり、データ伝送が行われなくなることを受信部31に通知するために用いられるシンボル群である。すなわち、Standby Codeは、パケットデータの伝送を終了し、Standby状態になるときに受信部31に対して伝送される。Standby Codeは、K28.5, Any**の2シンボルで表される。
制御コード挿入部91は、このような制御コードを付加したパケットデータを8B10Bシンボルエンコーダ92に出力する。
図24は、制御コード挿入後のパケットデータの例を示す図である。
図24に示すように、信号処理部83-0乃至83-Nにおいては、それぞれ、パケットデータの前にStart Codeが付加され、ペイロードデータにPad Codeが挿入される。パケットデータの後ろにはEnd Codeが付加され、End Codeの後ろにDeskew Codeが付加される。図24の例においては、Deskew Codeの後ろにIdle Codeが付加されている。
8B10Bシンボルエンコーダ92は、制御コード挿入部91から供給されたパケットデータ(制御コードが付加されたパケットデータ)に対して8B10B変換を施し、10ビット単位のデータに変換したパケットデータを同期部93に出力する。
同期部93は、8B10Bシンボルエンコーダ92から供給されたパケットデータの各ビットを、クロック生成部82により生成されたクロック信号に従って送信部94に出力する。なお、送信部22に同期部93が設けられないようにしてもよい。この場合、8B10Bシンボルエンコーダ92から出力されたパケットデータは、送信部94にそのまま供給される。
送信部94は、Lane0を構成する伝送路を介して、同期部93から供給されたパケットデータを受信部31に送信する。8レーンを用いてデータ伝送が行われる場合、Lane1~7を構成する伝送路をも用いてパケットデータが受信部31に送信される。
[受信部31の物理レイヤの構成]
次に、受信部31の物理レイヤの構成について説明する。
受信部31には、物理レイヤの構成として、PHY-RX状態制御部101、信号処理部102-0乃至102-Nが設けられる。信号処理部102-0は、受信部111、クロック生成部112、同期部113、シンボル同期部114、10B8Bシンボルデコーダ115、スキュー補正部116、および制御コード除去部117から構成される。Lane0を構成する伝送路を介して送信されてきたパケットデータは信号処理部102-0に入力され、Lane1を構成する伝送路を介して送信されてきたパケットデータは信号処理部102-1に入力される。また、LaneNを構成する伝送路を介して送信されてきたパケットデータは信号処理部102-Nに入力される。
このように、受信部31の物理レイヤには、信号処理部102-0乃至102-Nがレーンの数と同じ数だけ設けられ、各レーンを用いて伝送されてきたパケットデータの処理が、信号処理部102-0乃至102-Nのそれぞれにおいて並行して行われる。信号処理部102-0の構成について説明するが、信号処理部102-1乃至102-Nも同様の構成を有する。
受信部111は、Lane0を構成する伝送路を介して送信部22から伝送されてきたパケットデータを表す信号を受信し、クロック生成部112に出力する。
クロック生成部112は、受信部111から供給された信号のエッジを検出することによってビット同期をとり、エッジの検出周期に基づいてクロック信号を生成する。クロック生成部112は、受信部111から供給された信号を、クロック信号とともに同期部113に出力する。
同期部113は、クロック生成部112により生成されたクロック信号に従って、受信部111において受信された信号のサンプリングを行い、サンプリングによって得られたパケットデータをシンボル同期部114に出力する。クロック生成部112と同期部113によりCDR(Clock Data Recovery)の機能が実現される。
シンボル同期部114は、パケットデータに含まれる制御コードを検出することによって、または制御コードに含まれる一部のシンボルを検出することによってシンボル同期をとる。例えば、シンボル同期部114は、Start Code, End Code, Deskew Codeに含まれるK28.5のシンボルを検出し、シンボル同期をとる。シンボル同期部114は、各シンボルを表す10ビット単位のパケットデータを10B8Bシンボルデコーダ115に出力する。
また、シンボル同期部114は、パケットデータの伝送が開始される前のトレーニングモード時に送信部22から繰り返し送信されてくるSync Codeに含まれるシンボルの境界を検出することによってシンボル同期をとる。
10B8Bシンボルデコーダ115は、シンボル同期部114から供給された10ビット単位のパケットデータに対して10B8B変換を施し、8ビット単位のデータに変換したパケットデータをスキュー補正部116に出力する。
スキュー補正部116は、10B8Bシンボルデコーダ115から供給されたパケットデータからDeskew Codeを検出する。スキュー補正部116によるDeskew Codeの検出タイミングの情報はPHY-RX状態制御部101に供給される。
また、スキュー補正部116は、Deskew Codeのタイミングを、PHY-RX状態制御部101から供給された情報により表されるタイミングに合わせるようにしてレーン間のData Skewを補正する。PHY-RX状態制御部101からは、信号処理部102-0乃至102-Nのそれぞれにおいて検出されたDeskew Codeのタイミングのうち、最も遅いタイミングを表す情報が供給されてくる。
図25は、Deskew Codeを用いたレーン間のData Skewの補正の例を示す図である。
図25の例においては、Lane0~7の各レーンにおいて、Sync Code, Sync Code,…,Idle Code, Deskew Code, Idle Code, …, Idle Code, Deskew Codeの伝送が行われ、それぞれの制御コードが受信部31において受信されている。同じ制御コードの受信タイミングがレーン毎に異なり、レーン間のData Skewが生じている状態になっている。
この場合、スキュー補正部116は、1つ目のDeskew CodeであるDeskew Code C1を検出し、Deskew Code C1の先頭のタイミングを、PHY-RX状態制御部101から供給された情報により表される時刻t1に合わせるように補正する。PHY-RX状態制御部101からは、Lane0~7の各レーンにおいてDeskew Code C1が検出されたタイミングのうち、最も遅いタイミングであるLane7においてDeskew Code C1が検出された時刻t1の情報が供給されてくる。
また、スキュー補正部116は、2つ目のDeskew CodeであるDeskew Code C2を検出し、Deskew Code C2の先頭のタイミングを、PHY-RX状態制御部101から供給された情報により表される時刻t2に合わせるように補正する。PHY-RX状態制御部101からは、Lane0~7の各レーンにおいてDeskew Code C2が検出されたタイミングのうち、最も遅いタイミングであるLane7においてDeskew Code C2が検出された時刻t2の情報が供給されてくる。
信号処理部102-1乃至102-Nのそれぞれにおいて同様の処理が行われることによって、図25の矢印#1の先に示すようにレーン間のData Skewが補正される。
スキュー補正部116は、Data Skewを補正したパケットデータを制御コード除去部117に出力する。
制御コード除去部117は、パケットデータに付加された制御コードを除去し、Start CodeからEnd Codeまでの間のデータをパケットデータとしてリンクレイヤに出力する。
PHY-RX状態制御部101は、信号処理部102-0乃至102-Nの各部を制御し、レーン間のData Skewの補正などを行わせる。また、PHY-RX状態制御部101は、所定のレーンで伝送エラーが起きて制御コードが失われた場合、失われた制御コードに代えて、他のレーンで伝送されてきた制御コードを付加することによって制御コードの誤り訂正を行う。
[受信部31のリンクレイヤの構成]
次に、受信部31のリンクレイヤの構成について説明する。
受信部31には、リンクレイヤの構成として、LINK-RXプロトコル管理部121、レーン統合部122、パケット分離部123、ペイロードエラー訂正部124、およびByte to Pixel変換部125が設けられる。LINK-RXプロトコル管理部121は、状態制御部131、ヘッダエラー訂正部132、データ除去部133、およびフッタエラー検出部134から構成される。
レーン統合部122は、物理レイヤの信号処理部102-0乃至102-Nから供給されたパケットデータを、送信部22のレーン分配部65による各レーンへの分配順と逆順で並び替えることによって統合する。
例えば、レーン分配部65によるパケットデータの分配が図20の矢印#1の先に示すようにして行われている場合、各レーンのパケットデータの統合が行われることによって図20の左側のパケットデータが取得される。各レーンのパケットデータの統合時、データ除去部133による制御に従って、レーンスタッフィングデータがレーン統合部122により除去される。レーン統合部122は、統合したパケットデータをパケット分離部123に出力する。
パケット分離部123は、レーン統合部122により統合された1パケット分のパケットデータを、ヘッダデータを構成するパケットデータとペイロードデータを構成するパケットデータに分離する。パケット分離部123は、ヘッダデータをヘッダエラー訂正部132に出力し、ペイロードデータをペイロードエラー訂正部124に出力する。
また、パケット分離部123は、パケットにフッタが含まれている場合、1パケット分のデータを、ヘッダデータを構成するパケットデータとペイロードデータを構成するパケットデータとフッタデータを構成するパケットデータに分離する。パケット分離部123は、ヘッダデータをヘッダエラー訂正部132に出力し、ペイロードデータをペイロードエラー訂正部124に出力する。また、パケット分離部123は、フッタデータをフッタエラー検出部134に出力する。
ペイロードエラー訂正部124は、パケット分離部123から供給されたペイロードデータにパリティが挿入されている場合、パリティに基づいて誤り訂正演算を行うことによってペイロードデータのエラーを検出し、検出したエラーの訂正を行う。例えば、図16に示すようにしてパリティが挿入されている場合、ペイロードエラー訂正部124は、1つ目のBasic Blockの最後に挿入されている2つのパリティを用いて、パリティの前にある224個の画素データの誤り訂正を行う。
ペイロードエラー訂正部124は、各Basic Block, Extra Blockを対象として誤り訂正を行うことによって得られた誤り訂正後の画素データをByte to Pixel変換部125に出力する。パケット分離部123から供給されたペイロードデータにパリティが挿入されていない場合、パケット分離部123から供給されたペイロードデータはそのままByte to Pixel変換部125に出力される。
Byte to Pixel変換部125は、ペイロードエラー訂正部124から供給されたペイロードデータに含まれるペイロードスタッフィングデータをデータ除去部133による制御に従って除去する。
また、Byte to Pixel変換部125は、ペイロードスタッフィングデータを除去して得られたバイト単位の各画素のデータを、8ビット、10ビット、12ビット、14ビット、または16ビット単位の画素データに変換するByte to Pixel変換を行う。Byte to Pixel変換部125においては、図9乃至図13を参照して説明した、送信部22のPixel to Byte変換部62によるPixel to Byte変換と逆の変換が行われる。
Byte to Pixel変換部125は、Byte to Pixel変換によって得られた8ビット、10ビット、12ビット、14ビット、または16ビット単位の画素データをフレームデータ出力部141に出力する。フレームデータ出力部141においては、例えば、ヘッダ情報のLine Validにより特定される有効画素の各ラインがByte to Pixel変換部125により得られた画素データに基づいて生成され、ヘッダ情報のLine Numberに従って各ラインが並べられることによって1フレームの画像が生成される。
LINK-RXプロトコル管理部121の状態制御部131は、受信部31のリンクレイヤの状態を管理する。
ヘッダエラー訂正部132は、パケット分離部123から供給されたヘッダデータに基づいてヘッダ情報とCRC符号の組を3組取得する。ヘッダエラー訂正部132は、ヘッダ情報とCRC符号の組の各組を対象として、ヘッダ情報のエラーを検出するための演算である誤り検出演算を、そのヘッダ情報と同じ組のCRC符号を用いて行う。
また、ヘッダエラー訂正部132は、それぞれの組のヘッダ情報の誤り検出結果と、誤り検出演算により求められたデータの比較結果とのうちの少なくともいずれかに基づいて正しいヘッダ情報を推測し、正しいと推測したヘッダ情報と復号結果を出力する。誤り検出演算により求められたデータは、ヘッダ情報にCRCの生成多項式を適用することによって求められた値である。また、復号結果は、復号成功または復号失敗を表す情報である。
ヘッダ情報とCRC符号の3つの組をそれぞれ組1、組2、組3とする。この場合、ヘッダエラー訂正部132は、組1を対象とした誤り検出演算によって、組1のヘッダ情報にエラーがあるか否か(誤り検出結果)と、誤り検出演算により求められたデータであるデータ1を取得する。また、ヘッダエラー訂正部132は、組2を対象とした誤り検出演算によって、組2のヘッダ情報にエラーがあるか否かと、誤り検出演算により求められたデータであるデータ2を取得する。ヘッダエラー訂正部132は、組3を対象とした誤り検出演算によって、組3のヘッダ情報にエラーがあるか否かと、誤り検出演算により求められたデータであるデータ3を取得する。
また、ヘッダエラー訂正部132は、データ1とデータ2が一致するか否か、データ2とデータ3が一致するか否か、データ3とデータ1が一致するか否かをそれぞれ判定する。
例えば、ヘッダエラー訂正部132は、組1、組2、組3を対象としたいずれの誤り検出演算によっても誤りが検出されず、誤り検出演算によって求められたデータのいずれの比較結果もが一致した場合、復号結果として、復号成功を表す情報を選択する。また、ヘッダエラー訂正部132は、いずれのヘッダ情報も正しいと推測し、組1のヘッダ情報、組2のヘッダ情報、組3のヘッダ情報のうちのいずれかを出力情報として選択する。
一方、ヘッダエラー訂正部132は、組1を対象とした誤り検出演算でだけ誤りが検出されなかった場合、復号結果として、復号成功を表す情報を選択するとともに、組1のヘッダ情報が正しいと推測し、組1のヘッダ情報を出力情報として選択する。
また、ヘッダエラー訂正部132は、組2を対象とした誤り検出演算でだけ誤りが検出されなかった場合、復号結果として、復号成功を表す情報を選択するとともに、組2のヘッダ情報が正しいと推測し、組2のヘッダ情報を出力情報として選択する。
ヘッダエラー訂正部132は、組3を対象とした誤り検出演算でだけ誤りが検出されなかった場合、復号結果として、復号成功を表す情報を選択するとともに、組3のヘッダ情報が正しいと推測し、組3のヘッダ情報を出力情報として選択する。
ヘッダエラー訂正部132は、以上のようにして選択した復号結果と出力情報をレジスタ142に出力し、記憶させる。このように、ヘッダエラー訂正部132によるヘッダ情報の誤り訂正は、複数のヘッダ情報の中から、エラーのないヘッダ情報をCRC符号を用いて検出し、検出したヘッダ情報を出力するようにして行われる。
データ除去部133は、レーン統合部122を制御してレーンスタッフィングデータを除去し、Byte to Pixel変換部125を制御してペイロードスタッフィングデータを除去する。
フッタエラー検出部134は、パケット分離部123から供給されたフッタデータに基づいて、フッタに格納されたCRC符号を取得する。フッタエラー検出部134は、取得したCRC符号を用いて誤り検出演算を行い、ペイロードデータのエラーを検出する。フッタエラー検出部134は、誤り検出結果を出力し、レジスタ142に記憶させる。
[イメージセンサ11とDSP12の動作]
次に、以上のような構成を有する送信部22と受信部31の一連の処理について説明する。
はじめに、図26のフローチャートを参照して、伝送システム1を有する撮像装置の動作について説明する。図26の処理は、例えば、撮像装置に設けられたシャッタボタンが押されるなどして撮像の開始が指示されたときに開始される。
ステップS1において、イメージセンサ11の撮像部21は撮像を行う。撮像部21のフレームデータ入力部52(図5)は、撮像によって得られた1フレームの画像を構成する画素データを、1画素のデータずつ順に出力する。
ステップS2において、送信部22によりデータ送信処理が行われる。データ送信処理により、1ライン分の画素データをペイロードに格納したパケットが生成され、パケットを構成するパケットデータが受信部31に対して送信される。データ送信処理については図27のフローチャートを参照して後述する。
ステップS3において、受信部31によりデータ受信処理が行われる。データ受信処理により、送信部22から送信されてきたパケットデータが受信され、ペイロードに格納されている画素データが画像処理部32に出力される。データ受信処理については図28のフローチャートを参照して後述する。
ステップS2において送信部22により行われるデータ送信処理と、ステップS3において受信部31により行われるデータ受信処理は、1ライン分の画素データを対象として交互に行われる。すなわち、ある1ラインの画素データがデータ送信処理によって送信されたとき、データ受信処理が行われ、データ受信処理によって1ラインの画素データが受信されたとき、次の1ラインの画素データを対象としてデータ送信処理が行われる。送信部22によるデータ送信処理と、受信部31によるデータ受信処理は、適宜、時間的に並行して行われることもある。ステップS4において、画像処理部32のフレームデータ出力部141は、1フレームの画像を構成する全てのラインの画素データの送受信が終了したか否かを判定し、終了していないと判定した場合、ステップS2以降の処理を繰り返し行わせる。
1フレームの画像を構成する全てのラインの画素データの送受信が終了したとステップS4において判定した場合、ステップS5において、画像処理部32のフレームデータ出力部141は、受信部31から供給された画素データに基づいて1フレームの画像を生成する。
ステップS6において、画像処理部32は、1フレームの画像を用いて画像処理を行い、処理を終了させる。
次に、図27のフローチャートを参照して、図26のステップS2において行われるデータ送信処理について説明する。
ステップS11において、ヘッダ生成部72は、Frame Start, Frame End, Line Valid, Line Number, Reservedからなるヘッダ情報を生成する。
ステップS12において、ヘッダ生成部72は、ヘッダ情報を生成多項式に適用してCRC符号を計算する。
ステップS13において、ヘッダ生成部72は、ヘッダ情報にCRC符号を付加することによってヘッダ情報とCRC符号の組を生成し、同じヘッダ情報とCRC符号の組を3組繰り返して配置することによってヘッダを生成する。
ステップS14において、Pixel to Byte変換部62は、フレームデータ入力部52から供給された画素データを取得し、Pixel to Byte変換を行う。Pixel to Byte変換部62は、Pixel to Byte変換によって得られたバイト単位の画素データのグループ化、ペイロードスタッフィングデータの付加などを行うことによって生成したペイロードデータを出力する。ペイロードデータに対しては、適宜、ペイロードECC挿入部63によりパリティが挿入される。
ステップS15において、パケット生成部64は、1ライン分の画素データを含むペイロードデータと、ヘッダ生成部72により生成されたヘッダに基づいてパケットを生成し、1パケットを構成するパケットデータを出力する。
ステップS16において、レーン分配部65は、パケット生成部64から供給されたパケットデータを、データ伝送に用いられる複数のレーンに割り当てる。
ステップS17において、制御コード挿入部91は、レーン分配部65から供給されたパケットデータに制御コードを付加する。
ステップS18において、8B10Bシンボルエンコーダ92は、制御コードが付加されたパケットデータの8B10B変換を行い、10ビット単位のデータに変換したパケットデータを出力する。
ステップS19において、同期部93は、8B10Bシンボルエンコーダ92から供給されたパケットデータを、クロック生成部82により生成されたクロック信号に従って出力し、送信部94から送信させる。ステップS17乃至S19の処理は信号処理部83-0乃至83-Nにより並行して行われる。1ライン分の画素データの送信が終了したとき、図26のステップS2に戻りそれ以降の処理が行われる。
次に、図28のフローチャートを参照して、図26のステップS3において行われるデータ受信処理について説明する。
ステップS31において、受信部111は、送信部22から伝送されてきたパケットデータを表す信号を受信する。ステップS31乃至S36の処理は信号処理部102-0乃至102-Nにより並行して行われる。
ステップS32において、クロック生成部112は、受信部111から供給された信号のエッジを検出することによってビット同期をとる。同期部113は、受信部111において受信された信号のサンプリングを行い、パケットデータをシンボル同期部114に出力する。
ステップS33において、シンボル同期部114は、パケットデータに含まれる制御コードを検出するなどしてシンボル同期をとる。
ステップS34において、10B8Bシンボルデコーダ115は、シンボル同期後のパケットデータに対して10B8B変換を施し、8ビット単位のデータに変換したパケットデータを出力する。
ステップS35において、スキュー補正部116は、Deskew Codeを検出し、上述したように、Deskew CodeのタイミングをPHY-RX状態制御部101から供給された情報により表されるタイミングに合わせるようにしてレーン間のData Skewを補正する。
ステップS36において、制御コード除去部117は、パケットデータに付加された制御コードを除去する。
ステップS37において、レーン統合部122は、信号処理部102-0乃至102-Nから供給されたパケットデータを統合する。
ステップS38において、パケット分離部123は、レーン統合部122により統合されたパケットデータを、ヘッダデータを構成するパケットデータとペイロードデータを構成するパケットデータに分離する。
ステップS39において、ヘッダエラー訂正部132は、パケット分離部123により分離されたヘッダデータに含まれるヘッダ情報とCRC符号の各組を対象としてCRC符号を用いた誤り検出演算を行う。また、ヘッダエラー訂正部132は、各組の誤り検出結果と、誤り検出演算により求められたデータの比較結果とに基づいてエラーのないヘッダ情報を選択し、出力する。
ステップS40において、Byte to Pixel変換部125は、ペイロードデータのByte to Pixel変換を行い、8ビット、10ビット、12ビット、14ビット、または16ビット単位の画素データを出力する。Byte to Pixel変換の対象となるペイロードデータに対しては、適宜、パリティを用いた誤り訂正がペイロードエラー訂正部124により行われる。
1ライン分の画素データの処理が終了したとき、図26のステップS3に戻りそれ以降の処理が行われる。
イメージセンサ11とDSP12の間でのデータ伝送は、以上のように、1フレームの1ラインが1パケットに相当するパケットフォーマットを用いて行われる。
イメージセンサ11とDSP12間のデータ伝送に用いられるパケットフォーマットは、ヘッダ情報や、Start Code, End Code等のパケット境界を示す制御コードの伝送を最小限に抑えるフォーマットといえ、伝送効率の低下を防ぐことが可能になる。仮に、1パケットのペイロードに格納される画素データが1ラインより少ないパケットフォーマットを採用した場合、1フレーム全体の画素データを伝送するためにはより多くのパケットを伝送する必要があり、伝送するヘッダ情報や制御コードの数が多くなる分、伝送効率が低下してしまう。
また、伝送効率の低下を防ぐことによって伝送レイテンシを抑えることが可能となり、大量の画像データを高速に伝送する必要がある高画素・高フレームレートのインタフェースを実現することができる。
伝送の信頼度/冗長度を上げて受信部31側で誤り訂正を行うことを前提にしたパケットフォーマットを採用することによって、ヘッダ情報の伝送エラー対策を確保することが可能になる。Frame/Line(V/H)の同期情報等の伝送がヘッダ情報を用いて行われるため、ヘッダ情報が伝送エラーで失われると、システム上、大きな不具合となる可能性があるが、そのようなことを防ぐことができる。
また、ヘッダ情報の伝送エラー対策を確保するための実装コストや消費電力の増大を抑えることもできる。すなわち、イメージセンサ11とDSP12間のデータ伝送に用いられるパケットフォーマットは、CRC符号が付加されていることで、ヘッダ情報の伝送エラーの有無をDSP12において検出することができるようになっている。また、ヘッダ情報とCRC符号の組を3組伝送することで、ヘッダ情報の伝送エラーが生じた場合にDSP12において正しいヘッダ情報に訂正することができるようになっている。
仮に、ヘッダ情報の伝送エラー対策として誤り訂正符号を用いるとした場合、誤り訂正符号の計算を行う回路を送信部22に用意するとともに、誤り訂正演算を行う回路を受信部31に用意する必要があることになる。ヘッダ情報に付加されるのは誤り検出符号であるCRC符号であるため、誤り訂正に関する演算を行う回路を用意する場合に較べて、回路規模、消費電力を小さくすることができる。また、ヘッダ情報の誤りを検出した場合にヘッダ情報の再送を受信部31が送信部22に対して要求することも行われないため、再送要求のための逆方向の伝送路を用意する必要がない。
冗長度を上げ、8B10Bコードの複数のK Characterを組み合わせて制御コードを構成することによって、制御コードのエラー確率を低減させることができ、これにより、比較的簡単な回路で制御コードの伝送エラー対策を確保することが可能になる。
具体的には、Start Codeには3種類のK Characterを4シンボル組み合わせて用いているが、少なくともK28.5以外のシンボルを検出できれば受信部31においてStart Codeを特定することができ、伝送エラーに対する耐性が高いといえる。End Codeについても同様である。
また、Pad Codeに4種類のK Characterを組み合わせて用いているが、他の制御コードより多くの種類のK Characterを割り当てることによって、他の制御コードよりエラー耐性を上げることが可能になる。すなわち、4種類のうちの1種類のシンボルを検出できれば受信部31においてPad Codeを特定することができる。Pad Codeは、伝送頻度がStart CodeやEnd Codeなどよりも高いため、よりエラー耐性を上げることができる構造を持たせている。
さらに、レーン毎に、同じ制御コードを同じタイミングで伝送することによって、1つのレーンで伝送エラーが起きて制御コードが失われた場合でも、他のレーンの制御コードを使って、エラーとなった制御コードを再現することができる。
また、K Characterの数が限られているため、必要最小限のK Characterを組合せてそれぞれの制御コードを構成するようになされている。例えば、繰り返し送信することによって伝送エラーを比較的許容できるSync Code, Deskew Code, Standby Codeについては、K Characterを追加で割り当てる必要がないようなデータ構造を用いている。
再同期させるために必要な制御コードが1パケット(1ライン)毎に割り当てられているため、静電気等の外乱やノイズなどによりビット同期が外れてしまった場合に再同期を迅速にとることができる。また、同期外れによる伝送エラーの影響を最小限に抑えることができる。
具体的には、クロック生成部112と同期部113により実現されるCDRにおいて8B10B変換後のビットデータの遷移/エッジを検出することでビット同期をとることができる。送信部22がデータを送り続けていれば、CDRロック時間として想定された期間内でビット同期をとることができることになる。
また、シンボル同期が外れてしまった場合でも、特定のK Character(K28.5)をシンボル同期部114において検出することによって再同期を迅速にとることができる。K28.5はStart Code, End Code, Deskew Codeにそれぞれ用いられているから、1パケット分のパケットデータの伝送期間中に、3箇所でシンボル同期をとることが可能になる。
また、Deskew Codeを用いてレーン間のData Skewを補正することができるようにすることによって、レーン間の同期をとることもできる。
リンクレイヤにおいて、16個ずつなどのグループ単位(図14の例の場合、16バイト単位)で各パケットデータが並列処理されるようにすることによって、1クロック周期に1つずつパケットデータを処理する場合に較べて、回路規模やメモリ量を抑えることができる。実装上、パケットデータを1つずつ処理する場合と所定の単位毎にまとめて処理する場合とで、後者の方が回路規模等を抑えることができる。回路規模を抑えることができることによって、消費電力を抑えることも可能になる。
また、レーン割り当ての際、連続するパケットデータを異なるレーンに割り当てることによってエラー耐性を高めることができる。あるレーンにおいてパリティの誤り訂正能力を超えた数の連続するパケットデータに跨ってエラーが生じた場合であっても、受信部31においてレーン結合が行われることによって、エラーが生じたパケットデータの位置が分散することになり、パリティを用いたエラー訂正が可能になることがある。パリティによる誤り訂正能力はパリティ長により定まる。
さらに、物理レイヤに近い方を下位として、レーン分配・レーン統合より上位でECC処理を行うようにすることによって、送信部22と受信部31の回路規模を削減することが可能になる。例えば、送信部22において、パケットデータの各レーンへの割り当てが行われた後にペイロードにECCのパリティが挿入されるとした場合、ペイロードECC挿入部をレーン毎に用意する必要があり、回路規模が大きくなってしまうがそのようなことを防ぐことができる。
物理レイヤにおいてはパケットデータの並列処理が複数の回路で行われるが、PHY-TX状態制御部81やクロック生成部82については共通化することによって、それらの回路をレーン毎に用意する場合に較べて回路の簡素化を図ることができる。また、レーン毎に異なる制御コードを伝送しないプロトコルを用いることによって、各レーンのパケットデータを処理する回路の簡素化を図ることができる。
[レーン数の切り替え]
各レーンにおいて同じ制御コードを同じタイミングで伝送することは、通常のデータ伝送時だけでなく、例えばレーン数を切り替える場合にも行われる。レーン数を切り替える場合においても、アクティブなレーン(データ伝送に用いられるレーン)の状態は全て同じ状態になる。
図29は、レーン数を切り替える場合の制御シーケンスを示す図である。
図29の右側に垂直同期信号(XVS)、水平同期信号(XHS)のタイミングを示す。垂直同期信号が検出される時刻t1までの間に1フレームの画像を構成する各ラインの画素データが水平同期信号に従って伝送され、時刻t1のタイミングで、アクティブなレーンを4レーンから2レーンに変更する場合について説明する。時刻t1までは、4つのレーンを用いてデータ伝送が行われている。
図29のほぼ中央には縦方向に各レーンの状態を示している。「PIX DATA」は、その文字が付されているレーンにおいて画素データの伝送が行われていることを表す。「PIX DATA」に続く「E」、「BLK」、「S」は、それぞれ、Frame End、ブランキング期間、Frame Startを表す。
時刻t1までの1フレーム期間に伝送するフレームの画素データの伝送が終了した場合、ステップS81において、画像処理部32は、受信部31に対してレーン数を4から2に切り替えることを指示する。画像処理部32による指示はステップS71において受信部31により受信される。
時刻t1になったとき、ステップS82において、画像処理部32は、イメージセンサ11の撮像部21に対して、モードチェンジを要求する。撮像部21に対して送信されるモードチェンジの要求には、レーン数を4から2に切り替えることを表す情報も含まれている。図1等には示していないが、撮像部21と画像処理部32の間には、シャッタスピード、ゲインなどの撮像に関する設定値の情報を画像処理部32が撮像部21に対して送信するための伝送路が設けられている。モードチェンジの要求もこの伝送路を介して撮像部21に送信される。
ステップS51において、撮像部21は、画像処理部32からのモードチェンジの要求を受信し、ステップS52において、送信部22に対してレーン数を4から2に切り替えることを指示する。撮像部21による指示はステップS61において送信部22により受信される。
送信部22と受信部31の間ではStandby Sequenceが行われ、Lane0~3を使ってStandby Codeが送信部22から受信部31に繰り返し伝送される。Standby Sequenceが終了したとき、ステップS72において、受信部31から状態の検出結果が出力され、ステップS83において画像処理部32により受信される。また、アクティブな状態を維持するLane0とLane1についてはLowの状態となり、データ伝送を終了するLane2とLane3についてはHigh-Zの状態となる。
送信部22と受信部31の間ではTraining Sequenceが行われ、Lane0とLane1を使ってSync Codeが送信部22から受信部31に繰り返し伝送される。受信部31においてはビット同期が確保され、Sync Codeが検出されることによってシンボル同期が確保される。
Training Sequenceが終了したとき、ステップS73において、受信部31は、画像処理部32に対して準備が完了したことを通知する。受信部31による通知はステップS84において画像処理部32により受信され、レーン数を切り替える場合の一連の制御シーケンスが終了する。
このように、レーン数を切り替える制御シーケンスにおいては、続けてデータ伝送に用いられるLane0,1と同じ状態になるように、データ伝送を終了するLane2,3においてもStandby Sequence時にStandby Codeが伝送される。例えば、Lane2,3については、Standby Codeの伝送を行わないでそのままHigh-Zの状態にすることも考えられるが、続けてデータ伝送に用いられるレーンと異なる状態になってしまい、制御が複雑になる。
[フレームフォーマットの変形例]
図30は、イメージセンサ11-DSP12間のデータ伝送に用いられるフレームフォーマットの他の例を示す図である。上述した説明と重複する説明については適宜省略する。
図30に示すフレームフォーマットは、各ラインの画像データに付加されるヘッダに太線L11で囲むEmbedded Line, Data ID, Region Numberの3つのデータが追加されている点で図4のフォーマットと異なる。図5のヘッダ生成部72によりこれらの情報が生成され、ヘッダに付加されることになる。
図31は、図30のフレームフォーマットの1パケットを拡大して示す図である。1つのパケットは、ヘッダと、1ライン分の画素データであるペイロードデータから構成される。パケットにはフッタが付加されることもある。各パケットの先頭にはStart Codeが付加され、後ろにはEnd Codeが付加される。
ヘッダ情報には、上述したFrame Start, Frame End, Line Valid, Line Numberに加えて、ライン情報としてのEmbedded Line、データ識別としてのData ID、および領域情報としてのRegion Numberが含まれる。各情報の内容を図32に示す。
Embedded Lineは、Embedded Dataが挿入されているラインの伝送に用いられるパケットであるのか否かを表す1ビットの情報である。例えば、Embedded Dataを含むラインの伝送に用いられるパケットのヘッダのEmbedded Lineには1の値が設定され、他のラインの伝送に用いられるパケットのヘッダのEmbedded Lineには0の値が設定される。上述したように、撮像に関する設定値の情報が、Embedded Dataとして前ダミー領域A3や後ダミー領域A4の所定のラインに挿入される。
Data IDは、マルチストリーム伝送におけるデータのIDやデータ種別を示すPビットの情報である。Pビットは1ビット以上の所定の数のビットを表す。マルチストリーム伝送は、1つの送信部と1つの受信部の組を複数用いて行われるデータ伝送である。
Region Numberは、ペイロードに格納されている画素データが、撮像部21のどの領域のデータであるのかを示す1ビットの情報である。これらの3つのデータが追加されることによって、Reservedは30-Pビットになる。
<2.Mode Changeについて>
ここで、Mode Change(モードチェンジ)について説明する。Mode Changeは、データ伝送のモードの内容を規定する、上述したレーン数などのパラメータの変更時に行われる。
[(1)通常のMode Change]
・Mode Change
図33は、Mode Changeのシーケンスの例を示す図である。
図33の左側に縦に並べて示す3つのフレームは、Mode Change時に伝送されるデータのフレームフォーマットを示す。図33の上下方向が時間方向を示す。Mode Change時に行われる動作のうち、イメージセンサ11とDSP12の主な動作について説明する。
左端に示す垂直同期信号(XVS)により規定される時刻t51~t52、時刻t52~t53、および時刻t53~t54の各期間が、各フレームの伝送期間に相当する。各フレームを構成するそれぞれのラインが、水平同期信号(XHS)のタイミングに従って1パケットを用いて伝送される。
図34は、図33の1フレーム目を拡大して示す図である。
図34の例においては、時刻t51から時刻t61までの間、図4の前ダミー領域A3のデータに相当するBlanking Dataをペイロードに格納したパケットが伝送される。
また、時刻t61から時刻t62までの間、Embedded Dataをペイロードに格納したパケットが伝送され、時刻t62から時刻t63までの間、各ラインの画素データをペイロードに格納したパケットが伝送される。時刻t63から時刻t52までの間、図4の後ダミー領域A4のデータに相当するBlanking Dataをペイロードに格納したパケットが伝送される。
各パケットは、ペイロードの前にヘッダを付加することによって構成される。それぞれのパケットの前にはStart Codeが付加され、後ろにはEnd Codeが付加される。End Codeの後ろにはDeskew CodeとIdle Codeが付加される。
図33の右側のシーケンス図における白抜き矢印#11は、このような1フレーム目のデータの送受信が送信部22と受信部31の間で行われていることを示す。2フレーム目、3フレーム目についても、上のラインから順に、1ラインずつ伝送される。
1フレーム目の最後のラインの伝送が終了した時刻t52のタイミングのステップS131において、DSP12の画像処理部32は、受信部31に対してConfigを出力する。Configは、レジスタに設定されたパラメータを、受信動作に反映させることを要求する制御信号である。撮像部21と送信部22間、受信部31と画像処理部32間で用いられる各種の制御信号については後に詳述する。
Configの出力前、イメージセンサ11の撮像部21とDSP12の画像処理部32の間では所定のインタフェース(撮像部21と画像処理部32の間の図示せぬ伝送路)を介して通信が行われ、パラメータの変更が行われる。撮像部21においては、変更後のパラメータがレジスタ53(図5)に設定され、画像処理部32においては、変更後のパラメータがレジスタ142に設定される。
ステップS121において、受信部31は、画像処理部32から出力されたConfigを受信し、レジスタ142に設定された変更後のパラメータを読み出してデータの受信動作に反映させる。以降のデータの受信が、変更後のパラメータにより規定される内容で行われる。
ステップS132において、画像処理部32は、イメージセンサ11の撮像部21に対してMode Changeを発行する。Mode Changeの発行は、伝送モードの変更を要求する制御信号を送信することを意味する。Mode Changeの発行も、図示せぬインタフェースを用いて行われる。
Mode Changeの発行をステップS101において受信した撮像部21は、ステップS102において、送信部22に対してConfigを出力する。
ステップS111において、送信部22は、撮像部21から出力されたConfigを受信し、レジスタ53に設定された変更後のパラメータを読み出してデータの送信動作に反映させる。以降のデータの送信が、変更後のパラメータにより規定される内容で行われる。
ステップS112において、送信部22は、受信部31との間でStandby Sequenceを行う。上述したように、Standby Sequenceにおいては送信部22から受信部31に対してStandby Codeが繰り返し伝送される。
Standby Sequenceが終了したとき、送信部22と受信部31の間の各レーンはLow(Lowインピーダンス)となり、データ伝送が停止した状態になる。
ステップS114において、送信部22は、受信部31との間でTraining Sequenceを行う。Training Sequenceは、受信部31において、CDRを行うことによってクロックを再生し、同期を確立するとともに、レーン間のData Skewを補正するために行われる処理である。
図35は、Training Sequenceにおいて用いられる制御コードの例を示す図である。
図35の縦方向がレーンを示し、横方向が時間方向を示す。Training Sequenceにおいては、Sync Codeが繰り返し伝送され、その後、Idle Codeの繰り返しと1つのDeskew Codeを組として、その組が繰り返し伝送される。受信部31においては、Sync Codeを用いてクロックの再生と同期の確立が行われ、Deskew Codeを用いて、図25を参照して説明したようにして、レーン間のData Skewの補正が行われる。
Training Sequenceの後、図33のステップS115において、送信部22は、Idle Codeを送信する。
ステップS122において、受信部31は、送信部22から送信されたIdle Codeを受信する。このようなTraining Sequenceが行われることにより、受信部31は、変更後のパラメータに従って、送信部22から送信されてくるデータを受信できる状態になる。
送信部22による3フレーム目の各ラインの送信は、変更後のパラメータにより規定される内容で行われる。白抜き矢印#12は、3フレーム目のデータの送受信が、変更後のパラメータを用いて送信部22と受信部31の間で行われていることを示す。
以上のようなMode Changeが、パラメータの変更時に行われる。
図36は、レジスタに設定されるパラメータの例を示す図である。
Lane Numは、データストリームの伝送に用いるレーンの数を表す情報である。Lane Numには、例えば1,2,4,6,8のうちのいずれかの値が設定される。
Pixel Bitは、画像データを構成する各ピクセルのビット数を表す情報である。Pixel Bitには、例えば8,10,12,14,16のうちのいずれかの値が設定される。
Line Lengthは、1ラインのピクセル数を表す情報である。Line Lengthには、4以上の所定の値が設定される。
ECC Optionは、パケットを構成するペイロードデータの誤り訂正に用いられる誤り訂正符号の種類を表す情報である。ECC Optionには、0,1,2のうちのいずれかの値が設定される。
CRC Optionは、パケットを構成するフッタに含まれ、ペイロードデータの誤り検出に用いられる誤り検出符号の種類を表す情報である。CRC Optionには、On/Offのいずれかが設定される。CRC Optionの設定がOnであることは、誤り検出符号が含まれることを示し、Offであることは、誤り検出符号が含まれていないことを示す。
Baud Gradeは、それぞれのレーンの伝送レートの種類を表す情報である。Baud Gradeには、Grade1/Grade2のいずれかが設定される。
イメージセンサ11とDSP12においては、このような各パラメータの値として同じ値が設定される。イメージセンサ11のレジスタ53に設定されたパラメータは、撮像部21からConfigが出力されることに応じて送信部22により読み出され、送信動作に反映される。一方、DSP12のレジスタ142に設定されたパラメータは、画像処理部32からConfigが出力されることに応じて受信部31により読み出され、受信動作に反映される。
なお、パラメータの種類は、図36に示すものに限定されるものではなく、他のパラメータが用いられるようにしてもよい。
・Mode Change with Standby
Mode Changeには、図33のMode Changeの他に、Mode Change with Standbyが規定される。図33のMode Changeが、データ伝送の停止中に各レーンがLowになるものであるのに対して、Mode Change with Standbyは、データ伝送の停止中に各レーンがHigh-Z(Highインピーダンス)になるものである。
図37は、Mode Change with Standbyのシーケンスの例を示す図である。イメージセンサ11とDSP12の主な動作について説明する。
図37の右方に示すように、所定のフレームの画像データの送信終了後のステップS231において、DSP12の画像処理部32は、イメージセンサ11の撮像部21に対してStandbyを送信する。
StandbyをステップS201において受信したイメージセンサ11の撮像部21は、ステップS202において、送信部22に対してStandbyを出力する。
ステップS211において、受信部31は、画像処理部32から出力されたStandbyを受信し、受信部31との間でStandby Sequenceを行う。
Standby Sequenceが終了したとき、送信部22と受信部31はStandby modeの状態になる。送信部22と受信部31の間の各レーンはHigh-Zとなり、データ伝送が停止した状態になる。
例えばStandby modeの状態になっている間、イメージセンサ11の撮像部21とDSP12の画像処理部32の間では所定のインタフェースを介して通信が行われ、パラメータの変更が行われる。撮像部21においては、変更後のパラメータがレジスタ53に設定され、画像処理部32においては、変更後のパラメータがレジスタ142に設定される。
ステップS232において、画像処理部32は、受信部31に対してSetupを出力する。
ステップS221において、受信部31は、画像処理部32から出力されたSetupを受信し、Standby modeから起動する。受信部31においては、適宜、レジスタ142に設定されたパラメータが読み出され、受信動作に反映される。
ステップS233において、DSP12の画像処理部32は、イメージセンサ11の撮像部21に対してWakeupを送信する。
WakeupをステップS203において受信したイメージセンサ11の撮像部21は、ステップS204において、送信部22に対してSetupを出力する。
ステップS212において、送信部22は、撮像部21から出力されたSetupを受信し、Standby modeから起動する。送信部22においては、適宜、レジスタ53に設定されたパラメータが読み出され、送信動作に反映される。送信部22と受信部31の間の各レーンはLowとなる。
ステップS213において、送信部22は、受信部31との間でTraining Sequenceを行う。受信部31においては、Sync Codeを用いてクロックの再生と同期の確立が行われ、Deskew Codeを用いて、レーン間のData Skewの補正が行われる。
Training Sequenceの後、ステップS214において、送信部22は、Idle Codeを送信する。
Training Sequenceを終えた受信部31は、ステップS222において、画像処理部32に対してReadyを送信し、データの受信準備が完了したことを通知する。
ステップS234において、画像処理部32は、受信部31から出力されたReadyを受信する。その後、画像処理部32は、送信部22から送信され、受信部31において受信された画像データを取得して処理を行う。
Mode Change with Standbyは以上のようにして行われる。図33を参照して説明したMode Changeと、Mode Change with Standbyをそれぞれ区別する必要がない場合、単に、Mode Changeという。
・送信部22の状態遷移
図38は、送信側であるイメージセンサ11の各レイヤ間で用いられる制御信号の例を示す図である。
アプリケーションレイヤ(撮像部21)からリンクレイヤに対しては、ラインの開始と終了を表すLine Start/Line End、レジスタ53に設定されたパラメータを表すPixel Bit,Lane Num,Baud Grade,Line Length,ECC Option,CRC Optionが出力される。
また、アプリケーションレイヤからリンクレイヤに対しては、Config,Standby,Setupが出力される。Configは、レジスタ53に設定されたパラメータを送信動作に反映させることを要求する信号である。Standbyは、Standby Sequenceを開始することを要求する信号である。Setupは、Standby modeから起動することを要求する信号である。
このような各制御信号が、アプリケーションレイヤのシステム制御部51から出力される。LINK-TXプロトコル管理部61の状態制御部71は、アプリケーションレイヤから出力される制御信号を受信することに応じて、リンクレイヤの各部の状態を制御する。
リンクレイヤから物理レイヤに対しては、制御コードの送信の開始と終了を要求するTX Start/TX End、リンクレイヤから出力されるデータが、有効データであるか否かを表すData Valid/Data Invalidが出力される。
また、リンクレイヤから物理レイヤに対しては、レジスタ53に設定された6種類のパラメータのうちの、物理レイヤの処理に関係のあるLane NumとBaud Gradeが出力される。Lane NumとBaud Grade以外のパラメータは、リンクレイヤの処理に関係のあるパラメータである。
さらに、リンクレイヤから物理レイヤに対しては、Config,Standby,Setupが出力される。Configは、Standby modeの後、各レーンをLowの状態にすることを要求する信号である。Standbyは、Standby Sequenceの開始を要求する信号である。Setupは、Training Sequenceの開始を要求する信号である。
このような各制御信号が、リンクレイヤの状態制御部71から出力される。PHY-TX状態制御部81は、リンクレイヤから出力される制御信号を受信することに応じて、物理レイヤの各部の状態を制御する。
図39は、送信部22のリンクレイヤの状態遷移の例を示す図である。主な遷移について説明する。
図39において、それぞれのブロックはリンクレイヤの状態を表す。ある状態から他の矢印に向かう矢印は、それぞれの矢印の近傍の制御信号がアプリケーションレイヤから出力されたときに起こる状態遷移を表す。後述する図40、図42、図43等においても同様である。
例えば、中央に示すBlankingの状態において、アプリケーションレイヤからConfigが出力された場合、状態制御部71は、矢印#21の先に示すように、リンクレイヤの状態をMode Changeの状態に遷移させる。このとき、例えば図33を参照して説明したMode Changeが行われる。
Mode Changeの状態にある場合、状態制御部71から物理レイヤに対しては、StandbyまたはConfigが出力される。各ブロックの内側に示す制御信号は、その状態にある場合に物理レイヤに対して出力される信号を示す。
状態制御部71は、図39に示すような遷移図に従って、リンクレイヤの状態を制御する。
図40は、送信部22の物理レイヤの状態遷移の例を示す図である。主な遷移について説明する。
例えば、中央に示すIdle Codeの伝送中の状態において、リンクレイヤからStandbyが出力された場合、PHY-TX状態制御部81は、矢印#31の先に示すように、物理レイヤの状態をStandby Sequenceの状態に遷移させる。
Standby Sequenceが終わった場合、PHY-TX状態制御部81は、矢印#32の先に示すように各レーンをHigh-Zにする。各レーンがHigh-ZになっているときにリンクレイヤからSetupが出力された場合、PHY-TX状態制御部81は、矢印#33の先に示すように、各レーンをLowにする。Standby SequenceにおいてConfigが出力された場合も同様に、PHY-TX状態制御部81は、矢印#34の先に示すように各レーンをLowにする。
各レーンをLowにした後、PHY-TX状態制御部81は、物理レイヤの状態を、矢印#35の先に示すようにTraining Sequenceの状態とし、Training Sequenceが終了した場合、矢印#36の先に示すようにIdle Codeを伝送する状態とする。
PHY-TX状態制御部81は、図40に示すような遷移図に従って、物理レイヤの状態を制御する。
・受信部31の状態遷移
図41は、受信側であるDSP12の各レイヤ間で用いられる制御信号の例を示す図である。
送信部22からStart Code/End Codeが供給された場合、物理レイヤからリンクレイヤに対しては、受信の開始/終了を要求するRX Start/RX Endが出力される。このとき、リンクレイヤからアプリケーションレイヤ(画像処理部32)に対しては、Line Start/Line Endが出力される。
また、送信部22からPAD Codeが供給された場合、物理レイヤからリンクレイヤに対しては、物理レイヤから出力されるデータが、有効データであるか否かを表すData Valid/Data Invalidが出力される。このとき、リンクレイヤからアプリケーションレイヤに対しては、ヘッダの解析結果を表すHeader Infoなどが出力される。
Standby Sequenceを開始する場合、物理レイヤからリンクレイヤに対しては、Standby Detectが出力される。このとき、リンクレイヤからアプリケーションレイヤに対してはStandby Detectが出力される。
Training Sequenceを開始する場合、物理レイヤからリンクレイヤに対しては、RX Readyが出力される。このとき、リンクレイヤからアプリケーションレイヤに対してはRX Readyが出力される。
アプリケーションレイヤからリンクレイヤに対しては、レジスタ142に設定されたパラメータを表すPixel Bit,Lane Num,Baud Grade(Data Rate),Line Length,ECC Option,CRC Optionが出力される。ECC Option,CRC Optionはオプションのため、出力しないことも可能である。リンクレイヤから物理レイヤに対しては、レジスタ142に設定された6種類のパラメータのうちの、物理レイヤの処理に関係のあるLane NumとBaud Gradeが出力される。
また、アプリケーションレイヤからリンクレイヤに対しては、Config,Standby,Setupが出力される。Configは、レジスタ142に設定されたパラメータを受信動作に反映させることを要求する信号である。Standbyは、Standby Sequenceを開始することを要求する信号である。Setupは、Standby modeから起動することを要求する信号である。Config,Standby,Setupは、リンクレイヤから物理レイヤに対しても出力される。
PHY-RX状態制御部101は、送信部22から送信されてきた制御コードを受信することに応じて、または、リンクレイヤから出力される制御信号を受信することに応じて、物理レイヤの各部の状態を制御する。
また、LINK-RXプロトコル管理部121の状態制御部131は、リンクレイヤから出力される制御信号を受信することに応じて、または、アプリケーションレイヤから出力される制御信号を受信することに応じて、リンクレイヤの各部の状態を制御する。
図42は、受信部31のリンクレイヤの状態遷移の例を示す図である。主な遷移について説明する。
例えば、中央に示すBlankingの状態において、物理レイヤからStandby Detectが出力された場合、状態制御部131は、矢印#41の先に示すように、リンクレイヤの状態をWaitの状態に遷移させる。
Waitの状態において、アプリケーションレイヤからConfigが出力された場合、状態制御部131は、矢印#42の先に示すように、リンクレイヤの状態をMode Changeの状態に遷移させる。
状態制御部131は、図42に示すような遷移図に従って、リンクレイヤの状態を制御する。
図43は、受信部31の物理レイヤの状態遷移の例を示す図である。主な遷移について説明する。
例えば、中央に示すRX Readyを出力している状態において、Standby Sequenceを開始する場合、PHY-RX状態制御部101は、矢印#51の先に示すように、物理レイヤの状態をStandby Detectを出力する状態に遷移させる。
Standby Detectを出力している状態において、リンクレイヤからConfigが出力された場合、PHY-RX状態制御部101は、矢印#52の先に示すように、物理レイヤの状態をTraining Waitの状態に遷移させる。
Training Waitの状態において、Training Sequenceを開始する場合、PHY-RX状態制御部101は、矢印#53の先に示すように、物理レイヤの状態をRX Readyを出力する状態に遷移させる。
PHY-RX状態制御部101は、図43に示すような遷移図に従って、物理レイヤの状態を制御する。
[(2)Training Sequenceを省略したMode Change]
以上のように、データ伝送のモードは6種類のパラメータにより規定される。パラメータの変更時、Mode ChangeにおいてTraining Sequenceが行われ、データ伝送が一度停止することになる。
ところで、6種類のパラメータのうち、Lane NumとBaud Grade以外のパラメータは、仮に変更したとしても同期の確立とレーン間のData Skewの補正を再度行う必要がない、すなわち、Training Sequenceが不要なパラメータである。
Lane NumとBaud Gradeは物理レイヤの処理に関係のあるパラメータであり、変更した場合には同期がずれるとともにレーン間のData Skewの量が変化するためにTraining Sequenceが必要になる。一方、Lane NumとBaud Grade以外のパラメータは、リンクレイヤの処理に関係のあるパラメータであり、変更の前後で、同期のずれやレーン間のData Skewの量に変化がない。
Mode Changeの方式として、Training Sequenceを伴う上述したMode Changeの他に、Training Sequenceを省略したMode Changeが規定される。Training Sequenceを伴うMode ChangeとTraining Sequenceを省略したMode Changeは、変更するパラメータの種類に応じて切り替えて実行される。
図44は、Mode Changeの例を示す図である。
図44の上段に示すように、変更するパラメータがLane NumまたはBaud Gradeである場合、Training Sequenceを伴うMode Changeが行われる。
一方、図44の下段に示すように、変更するパラメータがLane NumとBaud Grade以外のパラメータである場合、Training Sequenceを省略したMode Change、または、Training Sequenceを伴うMode Changeが行われる。
このように、変更するパラメータの種類に応じてTraining Sequenceを適宜省略することにより、Mode Changeを簡略化することが可能になる。
また、同期の確立とData Skewの補正を再度行う必要がない場合であってもそれらの処理を行うとした場合、無駄な電力消費が受信側において発生することになるが、Training Sequenceを適宜省略することにより消費電力を抑えることが可能になる。
以下、適宜、Training Sequenceを省略したMode Changeを、簡易型Mode Changeという。
簡易型Mode Changeとして、図45に示すように、無効フレームの伝送がある簡易型Mode Changeと、無効フレームの伝送がない簡易型Mode Changeとの2種類が規定される。
・無効フレームの伝送がある簡易型Mode Changeのシーケンス
図46は、無効フレームの伝送がある簡易型Mode Changeのシーケンスの例を示す図である。図33の説明と重複する説明については適宜省略する。
図46の右端に示すように、1フレーム目の最後のラインの伝送が終了したステップS331において、DSP12の画像処理部32は、受信部31に対してConfigを出力する。
Configの出力前、イメージセンサ11の撮像部21とDSP12の画像処理部32の間では所定のインタフェースを介して通信が行われ、パラメータの変更が行われる。Pixel Bitなどの、Lane NumとBaud Grade以外のパラメータが変更されるものとする。撮像部21においては、変更後のパラメータがレジスタ53に設定され、画像処理部32においては、変更後のパラメータがレジスタ142に設定される。
ステップS321において、受信部31は、画像処理部32から出力されたConfigを受信し、レジスタ142に設定された変更後のパラメータを読み出してデータの受信動作に反映させる。以降のデータの受信が、変更後のパラメータにより規定される内容で行われる。
ステップS332において、画像処理部32は、イメージセンサ11の撮像部21に対してMode Changeを発行する。
Mode Changeの発行をステップS301において受信したイメージセンサ11の撮像部21は、ステップS302において、送信部22に対してConfigを出力する。
ステップS311において、送信部22は、撮像部21から出力されたConfigを受信し、レジスタ53に設定された変更後のパラメータを読み出してデータの送信動作に反映させる。以降のデータの送信が、変更後のパラメータにより規定される内容で行われる。
送信部22と受信部31の双方においてパラメータの変更が反映された後、白抜き矢印#61で示すようにBlanking Dataの送信が開始される。Blanking Dataの送信は、Training Sequenceに要する時間を含む、2フレーム目の送信が終了するタイミングである時刻t53まで続けられる。
すなわち、Training Sequence等が省略され、無効なデータではあるが、データの伝送が続けられることになる。
ここで送信されるBlanking Dataは、左側の枠F1で囲んで示すように無効フレームを構成するデータである。
Blanking Dataの伝送も、ライン毎に1つのパケットを用いて行われる。Blanking Dataを格納したペイロードの前にヘッダが付加されることによって各パケットが構成される。それぞれのパケットの前にはStart Codeが付加され、後ろにはEnd Codeが付加される。End Codeの後ろにはDeskew CodeとIdle Codeが付加される。
無効フレームの送信が終了した時刻t53において、3フレーム目の送信が開始される。送信部22による3フレーム目の各ラインの送信は、変更後のパラメータにより規定される内容で行われる。また、受信部31による3フレーム目の各ラインの受信は、変更後のパラメータにより規定される内容で行われる。
このように、送信部22は、簡易型Mode Changeの実行時、パラメータの変更を送信動作に即時に反映させ、データ伝送の一時停止を生じさせることなく無効フレームの送信を行う。
図47は、簡易型Mode Changeが用いられる場合の、送信部22のリンクレイヤの状態遷移の例を示す図である。
図47に示すように、中央に示すBlankingの状態からMode Changeの状態への遷移は、アプリケーションレイヤからConfigが出力され、かつ、変更されたパラメータがLane NumまたはBaud Gradeである場合に発生することになる。状態制御部71は、図47に示すような遷移図に従って、リンクレイヤの状態を制御する。
ここで、図48のシーケンス図を参照して、簡易型Mode Change時の各部の処理の詳細について説明する。図48に示す処理は、基本的に、図46を参照して説明した処理と同様の処理である。
パラメータの変更が撮像部21と画像処理部32の間で行われた後、ステップS401において、撮像部21は、変更後のパラメータをレジスタ53に設定する。
一方、ステップS431において、画像処理部32は、変更後のパラメータをレジスタ142に設定する。
ステップS432において、画像処理部32は、受信部31に対してConfigを出力する。
ステップS421において、受信部31は、画像処理部32から出力されたConfigを受信する。
ステップS422において、受信部31は、レジスタ142からパラメータを読み出してデータの受信動作に反映させる。状態制御部131は、リンクレイヤの各部を制御し、新たに設定されたパラメータに応じた処理を行わせる。
画素データを含むフレームである有効フレームの最後のラインの送信が終了したステップS433において、画像処理部32は、撮像部21に対してMode Changeを発行する。
ステップS402において、撮像部21は、Mode Changeの発行を受信する。
ステップS403において、撮像部21は、送信部22に対してConfigを出力する。
ステップS411において、送信部22は、撮像部21から出力されたConfigを受信する。
ステップS412において、送信部22は、レジスタ53からパラメータを読み出してデータの送信動作に反映させる。状態制御部71は、リンクレイヤの各部を制御し、新たに設定されたパラメータに応じた処理を行わせる。
変更されたパラメータがPixel Bit,Line Length,ECC Option,CRC Optionのうちのいずれかである場合、ステップS413において、状態制御部71は、リンクレイヤの状態を、簡易型Mode Changeを実行する状態とする。
ステップS414において、送信部22は、Blanking Dataを含む無効フレームを送信する。無効フレームの送信は、新たに設定されたパラメータに従って行われる。
無効フレームの送信が終了した場合、ステップS415において、送信部22は、画素データを含む有効フレームを送信する。
一方、ステップS423において、受信部31は、送信部22から送信された無効フレームを受信する。無効フレームの受信は、新たに設定されたパラメータに従って行われる。
無効フレームの受信が終了した場合、ステップS424において、受信部31は、送信部22から送信された有効フレームを受信する。その後、送信部22と受信部31の間では有効フレームの送受信が続けられる。
このように、簡易型Mode Changeは、変更するパラメータによっては不要ともいえるTraining Sequenceを省略するようにして行われる。
これにより、Mode Change時の送信側のシーケンスを簡略化することが可能になる。
また、CDRによる再同期などが不要になるため、受信側の消費電力の削減が可能になる。
なお、複数種類のパラメータが一度に変更されるようにしてもよい。この場合、Lane NumとBaud Gradeのうちの少なくともいずれかの変更が行われるときに、Training Sequenceを伴うMode Changeが行われることになる。また、Pixel Bit,Line Length,ECC Option,CRC Optionのうちの少なくともいずれかの変更が行われるときに、簡易型Mode Changeが行われることになる。
[(3)無効フレームの伝送がない簡易型Mode Change]
次に、無効フレームの伝送がない簡易型Mode Changeについて説明する。
・(3-1)シーケンスについて
図49は、無効フレームの伝送がない簡易型Mode Changeのシーケンスの例を示す図である。
図49に示すシーケンスは、パラメータの変更が行われた後、無効フレームの伝送を生じさせずに、枠F2で囲んで示すように有効フレームの伝送が行われる点で、図46を参照して説明したシーケンスと異なる。
図49の右端に示すように、ステップS481において、DSP12の画像処理部32は、受信部31に対してConfigを出力する。受信部31に対するConfigの出力は、例えば1フレーム目の所定のラインの伝送中に行われる。Configの出力前、イメージセンサ11の撮像部21とDSP12の画像処理部32の間では所定のインタフェースを介して通信が行われ、パラメータの変更が行われる。
ステップS471において、受信部31は、画像処理部32から出力されたConfigを受信し、所定のタイミングで、レジスタ142に設定された変更後のパラメータを読み出してデータの受信動作に反映させる。パラメータの反映タイミングについては後述する。
ステップS482において、画像処理部32は、イメージセンサ11の撮像部21に対してMode Changeを発行する。Mode Changeの発行も、1フレーム目の所定のラインの伝送中に行われる。
Mode Changeの発行をステップS451において受信したイメージセンサ11の撮像部21は、ステップS452において、送信部22に対してConfigを出力する。送信部22に対するConfigの出力も、1フレーム目の所定のラインの伝送中に行われる。
ステップS461において、送信部22は、撮像部21から出力されたConfigを受信し、所定のタイミングで、レジスタ53に設定された変更後のパラメータを読み出してデータの送信動作に反映させる。
送信部22と受信部31の双方においてパラメータの変更が反映された後の時刻t52以降、有効フレームである2フレーム目の伝送が行われる。白抜き矢印#71は、このような2フレーム目のデータの送受信が送信部22と受信部31の間で行われていることを示す。その後、送信部22と受信部31の間では有効フレームの送受信が続けられる。
このように、無効フレームの伝送を生じさせずに簡易型Mode Changeを行うようにすることが可能である。
ここで、無効フレームの伝送を生じさせないようにするためには、Mode Changeの発行と、Configに応じたパラメータの反映が、次のフレーム(変更前のパラメータを用いて伝送中のフレームの次のフレーム)の開始タイミングに間に合う必要がある。Configに応じたパラメータの反映には、Configの出力自体も含まれる。
Mode Changeの発行とConfigに応じたパラメータの反映のタイミングには、所定の制約が設定される。
変更するパラメータが、Pixel Bit,Line Length,ECC Option,CRC Optionのうちのいずれかである場合、Mode Changeの発行とConfigに応じたパラメータの反映のタイミングには、例えば以下のような制約が設定される。
例1
送信側:次のフレームの先頭を表すTX Start(図38)の出力まで
受信側:次のフレームの先頭を表すRX Start(図41)の出力まで
この場合、Mode Changeの発行とConfigに応じたパラメータの反映が、送信部22においては、リンクレイヤ(状態制御部71)から物理レイヤ(PHY-TX状態制御部81)に対してTX Startが出力されるまでに行われる必要がある。また、受信部31においては、物理レイヤ(PHY-RX状態制御部101)からリンクレイヤ(状態制御部131)に対してRX Startが出力されるまでに行われる必要がある。
例2
送信側:伝送中のフレームの最後を表すTX Endの出力まで
受信側:伝送中のフレームの最後を表すRX Endの出力まで
この場合、Mode Changeの発行とConfigに応じたパラメータの反映が、送信部22においては、リンクレイヤから物理レイヤに対してTX Endが出力されるまでに行われる必要がある。また、受信部31においては、物理レイヤからリンクレイヤに対してRX Endが出力されるまでに行われる必要がある。
上記例1、例2の制約を満たすタイミングとして、Mode Changeの発行とConfigに応じたパラメータの反映が、伝送中のフレームの垂直ブランキング期間中に行われるようにしてもよい。例えば図49の1フレーム目における、後ダミー領域A4のデータに相当するBlanking Dataの期間が、垂直ブランキング期間に相当する。
これにより、無効フレームの伝送がない簡易型Mode Changeによるパラメータの変更を、フレーム単位で行わせることが可能になる。
また、Mode Changeの発行とConfigに応じたパラメータの反映が、伝送中のラインの水平ブランキング期間中に行われるようにしてもよい。例えば図49の1フレーム目の所定のラインの最後尾に付加されるIdle Codeの期間が、水平ブランキング期間に相当する。
これにより、無効フレームの伝送がない簡易型Mode Changeによるパラメータの変更を、ライン単位で行わせることが可能になる。
以上のように、無効フレームの伝送を生じさせないようにすることにより、データの伝送効率の低下を防ぐことが可能になる。
・(3-2)Packet Headerを用いて設定変更フラグを伝送する例
無効フレームの伝送がない簡易型Mode Changeにおいて、パラメータの変更が生じたことが、ヘッダに格納された設定変更フラグを用いて送信側から受信側に通知されるようにしてもよい。
受信部31においては、ヘッダの解析が行われ、設定変更フラグに基づいて、パラメータの変更が生じているか否かの検出が行われる。パラメータの変更が生じていることを検出された場合、レジスタ142に設定された変更後のパラメータを読み出してデータの受信動作に反映させる処理が行われる。
後に詳述するが、この場合のシーケンスは、Configの出力に応じて行われる処理が異なる点を除いて、図49を参照して説明したシーケンスと基本的に同様のシーケンスとなる。
図50は、ヘッダに格納される情報の例を示す図である。
図50に示す各情報は、領域情報が含まれていない点で、図32に示す情報と異なる。図50の例においては、データ識別を示すデータ情報が4ビットとして定義されている。Reservedは27ビットになる。設定変更フラグは、27ビットのリザーブ領域(Reserved)を用いて設定される。
図51は、リザーブ領域の27ビット([26:0])の割り当ての例を示す図である。
図51に示すように、リザーブ領域の27ビットのうちの上位3ビット([26:24])は、Information Typeとして割り当てられる。
Information Type([2:0])の値が000(3’d0)であることは、リザーブ領域が、設定変更フラグの設定に用いられていないことを示す。例えば、受信側において設定変更フラグの値を解釈することができない場合、Information Typeの値として000が設定される。これにより、受信側の性能の違いによる互換性を確保することが可能になる。
Information Typeの値が001(3’d1)であることは、リザーブ領域が、設定変更フラグとしてのParameter Change Indicatorの設定に用いられていることを示す。
リザーブ領域の27ビットのうちの上位4ビット目以降の24ビット([23:0])は、Additional Informationとして割り当てられる。
図52は、Information Typeの値が001である場合のAdditional Informationの例を示す図である。
Additional Informationとして割り当てられた24ビットのうちの最上位ビット([23])は、Parameter Change Indicatorに割り当てられる。
Parameter Change Indicatorの値が1(1’b1)であることは、パラメータの変更が生じていることを示す。
無効フレームの伝送がない簡易型Mode Changeを行う場合、すなわち、Pixel Bit,Line Length,ECC Option,CRC Optionのうちのいずれかのパラメータの変更が生じた場合、Parameter Change Indicatorの値として1が設定されたヘッダを含むパケットが所定のタイミングで生成され、送信される。
一方、Parameter Change Indicatorの値が0(1’b0)であることは、パラメータの変更が生じていないことを示す。
なお、Additional Informationとして割り当てられた24ビットのうちの最上位ビット以外([22:0])はReservedとなる。
ここで、図53のシーケンス図を参照して、パラメータの変更が生じたことをParameter Change Indicatorを用いて通知する場合の、簡易型Mode Change時の各部の処理について説明する。
パラメータの変更が撮像部21と画像処理部32の間で行われた後、ステップS501において、撮像部21は、変更後のパラメータをレジスタ53に設定する。
一方、ステップS531において、画像処理部32は、変更後のパラメータをレジスタ142に設定する。
ステップS532において、画像処理部32は、受信部31に対してConfigを出力する。ここで出力されるConfigは、変更後のパラメータがレジスタ142に設定されたこと(Write new setting)を通知するものであり、レジスタ142からパラメータを読み出して反映することを受信部31に対して要求するものではない。受信部31に対するConfigの出力は、例えば1フレーム目の所定のラインの伝送中に行われる。
ステップS521において、受信部31は、画像処理部32から出力されたConfigを受信する。
ステップS533において、画像処理部32は、撮像部21に対してMode Changeを発行する。Mode Changeの発行も、例えば1フレーム目の所定のラインの伝送中に行われる。
ステップS502において、撮像部21は、Mode Changeの発行を受信する。
ステップS503において、撮像部21は、送信部22に対してConfigを出力する。ここで出力されるConfigは、変更後のパラメータがレジスタ53に設定されたこと(Write new setting)を通知するものであり、レジスタ53からパラメータを読み出して反映することを送信部22に対して要求するものではない。
ステップS511において、送信部22は、撮像部21から出力されたConfigを受信する。
例えば1フレーム目の最後のラインの送信が終了したステップS512において、送信部22は、レジスタ53からパラメータを読み出してデータの送信動作に反映させる。状態制御部71は、リンクレイヤの各部を制御し、新たに設定されたパラメータに応じた処理を行わせる。
変更されたパラメータがPixel Bit,Line Length,ECC Option,CRC Optionのうちのいずれかである場合、ステップS513において、送信部22の状態制御部71は、リンクレイヤの状態を、簡易型Mode Changeを実行する状態とする。
ステップS514において、送信部22のパケット生成部64は、2フレーム目の先頭ラインのデータをペイロードに格納し、Parameter Change Indicatorの値として1を設定したヘッダを付加することによってパケットを生成する。Parameter Change Indicatorの値として1が設定されたヘッダは、ヘッダ生成部72により生成され、パケット生成部64に対して供給される。
すなわち、この例においては、Parameter Change Indicatorは、あるフレームの先頭ラインのパケットのヘッダに設定される。
ステップS515において、送信部22は、先頭ラインのパケットを送信する。先頭ラインのパケットを構成するパケットデータはデータストリームとして受信部31に対して供給される。
ステップS522において、受信部31は、送信部22から送信されたデータストリームに対して処理を施し、先頭ラインのパケットを受信する。先頭ラインのパケットはパケット分離部123により分離され、ヘッダを構成する各情報が例えば状態制御部131に供給される。
ステップS523において、状態制御部131は、ヘッダを解析し、Parameter Change Indicatorの値として1が設定されていることに基づいて、Pixel Bit,Line Length,ECC Option,CRC Optionのうちのいずれかのパラメータの変更が生じていることを検出する。
ステップS524において、状態制御部131は、パラメータの変更が生じていることを検出したことに応じて、レジスタ142からパラメータを読み出してデータの受信動作に反映させる。状態制御部131は、リンクレイヤの各部を制御し、新たに設定されたパラメータに応じた処理を行わせる。これにより、送信部22と受信部31の双方においてパラメータの変更が反映された状態になる。
ステップS516において、送信部22は、有効フレームの各ラインのパケットを送信する。
一方、ステップS525において、受信部31は、送信部22から送信された各ラインのパケットを受信する。その後、送信部22と受信部31の間では有効フレームの送受信が続けられる。
このように、あるフレームの先頭ラインのパケットのヘッダを用いてParameter Change Indicatorを伝送することにより、当該先頭ライン以降においてパラメータの変更が生じているのか否かを送信側から受信側に通知することが可能になる。
また、無効フレームの伝送がない簡易型Mode Changeによるパラメータの変更を、フレーム単位で行わせることが可能になる。
Parameter Change Indicatorを用いた通知が、あるフレームの先頭ラインのパケットのヘッダを用いて行われるのではなく、各ラインのパケットのヘッダを用いて行われるようにしてもよい。
これにより、無効フレームの伝送がない簡易型Mode Changeによるパラメータの変更を、ライン単位で行わせることが可能になる。
Parameter Change Indicatorが図51を参照して説明したようにして設定されるようにすることにより、後方互換性を維持しながら、新しい情報を受信側に伝送することが可能になる。
また、27ビットのリザーブ領域を、Information typeの領域とAdditional Informationの領域に分けることで、拡張性を残しておくことが可能になる。
・(3-3)Packet Headerを用いてパラメータを伝送する例
パケットに付加されるヘッダを用いて、パラメータ自体が送信側から受信側に通知されるようにしてもよい。
図54は、リザーブ領域の27ビット([26:0])の割り当ての他の例を示す図である。
図54に示すように、リザーブ領域の27ビットのうちの上位3ビット([26:24])は、Information Typeとして割り当てられる。
Information Type([2:0])の値が000(3’d0)であることは、リザーブ領域が、パラメータの格納に用いられていないことを示す。例えば、受信側において、ヘッダに格納されたパラメータを解釈することができない場合、Information Typeの値として000が設定される。これにより、受信側の性能の違いによる互換性を確保することが可能になる。
Information Typeの値が001(3’d1)であることは、リザーブ領域が、パラメータとしてのLink Parametersの格納に用いられていることを示す。
リザーブ領域の27ビットのうちの上位4ビット目以降の24ビット([23:0])は、Additional Informationとして割り当てられる。
図55は、Information Typeの値が001である場合のAdditional Informationの例を示す図である。
Additional Informationとして割り当てられた24ビットのうちの上位3ビット([23:21])は、Pixel Bitに割り当てられる。3ビットを用いて、1画素のビット数が示される。
Pixel Bitの値が000(3’d0)であることは、1画素が8ビットで表されることを示す。Pixel Bitの値が001(3’d1)であることは、1画素が10ビットで表されることを示す。Pixel Bitの値が010(3’d2)であることは、1画素が12ビットで表されることを示す。Pixel Bitの値が011(3’d3)であることは、1画素が14ビットで表されることを示す。Pixel Bitの値が100(3’d4)であることは、1画素が16ビットで表されることを示す。
Additional Informationとして割り当てられた24ビットのうちの18ビット([20:3])は、Line Lengthに割り当てられる。18ビットを用いて、1ラインあたりの画素数が示される。
Additional Informationとして割り当てられた24ビットのうちの2ビット([2:1])は、ECC Optionに割り当てられる。2ビットを用いて、ECC Optionの種類が示される。
ECC Optionの値が00(2’d0)であることは、ECC Optionの種類がECC Option 0であることを示す。ECC Optionの値が01(2’d1)であることは、ECC Optionの種類がECC Option 1であることを示す。ECC Optionの値が10(2’d2)であることは、ECC Optionの種類がECC Option 2であることを示す。
Additional Informationとして割り当てられた24ビットのうちの最下位の1ビット([0])は、CRC Optionに割り当てられる。1ビットを用いて、CRC OptionのON/OFFが示される。
CRC Optionの値が1(1’b1)であることは、CRC OptionがONであることを示す。CRC Optionの値が0(1’b0)であることは、CRC OptionがOFFであることを示す。
このように、パケットのヘッダには、Pixel Bit,Line Length,ECC Option,CRC OptionであるLink Parametersが設定される。
ここで、図56のシーケンス図を参照して、Link Parametersをヘッダを用いて通知する場合の、簡易型Mode Change時の各部の処理について説明する。図56に示す処理のうち、図53を参照して説明した処理と同様の処理の説明については適宜省略する。
パラメータの変更が撮像部21と画像処理部32の間で行われた後、ステップS551において、撮像部21は、変更後のパラメータをレジスタ53に設定する。
一方、ステップS581において、画像処理部32は、変更後のパラメータをレジスタ142に設定する。
ステップS582において、画像処理部32は、受信部31に対してConfigを出力する。ここで出力されるConfigは、変更後のパラメータがレジスタ142に設定されたことを通知するものである。受信部31に対するConfigの出力は、例えば1フレーム目の所定のラインの伝送中に行われる。
ステップS571において、受信部31は、画像処理部32から出力されたConfigを受信する。
ステップS583において、画像処理部32は、撮像部21に対してMode Changeを発行する。Mode Changeの発行も、例えば1フレーム目の所定のラインの伝送中に行われる。
ステップS552において、撮像部21は、Mode Changeの発行を受信する。
ステップS553において、撮像部21は、送信部22に対してConfigを出力する。ここで出力されるConfigは、変更後のパラメータがレジスタ53に設定されたことを通知するものである。
ステップS561において、送信部22は、撮像部21から出力されたConfigを受信する。
1フレーム目の最後のラインの送信が終了したステップS562において、送信部22は、レジスタ53からパラメータを読み出してデータの送信動作に反映させる。状態制御部71は、リンクレイヤの各部を制御し、新たに設定されたパラメータに応じた処理を行わせる。
変更されたパラメータがPixel Bit,Line Length,ECC Option,CRC Optionのうちのいずれかである場合、ステップS563において、送信部22の状態制御部71は、リンクレイヤの状態を、簡易型Mode Changeを実行する状態とする。
ステップS564において、送信部22のパケット生成部64は、2フレーム目の先頭ラインのデータをペイロードに格納し、Link Parametersを含むヘッダを付加することによってパケットを生成する。Link Parametersの各値を含むヘッダは、ヘッダ生成部72により生成され、パケット生成部64に対して供給される。
ステップS565において、送信部22は、先頭ラインのパケットを送信する。先頭ラインのパケットを構成するパケットデータはデータストリームとして受信部31に対して供給される。
ステップS572において、受信部31は、送信部22から送信されたデータストリームに対して処理を施し、先頭ラインのパケットを受信する。先頭ラインのパケットはパケット分離部123により分離され、ヘッダを構成する各情報が例えば状態制御部131に供給される。
ステップS573において、状態制御部131は、ヘッダを解析し、Link Parametersが含まれていることを検出する。
ステップS574において、状態制御部131は、Link Parametersをデータの受信動作に反映させ、Link Parametersに応じた処理をリンクレイヤの各部に行わせる。これにより、送信部22と受信部31の双方においてパラメータの変更が反映された状態になる。
ステップS566において、送信部22は、有効フレームの各ラインのパケットを送信する。
一方、ステップS575において、受信部31は、送信部22から送信された各ラインのパケットを受信する。その後、送信部22と受信部31の間では有効フレームの送受信が続けられる。
このように、あるフレームの先頭ラインのパケットのヘッダを用いてLink Parametersを伝送することにより、フレーム単位で、変更後のパラメータを送信側から受信側に通知することが可能になる。
Link Parametersの通知が、あるフレームの先頭ラインのパケットのヘッダを用いて行われるのではなく、各ラインのパケットのヘッダを用いて行われるようにしてもよい。
これにより、無効フレームの伝送がない簡易型Mode Changeによるパラメータの変更を、ライン単位で行わせることが可能になる。
Link Parametersが図54を参照して説明したようにして設定されるようにすることにより、後方互換性を維持しながら、新しい情報を受信側に伝送することが可能になる。
なお、ヘッダを用いたLink Parametersの伝送が、パラメータの変更が生じ、簡易型Mode Changeを行う場合にだけ行われ、パラメータの変更が生じていない場合には行われないようにしてもよい。
ヘッダのリザーブ領域の割り当ては、上述した例に限られるものではない。例えば、Parameter Change Indicatorを格納する場合、リザーブ領域の27ビットのうちの先頭の1ビットがParameter Change Indicatorとして割り当てられるようにすることが可能である。また、Link Parametersとしてヘッダを用いて伝送される情報についても、図55を参照して説明した情報に限られるものではなく、他の情報が伝送されるようにしてもよい。
<3.変形例>
上述した複数のレーンを使ったチップ間のデータ伝送は、画像データだけでなく、音声データ、テキストデータなどの各種のデータの伝送にも用いることができる。
以上においては、イメージセンサ11とDSP12が同一の装置内に設けられるものとしたが、それぞれ異なる装置内に設けられるようにしてもよい。
・コンピュータの構成例
上述した一連の処理は、ハードウェアにより実行することもできるし、ソフトウェアにより実行することもできる。一連の処理をソフトウェアにより実行する場合には、そのソフトウェアを構成するプログラムが、専用のハードウェアに組み込まれているコンピュータ、または汎用のパーソナルコンピュータなどに、プログラム記録媒体からインストールされる。
図57は、上述した一連の処理をプログラムにより実行するコンピュータのハードウェアの構成例を示すブロック図である。
CPU(Central Processing Unit)1001、ROM(Read Only Memory)1002、RAM(Random Access Memory)1003は、バス1004により相互に接続されている。
バス1004には、さらに、入出力インタフェース1005が接続されている。入出力インタフェース1005には、キーボード、マウスなどよりなる入力部1006、ディスプレイ、スピーカなどよりなる出力部1007が接続される。また、入出力インタフェース1005には、ハードディスクや不揮発性のメモリなどよりなる記憶部1008、ネットワークインタフェースなどよりなる通信部1009、リムーバブルメディア1011を駆動するドライブ1010が接続される。
以上のように構成されるコンピュータでは、CPU1001が、例えば、記憶部1008に記憶されているプログラムを入出力インタフェース1005及びバス1004を介してRAM1003にロードして実行することにより、上述した一連の処理が行われる。
CPU1001が実行するプログラムは、例えばリムーバブルメディア1011に記録して、あるいは、ローカルエリアネットワーク、インターネット、デジタル放送といった、有線または無線の伝送媒体を介して提供され、記憶部1008にインストールされる。
なお、コンピュータが実行するプログラムは、本明細書で説明する順序に沿って時系列に処理が行われるプログラムであっても良いし、並列に、あるいは呼び出しが行われたとき等の必要なタイミングで処理が行われるプログラムであっても良い。
本技術の実施の形態は、上述した実施の形態に限定されるものではなく、本技術の要旨を逸脱しない範囲において種々の変更が可能である。
なお、本明細書に記載された効果はあくまで例示であって限定されるものでは無く、また他の効果があってもよい。
<4.応用例>
本開示に係る技術は、様々な製品へ応用することができる。例えば、本開示に係る技術は、内視鏡手術システムに適用されてもよい。この場合、上述したイメージセンサ11は、内視鏡側の筐体内に設けられ、DSP12は、内視鏡から送信されてきた画像データの処理を行う画像処理装置側の筐体内に設けられる。
図58は、本開示に係る技術が適用され得る内視鏡手術システム5000の概略的な構成の一例を示す図である。図58では、術者(医師)5067が、内視鏡手術システム5000を用いて、患者ベッド5069上の患者5071に手術を行っている様子が図示されている。図示するように、内視鏡手術システム5000は、内視鏡5001と、その他の術具5017と、内視鏡5001を支持する支持アーム装置5027と、内視鏡下手術のための各種の装置が搭載されたカート5037と、から構成される。
内視鏡手術では、腹壁を切って開腹する代わりに、トロッカ5025a~5025dと呼ばれる筒状の開孔器具が腹壁に複数穿刺される。そして、トロッカ5025a~5025dから、内視鏡5001の鏡筒5003や、その他の術具5017が患者5071の体腔内に挿入される。図示する例では、その他の術具5017として、気腹チューブ5019、エネルギー処置具5021及び鉗子5023が、患者5071の体腔内に挿入されている。また、エネルギー処置具5021は、高周波電流や超音波振動により、組織の切開及び剥離、又は血管の封止等を行う処置具である。ただし、図示する術具5017はあくまで一例であり、術具5017としては、例えば攝子、レトラクタ等、一般的に内視鏡下手術において用いられる各種の術具が用いられてよい。
内視鏡5001によって撮影された患者5071の体腔内の術部の画像が、表示装置5041に表示される。術者5067は、表示装置5041に表示された術部の画像をリアルタイムで見ながら、エネルギー処置具5021や鉗子5023を用いて、例えば患部を切除する等の処置を行う。なお、図示は省略しているが、気腹チューブ5019、エネルギー処置具5021及び鉗子5023は、手術中に、術者5067又は助手等によって支持される。
(支持アーム装置)
支持アーム装置5027は、ベース部5029から延伸するアーム部5031を備える。図示する例では、アーム部5031は、関節部5033a、5033b、5033c、及びリンク5035a、5035bから構成されており、アーム制御装置5045からの制御により駆動される。アーム部5031によって内視鏡5001が支持され、その位置及び姿勢が制御される。これにより、内視鏡5001の安定的な位置の固定が実現され得る。
(内視鏡)
内視鏡5001は、先端から所定の長さの領域が患者5071の体腔内に挿入される鏡筒5003と、鏡筒5003の基端に接続されるカメラヘッド5005と、から構成される。図示する例では、硬性の鏡筒5003を有するいわゆる硬性鏡として構成される内視鏡5001を図示しているが、内視鏡5001は、軟性の鏡筒5003を有するいわゆる軟性鏡として構成されてもよい。
鏡筒5003の先端には、対物レンズが嵌め込まれた開口部が設けられている。内視鏡5001には光源装置5043が接続されており、当該光源装置5043によって生成された光が、鏡筒5003の内部に延設されるライトガイドによって当該鏡筒の先端まで導光され、対物レンズを介して患者5071の体腔内の観察対象に向かって照射される。なお、内視鏡5001は、直視鏡であってもよいし、斜視鏡又は側視鏡であってもよい。
カメラヘッド5005の内部には光学系及び撮像素子が設けられており、観察対象からの反射光(観察光)は当該光学系によって当該撮像素子に集光される。当該撮像素子によって観察光が光電変換され、観察光に対応する電気信号、すなわち観察像に対応する画像信号が生成される。当該画像信号は、RAWデータとしてカメラコントロールユニット(CCU:Camera Control Unit)5039に送信される。なお、カメラヘッド5005には、その光学系を適宜駆動させることにより、倍率及び焦点距離を調整する機能が搭載される。
なお、例えば立体視(3D表示)等に対応するために、カメラヘッド5005には撮像素子が複数設けられてもよい。この場合、鏡筒5003の内部には、当該複数の撮像素子のそれぞれに観察光を導光するために、リレー光学系が複数系統設けられる。
(カートに搭載される各種の装置)
CCU5039は、CPU(Central Processing Unit)やGPU(Graphics Processing Unit)等によって構成され、内視鏡5001及び表示装置5041の動作を統括的に制御する。具体的には、CCU5039は、カメラヘッド5005から受け取った画像信号に対して、例えば現像処理(デモザイク処理)等の、当該画像信号に基づく画像を表示するための各種の画像処理を施す。CCU5039は、当該画像処理を施した画像信号を表示装置5041に提供する。また、CCU5039は、カメラヘッド5005に対して制御信号を送信し、その駆動を制御する。当該制御信号には、倍率や焦点距離等、撮像条件に関する情報が含まれ得る。
表示装置5041は、CCU5039からの制御により、当該CCU5039によって画像処理が施された画像信号に基づく画像を表示する。内視鏡5001が例えば4K(水平画素数3840×垂直画素数2160)又は8K(水平画素数7680×垂直画素数4320)等の高解像度の撮影に対応したものである場合、及び/又は3D表示に対応したものである場合には、表示装置5041としては、それぞれに対応して、高解像度の表示が可能なもの、及び/又は3D表示可能なものが用いられ得る。4K又は8K等の高解像度の撮影に対応したものである場合、表示装置5041として55インチ以上のサイズのものを用いることで一層の没入感が得られる。また、用途に応じて、解像度、サイズが異なる複数の表示装置5041が設けられてもよい。
光源装置5043は、例えばLED(light emitting diode)等の光源から構成され、術部を撮影する際の照射光を内視鏡5001に供給する。
アーム制御装置5045は、例えばCPU等のプロセッサによって構成され、所定のプログラムに従って動作することにより、所定の制御方式に従って支持アーム装置5027のアーム部5031の駆動を制御する。
入力装置5047は、内視鏡手術システム5000に対する入力インタフェースである。ユーザは、入力装置5047を介して、内視鏡手術システム5000に対して各種の情報の入力や指示入力を行うことができる。例えば、ユーザは、入力装置5047を介して、患者の身体情報や、手術の術式についての情報等、手術に関する各種の情報を入力する。また、例えば、ユーザは、入力装置5047を介して、アーム部5031を駆動させる旨の指示や、内視鏡5001による撮像条件(照射光の種類、倍率及び焦点距離等)を変更する旨の指示、エネルギー処置具5021を駆動させる旨の指示等を入力する。
入力装置5047の種類は限定されず、入力装置5047は各種の公知の入力装置であってよい。入力装置5047としては、例えば、マウス、キーボード、タッチパネル、スイッチ、フットスイッチ5057及び/又はレバー等が適用され得る。入力装置5047としてタッチパネルが用いられる場合には、当該タッチパネルは表示装置5041の表示面上に設けられてもよい。
あるいは、入力装置5047は、例えばメガネ型のウェアラブルデバイスやHMD(Head Mounted Display)等の、ユーザによって装着されるデバイスであり、これらのデバイスによって検出されるユーザのジェスチャや視線に応じて各種の入力が行われる。また、入力装置5047は、ユーザの動きを検出可能なカメラを含み、当該カメラによって撮像された映像から検出されるユーザのジェスチャや視線に応じて各種の入力が行われる。更に、入力装置5047は、ユーザの声を収音可能なマイクロフォンを含み、当該マイクロフォンを介して音声によって各種の入力が行われる。このように、入力装置5047が非接触で各種の情報を入力可能に構成されることにより、特に清潔域に属するユーザ(例えば術者5067)が、不潔域に属する機器を非接触で操作することが可能となる。また、ユーザは、所持している術具から手を離すことなく機器を操作することが可能となるため、ユーザの利便性が向上する。
処置具制御装置5049は、組織の焼灼、切開又は血管の封止等のためのエネルギー処置具5021の駆動を制御する。気腹装置5051は、内視鏡5001による視野の確保及び術者の作業空間の確保の目的で、患者5071の体腔を膨らめるために、気腹チューブ5019を介して当該体腔内にガスを送り込む。レコーダ5053は、手術に関する各種の情報を記録可能な装置である。プリンタ5055は、手術に関する各種の情報を、テキスト、画像又はグラフ等各種の形式で印刷可能な装置である。
以下、内視鏡手術システム5000において特に特徴的な構成について、更に詳細に説明する。
(支持アーム装置)
支持アーム装置5027は、基台であるベース部5029と、ベース部5029から延伸するアーム部5031と、を備える。図示する例では、アーム部5031は、複数の関節部5033a、5033b、5033cと、関節部5033bによって連結される複数のリンク5035a、5035bと、から構成されているが、図58では、簡単のため、アーム部5031の構成を簡略化して図示している。実際には、アーム部5031が所望の自由度を有するように、関節部5033a~5033c及びリンク5035a、5035bの形状、数及び配置、並びに関節部5033a~5033cの回転軸の方向等が適宜設定され得る。例えば、アーム部5031は、好適に、6自由度以上の自由度を有するように構成され得る。これにより、アーム部5031の可動範囲内において内視鏡5001を自由に移動させることが可能になるため、所望の方向から内視鏡5001の鏡筒5003を患者5071の体腔内に挿入することが可能になる。
関節部5033a~5033cにはアクチュエータが設けられており、関節部5033a~5033cは当該アクチュエータの駆動により所定の回転軸まわりに回転可能に構成されている。当該アクチュエータの駆動がアーム制御装置5045によって制御されることにより、各関節部5033a~5033cの回転角度が制御され、アーム部5031の駆動が制御される。これにより、内視鏡5001の位置及び姿勢の制御が実現され得る。この際、アーム制御装置5045は、力制御又は位置制御等、各種の公知の制御方式によってアーム部5031の駆動を制御することができる。
例えば、術者5067が、入力装置5047(フットスイッチ5057を含む)を介して適宜操作入力を行うことにより、当該操作入力に応じてアーム制御装置5045によってアーム部5031の駆動が適宜制御され、内視鏡5001の位置及び姿勢が制御されてよい。当該制御により、アーム部5031の先端の内視鏡5001を任意の位置から任意の位置まで移動させた後、その移動後の位置で固定的に支持することができる。なお、アーム部5031は、いわゆるマスタースレイブ方式で操作されてもよい。この場合、アーム部5031は、手術室から離れた場所に設置される入力装置5047を介してユーザによって遠隔操作され得る。
また、力制御が適用される場合には、アーム制御装置5045は、ユーザからの外力を受け、その外力にならってスムーズにアーム部5031が移動するように、各関節部5033a~5033cのアクチュエータを駆動させる、いわゆるパワーアシスト制御を行ってもよい。これにより、ユーザが直接アーム部5031に触れながらアーム部5031を移動させる際に、比較的軽い力で当該アーム部5031を移動させることができる。従って、より直感的に、より簡易な操作で内視鏡5001を移動させることが可能となり、ユーザの利便性を向上させることができる。
ここで、一般的に、内視鏡下手術では、スコピストと呼ばれる医師によって内視鏡5001が支持されていた。これに対して、支持アーム装置5027を用いることにより、人手によらずに内視鏡5001の位置をより確実に固定することが可能になるため、術部の画像を安定的に得ることができ、手術を円滑に行うことが可能になる。
なお、アーム制御装置5045は必ずしもカート5037に設けられなくてもよい。また、アーム制御装置5045は必ずしも1つの装置でなくてもよい。例えば、アーム制御装置5045は、支持アーム装置5027のアーム部5031の各関節部5033a~5033cにそれぞれ設けられてもよく、複数のアーム制御装置5045が互いに協働することにより、アーム部5031の駆動制御が実現されてもよい。
(光源装置)
光源装置5043は、内視鏡5001に術部を撮影する際の照射光を供給する。光源装置5043は、例えばLED、レーザ光源又はこれらの組み合わせによって構成される白色光源から構成される。このとき、RGBレーザ光源の組み合わせにより白色光源が構成される場合には、各色(各波長)の出力強度及び出力タイミングを高精度に制御することができるため、光源装置5043において撮像画像のホワイトバランスの調整を行うことができる。また、この場合には、RGBレーザ光源それぞれからのレーザ光を時分割で観察対象に照射し、その照射タイミングに同期してカメラヘッド5005の撮像素子の駆動を制御することにより、RGBそれぞれに対応した画像を時分割で撮像することも可能である。当該方法によれば、当該撮像素子にカラーフィルタを設けなくても、カラー画像を得ることができる。
また、光源装置5043は、出力する光の強度を所定の時間ごとに変更するようにその駆動が制御されてもよい。その光の強度の変更のタイミングに同期してカメラヘッド5005の撮像素子の駆動を制御して時分割で画像を取得し、その画像を合成することにより、いわゆる黒つぶれ及び白とびのない高ダイナミックレンジの画像を生成することができる。
また、光源装置5043は、特殊光観察に対応した所定の波長帯域の光を供給可能に構成されてもよい。特殊光観察では、例えば、体組織における光の吸収の波長依存性を利用して、通常の観察時における照射光(すなわち、白色光)に比べて狭帯域の光を照射することにより、粘膜表層の血管等の所定の組織を高コントラストで撮影する、いわゆる狭帯域光観察(Narrow Band Imaging)が行われる。あるいは、特殊光観察では、励起光を照射することにより発生する蛍光により画像を得る蛍光観察が行われてもよい。蛍光観察では、体組織に励起光を照射し当該体組織からの蛍光を観察するもの(自家蛍光観察)、又はインドシアニングリーン(ICG)等の試薬を体組織に局注するとともに当該体組織にその試薬の蛍光波長に対応した励起光を照射し蛍光像を得るもの等が行われ得る。光源装置5043は、このような特殊光観察に対応した狭帯域光及び/又は励起光を供給可能に構成され得る。
(カメラヘッド及びCCU)
図59を参照して、内視鏡5001のカメラヘッド5005及びCCU5039の機能についてより詳細に説明する。図59は、図58に示すカメラヘッド5005及びCCU5039の機能構成の一例を示すブロック図である。
図59を参照すると、カメラヘッド5005は、その機能として、レンズユニット5007と、撮像部5009と、駆動部5011と、通信部5013と、カメラヘッド制御部5015と、を有する。また、CCU5039は、その機能として、通信部5059と、画像処理部5061と、制御部5063と、を有する。カメラヘッド5005とCCU5039とは、伝送ケーブル5065によって双方向に通信可能に接続されている。
まず、カメラヘッド5005の機能構成について説明する。レンズユニット5007は、鏡筒5003との接続部に設けられる光学系である。鏡筒5003の先端から取り込まれた観察光は、カメラヘッド5005まで導光され、当該レンズユニット5007に入射する。レンズユニット5007は、ズームレンズ及びフォーカスレンズを含む複数のレンズが組み合わされて構成される。レンズユニット5007は、撮像部5009の撮像素子の受光面上に観察光を集光するように、その光学特性が調整されている。また、ズームレンズ及びフォーカスレンズは、撮像画像の倍率及び焦点の調整のため、その光軸上の位置が移動可能に構成される。
撮像部5009は撮像素子によって構成され、レンズユニット5007の後段に配置される。レンズユニット5007を通過した観察光は、当該撮像素子の受光面に集光され、光電変換によって、観察像に対応した画像信号が生成される。撮像部5009によって生成された画像信号は、通信部5013に提供される。
撮像部5009を構成する撮像素子としては、例えばCMOS(Complementary Metal Oxide Semiconductor)タイプのイメージセンサであり、Bayer配列を有するカラー撮影可能なものが用いられる。なお、当該撮像素子としては、例えば4K以上の高解像度の画像の撮影に対応可能なものが用いられてもよい。術部の画像が高解像度で得られることにより、術者5067は、当該術部の様子をより詳細に把握することができ、手術をより円滑に進行することが可能となる。
また、撮像部5009を構成する撮像素子は、3D表示に対応する右目用及び左目用の画像信号をそれぞれ取得するための1対の撮像素子を有するように構成される。3D表示が行われることにより、術者5067は術部における生体組織の奥行きをより正確に把握することが可能になる。なお、撮像部5009が多板式で構成される場合には、各撮像素子に対応して、レンズユニット5007も複数系統設けられる。
また、撮像部5009は、必ずしもカメラヘッド5005に設けられなくてもよい。例えば、撮像部5009は、鏡筒5003の内部に、対物レンズの直後に設けられてもよい。
駆動部5011は、アクチュエータによって構成され、カメラヘッド制御部5015からの制御により、レンズユニット5007のズームレンズ及びフォーカスレンズを光軸に沿って所定の距離だけ移動させる。これにより、撮像部5009による撮像画像の倍率及び焦点が適宜調整され得る。
通信部5013は、CCU5039との間で各種の情報を送受信するための通信装置によって構成される。通信部5013は、撮像部5009から得た画像信号をRAWデータとして伝送ケーブル5065を介してCCU5039に送信する。この際、術部の撮像画像を低レイテンシで表示するために、当該画像信号は光通信によって送信されることが好ましい。手術の際には、術者5067が撮像画像によって患部の状態を観察しながら手術を行うため、より安全で確実な手術のためには、術部の動画像が可能な限りリアルタイムに表示されることが求められるからである。光通信が行われる場合には、通信部5013には、電気信号を光信号に変換する光電変換モジュールが設けられる。画像信号は当該光電変換モジュールによって光信号に変換された後、伝送ケーブル5065を介してCCU5039に送信される。
また、通信部5013は、CCU5039から、カメラヘッド5005の駆動を制御するための制御信号を受信する。当該制御信号には、例えば、撮像画像のフレームレートを指定する旨の情報、撮像時の露出値を指定する旨の情報、並びに/又は撮像画像の倍率及び焦点を指定する旨の情報等、撮像条件に関する情報が含まれる。通信部5013は、受信した制御信号をカメラヘッド制御部5015に提供する。なお、CCU5039からの制御信号も、光通信によって伝送されてもよい。この場合、通信部5013には、光信号を電気信号に変換する光電変換モジュールが設けられ、制御信号は当該光電変換モジュールによって電気信号に変換された後、カメラヘッド制御部5015に提供される。
なお、上記のフレームレートや露出値、倍率、焦点等の撮像条件は、取得された画像信号に基づいてCCU5039の制御部5063によって自動的に設定される。つまり、いわゆるAE(Auto Exposure)機能、AF(Auto Focus)機能及びAWB(Auto White Balance)機能が内視鏡5001に搭載される。
カメラヘッド制御部5015は、通信部5013を介して受信したCCU5039からの制御信号に基づいて、カメラヘッド5005の駆動を制御する。例えば、カメラヘッド制御部5015は、撮像画像のフレームレートを指定する旨の情報及び/又は撮像時の露光を指定する旨の情報に基づいて、撮像部5009の撮像素子の駆動を制御する。また、例えば、カメラヘッド制御部5015は、撮像画像の倍率及び焦点を指定する旨の情報に基づいて、駆動部5011を介してレンズユニット5007のズームレンズ及びフォーカスレンズを適宜移動させる。カメラヘッド制御部5015は、更に、鏡筒5003やカメラヘッド5005を識別するための情報を記憶する機能を備えてもよい。
なお、レンズユニット5007や撮像部5009等の構成を、気密性及び防水性が高い密閉構造内に配置することで、カメラヘッド5005について、オートクレーブ滅菌処理に対する耐性を持たせることができる。
次に、CCU5039の機能構成について説明する。通信部5059は、カメラヘッド5005との間で各種の情報を送受信するための通信装置によって構成される。通信部5059は、カメラヘッド5005から、伝送ケーブル5065を介して送信される画像信号を受信する。この際、上記のように、当該画像信号は好適に光通信によって送信され得る。この場合、光通信に対応して、通信部5059には、光信号を電気信号に変換する光電変換モジュールが設けられる。通信部5059は、電気信号に変換した画像信号を画像処理部5061に提供する。
また、通信部5059は、カメラヘッド5005に対して、カメラヘッド5005の駆動を制御するための制御信号を送信する。当該制御信号も光通信によって送信されてよい。
画像処理部5061は、カメラヘッド5005から送信されたRAWデータである画像信号に対して各種の画像処理を施す。当該画像処理としては、例えば現像処理、高画質化処理(帯域強調処理、超解像処理、NR(Noise reduction)処理及び/又は手ブレ補正処理等)、並びに/又は拡大処理(電子ズーム処理)等、各種の公知の信号処理が含まれる。また、画像処理部5061は、AE、AF及びAWBを行うための、画像信号に対する検波処理を行う。
画像処理部5061は、CPUやGPU等のプロセッサによって構成され、当該プロセッサが所定のプログラムに従って動作することにより、上述した画像処理や検波処理が行われ得る。なお、画像処理部5061が複数のGPUによって構成される場合には、画像処理部5061は、画像信号に係る情報を適宜分割し、これら複数のGPUによって並列的に画像処理を行う。
制御部5063は、内視鏡5001による術部の撮像、及びその撮像画像の表示に関する各種の制御を行う。例えば、制御部5063は、カメラヘッド5005の駆動を制御するための制御信号を生成する。この際、撮像条件がユーザによって入力されている場合には、制御部5063は、当該ユーザによる入力に基づいて制御信号を生成する。あるいは、内視鏡5001にAE機能、AF機能及びAWB機能が搭載されている場合には、制御部5063は、画像処理部5061による検波処理の結果に応じて、最適な露出値、焦点距離及びホワイトバランスを適宜算出し、制御信号を生成する。
また、制御部5063は、画像処理部5061によって画像処理が施された画像信号に基づいて、術部の画像を表示装置5041に表示させる。この際、制御部5063は、各種の画像認識技術を用いて術部画像内における各種の物体を認識する。例えば、制御部5063は、術部画像に含まれる物体のエッジの形状や色等を検出することにより、鉗子等の術具、特定の生体部位、出血、エネルギー処置具5021使用時のミスト等を認識することができる。制御部5063は、表示装置5041に術部の画像を表示させる際に、その認識結果を用いて、各種の手術支援情報を当該術部の画像に重畳表示させる。手術支援情報が重畳表示され、術者5067に提示されることにより、より安全かつ確実に手術を進めることが可能になる。
カメラヘッド5005及びCCU5039を接続する伝送ケーブル5065は、電気信号の通信に対応した電気信号ケーブル、光通信に対応した光ファイバ、又はこれらの複合ケーブルである。
ここで、図示する例では、伝送ケーブル5065を用いて有線で通信が行われていたが、カメラヘッド5005とCCU5039との間の通信は無線で行われてもよい。両者の間の通信が無線で行われる場合には、伝送ケーブル5065を手術室内に敷設する必要がなくなるため、手術室内における医療スタッフの移動が当該伝送ケーブル5065によって妨げられる事態が解消され得る。
以上、本開示に係る技術が適用され得る内視鏡手術システム5000の一例について説明した。なお、ここでは、一例として内視鏡手術システム5000について説明したが、本開示に係る技術が適用され得るシステムはかかる例に限定されない。例えば、本開示に係る技術は、検査用軟性内視鏡システムや顕微鏡手術システムに適用されてもよい。
[構成の組み合わせ例]
本技術は、以下のような構成をとることもできる。
(1)
伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配する分配部と、
分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信する複数の信号処理部と、
前記データストリームの送信が所定のモードで行われている場合において、前記モードの内容を規定するパラメータを変更するとき、変更後の前記パラメータにより規定される前記モードでの前記データストリームの送信を、データの同期と前記レーン間のデータのタイミングのずれの補正とを前記受信装置において行うためのトレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える制御部と
を備える送信装置。
(2)
前記伝送対象のデータは、撮像して得られた画像データであり、
前記画像データは、それぞれの前記パケットにライン単位で格納される
前記(1)に記載の送信装置。
(3)
前記パラメータを設定し、前記画像データの供給元となる撮像部をさらに備え、
前記制御部は、前記受信装置から送信された、前記モードの変更を要求する情報が前記撮像部により受信された場合、前記撮像部により設定された前記パラメータの変更を反映させる
前記(2)に記載の送信装置。
(4)
変更後の前記パラメータにより規定される前記モードでの前記データストリームの送信を前記トレーニング処理を行わずに開始する場合、
複数の前記信号処理部は、前記トレーニング処理を行った場合に前記トレーニング処理に要する期間、ブランキングデータを送信し、前記ブランキングデータの送信終了後、前記データストリームを送信する
前記(2)または(3)に記載の送信装置。
(5)
複数の前記信号処理部は、前記パラメータの変更が行われたタイミングを基準として次のフレームの送信開始まで、前記ブランキングデータを送信する
前記(4)に記載の送信装置。
(6)
前記パラメータの変更が、所定のラインの送信後のブランキング期間に行われた場合、 複数の前記信号処理部は、前記所定のラインの次のラインの前記画像データを格納する前記パケットを構成する前記パケットデータの送信を、変更後の前記パラメータにより規定される前記モードで行う
前記(2)に記載の送信装置。
(7)
前記パラメータの変更が、所定のフレームの送信後のブランキング期間に行われた場合、
複数の前記信号処理部は、前記所定のフレームの次のフレームの前記画像データを格納する前記パケットを構成する前記パケットデータの送信を、変更後の前記パラメータにより規定される前記モードで行う
前記(2)に記載の送信装置。
(8)
前記パラメータの変更が行われたか否かを表すフラグをヘッダに含む前記パケットを生成するパケット生成部をさらに備える
前記(6)または(7)に記載の送信装置。
(9)
変更後の前記パラメータをヘッダに含む前記パケットを生成するパケット生成部をさらに備える
前記(6)または(7)に記載の送信装置。
(10)
前記パラメータは、
前記データストリームの送信に用いる前記レーンの数を表すレーン情報、
前記画像データを構成する各ピクセルのビット数を表すビット情報、
1ラインのピクセル数を表すライン情報、
前記パケットを構成するペイロードデータの誤り訂正に用いられる誤り訂正符号の種類を表す誤り訂正符号情報、
前記パケットを構成するフッタに含まれ、前記ペイロードデータの誤り検出に用いられる誤り検出符号の種類を表す誤り検出符号情報、
および、それぞれの前記レーンの伝送レートの種類を表すレート情報
のうちの少なくともいずれかを含む
前記(2)乃至(9)のうちのいずれかに記載の送信装置。
(11)
前記制御部は、変更する前記パラメータが、前記レーン情報または前記レート情報である場合、変更後の前記パラメータにより規定される前記モードでの前記データストリームの送信を前記トレーニング処理を行ってから開始させ、前記ビット情報、前記ライン情報、前記誤り訂正符号情報、または前記誤り検出符号情報である場合、変更後の前記パラメータにより規定される前記モードでの前記データストリームの送信を前記トレーニング処理を行わずに開始させる
前記(10)に記載の送信装置。
(12)
伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、
分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信し、
前記データストリームの送信が所定のモードで行われている場合において、前記モードの内容を規定するパラメータを変更するとき、変更後の前記パラメータにより規定される前記モードでの前記データストリームの送信を、データの同期と前記レーン間のデータのタイミングのずれの補正とを前記受信装置において行うためのトレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える
ステップを含む制御方法。
(13)
コンピュータに、
伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、
分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信し、
前記データストリームの送信が所定のモードで行われている場合において、前記モードの内容を規定するパラメータを変更するとき、変更後の前記パラメータにより規定される前記モードでの前記データストリームの送信を、データの同期と前記レーン間のデータのタイミングのずれの補正とを前記受信装置において行うためのトレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える
ステップを含む処理を実行させるプログラム。
(14)
伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを複数の前記レーンを用いて並列に送信する送信装置から送信されてきた前記データストリームを受信する複数の信号処理部と、
前記データストリームの送信が所定のモードで行われている場合において、前記モードの内容を規定するパラメータを変更するとき、変更後の前記パラメータにより規定される前記モードで送信された前記データストリームの受信を、データの同期と前記レーン間のデータのタイミングのずれの補正とを行うためのトレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える制御部と
を備える受信装置。
(15)
前記パケットのヘッダに含まれる、前記パラメータの変更が行われたか否かを表すフラグが、前記パラメータの変更が行われたことを表している場合、
前記制御部は、前記データストリームの受信を、前記トレーニング処理を行わずに開始させる
前記(14)に記載の受信装置。
(16)
前記制御部は、前記データストリームの受信を、前記ヘッダに含まれる前記パラメータを変更後の前記パラメータとして用いて、前記トレーニング処理を行わずに開始させる
前記(14)に記載の受信装置。
(17)
伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを複数の前記レーンを用いて並列に送信する送信装置から送信されてきた前記データストリームを受信し、
前記データストリームの送信が所定のモードで行われている場合において、前記モードの内容を規定するパラメータを変更するとき、変更後の前記パラメータにより規定される前記モードで送信された前記データストリームの受信を、データの同期と前記レーン間のデータのタイミングのずれの補正とを行うためのトレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える
ステップを含む制御方法。
(18)
コンピュータに、
伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを複数の前記レーンを用いて並列に送信する送信装置から送信されてきた前記データストリームを受信し、
前記データストリームの送信が所定のモードで行われている場合において、前記モードの内容を規定するパラメータを変更するとき、変更後の前記パラメータにより規定される前記モードで送信された前記データストリームの受信を、データの同期と前記レーン間のデータのタイミングのずれの補正とを行うためのトレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える
ステップを含む処理を実行させるプログラム。
(19)
伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配する分配部と、
分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信する複数の信号処理部と、
前記データストリームの送信が所定のモードで行われている場合において、前記モードの内容を規定するパラメータを変更するとき、変更後の前記パラメータにより規定される前記モードでの前記データストリームの送信を、データの同期と前記レーン間のデータのタイミングのずれの補正とを前記受信装置において行うためのトレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える制御部と
を備える送信装置と、
前記送信装置から送信されてきた前記データストリームを受信する複数の信号処理部と、
前記データストリームの送信が所定のモードで行われている場合において、前記パラメータを変更するとき、変更後の前記パラメータにより規定される前記モードで送信された前記データストリームの受信を、前記トレーニング処理を行ってから開始するか、前記トレーニング処理を行わずに開始するかを、変更する前記パラメータの種類に応じて切り替える制御部と
を備える受信装置と
を含む送受信システム。
1 伝送システム, 11 イメージセンサ, 12 DSP, 21 撮像部, 22 送信部, 31 受信部, 32 画像処理部, 62 Pixel to Byte変換部, 63 ペイロードECC挿入部, 64 パケット生成部, 65 レーン分配部, 72 ヘッダ生成部, 83-0乃至83-N 信号処理部, 91 制御コード挿入部, 92 8B10Bシンボルエンコーダ, 93 同期部, 94 送信部, 102-0乃至102-N 信号処理部, 111 受信部, 112 クロック生成部, 113 同期部, 114 シンボル同期部, 115 10B8Bシンボルデコーダ, 116 スキュー補正部, 117 制御コード除去部, 122 レーン統合部, 123 パケット分離部, 124 ペイロードエラー訂正部, 125 Byte to Pixel変換部, 132 ヘッダエラー訂正部

Claims (19)

  1. 伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配する分配部と、
    分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信する複数の信号処理部と、
    前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御する制御部と、
    を備え、
    前記制御部は、前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じた前記データストリームの送信を開始させる
    送信装置。
  2. 前記伝送対象のデータは、撮像して得られた画像データであり、
    前記画像データは、それぞれの前記パケットにライン単位で格納される
    請求項1に記載の送信装置。
  3. 前記パラメータを設定し、前記画像データの供給元となる撮像部をさらに備え、
    前記制御部は、前記パラメータの変更を要求する情報を前記受信装置から受信した場合、前記撮像部により設定された前記パラメータの変更を反映させる
    請求項2に記載の送信装置。
  4. 変更後の前記パラメータに応じた前記データストリームの送信を前記トレーニング処理を行わずに開始する場合、
    複数の前記信号処理部は、前記トレーニング処理を行った場合に前記トレーニング処理に要する期間、ブランキングデータを送信し、前記ブランキングデータの送信終了後、前記データストリームを送信する
    請求項2または3に記載の送信装置。
  5. 複数の前記信号処理部は、前記パラメータの変更が行われたタイミングを基準として次のフレームの送信開始まで、前記ブランキングデータを送信する
    請求項4に記載の送信装置。
  6. 前記パラメータの変更が、所定のラインの送信後のブランキング期間に行われた場合、
    複数の前記信号処理部は、前記所定のラインの次のラインの前記画像データを格納する前記パケットを構成する前記パケットデータの送信を、変更後の前記パラメータに応じて行う
    請求項2に記載の送信装置。
  7. 前記パラメータの変更が、所定のフレームの送信後のブランキング期間に行われた場合、
    複数の前記信号処理部は、前記所定のフレームの次のフレームの前記画像データを格納する前記パケットを構成する前記パケットデータの送信を、変更後の前記パラメータに応じて行う
    請求項2に記載の送信装置。
  8. 前記パラメータの変更が行われたか否かを表すフラグをヘッダに含む前記パケットを生成するパケット生成部をさらに備える
    請求項6または7に記載の送信装置。
  9. 変更後の前記パラメータをヘッダに含む前記パケットを生成するパケット生成部をさらに備える
    請求項6または7に記載の送信装置。
  10. 前記パラメータは、さらに、
    前記画像データを構成する各ピクセルのビット数を表すビット情報、
    1ラインのピクセル数を表すライン情報、
    前記パケットを構成するペイロードデータの誤り訂正に用いられる誤り訂正符号の種類を表す誤り訂正符号情報、
    前記パケットを構成するフッタに含まれ、前記ペイロードデータの誤り検出に用いられる誤り検出符号の種類を表す誤り検出符号情報
    のうちの少なくともいずれかを含む
    請求項2乃至9のうちのいずれかに記載の送信装置。
  11. 前記制御部は、変更する前記パラメータが、前記ビット情報、前記ライン情報、前記誤り訂正符号情報、または前記誤り検出符号情報である場合、変更後の前記パラメータに応じた前記データストリームの送信を前記トレーニング処理を行わずに開始させる
    請求項10に記載の送信装置。
  12. 伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、
    分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信し、
    前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御し、
    前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じた前記データストリームの送信を開始させる
    制御方法。
  13. コンピュータに、
    伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、
    分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信し、
    前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御し、
    前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じた前記データストリームの送信を開始させる
    処理を実行させるプログラム。
  14. 伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを複数の前記レーンを用いて並列に送信する送信装置から送信されてきた前記データストリームを受信する複数の信号処理部と、
    前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御する制御部と、
    を備え、
    前記制御部は、前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じて送信された前記データストリームの受信を開始させる
    受信装置。
  15. 前記パケットのヘッダに含まれる、前記パラメータの変更が行われたか否かを表すフラグが、前記パラメータの変更が行われたことを表している場合、
    前記制御部は、前記データストリームの受信を、前記トレーニング処理を行わずに開始させる
    請求項14に記載の受信装置。
  16. 前記制御部は、前記データストリームの受信を、前記パケットのヘッダに含まれる前記パラメータを変更後の前記パラメータとして用いて、前記トレーニング処理を行わずに開始させる
    請求項14に記載の受信装置。
  17. 伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを複数の前記レーンを用いて並列に送信する送信装置から送信されてきた前記データストリームを受信し、
    前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御し、
    前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じて送信された前記データストリームの受信を開始させる
    制御方法。
  18. コンピュータに、
    伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配し、分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを複数の前記レーンを用いて並列に送信する送信装置から送信されてきた前記データストリームを受信し、
    前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御し、
    前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じて送信された前記データストリームの受信を開始させる
    処理を実行させるプログラム。
  19. 伝送対象のデータを格納するパケットを構成するパケットデータを複数のレーンに分配する分配部と、
    分配した前記パケットデータを含む同一のデータ構造を有するデータストリームを、複数の前記レーンを用いて受信装置に対して並列に送信する複数の信号処理部と、
    前記データストリームの送信に関するパラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記レーン間のデータのタイミングのずれを補正するトレーニング処理を行うか否かを制御する制御部と、
    を備え、
    前記制御部は、前記パラメータが前記データストリームの送信に用いる前記レーンの数を表すレーン情報である場合、および、前記パラメータがそれぞれの前記レーンの伝送レートの種類を表すレート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じた前記データストリームの送信を開始させる
    送信装置と、
    前記送信装置から送信されてきた前記データストリームを受信する複数の信号処理部と、
    前記パラメータを変更する場合に、変更する前記パラメータの種類に応じて、前記トレーニング処理を行うか否かを制御する制御部と、
    を備え、
    前記パラメータが前記レーン情報である場合、および、前記パラメータが前記レート情報である場合には、前記トレーニング処理を行った後に、変更後の前記パラメータに応じて送信された前記データストリームの受信を開始させる
    前記受信装置と
    を含む送受信システム。
JP2022051318A 2017-06-09 2022-03-28 送信装置、受信装置、制御方法、プログラム、および送受信システム Active JP7326522B2 (ja)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
JP2017114381 2017-06-09
JP2017114381 2017-06-09
JP2019523450A JP7050059B2 (ja) 2017-06-09 2018-05-25 送信装置、受信装置、制御方法、プログラム、および送受信システム
PCT/JP2018/020115 WO2018225533A1 (ja) 2017-06-09 2018-05-25 送信装置、受信装置、制御方法、プログラム、および送受信システム

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2019523450A Division JP7050059B2 (ja) 2017-06-09 2018-05-25 送信装置、受信装置、制御方法、プログラム、および送受信システム

Publications (2)

Publication Number Publication Date
JP2022076012A true JP2022076012A (ja) 2022-05-18
JP7326522B2 JP7326522B2 (ja) 2023-08-15

Family

ID=64567193

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2019523450A Active JP7050059B2 (ja) 2017-06-09 2018-05-25 送信装置、受信装置、制御方法、プログラム、および送受信システム
JP2022051318A Active JP7326522B2 (ja) 2017-06-09 2022-03-28 送信装置、受信装置、制御方法、プログラム、および送受信システム

Family Applications Before (1)

Application Number Title Priority Date Filing Date
JP2019523450A Active JP7050059B2 (ja) 2017-06-09 2018-05-25 送信装置、受信装置、制御方法、プログラム、および送受信システム

Country Status (6)

Country Link
US (2) US11196961B2 (ja)
EP (1) EP3637715B1 (ja)
JP (2) JP7050059B2 (ja)
KR (1) KR102538714B1 (ja)
CN (1) CN110710177B (ja)
WO (1) WO2018225533A1 (ja)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2020255799A1 (ja) * 2019-06-18 2020-12-24 ソニーセミコンダクタソリューションズ株式会社 送信装置、受信装置、および通信システム
CN112422771B (zh) * 2019-08-21 2023-01-13 苏州华兴源创科技股份有限公司 一种资源重置系统
WO2021100602A1 (ja) * 2019-11-20 2021-05-27 ソニーセミコンダクタソリューションズ株式会社 送信装置、受信装置、および伝送システム
CN111540456B (zh) * 2020-06-08 2022-11-15 安翰科技(武汉)股份有限公司 数据载入方法及其胶囊内窥镜图像采集系统
US20230217102A1 (en) * 2020-06-10 2023-07-06 Sony Semiconductor Solutions Corporation Transmission device, reception device, and transmission-reception system
US11520729B2 (en) * 2021-05-04 2022-12-06 Qualcomm Incorporated I2C bus architecture using shared clock and dedicated data lines

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2012120158A (ja) * 2010-11-12 2012-06-21 Sony Corp 画像出力装置、画像出力方法、画像処理装置、画像処理方法、プログラム、データ構造、および撮像装置
US20140108686A1 (en) * 2012-05-22 2014-04-17 Mahesh Wagh Optimized Link Training And Management Mechanism
JP2015015533A (ja) * 2013-07-03 2015-01-22 株式会社リコー 画像データ伝送装置および画像データ伝送システム

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20010073607A (ko) * 2000-01-19 2001-08-01 구자홍 화상통신기기의 데이터 전송 프로토콜
JP3671920B2 (ja) 2001-11-15 2005-07-13 セイコーエプソン株式会社 スキュー調整回路及びスキュー調整方法
JP2008021228A (ja) * 2006-07-14 2008-01-31 Renesas Technology Corp データ処理装置
JP2012182697A (ja) * 2011-03-02 2012-09-20 Sony Corp 受信装置、送信装置、受信方法、送信方法、通信システム
JP2013051607A (ja) * 2011-08-31 2013-03-14 Canon Inc データ処理装置、方法および制御プログラム
US9052900B2 (en) * 2013-01-29 2015-06-09 Oracle International Corporation Serdes fast retrain method upon exiting power saving mode
JP6123882B2 (ja) 2013-03-19 2017-05-10 富士通株式会社 伝送装置、伝送システム、及び伝送方法
JP5805725B2 (ja) 2013-10-04 2015-11-04 ザインエレクトロニクス株式会社 送信装置、受信装置、送受信システムおよび画像表示システム
KR102195069B1 (ko) * 2014-08-06 2020-12-24 삼성전자주식회사 패킷 송신기 및 이를 포함하는 인터페이스 장치
US10009544B2 (en) * 2014-09-02 2018-06-26 Canon Kabushiki Kaisha Image capturing apparatus, control method of the same and image sensor

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2012120158A (ja) * 2010-11-12 2012-06-21 Sony Corp 画像出力装置、画像出力方法、画像処理装置、画像処理方法、プログラム、データ構造、および撮像装置
US20140108686A1 (en) * 2012-05-22 2014-04-17 Mahesh Wagh Optimized Link Training And Management Mechanism
JP2015015533A (ja) * 2013-07-03 2015-01-22 株式会社リコー 画像データ伝送装置および画像データ伝送システム

Also Published As

Publication number Publication date
EP3637715B1 (en) 2023-07-12
JP7326522B2 (ja) 2023-08-15
US11196961B2 (en) 2021-12-07
US11743423B2 (en) 2023-08-29
KR20200016202A (ko) 2020-02-14
CN110710177B (zh) 2022-12-16
JPWO2018225533A1 (ja) 2020-04-16
CN110710177A (zh) 2020-01-17
US20200195884A1 (en) 2020-06-18
WO2018225533A1 (ja) 2018-12-13
EP3637715A4 (en) 2020-05-06
EP3637715A1 (en) 2020-04-15
KR102538714B1 (ko) 2023-06-01
US20220094878A1 (en) 2022-03-24
JP7050059B2 (ja) 2022-04-07

Similar Documents

Publication Publication Date Title
JP7050059B2 (ja) 送信装置、受信装置、制御方法、プログラム、および送受信システム
JP7094952B2 (ja) 受信装置、制御方法、プログラム、および送受信システム
US20200126197A1 (en) Video signal processing apparatus, video signal processing method, and program
US20220078350A1 (en) Data transmission system, data transmission method, and computer program
US11996937B2 (en) Encoding device, encoding method, decoding device, decoding method, and program
US20240348266A1 (en) Encoding device, encoding method, decoding device, decoding method, and program
JP6132984B2 (ja) カプセル内視鏡システム及びその撮像方法
US10924724B2 (en) Medical stereoscopic observation device, medical stereoscopic observation method, program, and medical stereoscopic observation system
US11910105B2 (en) Video processing using a blended tone curve characteristic
US11558673B2 (en) Transmission device, reception device, transmission system, and transmission method
US20220322921A1 (en) Medical system, communication method, imaging device, information processing device, and endoscope system
WO2021230001A1 (ja) 情報処理装置及び情報処理方法
WO2020066972A1 (ja) 受信装置、および受信方法、並びに、画像処理システム

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20220415

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20221223

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20230110

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20230313

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: 20230704

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20230802

R150 Certificate of patent or registration of utility model

Ref document number: 7326522

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150