JP2011101336A - 階層マスク生成装置、フレーム補間処理装置 - Google Patents

階層マスク生成装置、フレーム補間処理装置 Download PDF

Info

Publication number
JP2011101336A
JP2011101336A JP2010012272A JP2010012272A JP2011101336A JP 2011101336 A JP2011101336 A JP 2011101336A JP 2010012272 A JP2010012272 A JP 2010012272A JP 2010012272 A JP2010012272 A JP 2010012272A JP 2011101336 A JP2011101336 A JP 2011101336A
Authority
JP
Japan
Prior art keywords
block
search range
frame
search
determining
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
JP2010012272A
Other languages
English (en)
Other versions
JP5164280B2 (ja
Inventor
Masafumi Nakao
政史 中尾
Kin Ebisu
欣 胡
Masashi Higashi
正史 東
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.)
Nanao Corp
Original Assignee
Nanao 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 Nanao Corp filed Critical Nanao Corp
Priority to JP2010012272A priority Critical patent/JP5164280B2/ja
Publication of JP2011101336A publication Critical patent/JP2011101336A/ja
Application granted granted Critical
Publication of JP5164280B2 publication Critical patent/JP5164280B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Image Analysis (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Television Systems (AREA)

Abstract

【課題】 高精度で高い演算速度の探索を行う。
【解決手段】 ブロック設定手段511は、代表ブロック座標について、大きさの異なるブロックを設定する。探索範囲候補特定手段521は、前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する。相対割合演算手段523は、前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームについて、前記各探索範囲候補の探索範囲内における移動オブジェクトの占める相対割合を演算する。決定手段525は、前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する。
【選択図】 図15

Description

この発明は、フレーム補間処理に関し、特に静止部分と動いている部分の区別に関する。
特許文献1には、 現在フレームと参照フレームの2枚の入力画像を、それぞれ複数のブロックに分割し、2つの入力画像に基づいて、各ブロックのLMV(ローカル動きベクトル)をそれぞれ検出し、ブロック各々に対応するLMVの信頼度指標としてのブロック重みを算出して、このブロック重みに応じて各ブロック対応の寄与率を設定してGMV(グローバル動きベクトル)を算出する動きベクトル検出装置が開示されている。
また、前記GMVを用いた中間フレーム画像生成時に、動いているブロックと動いていないブロックを区別するためのマスクを生成することができる。特許文献2には、前後フレームからマスクを生成することが開示されている(特許文献2の図4参照)。
特開2009−65332号公報 特開2003−018604号公報
特許文献2では、以下のような問題があった。動いているブロックの移動速度、移動距離が大きい場合、精度よく探索するためには、探索の範囲を広く設定する必要がある。一方、探索範囲を広くすると演算速度が問題となる。
この発明は、上記の問題点を解決して、精度を保ちつつ演算速度が高いマスク生成装置その方法を提供することを目的とする。また、精度を保ちつつ演算速度が高い探索を行う探索装置またはその方法を提供することを目的とする。さらに、これらを含むフレーム補間装置またはその方法を提供することを目的とする。
(1)本発明にかかる階層マスク生成装置は、第nフレームおよび第n+αフレームの画像データに基づいて生成され、前記第nフレームからみた第nフレーム動きマスクと、前記第n+αフレームからみた第n+αフレーム動きマスクであって、前記各動きマスクは、各画素が動きのある部分に該当するのか、または動きのない部分に該当するのかを表す信号である、が与えられると、ブロックごとに異なる探索範囲を決定するための階層マスクを生成する装置であって、A)前記各動きマスクが与えられると、各々について、所定の構成画素ブロックに分割する手段であって、前記の構成画素数は、各動きマスク毎に複数種類あり、この複数種類のブロックパターンに分割する分割手段、B)前記第nフレーム動きマスクにおける前記複数のブロックパターンについて、各ブロックのうち前記動きのあるブロックの周辺ブロックについて、前記ブロックのブロックサイズに応じて、ブロックサイズが大きくなるほど、周辺探索範囲を大きくして、前記動きのある部分の画素数の最大値を当該周辺ブロックの最大値として決定する第nフレーム周辺ブロック画素数決定手段、C)前記第n+αフレーム動きマスクにおける前記複数のブロックパターンについて、各ブロックのうち前記動きのあるブロックの周辺ブロックについて、前記ブロックのブロックサイズに応じて、ブロックサイズが大きくなるほど、周辺探索範囲を大きくして、前記動きのある部分の画素数の最大値を当該周辺ブロックの最大値として決定する第n+αフレーム周辺ブロック画素数決定手段、D)前記第nフレーム、第n+αフレーム動きマスクにおける前記複数のブロックパターン別に、同じブロックを比較して、当該ブロックの最大値および最小値を求める最大値最小値演算手段、E)前記ブロックパターン別の各ブロックの最小値が所定の閾値を超える場合には、そのブロックパターンで示される領域が探索範囲であるとして決定する階層マスク決定手段、を備えている。
かかる構成を採用することにより、オブジェクトの大きさ、移動速度に応じて探索範囲を変えることができる。よって、精度を保ちつつ演算速度が高いマスク生成装置を提供することができる。
(2)本発明にかかる探索範囲決定装置においては、C)前記ブロック設定手段は、前記代表ブロック座標について、大きさの異なるブロックを設定し、D)前記探索範囲決定手段は、d1)前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する探索範囲候補特定手段、d2)前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する相対割合演算手段、d3)前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する決定手段を備えている。
したがって、移動オブジェクトの大きさ、移動速度に応じて前記ブロック探索範囲を変えることができる。これにより、精度を保ちつつ演算速度が高い探索が可能となる。
(3)本発明にかかる探索範囲決定装置においては、前記動きマスクは、各画素が動きのある部分に該当するのか、または動きのない部分に該当するのかを表す信号であり、前記相対割合は、当該範囲内における動きのある部分の占める割合である。したがって、相対割合の演算が簡易迅速となる。
(4)本発明にかかる探索装置においては、D)前記ブロック設定手段は、前記代表ブロック座標について、大きさの異なるブロックを設定し、E)前記探索範囲決定手段は、e1)前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する探索範囲候補特定手段、e2)前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する相対割合演算手段、e3)前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する決定手段を備えている。
したがって、移動オブジェクトの大きさ、移動速度に応じて前記ブロック探索範囲を変えることができる。これにより、精度を保ちつつ演算速度が高い探索が可能となる。
(5)本発明にかかる探索装置においては、前記動きベクトル演算手段は、前記第nフレームおよび前記第n+αフレームの画像データを縮小させる画像縮小手段を有しており、前記決定手段からブロック探索範囲が与えられると、これを当該ブロックに対して採用する画像の縮小率であるとして、前記ブロックマッチングを行う。したがって、従来の縮小画像生成方法により、探索範囲を切り換えることができる。
(6)本発明にかかる探索装置においては、前記動きベクトル演算手段は、前記縮小画面について縮小率の大きな画像でのブロックマッチングによって得られた動きベクトルを、縮小率が次に小さい画像でのブロックマッチングにおける初期ベクトルとして採用して、当該初期ベクトルで特定されるブロックに基づく所定の範囲の探索処理を、前記縮小率を小さくして繰り返し探索する予備探索型ブロックマッチング手段であって、前記各ブロックについて、前記決定手段から与えられたブロック探索範囲に基づいて、前記繰り返し探索する開始画像の縮小率を決定して、前記ブロックマッチングを行う予備探索型ブロックマッチング手段を有する。
したがって、従来の縮小画像生成方法における探索による誤認識を防止することができる。
(7)本発明にかかる探索装置においては、前記動きベクトル演算手段は、前記縮小画面について縮小率の大きな画像でのブロックマッチングによって得られた動きベクトルを、縮小率が次に小さい画像でのブロックマッチングにおける初期ベクトルとして採用して、当該初期ベクトルで特定されるブロックに基づく所定の範囲の探索処理を、前記縮小率を小さくして繰り返し探索する予備探索型ブロックマッチング手段であって、前記繰り返し探索の各探索処理において全ブロックについての初期ベクトルを演算した後、当該縮小画像において得られた初期ベクトルを、前記階層マスクで使用可能なブロック以外はゼロベクトルとなるようにマスク処理をしたものを初期ベクトルとして前記繰り返し探索を行う。したがって、従来の縮小画像生成方法における探索による誤認識を防止することができる。
(8)本発明にかかるフレーム補間処理装置においては、前記ブロック設定手段は、前記代表ブロック座標について、大きさの異なるブロックを設定し、前記探索範囲決定手段は、前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する探索範囲候補特定手段、前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する相対割合演算手段、前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する決定手段を備えている。
したがって、移動オブジェクトの大きさ、移動速度に応じて前記ブロック探索範囲を変えることができる。これにより、精度を保ちつつ演算速度が高い探索が可能なフレーム補間処理ができる。
(9)(10)(11)本発明にかかる探索範囲決定方法、探索方法またはフレーム補間処理方法においては、前記ブロック設定ステップは、前記代表ブロック座標について、大きさの異なるブロックを設定し、前記探索範囲決定ステップでは、前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定し、前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算し、前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する。
したがって、移動オブジェクトの大きさ、移動速度に応じて前記ブロック探索範囲を変えることができる。これにより、精度を保ちつつ演算速度が高い探索が可能となる。
グローバル動きベクトル演算装置1の機能ブロック図である。 グローバル動きベクトル演算装置1におけるグローバル動きベクトル演算のフローチャートである。 平行移動パラメータ取得を説明する図である。 グローバル動きベクトル演算1のハード構成を示す図である。 演算したグローバル動きベクトルを用いたフレーム補間処理装置200の機能ブロック図である。 前後フレームの一例である。 動きオブジェクトマスク生成部の詳細ブロック図である。 補正部の詳細ブロック図である。 階層マスク生成部の詳細ブロック図である。 ブロック分割の一例である。 ブロック分割の一例である。 ブロック分割の一例である。 フレーム補間処理装置300の機能ブロック図である。 フレーム補間処理装置400の機能ブロック図である。 探索範囲決定装置500の機能ブロック図である。 従来の、縮小画像を用いての階層化動き推定方法を説明する図である。 ブロックマッチング型探索処理部204の詳細ブロック図である。 生成される縮小画面の一例である。 生成される縮小階層マスクの一例である。 縮小階層マスクを用いての下位層への提要を説明する図である。 縮小階層マスクを用いての下位層への提要を説明する図である。
以下、本発明における実施形態について、図面を参照して説明する。
(1.GMV演算の概要について)
本発明において採用したグローバル動きベクトル演算装置1の機能ブロック図を図1に示す。グローバル動きベクトル演算装置1は、ブロック別動きベクトル演算手段3、平行移動パラメータ演算手段6、回転・ズームパラメータ演算手段7、グローバル動きベクトル記憶手段9、展開後動きベクトル手段11、閾値記憶手段15、計算対象ブロック決定手段17、および繰り返し手段13を備えている。
ブロック別動きベクトル演算手段3は、第nフレームと第n+1フレームについて、それぞれ1画面を構成する画素を所定の矩形のブロックにブロック化して、ブロック別の動きベクトルであるローカル動きベクトルを求めるとともに、求めたブロックについてのローカル動きベクトルを計算対象ブロックのローカル動きベクトルとして与える。
平行移動パラメータ演算手段6は、前記計算対象ブロックのローカル動きベクトルが与えられると、各ブロックを注目ブロックとして、その周辺ブロックのローカル動きベクトルの平均と当該注目ブロックのローカル動きベクトルとの差分の絶対値に基づいて注目ブロックのローカル動きベクトルに重み付け係数を全計算対象ブロックについて演算するとともに、前記計算対象ブロックの各重み付け係数およびローカル動きベクトルから、最小二乗法によりグローバル動きベクトルの平行移動パラメータを演算する。回転・ズームパラメータ演算手段7は、前記平行移動パラメータが与えられると、この平行移動パラメータおよび、平行移動、回転、ズームの4パラメータで表したアフィン変換式からグローバル動きベクトルの回転・ズームパラメータを求める。グローバル動きベクトル記憶手段9は、前記平行移動パラメータおよび前記回転・ズームパラメータを記憶する。
展開後動きベクトル手段11は、前記平行移動パラメータ、および回転・ズームパラメータが与えられると、各ブロックについてのローカル動きベクトルに展開した展開後ローカル動きベクトルを演算する。
閾値記憶手段15は、計算対象ブロックを選別するための閾値を記憶する。計算対象ブロック決定手段17は、各ブロックについて、前記展開後ローカル動きベクトルと、ブロック別動きベクトル演算手段3が演算したローカル動きベクトルとの差が閾値記憶手段15に記憶された閾値内であるブロックを計算対象ブロックとして決定し、決定した計算対象ブロックについてのブロック別動きベクトル演算手段3が演算したローカル動きベクトルを平行移動パラメータ演算手段6に計算対象ブロックとして与える。
繰り返し手段11は、計算対象ブロック決定手段17の処理を所定回数繰り返し実行する手段であって、繰り返し回数が増える度に前記閾値を小さくして、前記繰り返し処理を行う。
このように、演算されたグローバル動きベクトルの前記平行移動パラメータ、および前記回転・ズームパラメータから、ブロック別の動きベクトルに展開させ、計算対象ブロックを前記閾値で決定し、決定したブロックに基づいて、前記平行移動パラメータ、および前記回転・ズームパラメータの計算を繰り返すことにより、より精度の高い前記平行移動パラメータおよび前記回転・ズームパラメータを取得することができる。
(2.GMV取得の詳細処理)
グローバル動きベクトル演算装置1の詳細ブロック図を図2に、演算処理のフローチャートを図3に示す。以下、図2,図3を用いて説明する。
ブロック別動きベクトル演算部31(図2)は、ブロック別動きベクトル演算処理(図3ステップS1)を実行する。具体的には、第nフレームと第n+1フレームについて、それぞれ1画面を構成する画素を所定の矩形のブロックにブロック化して、ブロック別の動きベクトルであるローカル動きベクトルを求める。演算結果は、局所動きベクトル記憶部33(図2参照)に記憶される。
重み付け演算部34(図2)は、ブロック重み付け処理(図3ステップS3)を実行する。
重み付け演算部34(図2)は、局所動きベクトル記憶部33からローカル動きベクトルが与えられると、ブロック(Xblk、Yblk)を注目ブロックとして、その周辺ブロックにおけるローカル動きベクトルの平均maveを式(1)により求める。
Figure 2011101336
Xblk、Yblkはブロックを示す座標、δは有効計算ブロックを示すマスク、mは動きベクトルである。δ(Xblk+k,Yblk+l)は、後述するように演算対象でないブロックについては、「0」と、それ以外は「1」に設定されるが、1回目は全てのブロックが演算対象であるので、「1」に設定される。
注目ブロックを順次変更することにより、全ブロックについてのローカル動きベクトルの平均mave(Xblk、Yblk)が求められる。
重み付け演算部34は、ブロック(Xblk、Yblk)のローカル動きベクトルm(Xblk、Yblk)とブロック(Xblk、Yblk)の周辺部ブロックの平均mave(Xblk、Yblk)と当該注目ブロックの差分の絶対値に基づいて、ブロック(Xblk、Yblk)のローカル動きベクトルに重み付け係数wを演算する。本実施形態においては、下記式(2)、式(3)によって重み付け係数wを求めた。
Figure 2011101336
Figure 2011101336
かかる重み付け演算は、全ブロックについて行われる。なお、差分の絶対値としては、L2ノルム、L1ノルムなどを採用することができる。
本実施形態においては、指数的な収斂を行うことにより、疑いのあるブロックの寄与を限りなく小さくすることができる。更に、1/2(あるいは1/4)のべき乗であるため固定小数点実装(シフトによる構成)がやりやすくなる。これにより、演算器をより簡易に構成できる。さらに、べき乗数とする絶対値に対し4乗とするようにした。これにより大きな差分である場合には、そのブロックの重み付け係数wをより小さくすることができる。
平行移動パラメータ演算部36(図2)は、局所動きベクトル記憶部33からローカル動きベクトルが与えられると、重み付け演算部34から各ブロックの重み付け係数を受け取り、アフィン変換における平行移動パラメータa1,a4を演算する(図3ステップS7)。
アフィン変換における6つのパラメータa1〜a6を求める式を、式(4)、式(5)に示す。
Figure 2011101336
本実施形態においては、各ローカル動きベクトルについて重み付け演算をしているので、式(4)、式(5)は、式(6)、式(7)と表される。これにより平行移動パラメータa1,a4が求められる。
Figure 2011101336
ズーム・回転パラメータ演算部37(図2)は、平行移動パラメータ演算部36から平行移動パラメータa1,a4が与えられると、重み付け演算部34から各ブロックの重み付け係数を受け取り、アフィン変換におけるズーム・回転パラメータa2,a3を演算する(図3ステップS9)。
本実施形態においては、式(6)、式(7)を一部限定することにより、ズーム・回転パラメータa2,a3を、平行移動パラメータa1,a4に基づいて求めるようにした。
カメラワークに限定した場合、アフィン変換のパラメータとしては、平行移動、回転、ズームに限定される。したがって、パラメータa5,a6は、下記で表される。
−a6=a2
−a5=−a3
これらを前記式(6),式(7)に代入すると、式(8)、式(9)が得られる。
Figure 2011101336
式(8)、式(9)を変形することにより、パラメータa2,a3は、式(10)、式(11)で表される。
Figure 2011101336
式(10)、式(11)から明らかなように、パラメータa2,a3は、パラメータa1,a4から演算することができる。
得られたパラメータa1〜a4は、グローバル動きベクトル記憶部39(図2)に記憶される。
繰り返し制御部43(図2)は、所定回数繰り返し済みか否か判断する(図3ステップS11)。本実施形態においては、繰り返し回数として「3回」を採用した。この場合、1回目であるので、演算対象ブロック選定処理(図3ステップS17)が実行される。
展開部41(図2)は、グローバル動きベクトル記憶部39からパラメータa1〜a4が与えられると、ブロック別動きベクトル演算部31と同じブロックのブロック別動きベクトルに展開する(GMVからLMVに変換)。
演算対象ブロック選定部47は、繰り返し制御部43から繰り返し命令が与えられると、各ブロックについて、展開されたブロック別動きベクトルと、局所動きベクトル記憶部33のブロック別動きベクトルの差を演算し、演算結果が閾値記憶部45に記憶されている閾値内であるブロックを演算対象ブロックとして決定する。
これを全ブロックについて繰り返すことにより、被選定ブロック位置を平行移動パラメータ演算部36および重み付け演算部34に与える。
かかる演算対象ブロックの選定処理の概念について図4を用いて説明する。図4は、説明のために、8つのブロックp1〜p8のローカル動きベクトルから、グローバル動きベクトルを求めた場合を示す。図4Aは8つ全てのブロックp1〜p8から得られたグローバル動きベクトル81を示す。このグローバル動きベクトル81と閾値Th内にあるブロックp1,p2,p4,p6が抽出される。演算処理としては、グローバル動きベクトル81から得られるローカル動きベクトルと比較することにより計算対象ブロックとして決定される。
重み付け演算部34(図2)は、被選定ブロック位置が与えられると、選定されたブロックを用いて、重み付け演算を行う(図3ステップS3)。具体的には、重み付け演算部34は、選定されなかったブロックについてδ(xblk,yblk)=0として、式(1)の周辺ブロックにおけるローカル動きベクトルの平均mave を演算する。
なお、選定対象とならなかったブロックについては、グローバル動きパラメータ演算に用いないため、そもそも、w(xblk,yblk)の計算も不要である。したがって、重み付け演算部34は、当該ブロックについては、w(xblk,yblk)=0として重み付け演算を省略する。
なお、上記式(8)〜(11)において、Σwとなっている全ての部分をΣδwと置き換えることによっても同様の動作が可能である。これにより総和計算に明示的にマスク処理を施すことができる。
平行移動パラメータ演算部36(図2)は、演算対象ブロック選定部47から、被選定ブロック位置が与えられると、指定されたブロックの重み付け係数を用いて、平行移動パラメータを演算する(図3ステップS7)。
ズーム・回転パラメータ演算部37(図2)は、被選定ブロックについて、その重み付け係数および平行移動パラメータa1,a4を用いて、パラメータa2,a3を演算する(図3ステップS7)。
このようにして、被選定ブロック(計算対象でないブロック以外のブロック)のLMVから求めたGMVパラメータa1〜a4が得られ、パラメータa1〜a4は、グローバル動きベクトル記憶部39に上書きされる。
図4Bに、8つのブロックp1〜p8のうち、計算対象ブロックとなったブロックp1,p2,p4,p6から、得られた新たなグローバル動きベクトル82を示す。
繰り返し制御部43(図2)は、所定回数繰り返し済みか否か判断する(図3ステップS11)。この場合、2回目であるので、所定回数である3回は処理していないと判断して、ステップS13に進み、1回目であるか否か判断する。この場合、1回目ではなく2回目であるので、閾値を小さくする処理を実行する(ステップS15)。具体的には、閾値記憶部45に記憶されている閾値を変更する変更命令を行う。本実施形態においては、「2」である閾値を「1」とした。
演算対象ブロック選定部47(図2)は、かかる小さくなった閾値を用いて、演算対象ブロックの選定処理を行う(図3ステップS17)。
図4Cは、計算対象ブロックとなったブロックp1,p2,p4,p6から、得られた新たなグローバル動きベクトル82および小さくなった閾値Th’により、グローバル動きベクトル82と閾値Th’内にあるブロックp1,p2,p3,p5,p9が抽出される。
以下、同様にして、図3ステップS3〜ステップS9の処理が実行され、新たなグローバル動きベクトルのパラメータa1〜a4がグローバル動きベクトル記憶部39に上書きされる。
図4Dは、計算対象ブロックとなったブロックp1,p2,p3,p5,p9から、得られた新たなグローバル動きベクトル83を示す。
以下、ステップS11にて3回目の処理が実行され、ステップS15で閾値がさらに小さくされる。本実施形態においては、閾値を「1」から「2/3」とした。ステップS17からステップS9の処理が実行され、あらたなグローバル動きベクトルのパラメータa1〜a4がグローバル動きベクトル記憶部39に追記される。
繰り返し制御部43(図2)は、所定回数の繰り返しが終わると、処理を終了する。
このように、得られたグローバル動きベクトルを用いて、閾値を小さくしつつ、計算対象ブロックを変更して、新たなグローバル動きベクトルを求める処理を繰り返すことにより、より精度の高いグローバル動きベクトルを得ることができる。
本実施形態においては、閾値を小さくする手法として、繰り返し回数をnとした場合に、閾値=2/nとした。本実施形態においては繰り返し回数を3回としたので、閾値は、最初は「2」、次は「1」、その次は「2/3」となる。
なお、繰り替え処理を行うか否かの条件については、回数としたが、閾値を設けておき、条件を満足するまで処理を繰り返すようにしてもよい。
また、計算対象ブロック決定手段17が求める差分については、実施形態においては、差分の絶対値を採用したがこれに限定されない。
(3.変形実施形態)
上記実施形態においては、GMVパラメータ演算について、重み付け係数を考慮して、最小二乗法で平行移動パラメータを求めて、これをアフィン変換の式に代入して、ズーム・回転パラメータを求めた。しかし、これに限定されず、他の手法によって4つのパラメータを演算するようにしてもよい。
本実施形態におけるGMVパラメータ演算手法は4種類のグローバル動きベクトルを簡易に計算できるという効果がある。したがって、本実施形態におけるグローバル動きベクトル演算装置1のうち、GMVパラメータ演算手段5(図1参照)における処理を単独の装置として把握することもできる。
また、繰り返し処理を行う手段(図1における展開後動きベクトル演算手段11、繰り返し手段13、閾値記憶手段15、および演算対象ブロック選定手段17)により、精度よくかつ高速にグローバル動きベクトルのパラメータ演算が可能となる。これらを単独の装置として把握することもできる。
すなわち、グローバル動きベクトルを求める演算装置であれば、どのような物にも適用可能であり、上記4パラメータだけでなく、6パラメータ(Affine)、さらに、8パラメータ(射影)を求めるグローバル動きベクトル演算装置に適用可能である。
繰り返し処理による計算ブロックの除外・復活を実施し再計算を行なうことにより、初期の誤ったパラメータが原因で正しいブロックまで過剰に除去されることを防ぐことができる。また、繰り返しごとに閾値の値を小さくすることにより、繰り返し演算の前、または繰り返し演算の序盤は、正しいパラメータとのずれが大きいおそれがある。これにより、当初は閾値を大きめにとることで正しいブロックの検出漏れを防ぐことができる。
上記実施形態では求めたGMVから閾値を小さくしながら、演算対象ブロックを変更しつつ、繰り返し演算を行っている。これにより、精度の高い中間フレームの生成が可能となる。
(4.GMVを用いた補間処理について)
上記開示したGMV演算装置にて得られたGMVを用いて、下記実施形態においては、ブロックごとに探索範囲を複数段階とする階層構造マスクを生成することにより、精度と演算速度の二律背反の要求を得ることができた。
補間処理を行うフレーム補間処理装置200の機能ブロック図について図5を用いて説明する。
補間処理を行うフレーム補間処理装置200は、カメラワーク補償部201、マスク生成部203、ブロックマッチング型探索処理204,局所動き補償部206、外乱除去部207、カメラワーク推定部209を備えている。
カメラワーク補償部201は前回のGMVパラメータを用いて補償後の前後フレームを出力する。一般的には、GMVはパラメータ、フレームn,n+1の中間フレームn+0.5を生成するために用いられる。本実施形態においては、演算遅延の抑制やフレーム記憶領域削減のために、フレームn,n+1から得られたGMVから、つぎの中間フレームn+1.5を生成するようにした。たとえば、等速直線運動と仮定すれば、
GMVact(n+1.5)=GMV0(n+0.5)
で求められる。
GMVact:実際にカメラワーク補償に用いるGMV
GMV0:カメラワーク推定部209から算出されたGMV
なお、等速直線運動ではなく、より滑らかさを加味するために、
GMVact(n+1.5) = {GMV0(n+0.5) +GMVact(n+0.5)}/2
として、GMVactを演算するようにしてもよい。
カメラワーク補償部201は、与えられた前後フレームn,n+1を、GMVact(n+0.5)を用いてそれぞれ中間フレーム時間n+0.5にあわせて補償する。補償後の前後フレームがマスク生成部203、ブロックマッチング探索処理部204,および局所動き補償部206に与えられる。
ここでは図6に示すような前後フレームが出力されたものとする。なお、図6Aは前フレームであり、図6Bは後フレームである。なお、図6において、物体244は静止しており、物体241は後フレームでは矢印α方向に移動しており、物体247は後フレームでは矢印β方向に移動している。
(4.1 マスク生成について)
マスク生成部203について説明する。マスク生成部203は、動きオブジェクトマスク生成部203aおよび階層マスク生成部203bを備えている。
(4.1.1 動きオブジェクトマスク生成について)
動きオブジェクトマスク生成部203aの詳細ブロックを図7に示す。動きオブジェクトマスク生成部203aは、エッジ抽出部251、261、仮動きオブジェクトマスク生成部252,262、補正部253、263を備えている。
エッジ抽出部251は、後フレームが与えられると、エッジ抽出を行う。エッジ抽出処理については、従来と同様であるので説明は省略する。仮動きオブジェクトマスク生成部252は、後フレームから前フレームの値を減算することにより、後フレームと前フレームとの差分を演算するとともに、値がマイナスの値となった画素はゼロとする。
エッジ抽出部261は、前フレームが与えられると、エッジ抽出を行う。仮動きオブジェクトマスク生成部262は、前フレームから後フレームの値を減算することにより、後フレームと前フレームとの差分を演算するとともに、値がマイナスの値となった画素はゼロとする。かかるマイナスとなった画素についてゼロとすることにより、仮動きオブジェクトマスク生成部252,262で、異なる差分画像が得られる。補正部253は、仮動きオブジェクトマスク生成部252、262からの2つの差分画像およびエッジ抽出部251から与えられるエッジ画像を用いて、補正処理を行う。補正部253の構成について図8を用いて説明する。
図8は、補正部263の詳細ブロック図である。膨張処理部255は、後フレームの仮動きオブジェクトマスクの膨張処理を行う。具体的には、仮動きオブジェクトマスクは、静止している部分は黒で、動いている画素が白の二値画像である。白の部分を1画素分だけ周辺方向に広げる処理を行う。膨張処理部257は、後フレームのフレームエッジ画像の膨張処理を行う。膨張処理については同様である。
論理積演算部256は、前フレームの仮動きオブジェクトマスクと、膨張後の後フレームの仮動きオブジェクトマスクとの論理和を演算する。後フレームの仮動きオブジェクトマスクは膨張処理がなされているため、多少の演算誤差を吸収することができる。論理和演算部258は、上記論理和演算結果と、膨張処理がなされた後フレームエッジの論理和演算を行う。
閾値比較部259は、膨張後の後フレームの仮動きオブジェクトマスクと、論理和演算部258の出力を所定の閾値で比較して、閾値以上の部分について、動きオブジェクトマスクの穴埋めを行う。
このように、エッジ抽出部251からのエッジ画像および穴埋めを行うことにより、前記2つの差分画像で動いている領域が前フレームと後フレームで重なっている場合でも、輪郭を取得することができる。例えば、図6に示す物体241の部分は、前後で輪郭が少しずれて重なった位置に存在する。したがって、論理積演算部256の出力は、一部が欠けた円の形のマスクとなる。これに輪郭情報を付加するとともに、輪郭となるまで穴埋めすることにより、円形状のマスクが得られる。
前フレーム用の補正部263は与えられるフレームが変わるだけで、補正部253と同様の構成をしており、同様にして、前フレームの動きオブジェクトマスクが生成される。これにより、前フレーム、後フレームの動きオブジェクトマスクが得られる。なお、この動きオブジェクトマスクは前フレーム用も後フレーム用もいずれも画素単位の二値画像である。
なお、本実施形態においては、各画素毎に「0」か「1」を示す情報を記憶することにより、画素単位の二値画像を動きマスクとして記憶するようにした。しかし、これに限定されず、他の形式で動きマスクを特定してもよい。
(4.1.2 階層マスク生成について)
得られた動きオブジェクトマスクを用いて、階層マスク生成部203b(図5参照)は、各ブロックの探索範囲を決定する階層マスクを生成する。階層マスク生成部203bの詳細を図9に示す。
階層マスク生成部203bは、ブロック分割部261、271、前フレームオブジェクト画素数計測部263,後フレームオブジェクト画素数計測部273、最大値抽出部265,275、ブロックパターン別前後フレーム比較部277,階層数決定部279を備えている。
(4.1.2.1 ブロック分割処理について)
ブロック分割部261は、前フレームの動きオブジェクトマスクを所定のブロックに分割する。動きオブジェクトマスクは、既に説明したように、動いている部分は白く、静止している部分については黒の二値画像である。本実施形態においては、第1分割部261aが画素数16*16に、第2分割部261bが画素数32*32に、第3分割部261cが画素数64*64のブロックに分割するようにした。かかる画素数は計算を容易にするためであるが、これに限定されるわけではない。また、分割部の数も限定されない。
ブロック分割部271も同様である。図10〜図12にブロック分割部261,271による分割結果の一例を示す。
図10は、画素数16*16にブロック分割した状態を示す。図10は最小矩形が8画素を表している。また、太線が各ブロックの境界を表している。また、画素との関係をわかりやすくするために、本来マスクとして黒である部分を白とし、白部分をハッチング処理している。また、図10Aが、ブロック分割部261によってブロック分割された前フレームであり、図10Bが、ブロック分割部271によってブロック分割された後フレームを示している。以下では、ブロックの左上角のブロック特定座標で特定するものとする。たとえば、図10Aにおいて、オブジェクト291は、ブロック(4,4)、(3,4)、(4,3)、計3つのブロックにわたって位置している。
図11は、画素数32*32にブロック分割した状態を示す。なお、図11に示す画素数32*32のブロック分割は、図10とは異なり、各ブロックをこのブロックサイズにおいて、1/2ブロック幅分X方向またはY方向にずらして重複するよう配置する。これにより、ブロックサイズが異なっても、ブロックの左上角のブロック座標は同じでなる。
図12は、画素数64*64におけるブロック分割した場合である。なお、ブロック分割は、このブロックサイズにおいて、1/4ブロック幅分X方向,Y方向にずらしながら重複して配置する。
(4.1.2.2 画素計測処理について)
前オブジェクト画素計測部263は、第1分割部261a〜第3分割部261cによって、前記ブロックサイズに分割された各ブロックについて、それぞれ、ブロック内の画素数を計測する。
前フレームオブジェクト画素計測部263(図9参照)による処理について、図10〜図12を参照しつつ説明する。
前フレームオブジェクト画素計測部263(図9参照)の画素数計測部263aは、1ブロックの画素数が16*16における計測を行う(図10参照)。画素数計測部263aは、ブロック(0,0)から順次その外側に位置するブロックについて探索を行う。図10Aでは、ブロック(0,0)が「0」、ブロック(0,1)が「0」、・・・・、ブロック(4,3)が「64」、・・・、ブロック(3,4)が「128」、ブロック(4,4)が「256」・・・となる。
後フレームオブジェクト画素計測部273(図5参照)の画素数計測部273aも同様の処理を行う。ブロック(0,0)が「0」、ブロック(0,1)が「0」、・・・・、ブロック(2,1)が「64」、・・・、ブロック(1,2)が「128」、ブロック(2,2)が「256」・・・となる。
前フレームオブジェクト画素計測部263(図9参照)の画素数計測部263bは、1ブロックの画素数が32*32における計測を行う(図11参照)。図11Aでは、ブロック(0,0)が「0」、ブロック(0,1)が「0」、・・・、ブロック(3,2)が「64」、・・・、ブロック(2,3)が「128」、ブロック(3,3)が「448」・・・となる。
後フレームオブジェクト画素計測部273(図5参照)の画素数計測部273bも同様の処理を行う。図11Bにおいては、ブロック(0,0)が「0」、ブロック(1,0)が「64」、・・・・、ブロック(1,1)が「448」・・・となる。
前フレームオブジェクト画素計測部263(図9参照)の画素数計測部263cは、1ブロックの画素数が64*64における計測を行う(図12参照)。図12Aでは、ブロック(0,0)が「0」、ブロック(1,0)が「64」、・・・ブロック(1,1)が「448」・・・となる。
後フレームオブジェクト画素計測部273(図5参照)の画素数計測部273cも同様の処理を行う。図12Bにおいては、ブロック(0,0)が「448」、ブロック(1,0)が「448」、・・・・、ブロック(1,1)が「448」・・・となる。
(4.1.2.3 最大値決定処理について)
前フレームブロック別最大値抽出部265(図9参照)は、画素数計測部263a〜263cが計測した各ブロックについて、その最大値を決定する。その際、所定範囲の周辺ブロックも含めて、当該ブロックの最大値とする。また、後述する階層数決定部279(図9参照)にて、ブロックサイズ別に比較する為に、画素数をブロック構成画素数との相対値とした。
以下、図10〜図12を参照しつつ説明する。
i)最大値抽出部265a、275aによる処理
前フレームブロック別最大値抽出部265(図9参照)の最大値抽出部265aは、計測した画素数について、その周辺ブロックも合わせて、そのうちの最大値を当該ブロックの最大値とする。本実施形態においては、16*16画素のブロックの場合は、周辺ブロックとして周囲1ブロックとした。
図10Aでは、ブロック(0,0)が「0」であり、その1ブロック周辺の範囲、であるブロック(0,1)、(1,0)、(1,1)は、ともに「0」、であるので、ブロック(0,0)の最大値は「0」となる。その際、相対値は16*16で除算しても「0」である。以下、かかる処理を繰り返す。ブロック(2,3)は「0」であるが、周辺1ブロックを探索すると、ブロック(3,4)が「128」である。したがって、ブロック(2,3)の最大値は、これを256で除算した「128/256」となる。同様にして、ブロック(2,4)、(2,5)の最大値は「128/256」となる。また、ブロック(3,2)の値は、「0」であるが、1ブロック周辺にあるブロック(4,3)が「64」である。したがって、ブロック(3,2)の最大値は、これを256で除算した「64/256」となる。また、ブロック(3,3)の値は、「0」であるが、1ブロック周辺にあるブロック(4,4)が「256」である。したがって、ブロック(3,3)の最大値は、これを256で除算した「256/256」となる。
後フレームオブジェクト画素計測部273(図5参照)の画素数計測部275aも同様の処理を行う。ブロック(0,0)が「0」、ブロック(0,1)〜(0,3)が「128/256」となる。ブロック(1,0)は「64」、ブロック(1,1)〜(1,3)が「256」・・・となる。
ii)最大値抽出部265b,275bによる処理
前フレームブロック別最大値抽出部265(図9参照)の最大値抽出部265bは、計測した画素数について、その周辺ブロックも合わせて、そのうちの最大値を当該ブロックの最大値とする。本実施形態においては、32*32画素のブロックの場合は、周辺ブロックとして周囲2ブロックとした。
図11Aでは、ブロック(0,0)が「0」であり、その2ブロック周辺の範囲、であるブロック(0,1)、(1,0)、(1,1)は、ともに「0」であるので、ブロック(0,0)の最大値は「0」となる。その際、相対値は32*32で除算しても「0」である。
以下、上記処理を繰り返す。ブロック(0,1)は「0」であるが、周辺2ブロックを探索すると、ブロック(2,3)が「128」である。したがって、ブロック(0,1)の最大値は、これを1024で除算した「128/1024」となる。同様にして、ブロック(0,2)、(0,3)は「128/1024」となる。
また、ブロック(1,0)は「0」であるが、周辺2ブロックを探索すると、ブロック(3,2)が「64」である。したがって、ブロック(1,0)の最大値は、これを1024で除算した「64/1024」となる。ブロック(1,1)は「0」であるが、周辺2ブロックを探索すると、ブロック(3,3)が「448」である。したがって、ブロック(1,1)の最大値は、これを1024で除算した「448/1024」となる。以下、同様にして、ブロック(1,2)、(1,3)は「448/1024」となる。
後フレームオブジェクト画素計測部273(図5参照)の画素数計測部275bも同様の処理を行う。ブロック(0,0)が「448/1024」、ブロック(0,1)〜(0,2)が「448/1024」となる。また、ブロック(0,3)が周囲2ブロック内のブロック(1,2)の「384/1024」となる。
iii)最大値抽出部265c,275cによる処理
前フレームブロック別最大値抽出部265(図9参照)の最大値抽出部265cは、計測した画素数について、その周辺ブロックも合わせて、そのうちの最大値を当該ブロックの最大値とする。本実施形態においては、64*64画素のブロックの場合は、周辺ブロックとして周囲3ブロックとした。
図12Aでは、ブロック(0,0)が「0」であるが、その3ブロック周辺の範囲、であるブロック(1,1)は、448である。したがって、ブロック(0,0)の最大値は、これを4096で除算した「448/4096」となる。同様にして、ブロック(0,1)〜ブロック(0,6)は「448/4096」となる。
後フレームオブジェクト画素計測部273(図5参照)の画素数計測部275cも同様の処理を行う。ブロック(0,0)が「448/4096」・・・となる。
(4.1.2.4 前後フレーム比較処理について)
ブロックパターン別前後フレーム比較部277は、3種類のブロックパターンそれぞれについて、各ブロックについての最大値、最小値を決定する。
16*16画素のブロックについては、前フレームのブロック(0,0)は「0」、後フレームのブロック(0,0)は「0」である。したがって、ブロック(0,0)は最大値、最小値とも「0」となる。前フレームのブロック(0,1)は「0」、後フレームのブロック(0,1)は「128/256」である。したがって、ブロック(0,1)は最大値「128/256」、最小値「0」となる。同様にして、ブロック(0,2)、(0,3)は最大値「128/256」、最小値「0」となる。ブロック(1,0)については、最大値「64/256」、最小値「0」となる。
32*32画素のブロックについては、前フレームのブロック(0,0)は「0」、後フレームのブロック(0,0)は「448/1024」である。したがって、ブロック(0,0)は最大値「448/1024」、最小値「0」となる。また、前フレームのブロック(0,1)は「128/1024」、後フレームのブロック(0,1)は「448/1024」である。したがって、ブロック(0,1)は最大値「448/1024」、最小値「128/1024」となる。
64*64画素のブロックについては、前フレームのブロック(0,0)は「448/4096」、後フレームのブロック(0,0)は「448/4096」である。したがって、ブロック(0,0)は最大値、最小値とも「448/4096」となる。また、前フレームのブロック(0,1)は「448/4096」、後フレームのブロック(0,1)は「448/4096」である。したがって、ブロック(0,1)は最大値、最小値とも「448/4096」となる。
このようにして、前後フレームの対応するブロックの値から、最大値、最小値がブロックパターン毎に求められる。
階層数決定部279(図9参照)は、閾値処理により、当該ブロックの検索範囲を特定する階層数を決定する。具体的には、ブロックについて、閾値が定められており、最小値が閾値を超えている場合には、階層数として決定する。
本実施形態においては、閾値を「1/2」とするとともに、得られた値が、1/4以上1/2未満の場合はその下の階層(ブロックを構成する画素数が小さなもの)の同位置の最大値が3/4以上であれば、大きなブロックの階層数として決定するようにした。
例えば、32*32画素のブロックでは、最小値が1/4であり、16*16画素のブロックでは、最小値3/4であれば、32*32画素が階層として設定される。
図10〜図12の場合、ブロック(0,0)については、16*16画素の場合、最大値、最小値とも「0」、32*32画素の場合、最大値「448/1024」、最小値「0」、64*64画素の場合、最大値、最小値とも「448/4096」である。いずれも閾値「1/2」はもちろん、「1/4」も越えていないので、階層数は「0」、すなわち、探索しないブロックとして決定される。
ブロック(0,1)については16*16画素の場合、最大値「128/256」、最小値「0」、32*32画素の場合、最大値「448/1024」、最小値「128/1024」、64*64画素の場合、最大値、最小値とも「448/4096」である。したがって、ブロック(0,0)の場合と同様に、階層数は「0」として決定される。
以上の処理を繰り返すことにより、各ブロックの階層数が決定される。
なお、複数種類のブロックについて、閾値を超えている場合もある、その場合は、そのうちの大きな方のブロックの階層数とすればよい。たとえば、16*16画素と32*32画素の場合と2つとも閾値を超える場合、大きい方のブロックである階層数「2」と決定される。
階層数によって、予め定められた探索範囲が決定される。本実施形態においては、階層数と、前、後フレームオブジェクト画素数計測部263,273の計測範囲とを一致させるようにした。すなわち、階層数が「1」であれば、周囲1ブロックまで、階層数が「2」であれば、周囲2ブロックまで、階層数が「3」であれば、周囲3ブロックとした。しかし、探索範囲については、これに限定されない。
以上説明したように、マスク生成部203は、ブロックマッチングの探索範囲をオブジェクトの大きさおよび移動速度に基づき、ブロックごとに複数段階としている。このように、移動範囲の広いことが予測される部分は探索範囲を広くできるように階層数を上げ、移動範囲の狭いことが予測される部分は探索範囲を狭くするように階層数を下げることができる。これにより、演算量を無駄に増やすことなく、精度の高い探索が可能となる。特に、移動がない部分、たとえば、背景のように差分が発生しない部分については、探索しないという制御も可能である。
また、動きオブジェクトマスクは、画素単位であるので、オブジェクト単位の切り出しが可能となる。
生成される階層マスクとしては、複数の探索範囲を有する動き推定演算部のうち、いずれを使用するかを選ぶための制御情報である。
(4.2 補償処理について)
図5に示すブロックマッチング型探索処理204は、カメラワーク補償部201から与えられた補償後の前後フレームおよびマスク生成部203の階層マスク生成部203bから与えられる階層マスクを用いて、ブロックごとのブロックマッチング処理を行い、ブロックごとのローカル動きベクトルを求める。
本実施形態においては、ブロックごとに、探索範囲が異なる以外は従来と同様であるのでブロックマッチング型探索処理の説明は省略する。
局所動き補償部206はブロックマッチング型探索処理204からローカル動きベクトルを受け取ると、カメラワーク補償部201から与えられた補償後の前後フレームから、中間フレームを生成して出力する。局所動き補償部206は、その際、動きオブジェクトマスク生成部203aより動きオブジェクトマスクを受け取って、これにより動いていない領域については、補償処理をする必要がない。中間フレームの生成については、従来と同様であるので詳細な説明は省略する。
局所動き探索範囲マスクをLMV算出(局所動き推定)に用いることで、単一ブロック内で背景とオブジェクトの分離ができ、精度の向上を図ることができる。また、局所動き補償にマスクを用いることで、中間フレームのブロックノイズが減少するので、補償精度を向上することができる。
本実施形態においては、既に説明したように、1つ前のGMVを用いて、カメラワーク補償を行っている。
カメラワーク推定部209は、LMVへの分解部210から与えられたローカル動きベクトル、およびブロックマッチング型探索処理部204から出力されたローカル動きベクトルを用いてカメラワーク推定を行う。カメラワーク推定部209から出力されたグローバル動きベクトルは、LMVへの分解部208にてローカル動きベクトルに展開される。外乱除去部207は、与えられたローカル動きベクトルを用いて、計算対象ブロック選定部47(図2参照)による被選定ブロック選定処理をおこない、外乱を除去する。カメラワーク推定部209は、外乱除去後のローカル動きベクトルを用いてカメラワーク推定を行い、グローバル動きベクトルを求める。このグローバル動きベクトルが次のフレームを補償するグローバル動きベクトルとしてカメラワーク補償部201に与えられる。
なお、本実施形態においては、前回算出したグローバル動きベクトルをLMVへの分解部210にて展開するようにした。しかし、これに限られることなく、前回算出したグローバル動きベクトルをカメラワーク推定部209の出力するグローバル動きベクトルとあわせて出力するようにしてもよい。
また、本実施形態においては、カメラワーク推定部209、LMVへの分解部208、外乱除去部207と接続され、さらに、外乱除去部207の出力が、再び、カメラワーク推定部209に与えられている。しかし、これに限らず、外乱除去部207、カメラワーク推定部209と接続して、ブロックマッチング型探索処理部204からの出力を、外乱除去部207に与えて、カメラワーク推定部209にてカメラワーク推定をするようにしてもよい。
(4.3 補償処理の変形実施形態)
図13に補償処理を行う他の実施形態であるフレーム補間処理装置300の機能ブロック図を示す。図5に示す実施形態では、動きオブジェクトマスク生成部203aに、グローバル動きベクトルを用いて補償後のフレームを用いて、差分を求めた。これに対して、この実施形態では、前回算出したGMVを用いてLMVを生成し、これをマスク生成部303の動きオブジェクトマスク生成部303aに与えている。動きオブジェクトマスク生成部303aは、与えられたLMVを用いて前後フレームを各ブロック単位で移動させたものを補償後フレームとして、差分をとるようにしている。これにより、図5に示す実施形態と比べると、精度は低いが簡易な構成で、実現が可能である。また、前回算出したGMVを用いて生成したLMVは、局所動き補償部306にも与えられ、局所動き補償がなされる。
カメラワーク推定部309、LMVへの分解部308,外乱除去部307による処理については、図5の場合と同様である。
図14に補償処理を行う他の実施形態であるフレーム補間処理装置400の機能ブロック図を示す。図13に示す実施形態では、カメラワーク補償を行っていないが、この例では、マスク生成時には、LMVのみで処理を行うが、局所動き補償部406に対しては、GMVを用いて補償した前後フレームを与えている点が異なる。GMVを用いた補償処理により背景部分の回転・ズームを伴う場合に画質の劣化が抑制される。
この実施形態では、GMVを用いた補償処理はマスク生成処理の後までに間に合えばよいので、その分だけ、演算するための時間を稼ぐことができる。
この実施形態では、ブロックマッチング型ME処理部404はカメラワークを考慮していないブロックマッチング型探索処理を行っている。これに対して、局所動き補償部406で用いる画像はカメラワーク補償を行なった後の画像である。これらの整合性を保つためにカメラワーク除去LMV計算部405で、その分を除去した処理をおこなう。
また、カメラワーク推定部409、LMVへの分解部408,外乱除去部407による処理については、図5の場合と同様である。
(4.4 階層マスク生成装置としての開示)
上記実施形態における階層マスク生成部203b、303b、403bは、下記に示す階層マスク生成装置として把握することもできる。
第nフレームおよび第n+αフレームの画像データに基づいて生成され、前記第nフレームからみた第nフレーム動きマスクと、前記第n+αフレームからみた第n+αフレーム動きマスクであって、前記各動きマスクは、動いている部分が白で、動いていない部分が黒の2値画像である、が与えられると、ブロックごとに異なる探索範囲を決定するための階層マスクを生成する装置であって、
前記各動きマスクが与えられると、各々について、所定の構成画素ブロックに分割する手段であって、前記の構成画素数は、各動きマスク毎に複数種類あり、この複数種類のブロックパターンに分割する分割手段、
前記第nフレーム動きマスクにおける前記複数のブロックパターンについて、各ブロックのうち前記白部分が存在するブロックの周辺ブロックについて、前記ブロックのブロックサイズに応じて、ブロックサイズが大きくなるほど、周辺探索範囲を大きくして、前記白部分の画素数の最大値を当該周辺ブロックの最大値として決定する第nフレーム周辺ブロック画素数決定手段、
前記第n+αフレーム動きマスクにおける前記複数のブロックパターンについて、各ブロックのうち前記白部分が存在するブロックの周辺ブロックについて、前記ブロックのブロックサイズに応じて、ブロックサイズが大きくなるほど、周辺探索範囲を大きくして、前記白部分の画素数の最大値を当該周辺ブロックの最大値として決定する第n+αフレーム周辺ブロック画素数決定手段、
前記第nフレーム、第n+αフレーム動きマスクにおける前記複数のブロックパターン別に、同じブロックを比較して、当該ブロックの最大値および最小値を求める最大値最小値演算手段、
前記ブロックパターン別の各ブロックの最小値が所定の閾値を超える場合には、そのブロックパターンで示される領域が探索範囲であるとして決定する階層マスク決定手段、
を備えた階層マスク生成装置。
かかる構成を採用することにより、オブジェクトの大きさ、移動速度に応じて探索範囲を変えることができる。
なお、「ブロックパターンが異なる」とは、実施形態では、ブロックサイズだけでなく、各ブロックを重複して配置した場合について説明したが、ブロックサイズのみ異なるようにしてもよい。
(4.5 探索範囲決定装置としての開示)
上記実施形態における階層マスク生成部203b、303b、403bは、図15に示す探索範囲決定装置として把握することもできる。図15に探索範囲決定装置500の機能ブロックを示す。
探索範囲決定装置500は、第nフレームおよび第n+αフレームにおける移動オブジェクトの領域を特定するための動きマスクを用いた移動オブジェクト探索における探索範囲を決定する探索範囲決定装置であって、ブロック設定手段511および探索範囲決定手段512を備えている。
ブロック設定手段511、探索範囲決定手段512の概要について説明する。ブロック設定手段511は、第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定する。探索範囲決定手段512は、前記分割された各ブロックについて、前記第n+αフレームにおける所定の探索範囲を決定する。
詳細としては、ブロック設定手段511は、前記代表ブロック座標について、大きさの異なるブロックを設定する。探索範囲決定手段512は、探索範囲候補特定手段521、相対割合演算手段523、決定手段525を有する。探索範囲候補特定手段521は、前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する。相対割合演算手段523は、前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する。決定手段525は、前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する。
したがって、移動オブジェクトの大きさ、移動速度に応じて前記ブロック探索範囲を変えることができる。
なお、探索範囲候補については、ブロックの大きさに応じて予め決めておけばよい。また、ブロックが大きくなると探索範囲をより拡大するようにしてもよいし、固定としてもよい。
本実施形態においては、大きさの異なるブロックを複数設定するようにしたが、画像自体を縮小してもよい。
(4.6 探索装置としての開示)
上記実施形態における階層マスク生成部203bおよびブロックマッチング型ME処理部204は、下記に示す探索装置して把握することもできる。階層マスク生成部303bと304,および階層マスク生成部403bとブロックマッチング型ME処理部404についても同様である。
A)第nフレームおよび第n+αフレームにおける移動オブジェクトの領域を特定するための動きマスクを用いた移動オブジェクト探索における探索範囲を決定する探索装置であって、B)第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定するブロック設定手段、C)前記分割された各ブロックについて、前記第n+αフレームにおける所定の探索範囲を決定する探索範囲決定手段、D)前記各ブロックの探索範囲においてブロックマッチングを行ない、対象フレームの動きベクトルを求める動きベクトル演算手段、を備えた探索装置において、E)前記動きベクトル演算手段は、前記代表ブロック座標について、大きさの異なるブロックを設定し、F)前記探索範囲決定手段は、f1)前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する探索範囲候補特定手段、f2)前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する相対割合演算手段、f3)前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する決定手段を備えていること、を特徴とする探索装置。
(4.7 動きオブジェクトマスク生成装置としての開示)
上記実施形態における動きオブジェクトマスク生成部203aは、下記に示す動きマスク生成装置として把握することもできる。
第nフレームおよび第n+αフレームの画像データに基づいて生成され、前記第nフレームからみた第nフレーム動きマスクと、前記第n+αフレームからみた第n+αフレーム動きマスクであって、前記各動きマスクは、動いている部分が白で、動いていない部分が黒の2値画像である、を生成する動きマスク生成部装置であって、
第nフレームから第n+αフレームの画像データを減算して、値がマイナスとなる画素については値をゼロとした前記第nフレームからみた第nフレーム動きマスクを生成する第1マスク生成手段、
第n+αフレームから第nフレームの画像データを減算して、値がマイナスとなる画素については値をゼロとした前記第n+αフレームからみた第n+αフレーム動きマスクを生成する第2マスク生成手段、
前記第nフレームの画像データから第nフレームエッジ画像を抽出する第1エッジ抽出手段、
前記第n+αフレームの画像データから第n+αフレームエッジ画像抽出する第2エッジ抽出手段、
第nフレーム動きマスクを、前記第nフレームエッジ画像および第n+αフレーム動きマスクによって補正する第1補正手段、
第n+αフレーム動きマスクを、前記第n+αフレームエッジ画像および第nフレーム動きマスクによって補正する第2補正手段、
を備えた動きマスク生成装置。
また、上記開示した装置を任意に組み合わせることもできる。
(4.8 縮小画面を用いた探索装置としての開示)
上記では、画像を固定とし、複数の探索範囲を採用した場合を例として説明したが、従来の縮小画像を用いた階層化動き推定法(以下、縮小画像階層化動き推定法という)についても同様である。以下、説明する。まず、前記制御情報は、探索範囲として、いずれの縮小画像を用いるかを示すフラグ信号となる。
通常、縮小画像階層化動き推定法は、縮小画像で検索をして、その動きベクトルを拡大変換した拡大変換動きベクトルを求めて、かかる拡大変換動きベクトルで特定されるブロックを中心にして所定の探索範囲についてブロックマッチングを行うというものである。
簡単に説明する。図16Aに示すような縮小画面を生成しておき、かかる縮小画面における各ブロック701〜704についての動きベクトルを求める。ここでは、図16Bに示す動きベクトルが得られたものとする。次に、得られた動きベクトルを初期ベクトルとして下位層に適用して、対策を行う。具体的には、図16Bに示す各動きベクトルそのまま、拡大して、図16Cに示す動きベクトルとし、各ブロックについて初期ベクトルで示された範囲を中心として、所定の探索範囲を探索する。これを、各階層について繰り返す。
上記縮小画像を用いた探索については、静止画像部分も動画部分も探索範囲が同じであるので、静止画部分に同じ画像が複数あった場合等は、正しい探索結果が得られないという問題があった。
本件階層マスクによって、採用する縮小画像を特定することにより、既に説明したように、ブロックごとに用いる縮小画面を切り換えることができる。したがって、静止部分については、探索範囲を狭くすることができる。
このように、本件階層マスクを用いた探索範囲決定方法は、従来の縮小画像階層化動き推定法にも適用可能である。
なお、かかる探索処理は速度が優先されるのでハードウェアで実行される。したがって、各ブロックについて、探索範囲をその都度切り換える処理は、かえって時間がかかることになる。そこで、以下に示す実施形態においては、所定数の縮小された階層マスク(以下縮小階層マスクという)を生成し、縮小画像階層化動き推定法における上位層の動きベクトルを下位層に適用する際に、かかる縮小階層マスクを、探索範囲外のブロックについては、初期ベクトルをゼロとするようなマスクとして利用し、これにより、探索範囲がブロックごとに異なることを可能とした。
図17に、階層マスクとして、階層3〜階層1までを用いた場合の、ブロックマッチング型探索処理部204の詳細ブロック図を示す。各部について説明する。なお、本実施形態においては、オリジナル画像として図18Aに示すデータとし、また、縮小した階層縮小マスクとして、図19Aに示す階層マスクが与えられたものとする。ここで、縮小階層マスクの数としては、階層数に応じて変化し、縮小していない階層マスクを含んで、計(階層数−1)個を生成する。これは、第n層の動きベクトルを、第n-1層に適用するときに、当該第n-1層の、縮小階層マスクを用いるので、最終的には、階層数−1の縮小マスクが存在すればよいからである。
図17に示す縮小画面生成部911は、図18Aに示すオリジナル画像からブロックサイズはそのままにした1/4画像データを生成する。オリジナル画像(図18A)では、物体601は1ブロックとほぼ同じ大きさで表示されているが、1/4縮小画面(同図B)では、1/4に縮小されている(物体611〜614参照)。縮小画面生成部921は、縮小画面生成部911が生成した1/4画像データをさらに、1/4倍に縮小した1/16画像を生成する。これにより図18Cに示すように、オリジナルからすると、1/16縮小画像として物体621〜624が生成される。
図17に示す縮小階層マスク生成部901は、縮小階層マスクを生成する。図19A,Bを用いて、縮小階層マスクの生成について説明する。オリジナルの階層マスク641(同図A参照)から、縮小階層マスク642(同図B参照)を生成する。本実施形態においては、4つのブロックの右上を代表として他を間引くことにより、オリジナルの階層マスクを1/4に縮小するようにしたが、これに限定されない。
図17に示すブロックマッチング型探索処理部913は、縮小画像生成部921が生成した画像を用いて、ブロックマッチング型探索を行う。ここでは、かかる探索により、図20Aに示す動きベクトルLMV1sが得られたものとする。下位階層へのMV転送処理部914は、この動きベクトルを下位層である階層2に適用する。具体的には、まず、従来と同様に、拡大処理をする(同図B参照)。そして、図19Bに示す縮小階層マスクを用いて、マスキング処理をする。マスキング処理としては、当該階層よりも上位の階層であるブロックの領域を白抜きしたマスクとして扱われる。これにより、階層3において、探索範囲とはならなかったブロックについてはゼロベクトルとする初期ベクトルLMV1’sが得られる。図20にかかる処理の概要を示す。
図17に示すブロックマッチング型探索処理部923は、縮小画像生成部911が生成した画像について、初期ベクトルLMV1’sを用いて探索を行なう。具体的には、初期ベクトルが与えられているブロックについては、当該初期ベクトルに基づいて特定されるブロックを中心に探索処理がなされる。初期ベクトルがゼロベクトルのブロックはそのブロックを中心に探索処理がなされる。
ここでは、図21Aに示す動きベクトルLMV2sが得られたものとする。
下位階層へのMV転送処理部924は、この動きベクトルLMV2sを下位層に適用する。具体的には、まず、従来と同様に、拡大処理をする(同図B参照)。そして、図19Aに示す階層マスクを用いて、マスキング処理をする。マスキング処理において、この階層マスクは、当該階層よりも上位の階層であるブロックの領域を白抜きしたマスクとして扱われる。これにより、階層1において探索範囲とはならなかったブロックについてはゼロベクトルとする初期ベクトルLMV2’sが得られる(図21D参照)。図21にかかる処理の概要を示す。
ブロックマッチング型探索処理部933は、オリジナル画像を用いて、初期ベクトルLMV2’sを用いてブロックマッチング型探索を行う。
このようにして、本実施形態においては、階層マスクから生成した縮小マスクを用いて、不要なブロックについては初期ベクトルをゼロベクトルとするようにした。これにより、ブロックごとに範囲を変更する探索が可能となる。
(5.他の実施形態)
本実施形態においては、順方向における動きベクトルを求める場合、すなわち、α=1である場合について説明したが、αは0以外の整数、または分数であってもよい。たとえば、α=−1の場合には、逆方向の動きベクトルを求めることとなる。
また、順方向型探索装置である場合について説明したので、参照フレームが第nフレーム、対象フレームが第n+1フレームに該当する場合について説明した。これに対して、逆方向探索の場合は、対象フレームが第nフレーム、参照フレームが、第n+1フレームとなる。さらに、対称型探索装置に適用することもできる。その場合、例えば、第n+0.5フレームが対象フレームとなる。このように、対象フレームについては、限定されない。
また、ブロック形状は、矩形に限定されることなく、任意の形状に適用可能である。これにより、オブジェクトの形状のブロックを定義して、ブロックマッチングするようにしてもよい。
上記各実施形態においては、各ブロックで行っているアルゴリズムを、ハードウェア記述言語(Hardware Description Language)で記述することにより、各ブロックを構成すればよい。
上記実施形態においては、図1、図5に示す機能を実現するために、並列処理を可能とするために、全てをハードウェア処理する場合について説明した(例えば、図2参照)。しかし、これに限定されず、一部をソフトウェアによって実現してもよい。その場合、プログラムの一部の処理を、オペレーティングシステム(OS)にさせるようにしてもよい。
上記開示した発明は下記のような装置として把握することができる。
A)第nフレームと第n+αフレームについて、それぞれ1画面を構成する画素を所定の矩形のブロックにブロック化して、ブロック別の動きベクトルであるローカル動きベクトルを求めるとともに、求めたブロックについてのローカル動きベクトルを計算対象ブロックのローカル動きベクトルとして与えるブロック別動きベクトル演算手段、B)前記計算対象ブロックのローカル動きベクトルが与えられると、各ブロックを注目ブロックとして、その周辺ブロックのローカル動きベクトルの平均と当該注目ブロックのローカル動きベクトルとの差分の絶対値に基づいて注目ブロックのローカル動きベクトルに重み付け係数を全計算対象ブロックについて演算するとともに、前記計算対象ブロックの各重み付け係数およびローカル動きベクトルから、最小二乗法によりグローバル動きベクトルの平行移動パラメータを演算する平行移動パラメータ演算手段、C)前記平行移動パラメータが与えられると、この平行移動パラメータおよび、平行移動、回転、ズームの4パラメータで表したアフィン変換式からグローバル動きベクトルの回転・ズームパラメータを求める回転・ズームパラメータ演算手段、D)前記平行移動パラメータ、および回転・ズームパラメータが与えられると、各ブロックについてのローカル動きベクトルに展開した展開後ローカル動きベクトルを演算する展開後動きベクトル手段、E)計算対象ブロックを選別するための閾値を記憶する閾値記憶手段、F)各ブロックについて、前記展開後ローカル動きベクトルと、前記ブロック別動きベクトル演算手段が演算したローカル動きベクトルとの差が前記閾値記憶手段に記憶された閾値内であるブロックを計算対象ブロックとして決定し、決定した計算対象ブロックについての前記ブロック別動きベクトル演算手段が演算したローカル動きベクトルを前記平行移動パラメータ演算手段に計算対象ブロックとして与える計算対象ブロック決定手段、G)計算対象ブロック決定手段の処理を所定回数繰り返し実行する手段であって、繰り返し回数が増える度に前記閾値を小さくして、前記繰り返し処理を行う繰り返し手段を備えたグローバル動きベクトル演算装置。
このように、最小二乗法によりグローバル動きベクトルの平行移動パラメータを演算し、この平行移動パラメータからアフィン変換式により、グローバル動きベクトルの回転・ズームパラメータを求めることにより、カメラワークにおける平行移動、回転・ズームパラメータを簡易に求めることができる。
また、前記求めたグローバル動きベクトルのパラメータについて、閾値を変更しつつ計算対象ブロックを変更して繰り返し演算を行うことにより、より精度の高いグローバル動きベクトルの平行移動パラメータ、および回転・ズームパラメータを求めることができる。
A)演算結果であるブロック別のローカル動きベクトルを記憶するローカル動きベクトル記憶手段、B)前記ブロックごとのローカル動きベクトルからグローバル動きベクトルの平行移動、回転、ズームの各パラメータを求めるグローバル動きベクトル演算手段、C)求めたグローバル動きベクトルを各ブロックのローカル動きベクトルに展開した展開ローカル動きベクトルを求める展開動きベクトル演算手段、D)計算対象ブロックを選別するための閾値を記憶する閾値記憶手段、E)各ブロックについて、前記ローカル動きベクトル記憶手段に記憶されたローカル動きベクトルと展開ローカル動きベクトルとの差分を求め、前記閾値を超えないブロックを対象ブロックとして決定する演算対象ブロック選定手段、F)前記対象ブロックとして決定されなったブロックを除外して、前記グローバル動きベクトル演算手段に新たなグローバル動きベクトルを求めさせる処理を、所定条件まで繰り返し実行する繰り返し手段を備えたグローバル動きベクトル演算装置。
前記求めたグローバル動きベクトルのパラメータについて、繰り返し演算を行うことにより、より精度の高いグローバル動きベクトルの平行移動パラメータ、および回転・ズームパラメータを求めることができる。
前記繰り返し手段は、前記繰り返し回数が増える度に前記閾値を小さくして、前記繰り返し処理を行ってもよい。したがって、繰り返し回数が多くなるにつれて、計算対象ブロックをより適切な範囲に選択することができる。これにより、精度の高いグローバル動きベクトルの平行移動パラメータ、および回転・ズームパラメータを求めることができる。
前記グローバル動きベクトル演算手段は、1)前記計算対象ブロックのローカル動きベクトルが与えられると、各ブロックを注目ブロックとして、その周辺ブロックのローカル動きベクトルの平均と当該注目ブロックのローカル動きベクトルとの差分の絶対値に基づいて注目ブロックのローカル動きベクトルに重み付け係数を全計算対象ブロックについて演算するとともに、前記計算対象ブロックの各重み付け係数およびローカル動きベクトルから、最小二乗法によりグローバル動きベクトルの平行移動パラメータを演算する平行移動パラメータ演算手段、2)前記平行移動パラメータが与えられると、この平行移動パラメータおよび、平行移動、回転、ズームの4パラメータで表したアフィン変換式からグローバル動きベクトルの回転・ズームパラメータを求める回転・ズームパラメータ演算手段、で構成してもよい。
したがって、簡易にグローバル動きベクトルの平行移動パラメータ、および回転・ズームパラメータを求めることができる。
前記重み付け係数は、注目ブロックおよびその周辺ブロックのローカル動きベクトルの平均と、当該注目ブロックのローカル動きベクトルとの差分の絶対値のべき乗としてもよい。したがって、疑いのあるブロックの寄与を限りなく小さくすることができる。
A)演算結果であるブロック別のローカル動きベクトルを記憶するローカル動きベクトルおよび計算対象ブロックを選別するための閾値を記憶しておき、B)前記ブロックごとのローカル動きベクトルからグローバル動きベクトルの平行移動、回転、ズームの各パラメータを求め、C)求めたグローバル動きベクトルを各ブロックのローカル動きベクトルに展開した展開ローカル動きベクトルを求め、D)各ブロックについて、前記記憶されているローカル動きベクトルと前記展開ローカル動きベクトルとの差分を求め、E)前記閾値と比較し、これを超えないブロックを対象ブロックとして決定し、F)前記対象ブロックとして決定されなったブロックを除外して、グローバル動きベクトルの平行移動、回転、ズームの各パラメータを求めさせる処理を、所定条件まで繰り返し実行するグローバル動きベクトル演算装置。
前記求めたグローバル動きベクトルのパラメータについて、繰り返し演算を行うことにより、より精度の高いグローバル動きベクトルの平行移動パラメータ、および回転・ズームパラメータを求めることができる。
上記グローバル動きベクトル演算装置にさらに、B)前記グローバル動きベクトル演算装置から与えられたグローバル動きベクトルによって、第nフレームおよび第n+αフレームをカメラワーク補償した補償後第nフレームと補償後第n+αフレームを出力するカメラワーク補償手段、C)前記補償後第nフレームと補償後第n+αフレームを用いて、静止部分を特定するためのマスクを生成するマスク生成手段、D)前記マスクを用いて、前記補償後第nフレームと補償後第n+αフレームのブロックマッチング型探索処理を行い、マッチング結果に基づいて、ブロックごとのローカル動きベクトルを出力するブロックマッチング探索処理手段、E)前記ブロックマッチング探索処理手段から与えられたローカル動きベクトルと、前記補償後第n、n+αフレームと、前記生成されたマスクを用いて、前記補償後第nフレームと補償後第n+αフレームの中間フレームを生成して出力する局所動き補償手段を備えたフレーム補間処理装置。
したがって、より精度の高いグローバル動きベクトルの平行移動パラメータ、および回転・ズームパラメータによるカメラワーク補償が可能なフレーム補間処理が可能となる。

Claims (11)

  1. 第nフレームおよび第n+αフレームの画像データに基づいて生成され、前記第nフレームからみた第nフレーム動きマスクと、前記第n+αフレームからみた第n+αフレーム動きマスクであって、前記各動きマスクは、各画素が動きのある部分に該当するのか、または動きのない部分に該当するのかを表す信号である、が与えられると、ブロックごとに異なる探索範囲を決定するための階層マスクを生成する装置であって、
    前記各動きマスクが与えられると、各々について、所定の構成画素ブロックに分割する手段であって、前記の構成画素数は、各動きマスク毎に複数種類あり、この複数種類のブロックパターンに分割する分割手段、
    前記第nフレーム動きマスクにおける前記複数のブロックパターンについて、各ブロックのうち前記動きのある部分が存在するブロックの周辺ブロックについて、前記ブロックのブロックサイズに応じて、ブロックサイズが大きくなるほど、周辺探索範囲を大きくして、前記白部分の画素数の最大値を当該周辺ブロックの最大値として決定する第nフレーム周辺ブロック画素数決定手段、
    前記第n+αフレーム動きマスクにおける前記複数のブロックパターンについて、各ブロックのうち前記動きのある部分が存在するブロックの周辺ブロックについて、前記ブロックのブロックサイズに応じて、ブロックサイズが大きくなるほど、周辺探索範囲を大きくして、前記白部分の画素数の最大値を当該周辺ブロックの最大値として決定する第n+αフレーム周辺ブロック画素数決定手段、
    前記第nフレーム、第n+αフレーム動きマスクにおける前記複数のブロックパターン別に、同じブロックを比較して、当該ブロックの最大値および最小値を求める最大値最小値演算手段、
    前記ブロックパターン別の各ブロックの最小値が所定の閾値を超える場合には、そのブロックパターンで示される領域が探索範囲であるとして決定する階層マスク決定手段、
    を備えた階層マスク生成装置。
  2. 第nフレームおよび第n+αフレームにおける移動オブジェクトの領域を特定するための動きマスクを用いた移動オブジェクト探索における探索範囲を決定する探索範囲決定装置であって、
    第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定するブロック設定手段、
    前記分割された各ブロックについて、前記第n+αフレームにおける所定の探索範囲を決定する探索範囲決定手段、
    を備えた探索範囲決定装置において、
    前記ブロック設定手段は、前記代表ブロック座標について、大きさの異なるブロックを設定し、
    前記探索範囲決定手段は、以下の手段を備えていること、
    前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する探索範囲候補特定手段、
    前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する相対割合演算手段、
    前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する決定手段、
    を特徴とする探索範囲決定装置。
  3. 請求項2の探索範囲決定装置において、
    前記動きマスクは、各画素が動きのある部分に該当するのか、または動きのない部分に該当するのかを表す信号であり、
    前記相対割合は、当該範囲内における動きのある部分の占める割合であること、
    を特徴とする探索範囲決定装置。
  4. 第nフレームおよび第n+αフレームにおける移動オブジェクトの領域を特定するための動きマスクを用いた移動オブジェクト探索における探索範囲を決定する探索装置であって、
    第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定するブロック設定手段、
    前記分割された各ブロックについて、前記第n+αフレームにおける所定の探索範囲を決定する探索範囲決定手段、
    前記各ブロックの探索範囲においてブロックマッチングを行ない、対象フレームの動きベクトルを求める動きベクトル演算手段、
    を備えた探索装置において、
    前記ブロック設定手段は、前記代表ブロック座標について、大きさの異なるブロックを設定し、
    前記探索範囲決定手段は、以下の手段を備えていること、
    前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する探索範囲候補特定手段、
    前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する相対割合演算手段、
    前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する決定手段、
    を特徴とする探索装置。
  5. 請求項4の探索装置において、
    前記動きベクトル演算手段は、前記第nフレームおよび前記第n+αフレームの画像データを縮小させる画像縮小手段を有しており、前記決定手段からブロック探索範囲が与えられると、これを当該ブロックに対して採用する画像の縮小率であるとして、前記ブロックマッチングを行うこと、
    を特徴とする探索装置。
  6. 請求項5の探索装置において、
    前記動きベクトル演算手段は、前記縮小画面について縮小率の大きな画像でのブロックマッチングによって得られた動きベクトルを、縮小率が次に小さい画像でのブロックマッチングにおける初期ベクトルとして採用して、当該初期ベクトルで特定されるブロックに基づく所定の範囲の探索処理を、前記縮小率を小さくして繰り返し探索する予備探索型ブロックマッチング手段であって、前記各ブロックについて、前記決定手段から与えられたブロック探索範囲に基づいて、前記繰り返し探索する開始画像の縮小率を決定して、前記ブロックマッチングを行う予備探索型ブロックマッチング手段を有すること、
    を特徴とする探索装置。
  7. 請求項5の探索装置において、
    前記動きベクトル演算手段は、前記縮小画面について縮小率の大きな画像でのブロックマッチングによって得られた動きベクトルを、縮小率が次に小さい画像でのブロックマッチングにおける初期ベクトルとして採用して、当該初期ベクトルで特定されるブロックに基づく所定の範囲の探索処理を、前記縮小率を小さくして繰り返し探索する予備探索型ブロックマッチング手段であって、前記繰り返し探索の各探索処理において全ブロックについての初期ベクトルを演算した後、当該縮小画像において得られた初期ベクトルを、前記階層マスクで使用可能なブロック以外はゼロベクトルとなるようにマスク処理をしたものを初期ベクトルとして前記繰り返し探索を行う予備探索型ブロックマッチング手段を有すること、
    を特徴とする探索装置。
  8. 第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定するブロック設定手段、
    前記分割された各ブロックについて、第n+αフレームにおける所定の探索範囲を決定する探索範囲決定手段、
    前記決定された探索範囲においてブロックマッチングを行い、対象フレームの動きベクトルを求める動きベクトル演算手段、
    前記動きベクトル演算手段から与えられたローカル動きベクトルと、前記第n、n+αフレームと、前記生成されたマスクを用いて、前記第nフレームと第n+αフレームの間の、補間フレームを生成する局所動き補償手段、
    を備えたフレーム補間処理装置において、
    前記ブロック設定手段は、前記代表ブロック座標について、大きさの異なるブロックを設定し、
    前記探索範囲決定手段は、以下の手段を備えていること、
    前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定する探索範囲候補特定手段、
    前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算する相対割合演算手段、
    前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームについて、前記各探索範囲候補の探索範囲内における移動オブジェクトの占める相対割合を演算する相対割合演算手段、
    前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定する決定手段、
    を特徴とするフレーム補間処理装置。
  9. 第nフレームおよび第n+αフレームにおける移動オブジェクトの領域を特定するための動きマスクを用いた移動オブジェクト探索における探索範囲を決定する探索範囲決定方法であって、
    第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定するブロック設定ステップ、
    前記分割された各ブロックについて、前記第n+αフレームにおける所定の探索範囲を決定するステップ、
    を備えた探索範囲決定方法において、
    前記ブロック設定ステップは、前記代表ブロック座標について、大きさの異なるブロックを設定し、
    前記探索範囲決定ステップでは、
    前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定し、
    前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算し、
    前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定すること、
    を特徴とする探索範囲決定方法。
  10. 第nフレームおよび第n+αフレームにおける移動オブジェクトの領域を特定するための動きマスクを用いた移動オブジェクト探索における探索範囲を決定する探索方法であって、
    第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定するブロック設定ステップ、
    前記分割された各ブロックについて、前記第n+αフレームにおける所定の探索範囲を決定する探索範囲決定ステップ、
    前記各ブロックの探索対象フレームの動きベクトルを求める動きベクトル演算ステップ、
    を備えた探索方法において、
    前記ブロック設定ステップは、前記代表ブロック座標について、大きさの異なるブロックを設定し、
    前記探索範囲決定ステップは、
    前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定し、
    前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算し、
    前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定すること、
    を特徴とする探索方法。
  11. 第nフレームにおける画像を所定画素単位のブロックに分割し、所定の代表ブロック座標で各ブロックを特定するブロック設定ステップ、
    前記分割された各ブロックについて、第n+αフレームにおける所定の探索範囲を決定する探索範囲決定ステップ、
    前記決定された探索範囲において対象フレームの動きベクトルを求める動きベクトル演算ステップ、
    前記与えられたローカル動きベクトルと、前記第n、n+αフレームと、前記生成されたマスクを用いて、前記第nフレームと第n+αフレームの間の補間フレームを生成する局所動き補償ステップ、
    を備えたフレーム補間処理方法において、
    前記ブロック設定ステップは、前記代表ブロック座標について、大きさの異なるブロックを設定し、
    前記探索範囲決定ステップは、
    前記異なる大きさのブロック毎に第n+αフレームの探索範囲を探索範囲候補として特定し、
    前記代表ブロック座標で特定される第nフレームのブロック内における移動オブジェクトの占める相対割合を演算するとともに、対応する前記第n+αフレームのブロックについて、前記各探索範囲候補の探索範囲内のブロックにおける移動オブジェクトの占める相対割合を演算し、
    前記相対割合が大きなブロックに対応する探索範囲候補を、前記代表ブロック座標で特定されるブロック探索範囲として決定すること、
    を特徴とするフレーム補間処理方法。
JP2010012272A 2009-10-06 2010-01-22 階層マスク生成装置、フレーム補間処理装置 Expired - Fee Related JP5164280B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2010012272A JP5164280B2 (ja) 2009-10-06 2010-01-22 階層マスク生成装置、フレーム補間処理装置

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
JP2009232315 2009-10-06
JP2009232315 2009-10-06
JP2010012272A JP5164280B2 (ja) 2009-10-06 2010-01-22 階層マスク生成装置、フレーム補間処理装置

Publications (2)

Publication Number Publication Date
JP2011101336A true JP2011101336A (ja) 2011-05-19
JP5164280B2 JP5164280B2 (ja) 2013-03-21

Family

ID=44191532

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2009257332A Expired - Fee Related JP4964937B2 (ja) 2009-10-06 2009-11-10 動きベクトル検出装置、フレーム補間処理装置およびそれらの方法
JP2010012272A Expired - Fee Related JP5164280B2 (ja) 2009-10-06 2010-01-22 階層マスク生成装置、フレーム補間処理装置

Family Applications Before (1)

Application Number Title Priority Date Filing Date
JP2009257332A Expired - Fee Related JP4964937B2 (ja) 2009-10-06 2009-11-10 動きベクトル検出装置、フレーム補間処理装置およびそれらの方法

Country Status (1)

Country Link
JP (2) JP4964937B2 (ja)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2017154318A1 (ja) * 2016-03-09 2017-09-14 ソニー株式会社 情報処理装置、情報処理方法、プログラム及び情報処理システム
JP2022064853A (ja) * 2020-10-14 2022-04-26 アクシス アーベー 動きセグメント化のための方法およびシステム

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2013066164A (ja) * 2011-09-02 2013-04-11 Sony Corp 画像処理装置、および画像処理方法、並びにプログラム

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH06133299A (ja) * 1992-10-15 1994-05-13 Ricoh Co Ltd 動きベクトル検出方法
JPH0937269A (ja) * 1995-07-25 1997-02-07 Hitachi Ltd 画像圧縮装置
JP2000134585A (ja) * 1998-10-23 2000-05-12 Hitachi Ltd 動きベクトル決定方法、画像信号のフレーム数変換方法および回路
JP2008219141A (ja) * 2007-02-28 2008-09-18 Sanyo Electric Co Ltd 動きベクトル検出装置、それを用いた画像符号化装置および撮像装置

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2586686B2 (ja) * 1990-04-19 1997-03-05 日本電気株式会社 動画像の動き情報検出装置および動画像の動き補償フレーム間予測符号化装置
JP4052588B2 (ja) * 2004-01-26 2008-02-27 Kddi株式会社 動き予測情報検出装置
JP4496992B2 (ja) * 2005-03-02 2010-07-07 日本電信電話株式会社 動物体アップフレーム検出方法及びプログラム及びプログラムを格納した記憶媒体及び動物体アップショット検出方法及び動物体アップフレームあるいはショット検出方法及びプログラム及びプログラムを格納した記憶媒体
EP1755342A1 (en) * 2005-08-19 2007-02-21 Thomson Licensing Method and apparatus for iteratively calculating a set of global motion parameters for a picture sequence from block motion vectors
JP5045320B2 (ja) * 2007-09-05 2012-10-10 ソニー株式会社 画像処理装置、および画像処理方法、並びにコンピュータ・プログラム
JP4876065B2 (ja) * 2007-12-14 2012-02-15 キヤノン株式会社 動きベクトル検出装置及び動きベクトル検出方法及び撮像装置及びプログラム
JP4623111B2 (ja) * 2008-03-13 2011-02-02 ソニー株式会社 画像処理装置、画像処理方法及びプログラム
JP4544334B2 (ja) * 2008-04-15 2010-09-15 ソニー株式会社 画像処理装置および画像処理方法
JP4506875B2 (ja) * 2008-05-19 2010-07-21 ソニー株式会社 画像処理装置および画像処理方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH06133299A (ja) * 1992-10-15 1994-05-13 Ricoh Co Ltd 動きベクトル検出方法
JPH0937269A (ja) * 1995-07-25 1997-02-07 Hitachi Ltd 画像圧縮装置
JP2000134585A (ja) * 1998-10-23 2000-05-12 Hitachi Ltd 動きベクトル決定方法、画像信号のフレーム数変換方法および回路
JP2008219141A (ja) * 2007-02-28 2008-09-18 Sanyo Electric Co Ltd 動きベクトル検出装置、それを用いた画像符号化装置および撮像装置

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2017154318A1 (ja) * 2016-03-09 2017-09-14 ソニー株式会社 情報処理装置、情報処理方法、プログラム及び情報処理システム
JPWO2017154318A1 (ja) * 2016-03-09 2019-01-10 ソニー株式会社 情報処理装置、情報処理方法、プログラム及び情報処理システム
US10845186B2 (en) 2016-03-09 2020-11-24 Sony Corporation Information processing device, information processing method, and information processing system
JP2022064853A (ja) * 2020-10-14 2022-04-26 アクシス アーベー 動きセグメント化のための方法およびシステム
JP7359816B2 (ja) 2020-10-14 2023-10-11 アクシス アーベー 動きセグメント化のための方法およびシステム

Also Published As

Publication number Publication date
JP2011100428A (ja) 2011-05-19
JP5164280B2 (ja) 2013-03-21
JP4964937B2 (ja) 2012-07-04

Similar Documents

Publication Publication Date Title
KR102115066B1 (ko) 비디오 안정화를 위한 적응적 경로 평활화
US9824431B2 (en) Image synthesis apparatus, image synthesis method, and recording medium
US9436981B2 (en) Dictionary creation device, image processing device, image processing system, dictionary creation method, image processing method, and program
US8873886B2 (en) Apparatus and method for displaying a region of an image in an enlarged manner, and program therefor
US10931875B2 (en) Image processing device, image processing method and storage medium
US8416989B2 (en) Image processing apparatus, image capture apparatus, image processing method, and program
WO2013114675A1 (ja) 画像処理装置、歪補正マップ作成装置、および半導体計測装置
JP5164280B2 (ja) 階層マスク生成装置、フレーム補間処理装置
US20130235274A1 (en) Motion vector detection device, motion vector detection method, frame interpolation device, and frame interpolation method
US9142031B2 (en) Image processing apparatus with detection of motion vector between images, control method therefor, and storage medium storing control program therefor
JP6532328B2 (ja) 画像処理装置、その制御方法、および制御プログラム
JPH10111946A (ja) 画像追跡装置
JPWO2013011797A1 (ja) 劣化復元システム、劣化復元方法およびプログラム
JP2011154634A (ja) 画像処理装置、画像処理方法及び画像処理用プログラム
JP2012118923A (ja) 領域分割装置及び領域分割方法
Ge et al. Image completion using global patch matching and optimal seam synthesis
WO2015159778A1 (ja) 画像処理装置、画像処理方法及び画像処理プログラム
JP5857531B2 (ja) 画像処理装置、画像処理方法及びプログラム
KR20140054713A (ko) 영상 처리 방법 및 장치
JP2008225778A (ja) 画像処理装置
JP5719271B2 (ja) 画像処理方法、画像処理装置及び画像処理プログラム
JP2009104228A (ja) 画像位置合わせ方法及び画像位置合わせプログラム
CN114257756A (zh) 校正移动向量的视频处理方法
JP2004086793A (ja) 物体画像抽出方法、物体画像抽出プログラム
CN115619709A (zh) 一种3d平面检测与重建方法、装置及存储介质

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20120906

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20120918

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20121112

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20121217

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

Free format text: PAYMENT UNTIL: 20151228

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

Free format text: PAYMENT UNTIL: 20151228

Year of fee payment: 3

S533 Written request for registration of change of name

Free format text: JAPANESE INTERMEDIATE CODE: R313533

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

LAPS Cancellation because of no payment of annual fees