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

JP6604998B2 - 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム - Google Patents

画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム Download PDF

Info

Publication number
JP6604998B2
JP6604998B2 JP2017141305A JP2017141305A JP6604998B2 JP 6604998 B2 JP6604998 B2 JP 6604998B2 JP 2017141305 A JP2017141305 A JP 2017141305A JP 2017141305 A JP2017141305 A JP 2017141305A JP 6604998 B2 JP6604998 B2 JP 6604998B2
Authority
JP
Japan
Prior art keywords
image
reliability
motion
vector
motion vector
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.)
Active
Application number
JP2017141305A
Other languages
English (en)
Other versions
JP2019022162A (ja
Inventor
武史 安冨
陽一 高橋
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Inc
Original Assignee
Canon Inc
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 Canon Inc filed Critical Canon Inc
Priority to JP2017141305A priority Critical patent/JP6604998B2/ja
Priority to US16/034,975 priority patent/US10846822B2/en
Publication of JP2019022162A publication Critical patent/JP2019022162A/ja
Application granted granted Critical
Publication of JP6604998B2 publication Critical patent/JP6604998B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T3/00Geometric image transformations in the plane of the image
    • G06T3/40Scaling of whole images or parts thereof, e.g. expanding or contracting
    • G06T3/4038Image mosaicing, e.g. composing plane images from plane sub-images
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/20Analysis of motion
    • G06T7/223Analysis of motion using block-matching
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/513Processing of motion vectors
    • 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/68Control of cameras or camera modules for stable pick-up of the scene, e.g. compensating for camera body vibrations
    • H04N23/681Motion detection
    • H04N23/6812Motion detection based on additional sensors, e.g. acceleration sensors
    • 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/68Control of cameras or camera modules for stable pick-up of the scene, e.g. compensating for camera body vibrations
    • H04N23/682Vibration or motion blur correction
    • H04N23/683Vibration or motion blur correction performed by a processor, e.g. controlling the readout of an image memory
    • 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/68Control of cameras or camera modules for stable pick-up of the scene, e.g. compensating for camera body vibrations
    • H04N23/689Motion occurring during a rolling shutter mode
    • 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/698Control of cameras or camera modules for achieving an enlarged field of view, e.g. panoramic image capture
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/14Picture signal circuitry for video frequency region
    • H04N5/144Movement detection
    • H04N5/145Movement estimation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/222Studio circuitry; Studio devices; Studio equipment
    • H04N5/262Studio circuits, e.g. for mixing, switching-over, change of character of image, other special effects ; Cameras specially adapted for the electronic generation of special effects
    • H04N5/2628Alteration of picture size, shape, position or orientation, e.g. zooming, rotation, rolling, perspective, translation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/10Image acquisition modality
    • G06T2207/10016Video; Image sequence
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/527Global motion vector estimation

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Studio Devices (AREA)
  • Image Analysis (AREA)
  • Exposure Control For Cameras (AREA)
  • Details Of Cameras Including Film Mechanisms (AREA)
  • Stereoscopic And Panoramic Photography (AREA)
  • Automatic Focus Adjustment (AREA)
  • Image Processing (AREA)

Description

本発明は、画像処理装置に関するものであり、特に複数の画像に対して位置合わせを行う画像処理装置に関するものである。
デジタルカメラやカメラ機能付きの携帯電話などを移動させながら複数の画像を撮像し、撮像した複数の画像を繋ぎ合わせることによるパノラマ合成の技術が知られている。パノラマ合成では、違和感のない合成画像を取得するために、画像の位置合わせが不可欠である。
特許文献1では、ジャイロセンサなどで検出したデジタルカメラの動き情報と画像の比較で得られた動きベクトルとの両方を用いて、位置合わせを行うという方法が提示されている。特許文献1に提示された技術では、デジタルカメラの動き情報に基づいて、画像の位置合わせに用いる動きベクトルを選択することが記載されている。
特表2014−519739号公報
しかしながら、ジャイロセンサなどのセンサによって検出されたデジタルカメラの動き情報は、撮像条件など複数の要因で信頼度がばらつくことがある。同様に、動きベクトルに関しても、信頼度がばらつくことがある。それに対して特許文献1に開示された技術では、ジャイロセンサなどが検出した動き情報の信頼度を考慮せずに動きベクトルの選択を行っているため、誤った動きベクトルが選択されてしまい、位置合わせの精度が下がる可能性がある。
本発明は、上記の課題を鑑みてなされたものであり、動き情報と動きベクトルとを用いて画像間の位置合わせを行う際に、より適切な動きベクトルを得ることを目的とする。
本発明は、撮像手段が第1の画像と第2の画像とを撮像する間の前記撮像手段の動き情報を、前記撮像手段とは別のセンサの出力に基づいて検出する第1の検出手段と、前記第1の画像と第2の画像の間の複数の動きベクトルを検出する第2の検出手段と、第1の方向と、前記第1の方向と直交する第2の方向とのそれぞれで、前記第1の検出手段が検出した前記動き情報の第1の信頼度と前記第2の検出手段が検出した前記動きベクトルの第2の信頼度との高さの判断を行う判断手段と、前記第1の方向と前記第2の方向とのそれぞれにおいて、前記動きベクトルと前記動き情報が示すベクトルとのうちの前記第1の信頼度または前記第2の信頼度の高いもの、または、前記動きベクトルと前記動き情報から前記第1の信頼度と前記第2の信頼度との少なくともいずれかに応じて求めたベクトルの成分を求め、前記第1の方向と前記第2の方向のそれぞれにおいて求めたベクトルの成分から合成したベクトルに基づいて、前記第1の画像と前記第2の画像とに対して位置合わせを行う位置合わせ手段とを有することを特徴とする画像処理装置を提供する。
本発明によれば、画像の位置合わせに用いる動きベクトルの精度を向上させることができる。
本発明の実施形態に係るデジタルカメラの概略構成を示す背面斜視図である。 本発明の実施形態に係るデジタルカメラのハードウェア構成を示すブロック図である。 本発明の実施形態に係るパノラマ撮像中のデジタルカメラの動く方向と画像データの切り出し領域との関係を説明するための図である。 本発明の実施形態に係るパノラマ画像の合成処理の流れを説明する図である。 本発明の実施形態を説明するためのフローチャートである。 本発明の実施形態における検出部が検出した動き情報の誤差を説明するための図である。 本発明の実施形態における動き情報の信頼度の判断を説明するための図である。 本発明の実施形態における繰り返しパターンを説明するための図である。 本発明の実施形態における動きベクトルの信頼度の判断を説明するためのフローチャートである。 本発明の実施形態における動きベクトルの補正を説明するためのフローチャートである。 本発明の実施形態における動きベクトルの補正を説明するための図である。 本発明の実施形態における動きベクトルの除外を説明するための図である。 本発明の実施形態において画像全体の動きベクトル用いる位置合わせを説明するための図である。
以下では、添付の図面を参照しながら、本発明の好適な実施形態について詳細に説明する。
図1は、本発明の実施形態に係るデジタルカメラの概略構成を示す背面斜視図である。
デジタルカメラ100の背面には、画像や各種の情報を表示する表示部101と、ユーザによる各種操作を受け付ける各種スイッチやボタン等の操作部材からなる操作部102が設けられている。また、デジタルカメラ100の背面には、撮像モード等を切り替えるモード切替スイッチ104と、回転操作可能なコントローラホイール103が設けられている。デジタルカメラ100の上面には、撮像指示を行うシャッタボタン121と、デジタルカメラ100の電源のオン/オフを切り替える電源スイッチ122と、被写体に対して閃光を照射するストロボ141が設けられている。
デジタルカメラ100は、接続ケーブル111及びコネクタ112を介して外部装置と接続可能であり、外部装置に画像データ(静止画データ、動画データ)等を出力することができる。デジタルカメラ100の下面には、蓋131により開閉可能な記憶媒体スロット(不図示)が設けられており、記憶媒体スロットに対してメモリカード等の記憶媒体130を挿抜することができるようになっている。
記憶媒体スロットに格納された記憶媒体130は、デジタルカメラ100のシステム制御部210(図2参照)と通信可能である。なお、記憶媒体130は、記憶媒体スロットに対して挿抜可能なメモリカード等に限定されるものではなく、光学ディスクやハードディスク等の磁気ディスクであってもよく、更に、デジタルカメラ100の本体に内蔵されていてもよい。
図2は、デジタルカメラ100のハードウェア構成を示すブロック図である。デジタルカメラ100は、バリア201、撮像レンズ202、シャッタ203及び撮像部204を備える。バリア201は、撮像光学系を覆うことにより、撮像光学系の汚れや破損を防止する。撮像レンズ202は、ズームレンズ、フォーカスレンズを含むレンズ群により構成されており、撮像光学系を構成する。シャッタ203は、絞り機能を備え、撮像部204に対する露光量を調節する。撮像部204は、光学像を電気信号(アナログ信号)に変換する撮像素子であり、例えば、RGBの画素が規則的に配置されたベイヤー配列構造を有するCCDセンサやCMOSセンサ等のイメージセンサである。なお、シャッタ203は、機械式シャッタ(以下、メカシャッタという)であってもよいし、撮像素子のリセットタイミングの制御によって蓄積時間を制御する電子シャッタであってもよい。
または、撮像部204を、ステレオ画像が取得できる、1つ画素に複数の光電変換部に設けられる構造にすれば、後述する自動焦点検出(AF)処理がより素早くできる。
デジタルカメラ100は、A/D変換器205、画像処理部206、メモリ制御部207、D/A変換器208、メモリ209及びシステム制御部210を備える。撮像部204からA/D変換器205へアナログ信号が出力され、A/D変換器205は、取得したアナログ信号をデジタル信号からなる画像データに変換して、画像処理部206またはメモリ制御部207へ出力する。
画像処理部206は、A/D変換器205から取得した画像データまたはメモリ制御部207から取得したデータに対して、画素補間やシェーディング補正等の補正処理、ホワイトバランス処理、γ補正処理、色変換処理等を行う。また、画像処理部206は、画像の切り出しや変倍処理を行うことで電子ズーム機能を実現する。更に、画像処理部206は撮像した画像の画像データを用いて所定の演算処理を行い、こうして得られた演算結果に基づいてシステム制御部210が露光制御や測距制御を行う。例えば、システム制御部210により、TTL(スルー・ザ・レンズ)方式のAF(オートフォーカス)処理、AE(自動露出)処理、EF(ストロボプリ発光)処理が行われる。画像処理部206は、撮像した画像の画像データを用いて所定の演算処理を行い、得られた演算結果を用いて、システム制御部210はTTL方式のAWB(オートホワイトバランス)処理を行う。
画像処理部206は、複数の画像からパノラマ画像を合成し、またその合成結果の判断を行う画像合成処理回路を有する。画像合成処理回路は、単純な加算平均合成だけでなく、合成対象の画像データの各領域において最も明るい値または暗い値を持つ画素を選択して1枚の画像データを生成する比較明合成や比較暗合成等の処理を行うことができる。また、合成結果を特定の基準に基づいて評価し、判定する。たとえば、合成された画像の数が所定数に満たさない場合や、合成後の画像の長さが基準値に満たさない場合に、合成に失敗したと判定する。なお、画像処理部206を備える構成の代わりに、システム制御部210によるソフトウェア処理によって画像合成処理の機能を実現する構成としてもよい。
A/D変換器205から出力される画像データは、画像処理部206及びメモリ制御部207を介して、或いは、メモリ制御部207を介して、メモリ209に書き込まれる。メモリ209は、表示部101に表示する画像データを格納する画像表示用メモリ(ビデオメモリ)を兼ねている。メモリ209は、所定枚数の静止画像、パノラマ画像(広角画像)、パノラマ画像合成結果を格納することができる記憶容量を備えている。なお、メモリ209は、システム制御部210が不揮発性メモリ211から読み出したプログラム等を展開する作業領域として用いることもできる。
メモリ209に格納されている画像表示用データ(デジタルデータ)は、D/A変換器208に送信される。D/A変換器208は、受信したデジタルデータをアナログ信号に変換して表示部101に供給し、これにより、表示部101に画像が表示される。表示部101は、液晶ディスプレイまたは有機ELディスプレイ等の表示装置であり、D/A変換器208からのアナログ信号に基づいて画像を表示する。表示部101における画像表示のオン/オフは、システム制御部210によって切り替えられ、画像表示をオフにすることで電力消費を低減させることができる。なお、撮像部204からA/D変換器205を通じてメモリ209に蓄積されるデジタル信号をD/A変換器208によりアナログ信号に変換して表示部101に逐次表示することにより、スルー画像を表示する電子ビューファインダ機能を実現することができる。
デジタルカメラ100は、不揮発性メモリ211、システムタイマ212、システムメモリ213、検出部215及びストロボ制御部217を備える。不揮発性メモリ211は、電気的に消去や記憶が可能なメモリ(例えば、EEPROM等)であり、システム制御部210が実行するプログラムや動作用の定数等を格納する。また、不揮発性メモリ211は、システム情報を記憶する領域やユーザ設定情報を記憶する領域を有しており、システム制御部210は、デジタルカメラ100の起動時に不揮発性メモリ211に記憶された種々の情報や設定を読み出して復元する。
システム制御部210は、CPUを備え、不揮発性メモリ211に記憶されている各種のプログラムコードを実行することにより、デジタルカメラ100の全体的な動作を制御する。なお、システム制御部210が不揮発性メモリ211から読み出したプログラムや動作用の定数、変数等は、システムメモリ213上に展開される。システムメモリ213には、RAMが用いられる。更に、システム制御部210は、メモリ209やD/A変換器208、表示部101等を制御することにより、表示制御を行う。システムタイマ212は、各種の制御に用いる時間や内蔵された時計の時間を計測する。ストロボ制御部217は、被写体の明るさに応じて、ストロボ141の発光を制御する。検出部215は、ジャイロやセンサを含み、デジタルカメラ100の角速度情報、姿勢情報等を取得する。なお、角速度情報は、デジタルカメラ100によるパノラマ撮像時の角速度及び角加速度の情報を含む。また、姿勢情報は、水平方向に対するデジタルカメラ100の傾き等の情報を含む。
図2に示される表示部101、操作部102、コントローラホイール103、シャッタボタン121、モード切替スイッチ104、電源スイッチ122及びストロボ141は、図1を参照して説明したものと同じである。
操作部102を構成する各種の操作部材は、例えば、表示部101に表示される種々の機能アイコンの選択に用いられ、所定の機能アイコンが選択されることにより、場面毎に機能が割り当てられる。即ち、操作部102の各操作部材は、各種の機能ボタンとして作用する。機能ボタンとしては、例えば、終了ボタン、戻るボタン、画像送りボタン、ジャンプボタン、絞込みボタン、属性変更ボタン、DISPボタン等が挙げられる。例えば、メニューボタンが押下されると、各種の設定を行うためのメニュー画面が表示部101に表示される。ユーザは、表示部101に表示されたメニュー画面と、上下左右の4方向ボタンやSETボタンとを用いて、直感的に設定操作を行うことができる。
回転操作が可能な操作部材であるコントローラホイール103は、4方向ボタンと共に選択項目を指定するとき等に使用される。コントローラホイール103を回転操作すると、操作量(回転角度や回転回数等)に応じた電気的なパルス信号が発生する。システム制御部210は、このパルス信号を解析して、デジタルカメラ100の各部を制御する。
シャッタボタン121は、第1スイッチSW1と第2スイッチSW2を有する。第1スイッチSW1は、シャッタボタン121の操作途中の半押し状態でオンとなり、これにより、撮像準備を指示する信号がシステム制御部210に送信される。システム制御部210は、第1スイッチSW1がオンになった信号を受信すると、AF処理、AE処理、AWB処理、EF処理等の動作を開始する。第2スイッチSW2は、シャッタボタン121の操作が完了する全押し状態でオンとなり、これにより、撮像開始を指示する信号がシステム制御部210に送信される。システム制御部210は、第2スイッチSW2がオンになった信号を受信すると、撮像部204からの信号読み出しから記憶媒体130への画像データの書き込みまでの一連の撮像動作を行う。
モード切替スイッチ104は、デジタルカメラ100の動作モードを、静止画撮像モード、動画撮像モード、再生モード等の各種モードの間で切り替えるためのスイッチである。静止画撮像モードは、オート撮像モード等の他に、パノラマ撮像によりパノラマ画像を合成するパノラマ画像撮像モードを含む。
デジタルカメラ100は、電源部214及び電源制御部218を備える。電源部214は、アルカリ電池やリチウム電池等の一次電池、NiCd電池やNiMH電池、Li電池等の二次電池、或いは、ACアダプタ等であり、電源制御部218へ電力を供給する。電源制御部218は、電源部214における電池の装着の有無、電池の種類、電池残量等を検出し、その検出結果及びシステム制御部210の指示に基づいて、必要な電圧を必要な期間、記憶媒体130を含む各部へ供給する。
デジタルカメラ100は、記憶媒体130が記憶媒体スロット(不図示)に装着された際に、記憶媒体130とシステム制御部210との間の通信を可能にするための記憶媒体I/F216を備える。記憶媒体130の詳細については、図1を参照して既に説明しているため、ここでの説明を省略する。
次に、パノラマ撮像の方法と、複数の撮像画像からパノラマ画像を合成する方法について説明する。最初に、パノラマ画像を合成するために撮像画像の画像データから所定の領域を切り出す処理について説明する。
図3は、パノラマ撮像中のデジタルカメラ100の動く方向と画像データの切り出し領域との関係を説明するための図である。
図3(a)は、撮像部204が有する撮像素子の有効画像領域を示しており、“Wv”は水平方向の有効画素数であり、“Hv”は垂直方向の有効画素数である。図3(b)は、撮像画像の画像データから切り出した切り出し領域を示しており、“Wcrop”は水平方向の切り出し画素数であり、“Hcrop”は垂直方向の切り出し画素数である。
図3(c)は、矢印で示す水平方向にデジタルカメラ100を移動させながらパノラマ撮像を行った場合の画像データに対する切り出し領域を示す図である。図3(c)においてハッチングにて示した領域S1が画像データからの切り出し領域を示しており、下記の(式1)および(式2)を満たす。
Wv>Wcrop・・・・・・(式1)
Hv=Hcrop・・・・・・(式2)
同様に、図3(d)は、矢印で示す鉛直方向にデジタルカメラ100を移動させながらパノラマ撮像を行った場合の画像データに対する切り出し領域を示す図である。図3(d)においてハッチングにて示した領域S2が画像データの切り出し領域を示しており、下記の(式3)および(式4)を満たす。
Wv=Wcrop・・・・・・(式3)
Hv>Hcrop・・・・・・(式4)
撮像画像の画像データの切り出し領域は、画像データ毎に異なるようにしてもよい。また、パノラマ撮像の開始時とパノラマ撮像の終了時の画像データについては、画角を広くするために切り出し領域を広くしてもよい。画像データの切り出し領域の決定方法は、例えば、撮像直後のデジタルカメラ100の角度と1フレーム前のデジタルカメラ100の角度との差等により決定することができる。パノラマ画像の合成処理に必要な画像データのみを切り出して保存することにより、メモリ209の記憶容量を節約することができる。
なお、前述した切り出し領域は、できるだけ撮像画像の中央に設定するとよい。これは、撮像画像の中央は、一般的に歪が少なく、切り出し領域を画像の中央に設定すれば、より自然な合成画像が生成できるからである。
次に、パノラマ画像の合成方法について説明する。システム制御部210は、パノラマ撮像時に保存された切り出し領域をメモリ209から読み出し、読み出した画像データにパノラマ合成を行う。
図4は、パノラマ画像の合成処理の流れを説明する図である。図4では、ドットハッチングされた領域は、被写界にある並木を模式的に表した領域であり、斜線ハッチングされた領域は、画像データの切り出し領域を表している。図4(a)は、ユーザがシャッタボタン121を押下し、第1スイッチSW1がオンにされた状態を示し、ユーザは、主被写体に対してピント合わせを行うことを示している。図4(b)は、シャッタボタン121の第2スイッチSW2がオンにされた位置を示しており、ユーザが合成しようとしているパノラマ画像の一方の端に合わせて画角を設定している。図4(b)では、撮像部204は画像410を撮像する。図4(c)乃至図4(e)では、ユーザが合成しようとしているパノラマ画像の他方の端に向けてデジタルカメラ100を移動させながら、パノラマ撮像を行っている状態を模式的に示している。図4(e)は、ユーザがシャッタボタン121の押下をやめ、パノラマ撮像が終了した状態を示している。図4(b)乃至図4(e)では、撮像部204が画像410乃至470計7枚の画像を撮像したが、画像430、450および460は不図示である。画像処理部206は、撮像部204が撮像した画像410乃至470に対して切り出し処理を行い、切り出し領域411乃至471を生成する。システム制御部210において、切り出し領域の幅は、予め定めてもよいが、パノラマ撮像中のデジタルカメラ100の移動速度などに応じて変化させてもよい。
図4(f)は、画像処理部206が、撮像部204が撮像した複数の画像を合成してできたパノラマ画像を示している。ここで、システム制御部210は、合成を行う前に、画像に対して位置合わせを行う。また、手振れなどのため、切り出し領域411乃至471の上辺と下辺とは合っていないため、画像処理部206は、縦方向に対しても切り出し処理を行う。その結果、画像処理部206は、領域400が示したようなパノラマ画像を生成する。
システム制御部210は、画像処理部206が検出した複数の動きベクトルに基づいて、位置合わせを行う。一例としては、画像処理部206は、切り出し領域を任意のサイズの小ブロックに分割し、小ブロック毎に輝度の差分絶対値和(Sum of Absolute Difference、以下、SADをいう)が最小となる対応点を算出する。システム制御部210は、算出したSADが最小となる対応点より、動きベクトルを算出することができる。システム制御部210は、SADのほかに、差分二乗和(Sum of Squared Difference、以下SSDをいう)や正規化相互相関(Normalized Cross Correlation、以下NCCをいう)などを用いてもよい。
図4では、説明を容易にするため、切り出し領域411乃至471の互いに重畳する領域がなく、かつ、互いに隣接している例を示している。もし、重畳する領域が存在していれば、重畳する領域の中央を境目として、画像処理部206は、その左側に片方の切り出し領域、右側にもう片方の切り出し領域の画素情報を合成画像に出力する。もしくは、画像処理部206は、境目上に両方の切り出し領域の画素情報を50%ずつ合成した値を出力し、境目からの距離が離れるに従って境目の左側では片方の切り出し領域を、境目の右側ではもう片方の切り出し領域の割合を大きくしながら合成を行う。
本実施形態では、従来の位置合わせと異なり、検出部215が検出した角速度情報だけでなく、その信頼度などを用いて、前述した画像処理部206が検出した複数の動きベクトルの選択を行う。以下では、フローチャートを用いて本実施形態のフローについて説明する。
図5は、本実施形態を説明するためのフローチャートである。ユーザが、モード切替スイッチ104で、パノラマ画像合成モードを選択した場合に、デジタルカメラ100が図5の処理を実行する。
ステップS501で、ユーザがパノラマ撮像のための設定を行う。たとえば、ユーザがパノラマ合成画像の画角や撮像方向などの設定を行う。もし、ステップS501で、ユーザが設定をしなかった場合は、デジタルカメラ100は、パノラマ撮像において、初期の設定を用いるか、前回のパノラマ撮像のときの設定を用いる。
続いて、ステップS502で、システム制御部210は、第1スイッチSW1が押されたか否かの判定を行い、第1スイッチSW1が押されたと判定された場合、ステップS503の処理に移る。第1スイッチSW1が押されなかったと判定された場合、ステップS501の処理に戻る。
ステップS503で、検出部215は、姿勢検知処理を行う。姿勢検知処理では検出部215は、デジタルカメラ100の向きを判断する。もし、ユーザがステップS501での設定で、デジタルカメラ100の向きを予め設定したのであれば、ここで、システム制御部210は、デジタルカメラ100の設定された向きと実際の向きとを比較し、異なる場合では適宜に警告を出す。
ステップS504で、デジタルカメラ100は、自動露出処理制御(AE)処理と自動焦点検出(AF)処理とを行う。
ステップS505で、システム制御部210は、ステップS504のAE処理結果に基づいて撮像感度などの撮像条件を決定する。
ステップS506で、デジタルカメラ100は、被写体の距離を検出する。システム制御部210は、被写体の距離を、ステップS504のAF処理で被写体が合焦状態であると判断したときの撮像部204の焦点距離から求める。
次に、ステップS507で、システム制御部210は、第2スイッチSW2が押されたか否かの判定を行う。ステップS507において、第2スイッチSW2が押されなかったと判定された場合、システム制御部210は、ステップS502に戻り、第1スイッチSW1が押されたままか否か(いわゆる半押しのままか否か)判定する。ステップS507において、システム制御部210は、第2スイッチSW2が押されたと判定された場合、ステップS508に進み、ステップS505で決定した撮像条件で撮像部204が撮像する。
ステップS509で、検出部215は、角速度などの動き情報の検出を行う。ここで、検出部215から得られる角速度の情報は安定せずオフセットが加算された状態で出力されることがあるため、ハイパスフィルタを利用し、オフセットを除去した値を使ってもよい。検出部215が検出した動き情報は、のちのステップS514での位置合わせの係数の算出に用いられる。
ステップS510で、システム制御部210は、ステップS508で撮像部204が撮像した画像は、1枚目の画像かどうかについて判断する。ステップS508で撮像部204が撮像した画像が1枚目の画像の場合、メモリ209にこの1枚の画像しかなく、画像処理部206が位置合わせを行うことができない。そのため、ステップS510でシステム制御部210が1枚目の画像と判断した場合、フローをステップS508に戻す。一方、ステップS510でシステム制御部210が1枚目の画像でないと判断した場合、ステップS511に進む。
ステップS511で、システム制御部210が、動きベクトルの検出を行う。画像処理部206は、2枚の画像の一方に対して、複数の小ブロックを設定する。各々の小ブロックを同じサイズに設定することが好ましい。また、画像処理部206は、画像の全部でなく画像の一部に小ブロックを設定するようにしてもよい。システム制御部210は、一方の画像に設定された複数の小ブロックのいずれかを選択し、他方の画像において、この選択した小ブロックと同じ位置であって、かつ、この小ブロックより広い探索ブロックを設定する。システム制御部210は、他方の画像の探索ブロックの中で、一方の画像の選択した小ブロックと最も相関が高くなる(SADの値が最小となる)領域を抽出する。システム制御部210は、抽出した領域の中心である対応点の座標と、選択した小ブロックの中心位置の座標から、その小ブロックに対応する動きベクトルを算出することができる。システム制御部210は、これを全ての小ブロックに対して行い、全ての小ブロックに対応する動きベクトルを算出する。
ステップS512で、システム制御部210は、動き情報の信頼度を判断する。詳細について後述する。
ステップS513で、システム制御部210は、動きベクトルの信頼度を判断する。詳細について後述する。
ステップS514で、システム制御部210は、動きベクトルに対して、補正を行う。詳細について後述する。
ステップS515で、システム制御部210は、補正後の動きベクトルを用いて、位置合わせの係数の算出を行う。並進移動のみでよい場合、システム制御部210は、補正後の動きベクトルの平均値を用いることができる。または、システム制御部210は、補正後の動きベクトルのうち、同じ方向を示す動きベクトルを数え、最も多い個数の動きベクトルを用いる。画像に対して拡大縮小・回転の処理をする必要があれば、システム制御部210は、位置合わせの係数として、例えば射影変換係数を用いる。ただし、位置合わせの係数として射影変換係数だけに限定するわけではなく、アフィン変換係数や水平垂直シフトのみの簡略化した位置合わせの係数を用いてもよい。
ステップS516で、システム制御部210は、位置合わせを行う。たとえば、システム制御部210は、(式5)に示した式を用いて位置合わせを行うことができる。
Figure 0006604998
(式5)では、(x´、y´)は位置合わせを行った後の座標を示し、(x、y)は位置合わせを行う前の座標を示す。行列AはステップS515でシステム制御部210が算出した位置合わせの係数を示す。
ステップS517でシステム制御部210は撮像が継続中かを判定し、継続している場合はステップS508に処理を戻し、撮像が終了したと判定した場合はステップS518に進む。システム制御部210は、ステップS501のユーザ設定に基づいて、撮像が継続か終了かを判断する。たとえば、ステップS501で設定した画角に達したら、システム制御部210は撮像が終了したと判断する。
ステップS518で、画像処理部206は、パノラマ合成を行う。画像処理部206は、それぞれの画像に対して、まず、歪の小さな中央付近の矩形領域を切り出す。次に、画像処理部206は、それぞれの画像から切り出した領域に対して合成処理を行う。合成処理の詳細は、前述した図4の説明の通りで、ここで省略する。
<動き情報の信頼度と動きベクトルの信頼度との判断>
次に、上述したステップS512での動き情報の信頼度の判断、およびステップS513での動きベクトルの信頼度の判断について説明する。
前述したように、システム制御部210は、ステップ511で、画像間の比較を行うことによって、動きベクトルの検出を行う。しかしながら、画像により、一部の動きベクトルを誤検出してしまう可能性がある。たとえば、空や芝生など、同じような模様が続く風景や波や滝など常に模様が変化する風景に対して、動きベクトルの検出を誤ってしまう可能性が高い。この課題を解決するために、本実施形態で、システム制御部210は、誤検出の可能性の高い動きベクトルに対して、検出部215が検出した動き情報を用いて補正を行う。
しかしながら、検出部215がステップS509で検出した動き情報も常に正しいとは限らず、大きな誤差を含む可能性もある。システム制御部210は、正しくない動き情報を用いて動きベクトルに対して補正を行うと、逆に位置合わせの精度を下げてしまう可能性がある。
したがって、本実施形態では、システム制御部210は、動き情報の信頼度および動きベクトルの信頼度を判断し、これらの信頼度を参考にして動きベクトルに対する補正を行う。
動き情報の信頼度は、検出部215の性質によって決まるものであり、撮像中に様々な影響を受けて変わってしまう可能性がある。システム制御部210は、こうした信頼度が影響を受ける場面を検知したら、信頼度を調整する。
図6は、本実施形態における検出部215が検出した動き情報の誤差を説明するための図である。説明を簡単にするため、撮像部204が二次元で単一方向に動くと仮定し、システム制御部210が、検出部215が検出した角速度に基づいて撮像部204の動きの速さを得るとする。撮像部204が時刻T1に前の画像を撮像するための露光を完了し、時刻T2で次の画像を撮像するための露光を開始するものとする。検出部215が、時刻T1と時刻T2の間で等間隔の6つの時刻で(t1乃至t6)で撮像部204の速さを得たとする。システム制御部210は、図6(a)における縦棒601の面積を動き情報として得る。同様に、システム制御部210は、図6(b)における縦棒611の面積を動き情報として得る。ただし、図6(a)と図6(b)とでは、曲線603および曲線613は、実際の連続的な撮像部204の動きの速さを示し、空白部分602と612とは、検出部215の検出の誤差を意味する。図6(a)と図6(b)とを比較すると、分散の大きい図6(b)では、誤差を意味する空白部分612の面積が大きいとわかる。前述したように、検出部215が検出結果から得られた速度の分散が大きいと、動き情報の誤差が大きい可能性がある。
また、動き情報の誤差の変化のもう1つの例としては、シャッタ203がメカシャッタである場合のその動作による影響が挙げられる。メカシャッタであるシャッタ203が動作すると、デジタルカメラ100が振動してしまい、検出部215に設けられるジャイロセンサの検出精度に影響を与える可能性がある。ただし、こうした影響は、主にメカシャッタが動作する方向で起き、それと直交する方向では起きる影響が少ない。
また、動き情報の誤差に影響を与えるもう1つの要因としては、デジタルカメラ100の起動直後であることが挙げられる。デジタルカメラ100の起動直後では、ノイズの重畳の仕方が通常と比べ変わってしまい、検出部215が検出した動き情報の誤差が大きくなる可能性がある。
また、動き情報の誤差に影響を与えるもう1つの要因としては、被写体距離が挙げられる。システム制御部210は、近距離被写体に対して画像間の動きベクトルを検出する場合に、検出部215が検出した動き情報との乖離が大きくなることがある。これは、検出部215は、基準となる被写体距離に基づいて、ジャイロから得られた角速度情報を動き情報に換算しているが、被写体距離が近い場合には、この基準となる被写体距離との乖離が大きくなってしまうことが一因である。
前述したような動き情報の検出結果や動きベクトルの検出結果は、二次元座標系(一般的には直交系)を用いて、XY方向のそれぞれに分離してもよい。システム制御部210は、X方向をデジタルカメラ100の移動方向と平行する方向とし、Y方向をX方向と直交する方向としてよい。つまり、デジタルカメラ100は、X方向、Y方向のそれぞれにおいて、動き情報の検出と、動きベクトルの検出を行うとともに、動き情報の信頼度の判断と、動きベクトルの選択とを行う。すなわち、ステップS509とステップS511で得られた動き情報と動きベクトルのそれぞれをX方向の成分とY方向の成分に分離し、それぞれの方向において動きベクトルを選択するための判断を行うようにすればよい。以下では、2次元座標系を用いるステップS512とステップS513の詳細について説明する。
図7は、本実施形態における動き情報の信頼度の判断を説明するための図である。前述したように、このフローでは、XY方向を有する二次元座標系に基づいて説明する。
ステップS701で、システム制御部210は、検出部215が検出したX方向での速度の分散が所定値より大きいかどうかについて判断し、大きい場合はステップS702に進み、そうでない場合ステップS703に進む。ステップS702では、システム制御部210は、X方向での速度の分散に応じてX方向の動き情報の信頼度を下げるか、予め定められた量でX方向の動き情報の信頼度を下げる。ステップS703とステップS704での処理は、ステップS701とステップS702におけるX方向をY方向に置き換えたものである。
ステップS705で、システム制御部210は、シャッタ203がメカシャッタかどうかについて判断する。シャッタ203がメカシャッタであれば、ステップS706に進み、システム制御部210は、シャッタ203が動作した方向の信頼度を下げる。たとえば、水平方向をX方向、鉛直方向をY方向とすると、デジタルカメラ100を横向きに置き、シャッタ203が動作する方向がY方向であることが多く、システム制御部210は、Y方向の動き情報の信頼度を下げる。ユーザがデジタルカメラ100を斜めに持つとすると、シャッタ203が動作する方向が鉛直でなくなる。このような場合でも水平方向をX方向、鉛直方向をY方向とすれば、システム制御部210は、ステップS503で検出部215が検出した姿勢情報に応じて、X方向とY方向との動き情報の信頼度を下げる。
一方、シャッタ203が電子シャッタの場合、機械的な動作をせず、デジタルカメラ100に対して振動を与えることがないため、動き情報の信頼度が変わらない。
ステップS707で、システム制御部210は、デジタルカメラ100が起動されてから所定の時間以内かどうかについて判断し、時間内であれば、ステップS708に進み、X方向およびY方向の動き情報の信頼度を下げ、ステップS709に進む。一方、ステップS707で、システム制御部210は、起動直後でないと判断すると、直接ステップS709に進む。
ステップS709で、システム制御部210は、被写体距離が所定量より近いかどうかについて判断し、近ければ、ステップS710に進み、X方向およびY方向の動き情報の信頼度を下げる。一方、ステップS709で、システム制御部210は、被写体距離が所定量ほど近くないと判断する場合、動き情報の信頼度を下げずに終了する。
次に、動きベクトルの信頼度の判断について詳細に説明する。
動きベクトルの信頼度に影響を与える要因の1つとしては、撮像された画像における繰り返しパターンが挙げられる。繰り返しパターンのある画像では、デジタルカメラを動かしても似たような画像が映ることが多く、システム制御部210は、SAD、SSD、NCCのいずれの方法用いても検出した動きベクトルの誤差が大きい。
図8は本実施形態において繰り返しパターンを説明するための図である。図8は、デジタルカメラ100が同様な被写体を有する画角800に対して撮像した3枚の画像810、820および830を示す。画角800において、横方向で同様な被写体が繰り返し配置されている。デジタルカメラ100が、最初に画像810を撮像し、横方向に移動して画像820を撮像し、また、画像810を撮像した位置から縦方向に移動して画像830を撮像する。システム制御部210は、画像820および画像830それぞれの画像810に対する動きベクトルの検出を行う。
図8(a)と図8(b)とを比較して、デジタルカメラ100が移動したにもかかわらず、同じような画像が撮像されたことがわかる。システム制御部210は、デジタルカメラ100が画像810と820とを撮像する間にまったく動いていないと判断する可能性が高い。このように、システム制御部210は、各々のブロックを比較しても正しい動きベクトルを得ることが困難である。
一方、図8(a)と図8(c)とを比較することで、画像830は画像810に対して下方向に移動したことがわかる。システム制御部210は、画像810と830とを比較することで動きベクトルを検出する場合、図8(a)と図8(b)と比較する場合と比べて信頼度が高いと考えられる。
上述したように、画像において繰り返しパターンが存在すると、動きベクトルの信頼度が下がる可能性がある。特に、特定な方向に繰り返しパターンが存在すると、その方向における動きベクトルの信頼度が下がる可能性がある。
また、繰り返しパターンのほかに、画像に一方向に伸びた線状の被写体が存在すると、その線に沿った方向においては、繰り返しパターンと同様に動きベクトルの信頼度が下がる可能性がある。
ほかに、動きベクトルの信頼度を下げる要因としては、低コントラスト領域の存在が挙げられる。前述したSAD、SSD、NCCのいずれの方法でも輝度を用いて動きベクトルの検出を行うことが多く、低コントラスト領域はブロック間の輝度の違いが小さく、誤差が出やすい。
ステップS513では、システム制御部210は、上述したような要因を考慮して、動きベクトルの信頼度を判断する。
図9は、本実施形態におけるステップS513でシステム制御部210が動きベクトルの信頼度の判断を説明するためのフローチャートである。以下の説明では、図7と同じように、システム制御部210は、X方向とY方向とのそれぞれについて動きベクトルの信頼度の判断を行う。
ステップS901では、システム制御部210は、信頼度の判断処理を済んでいない動きベクトルを処理対象として選択する。
ステップS902では、処理対象の動きベクトルを検出したブロックに、X方向に繰り返しパターンまたは線状の被写体が存在する場合、ステップS903に進み、システム制御部210は、処理対象の動きベクトルのX方向の信頼度を下げる。ステップS902で、X方向に繰り返しパターンまたは線状の被写体が存在しない場合、フローはステップS904に進む。
ステップS904では、処理対象の動きベクトルを検出したブロックに、Y方向に繰り返しパターンまたは線状の被写体が存在する場合、ステップS905に進み、システム制御部210は、処理対象の動きベクトルのY方向の信頼度を下げる。ステップS904で、Y方向に繰り返しパターンまたは線状の被写体が存在しない場合、フローはステップS906に進む。
上述した線状の被写体および繰り返しパターンの判断では、一例としてシステム制御部210がSADを通じて行う。画像に線状の被写体が存在すると、特定の方向に対してSADの変化量が極端に小さくなる。システム制御部210、画像全体に対してSADの変化量を判断し、たとえば、X方向に沿ってSADの変化量が小さい場合ではX方向に線状の被写体が存在すると判断する。Y方向についても同様である。また、画像に繰り返しパターンが存在すると、システム制御部210がSADの微分を求めることによって、SADが極小となる点を検出できる。SADが極小となる点が複数検出されると、システム制御部210は、繰り返しパターンが存在すると判断する。システム制御部210は、SADの極小値となる点がX方向に複数検出する場合には、X方向に繰り返しパターンが存在すると判断する。Y方向についても同様である。
ステップS904で、画像処理部206は、処理対象の動きベクトルを検出したブロックのコントラストを検出する。システム制御部210は、画像処理部206が検出したコントラストを予め定められた閾値と比較し、コントラストが閾値より小さければ、ステップS907に進み、X方向とY方向との動きベクトルの信頼度を下げる。一方、ステップS906でコントラストが閾値以上であれば、直接ステップS908に進む。
ステップS908で、システム制御部210は、すべての動きベクトルが処理を済んでいるかどうかについて判断する。すべての動きベクトルが信頼度の判断の処理を済んでいればこのフローを終了し、まだすべての動きベクトルが済んでいなければステップS901に戻る。
以上では、動き情報および動きベクトルの信頼度の判断について説明した。
<動きベクトルの補正>
前述したように、ステップS511でシステム制御部210が検出した動きベクトルには、誤差のある可能性があり、そのせいで画像の位置合わせの精度が下がる可能性もある。そのために、ステップS514で、システム制御部210は動きベクトルに対して補正を行う。まず、システム制御部210は、動き情報の信頼度とそれぞれの動きベクトルの信頼度とを比較し、補正が必要な動きベクトルを特定する。その後、システム制御部210は、動き情報を用いて補正が必要な動きベクトルに対して補正を行う。以下は、その一例について説明する。
図10は本実施形態におけるステップS514での動きベクトルの補正を説明するためのフローチャートである。
ステップS1001で、システム制御部210は、動きベクトルの補正処理を済んでいない動きベクトルを処理対象として選択する。
ステップS1002では、システム制御部210は、X方向において、動きベクトルの信頼度と動き情報の信頼度とを比較する。動きベクトルの信頼度が動き情報の信頼度よりも低ければ、システム制御部210は、ステップS1003に進み、X方向の動きベクトルを動き情報のX方向の成分に置き換える。一方、ステップS1002で、動きベクトルの信頼度が動き情報の信頼度以上であれば、直接、ステップS1004に進む。
ステップS1004では、システム制御部210は、Y方向において、動きベクトルの信頼度と動き情報の信頼度とを比較する。動きベクトルの信頼度が動き情報の信頼度よりも低ければ、システム制御部210は、ステップS1005に進み、Y方向の動きベクトルを動き情報のY方向の成分に置き換える。一方、ステップS1004で、動きベクトルの信頼度が動き情報の信頼度以上であれば、直接、ステップS1006に進む。
ステップS1006で、システム制御部210は、すべての動きベクトルが処理を済んでいるかどうかについて判断する。すべての動きベクトルが処理を済んでいればこのフローを終了し、まだすべての動きベクトルが済んでいなければステップS1001に戻る。
上述した説明では、動き情報の信頼度が動きベクトルの信頼度より小さければ動きベクトルに対して処理を行わないとしたが、これに限らず、様々な変形することができる。たとえば、システム制御部210は、動きベクトルの信頼度と動き情報の信頼度との大小関係に応じて、動き情報を参照して動きベクトルを補正し、補正後の動きベクトルを用いて位置合わせを行うようにしてもよい。具体的に、システム制御部210は、動きベクトルと動き情報との信頼度を比較し、動きベクトルの信頼度の方が高いとき、動きベクトルをそのまま位置合わせに用いる。一方、動き情報の信頼度の方が高いとき、動き情報をそのまま位置合わせに用いるのでなく、動きベクトルに対して、動き情報との差が小さくなるように補正を行う。そして、システム制御部210は、補正後の動きベクトルを位置合わせに用いる。
図11は、本実施形態における動きベクトルの補正を説明するための図である。図11では、画像1100と1101とに対して位置合わせを行うとき、それぞれのブロックで検出した動きベクトルの補正を図示している。図11では、水平方向をX方向とし、鉛直方向をY方向とする。
図11(a)では、重複する画角を有する画像1100と1101とを示している。図11(b)では検出部215から得られるデジタルカメラ100の動き情報を示すベクトル1102を示している。画像1100と1101と比較すると、デジタルカメラ100が撮像中、右上に動いていたと思われるが、動き情報を示すベクトルは、上方向の成分がない。これは、誤差による影響とする。
図11(c)では、システム制御部210がSADに基づいて検出したブロックごとの動きベクトルをしている。動きベクトル1103は、X方向とY方向とともに信頼度が高いため、補正の対象になっていない。動きベクトル1104が位置するブロックでは、線状の被写体が検出されたため、システム制御部210にX方向の信頼度が低いと判断された。動きベクトル1104のX方向の信頼度が動き情報のX方向の信頼度よりも低いとすると、システム制御部210は、動きベクトル1104のX方向の成分を動き情報に基づくベクトル1102のX方向の成分に置き換える。
動きベクトル1105が位置するブロックには、システム制御部210が繰り返しパターン(図示の草地)をX方向とY方向と両方において検出し、動きベクトル1105のX方向とY方向との信頼度が低いと判断した。動きベクトル1105の信頼度がX方向とY方向とにおいて動き情報の信頼度より低いとすると、システム制御部210は、動きベクトル1105のX方向とY方向との成分をともに動き情報を示すベクトル1102のものに置き換える。(実質、動きベクトル1105そのものを動き情報を示すベクトル1102に置き換える。)
動きベクトル1106が位置するブロックは、低コントラスト領域であるため、動きベクトル1106の信頼度は、X方向とY方向とにおいて低い。動きベクトル1106の信頼度がX方向とY方向とにおいて動き情報の信頼度より低いとすると、その処理は動きベクトル1105に対する処理と同様となる。
システム制御部210が前述した処理を、図11(c)に示したすべての動きベクトルに対して行うと、図11(d)に示したような補正後の動きベクトルが得られる。図11(d)では、点線の矢印が置き換え処理を経た動きベクトルを示す。
最後に、システム制御部210は、図11(d)に示した補正後の動きベクトルを用いて、位置合わせの係数の算出のためのベクトルを算出する。ここでは、画像1100と1101とを撮像する間にデジタルカメラ100が並進移動するだけと仮定し、アフィン変換などを行う必要はない。システム制御部210は、補正後の動きベクトルの平均で図11(e)に示したベクトルを算出することができる。
なお、以上の説明では、信頼度の大小関係に基づいて、検出した動きベクトルか動き情報のどちらかを位置合わせに用いるようにしたが、信頼度の大小関係に応じて、動きベクトルに対する補正の程度を調整してもよい。
また、以上に述べた実施形態では、システム制御部210は、画像に設定したすべてのブロックで検出した動きベクトルを位置合わせに用いるようにしたが、一部の動きベクトルを位置合わせに用いないことも考えられる。たとえば、システム制御部210は、それぞれの動きベクトルと動き情報とを比較し、動き情報との差分の大きさが閾値よりも大きい動きベクトルを、補正せずに位置合わせに用いないようにする。つまり、システム制御部210は、検出した動きベクトルの一部を、画像の位置合わせの係数の算出に用いる対象から除外する。
図12は、本実施形態における動きベクトルの除外を示すための図である。図12(a)はデジタルカメラ100が移動されながら撮像した2枚の画像と検出部215が検出した動き情報とを示し、図12(b)はシステム制御部210が検出した複数の動きベクトルを示している。システム制御部210は、ステップS514の動きベクトルの補正の直前に、それぞれの動きベクトルと動き情報を示すベクトルとの差分を求める。この差分の大きさが予め定められた閾値よりも大きい動きベクトルは、システム制御部210により補正されずに除外される。図12(b)では、灰色のブロックから検出した動きベクトルは、動き情報との差分の大きさが閾値より大きいとシステム制御部210に判断され、それらの動きベクトルは位置合わせに用いられていない。また、システム制御部210は、ここで述べた閾値を、動き情報の信頼度によって変えるようにしてもよい。具体的には、システム制御部210は、動き情報の信頼度が低い場合には、動きベクトルと動き情報を示すベクトルとの差分との比較対象である閾値の値を大きく設定することで、動きベクトルを除外されにくくするようにする。
さらに、図12(c)では、4×4の合計16個のブロックを含むエリア1201を示す。システム制御部210は、エリア1201内において、所定の数より多いブロックを位置合わせから除外すると判断した場合には、エリア1201内のすべてのブロックを、位置合わせから除外するようにする。また、移動体が存在する場合、動き情報との差分の大きい動きベクトルを検出したブロックだけでなく、その周辺のブロックにも移動体の一部が含まれる可能性がある。そのため、差分の大きい動きベクトルを検出したブロックの周辺のブロックも位置合わせから除外することで、より精度の高い位置合わせを実現できる。
また、図13は、本実施形態において画像全体の動きベクトルを用いた位置合わせを説明するための図である。図13(a)は、検出部215が検出したデジタルカメラ100の動き情報を示している。動き情報の信頼度の判断方法は上述と同じである。図13(b)は、システム制御部210が検出した画像全体の動きベクトルを示している。画像全体の動きベクトルの検出方法は、まず上述した図11(c)と同じように、システム制御部210は、複数のブロックに分け、ブロックごとに動きベクトルを検出する。システム制御部210は、これらの複数の動きベクトルの平均で、画像全体の動きベクトルを決める。そして、システム制御部210は、画像全体の動きベクトルの信頼度についても判断する。判断方法としては、システム制御部210は、前述したステップS513の判断方法で各々のブロックの動きベクトルの信頼度を判断し、その平均を画像全体の動きベクトルの信頼度とし、動き情報の信頼度と比較する。または、システム制御部210は、それぞれのブロックの動きベクトルの信頼度と動き情報の信頼度とを比較し、X方向とY方向とのそれぞれにおいて、動き情報の信頼度より高い信頼度を持つ動きベクトルの割合を統計する。動き情報の信頼度より高い信頼度を持つ動きベクトルの割合が予め定められた閾値よりも高いと、システム制御部210は、画像全体の動きベクトルの信頼度が動き情報より高いと判断する。最後に、システム制御部210は、信頼度の比較の結果に基づいて、X方向とY方向とのそれぞれにおいて画像全体の動きベクトルに対して補正が必要であれば、補正を行い、補正済みの画像全体の動きベクトルを位置合わせの係数の算出に用いる。図13(c)では、一例として、X方向における画像全体の動きベクトルを動き情報を示すベクトルのX方向の成分に置き換える場面を示している。
なお、以上の実施形態についての説明では、システム制御部210が動きベクトルを補正するように説明したが、システム制御部210が画像の位置合わせにおいて、いずれかの補正情報を選択するように実施してもよい。たとえば、システム制御部210は、画像のブロックごとに、動き情報と動きベクトルとの信頼度を比較し、信頼度の高い方を位置合わせの係数の算出に使用するようにしてもよい。
本実施形態によれば、検出部215が検出した動き情報と動き情報の信頼度とシステム制御部210が検出した動きベクトルの信頼度とに基づいて画像の位置合わせに用いる動きベクトルに対して補正を行い、画像の位置合わせの精度を高めることができる。
(その他の実施形態)
なお、上記実施形態においては、個人向けのデジタルカメラをもとに説明を行ったが、パノラマ撮像および合成機能を搭載していれば、携帯機器やスマートフォン、あるいは、サーバーに接続されたネットワークカメラなどに適用することも可能である。
なお、本発明は、上述の実施形態の1つ以上の機能を実現するプログラムを、ネットワークまたは記憶媒体を介してシステムまたは装置に供給し、そのシステムまたは装置のコンピュータにおける1つ以上のプロセッサーがプログラムを読み出し作動させる処理でも実現可能である。また、1以上の機能を実現する回路(例えば、ASIC)によっても実現可能である。
100 デジタルカメラ
102 操作部
104 モード切替スイッチ
130 記録媒体
204 撮像部
206 画像処理部
207 メモリ制御部
209 メモリ
210 システム制御部
215 検出部
216 I/F

Claims (19)

  1. 撮像手段が第1の画像と第2の画像とを撮像する間の前記撮像手段の動き情報を、前記撮像手段とは別のセンサの出力に基づいて検出する第1の検出手段と、
    前記第1の画像と第2の画像の間の複数の動きベクトルを検出する第2の検出手段と、
    第1の方向と、前記第1の方向と直交する第2の方向とのそれぞれで、前記第1の検出手段が検出した前記動き情報の第1の信頼度と前記第2の検出手段が検出した前記動きベクトルの第2の信頼度との高さの判断を行う判断手段と、
    前記第1の方向と前記第2の方向とのそれぞれにおいて、前記動きベクトルと前記動き情報が示すベクトルとのうちの前記第1の信頼度または前記第2の信頼度の高いもの、または、前記動きベクトルと前記動き情報から前記第1の信頼度と前記第2の信頼度との少なくともいずれかに応じて求めたベクトルの成分を求め、前記第1の方向と前記第2の方向のそれぞれにおいて求めたベクトルの成分から合成したベクトルに基づいて、前記第1の画像と前記第2の画像とに対して位置合わせを行う位置合わせ手段とを有することを特徴とする画像処理装置。
  2. 前記第2の検出手段は、前記第1の画像に複数の領域を設定し、該複数の領域を用いて前記複数の動きベクトルを検出することを特徴とする請求項1に記載の画像処理装置。
  3. 補正手段を有し、
    前記補正手段は、前記動き情報と前記第1の信頼度と前記第2の信頼度とに基づいて、前記複数の動きベクトルの少なくとも一部に対して補正を行い、
    前記位置合わせ手段は、前記補正を行った後の前記複数の動きベクトルを前記位置合わせに用いることを特徴とする請求項1または2に記載の画像処理装置。
  4. 前記第1の信頼度よりも低い前記第2の信頼度をもつ前記動きベクトルに対して、
    前記位置合わせ手段は、該動きベクトルを前記動き情報が示すベクトルに置き換え、置き換えた後の該動きベクトルを前記位置合わせに用いる、
    または、
    前記位置合わせ手段は、該動きベクトルを前記位置合わせに用いずに、前記動き情報が示すベクトルを前記位置合わせに用いることを特徴とする請求項1乃至3のいずれか1項に記載の画像処理装置。
  5. 前記動き情報の分散が第1の値の場合は、前記動き情報の分散が前記第1の値よりも小さい第2の値の場合よりも、前記第1の信頼度が低いことを特徴とする請求項1乃至4のいずれか1項に記載の画像処理装置。
  6. 前記第1の検出手段が起動されてから所定の時間以内の場合は、起動されてから所定の時間以内でない場合よりも、前記第1の信頼度が低いことを特徴とする請求項1乃至5のいずれか1項に記載の画像処理装置。
  7. 前記第1の画像または前記第2の画像の被写体距離が所定の被写体距離よりも近い場合には、該所定の被写体距離よりも近くない場合よりも、前記第1の信頼度が低いことを特徴とする請求項1乃至6のいずれか1項に記載の画像処理装置。
  8. 前記第1の画像または前記第2の画像の定められた領域のコントラストが予め定められた閾値よりも低い場合には、前記コントラストが前記閾値以上の場合よりも、前記第2の信頼度が低いことを特徴とする請求項1乃至7のいずれか1項に記載の画像処理装置。
  9. 前記第2の検出手段は、前記定められた領域を用いて前記動きベクトルを検出することを特徴とする請求項8に記載の画像処理装置。
  10. 前記第1の方向は、前記第1の画像と第2の画像とを撮像する間の前記撮像手段の移動方向と平行な方向であることを特徴とする請求項1乃至9のいずれか1項に記載の画像処理装置。
  11. 前記第1の方向は、予め設定された方であることを特徴とする請求項1乃至9のいずれか1項に記載の画像処理装置。
  12. 前記撮像手段が撮像するとき、前記第1の方向または前記第2の方向においてメカシャッタの動作がある場合には、前記メカシャッタの動作がない場合よりも、前記第1の方向または前記第2の方向における前記第1の信頼度が低いことを特徴とする請求項乃至11のいずれか1項に記載の画像処理装置。
  13. 前記判断手段は、前記第1の画像または前記第2の画像において、前記第1の方向に繰り返しパターンまたは前記第1の方向に沿う線状の被写体を検出した場合には、前記第1の方向に繰り返しパターンおよび前記第1の方向に沿う線状の被写体を検出しなかった場合よりも、前記第1の方向における第2の信頼度が低いと判断し、前記第2の方向に繰り返しパターンまたは前記第2の方向に沿う線状の被写体を検出した場合には、前記第2の方向に繰り返しパターンおよび前記第2の方向に沿う線状の被写体を検出しなかった場合よりも、前記第2の方向における第2の信頼度が低いと判断することを特徴とする請求項1乃至12のいずれか1項に記載の画像処理装置。
  14. 前記位置合わせ手段は、前記動き情報との違いが所定値よりも小さい前記動きベクトルを選択して前記位置合わせに用いるものであって、
    前記所定値を前記第1の信頼度により定め、前記第1の信頼度が第3の値の場合の前記所定値が、前記第1の信頼度が前記第3の値より低い第4の値の場合の前記所定値より小さく設定することを特徴とする請求項1乃至13のいずれか1項に記載の画像処理装置。
  15. 前記第1の画像と前記第2の画像との対応するエリアにおいて、前記動き情報との違いが所定値よりも大きい前記動きベクトルの数が、予め定められた所定の数よりも多い場合、前記位置合わせ手段は、該エリアにあるすべての前記動きベクトルを前記位置合わせに用いないことを特徴とする請求項14に記載の画像処理装置。
  16. 前記センサは、ジャイロセンサであることを特徴とする請求項1乃至15のいずれか1項に記載の画像処理装置。
  17. 撮像手段と、
    前記撮像手段が第1の画像と第2の画像とを撮像する間の前記撮像手段の動き情報を、前記撮像手段とは別のセンサの出力に基づいて検出する第1の検出手段と、
    前記第1の画像と第2の画像の間の複数の動きベクトルを検出する第2の検出手段と、
    第1の方向と、前記第1の方向と直交する第2の方向とのそれぞれで、前記第1の検出手段が検出した前記動き情報の第1の信頼度と前記第2の検出手段が検出した前記動きベクトルの第2の信頼度との高さの判断を行う判断手段と、
    前記第1の方向と前記第2の方向とのそれぞれにおいて、前記動きベクトルと前記動き情報が示すベクトルとのうちの前記第1の信頼度または前記第2の信頼度の高いもの、または、前記動きベクトルと前記動き情報から前記第1の信頼度と前記第2の信頼度との少なくともいずれかに応じて求めたベクトルの成分を求め、前記第1の方向と前記第2の方向のそれぞれにおいて求めたベクトルの成分から合成したベクトルに基づいて、前記第1の画像と前記第2の画像とに対して位置合わせを行う位置合わせ手段とを有することを特徴とする撮像装置。
  18. 撮像手段が第1の画像と第2の画像とを撮像する間の前記撮像手段の動き情報を、前記撮像手段とは別のセンサの出力に基づいて検出する第1の検出ステップと、
    前記第1の画像と第2の画像の間の複数の動きベクトルを検出する第2の検出ステップと、
    第1の方向と、前記第1の方向と直交する第2の方向とのそれぞれで、前記第1の検出ステップにおいて検出した前記動き情報の第1の信頼度と前記第2の検出ステップにおいて検出した前記動きベクトルの第2の信頼度との高さの判断を行う判断ステップと、
    前記第1の方向と前記第2の方向とのそれぞれにおいて、前記動きベクトルと前記動き情報が示すベクトルとのうちの前記第1の信頼度または前記第2の信頼度の高いもの、または、前記動きベクトルと前記動き情報から前記第1の信頼度と前記第2の信頼度との少なくともいずれかに応じて求めたベクトルの成分を求め、前記第1の方向と前記第2の方向のそれぞれにおいて求めたベクトルの成分から合成したベクトルに基づいて、前記第1の画像と前記第2の画像とに対して位置合わせを行う位置合わせステップとを有することを特徴とする画像処理装置の制御方法。
  19. 画像処理装置のコンピュータに動作させるコンピュータのプログラムであって、
    撮像手段が第1の画像と第2の画像とを撮像する間の前記撮像手段の動き情報を、前記撮像手段とは別のセンサの出力に基づいて検出する第1の検出ステップと、
    前記第1の画像と第2の画像の間の複数の動きベクトルを検出する第2の検出ステップと、
    第1の方向と、前記第1の方向と直交する第2の方向とのそれぞれで、前記第1の検出ステップにおいて検出した前記動き情報の第1の信頼度と前記第2の検出ステップにおいて検出した前記動きベクトルの第2の信頼度との高さの判断を行う判断ステップと、
    前記第1の方向と前記第2の方向とのそれぞれにおいて、前記動きベクトルと前記動き情報が示すベクトルとのうちの前記第1の信頼度または前記第2の信頼度の高いもの、または、前記動きベクトルと前記動き情報から前記第1の信頼度と前記第2の信頼度との少なくともいずれかに応じて求めたベクトルの成分を求め、前記第1の方向と前記第2の方向のそれぞれにおいて求めたベクトルの成分から合成したベクトルに基づいて、前記第1の画像と前記第2の画像とに対して位置合わせを行う位置合わせステップとを行わせることを特徴とするプログラム。
JP2017141305A 2017-07-20 2017-07-20 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム Active JP6604998B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2017141305A JP6604998B2 (ja) 2017-07-20 2017-07-20 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム
US16/034,975 US10846822B2 (en) 2017-07-20 2018-07-13 Image processing apparatus, image pickup apparatus, control method of image processing apparatus, and recording apparatus

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2017141305A JP6604998B2 (ja) 2017-07-20 2017-07-20 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム

Publications (2)

Publication Number Publication Date
JP2019022162A JP2019022162A (ja) 2019-02-07
JP6604998B2 true JP6604998B2 (ja) 2019-11-13

Family

ID=65023054

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2017141305A Active JP6604998B2 (ja) 2017-07-20 2017-07-20 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム

Country Status (2)

Country Link
US (1) US10846822B2 (ja)
JP (1) JP6604998B2 (ja)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2022120683A (ja) * 2021-02-05 2022-08-18 キヤノン株式会社 画像処理装置及び画像処理方法、プログラム、記憶媒体

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH11271831A (ja) * 1998-03-24 1999-10-08 Nikon Corp 交換レンズ及びブレ補正カメラ
US8300015B2 (en) * 2005-07-05 2012-10-30 Stmicroelectronics S.A. Method of detecting the movement of an entity equipped with an image sensor and device for implementing same
US7777781B2 (en) * 2005-08-26 2010-08-17 Avago Technologies Ecbu Ip (Singapore) Pte. Ltd. Method and system for determining the motion of an imaging apparatus
JP4800163B2 (ja) * 2006-09-29 2011-10-26 株式会社トプコン 位置測定装置及びその方法
JP2008219124A (ja) * 2007-02-28 2008-09-18 Sanyo Electric Co Ltd 撮像装置
JP2009008858A (ja) * 2007-06-27 2009-01-15 Olympus Imaging Corp ブレ補正装置及び撮像装置
JP2012029138A (ja) * 2010-07-26 2012-02-09 Olympus Corp 撮像装置
JP2012220886A (ja) * 2011-04-13 2012-11-12 Nikon Corp ブレ補正装置および光学機器
US8600194B2 (en) 2011-05-17 2013-12-03 Apple Inc. Positional sensor-assisted image registration for panoramic photography
JP2013020528A (ja) * 2011-07-13 2013-01-31 Sony Corp 画像処理装置および方法、並びにプログラム
JP5971954B2 (ja) * 2012-01-12 2016-08-17 キヤノン株式会社 画像処理装置、画像処理装置を有する撮像装置、画像処理方法、プログラム、及びプログラムを記憶した記憶媒体
JP6153318B2 (ja) * 2012-11-30 2017-06-28 キヤノン株式会社 画像処理装置、画像処理方法、画像処理プログラム、および、記憶媒体
JP2014202793A (ja) * 2013-04-01 2014-10-27 オリンパス株式会社 撮像装置及び撮像装置の像ブレ補正方法
JP2014232278A (ja) * 2013-05-30 2014-12-11 富士フイルム株式会社 ブレ補正装置及び観察装置
JP6565465B2 (ja) * 2015-08-12 2019-08-28 セイコーエプソン株式会社 画像表示装置、コンピュータープログラム、および画像表示システム
JP6604783B2 (ja) * 2015-09-09 2019-11-13 キヤノン株式会社 画像処理装置、撮像装置および画像処理プログラム
JP6659130B2 (ja) * 2015-12-04 2020-03-04 キヤノン株式会社 画像処理装置、撮像装置、画像処理方法およびプログラム

Also Published As

Publication number Publication date
US20190026863A1 (en) 2019-01-24
JP2019022162A (ja) 2019-02-07
US10846822B2 (en) 2020-11-24

Similar Documents

Publication Publication Date Title
JP6833746B2 (ja) 撮像装置、撮像方法、プログラムおよび記録媒体
US10694104B2 (en) Image processing apparatus, image capturing apparatus, and image processing method
JP6604831B2 (ja) 画像処理装置、画像処理装置の制御方法及びプログラム
US10757326B2 (en) Image processing apparatus and image processing apparatus control method
JP2016076805A (ja) 画像処理装置、その制御方法、および制御プログラム、並びに撮像装置
JP6833801B2 (ja) 撮像装置、撮像方法、プログラムおよび記録媒体
JP2013183306A (ja) 撮像装置、撮像方法、及びプログラム
JP6647246B2 (ja) 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム
JP7163057B2 (ja) 撮像装置、撮像方法、プログラムおよび記録媒体
JP7158841B2 (ja) 撮像装置、撮像方法、プログラム、記録媒体および画像処理装置
JP2019125928A (ja) 撮像装置、撮像方法およびプログラム
JP6604998B2 (ja) 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム
JP6590894B2 (ja) 画像処理装置、撮像装置、画像処理方法およびプログラム
JP7158892B2 (ja) 画像処理装置、画像処理方法、撮像装置、プログラムおよび記録媒体
JP2008028890A (ja) 撮像装置、撮像方法及び撮像プログラム
US11109034B2 (en) Image processing apparatus for alignment of images, control method for image processing apparatus, and storage medium
JP7086774B2 (ja) 撮像装置、撮像方法およびプログラム
JP7051586B2 (ja) 撮像装置、撮像方法およびプログラム
JP5743729B2 (ja) 画像合成装置
JP6590899B2 (ja) 撮像装置、撮像方法およびプログラム
JP2019186831A (ja) 画像処理装置、撮像装置、画像処理方法およびプログラム
JP2018207178A (ja) 撮像装置、撮像装置の制御方法およびプログラム
JP6929133B2 (ja) 撮像装置、撮像装置の制御方法およびプログラム
JP2019068243A (ja) 画像処理装置、撮像装置、画像処理装置の制御方法およびプログラム
JP2011049739A (ja) 撮像装置及びその制御方法、並びにプログラム

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20180320

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20190418

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20190514

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20190711

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20191015

R151 Written notification of patent or utility model registration

Ref document number: 6604998

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151