読取装置、方法及びプログラム
【課題】歪みが生じたコードであっても読み取り可能な読取装置、方法及びプログラムを提供する。
【解決手段】実施形態の読取装置は、取得部と、検出部と、統合部と、読取部と、を備える。取得部は、コードを含む画像を取得する。検出部は、画像からコードの一部を含む複数の局所領域を検出する。統合部は、複数の局所領域を統合してコード領域を得る。読取部は、コード領域を読み取る。
【解決手段】実施形態の読取装置は、取得部と、検出部と、統合部と、読取部と、を備える。取得部は、コードを含む画像を取得する。検出部は、画像からコードの一部を含む複数の局所領域を検出する。統合部は、複数の局所領域を統合してコード領域を得る。読取部は、コード領域を読み取る。
【発明の詳細な説明】
【技術分野】
【0001】
本発明の実施形態は、読取装置、方法及びプログラムに関する。
【背景技術】
【0002】
バーコードなどの各種コードは、商品販売、物流、及び生産工程など幅広い分野において、物品の管理情報の表記に用いられている。このようなコードの読み取りには、コードを直接指示して読み取るハンドスキャナやペン入力スキャナ、又は複数方向にビームを走査させていずれかのビームでコードを読み取る定置型スキャナなどが用いられる。
【先行技術文献】
【特許文献】
【0003】
【特許文献1】特開2002−150213号公報
【発明の概要】
【発明が解決しようとする課題】
【0004】
しかしながら、上述したような従来技術では、変形可能な物体にコードが印刷又は貼り付けられている場合、物体の変形に伴いコードに歪みが生じるため、コードを読み取れない場合がある。本発明が解決しようとする課題は、歪みが生じたコードであっても読み取り可能な読取装置、方法及びプログラムを提供することである。
【課題を解決するための手段】
【0005】
実施形態の読取装置は、取得部と、検出部と、統合部と、読取部と、を備える。取得部は、コードを含む画像を取得する。検出部は、画像からコードの一部を含む複数の局所領域を検出する。統合部は、複数の局所領域を統合してコード領域を得る。読取部は、コード領域を読み取る。
【図面の簡単な説明】
【0006】
【図1】第1実施形態の読取装置の例を示す構成図。
【図2】第1実施形態のコードの例を示す図。
【図3】第1実施形態の検出部の詳細例を示す構成図。
【図4】第1実施形態の検出部により検出された複数の局所領域の例を示す図。
【図5】第1実施形態の統合部により得られたコード領域の例を示す図。
【図6】第1実施形態の統合部により得られたコード領域の例を示す図。
【図7】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図8】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図9】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図10】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図11】第1実施形態の読取処理例を示すフローチャート。
【図12】第2実施形態の読取装置の例を示す構成図。
【図13】第2実施形態の検出部の検出対象のオブジェクトの例を示す図。
【図14】第2実施形態の統合部により得られたコード領域の例を示す図。
【図15】第2実施形態の読取処理例を示すフローチャート。
【図16】第1〜第2実施形態の読取装置のハードウェア構成例を示すブロック図。
【発明を実施するための形態】
【0007】
以下、添付図面を参照しながら、実施形態を詳細に説明する。
【0008】
(第1実施形態)
図1は、第1実施形態の読取装置10の一例を示す構成図である。図1に示すように、読取装置10は、取得部11と、検出部13と、統合部15と、読取部17とを、備える。読取装置10の各部は、例えば、CPU(Central Processing Unit)などの処理装置にプログラムを実行させること、即ち、ソフトウェアにより実現してもよいし、IC(Integrated Circuit)などのハードウェアにより実現してもよいし、ソフトウェア及びハードウェアを併用して実現してもよい。
【0009】
取得部11は、画像入力部(図示省略)から入力される画像を取得する。画像入力部は、例えば、デジタルカメラなどの撮像装置により実現でき、撮像した画像を入力する。第1実施形態では、画像入力部が入力する画像、即ち、取得部11が取得する画像は、湾曲など変形可能な物体に印刷又は貼り付けられているコードを撮像した画像を想定している。このため、第1実施形態では、取得部11は、コードを含む画像を取得することになる。なお、物体の変形に伴い歪みが生じているコードを画像入力部が撮像した場合には、取得部11が取得した画像内のコードにも当然歪みが生じている。
【0010】
第1実施形態のコードは、光学的に認識可能なコードであり、局所的に類似した模様が繰り返し並んだパタンが用いられる。具体的には、第1実施形態のコードは、第1方向には模様が異なり、第1方向に対して垂直な第2方向には模様が一様なパタンが用いられる。第1実施形態では、第1方向は、コードが印刷又は貼り付けられる物体の主軸方向を想定しており、以下では、第1方向をコードの主軸方向と称するものとする。物体の主軸とは、例えば、物体の長手方向の中心軸が該当し、コードの主軸とは、例えば、コードの主軸方向(第1方向)での中心軸が該当する。
【0011】
図2は、第1実施形態のコード21の一例を示す図である。図2に示す例では、コード21は、コード21の主軸方向に対して白黒の縞模様のパタンが用いられた1次元のコードとなっている。なお図2に示す例では、ケーブル(図示省略)に印刷されることを想定して、コード21を円筒形状で表しているが、コード21の形状はこれに限定されるものではない。また図2に示す例では、コード21の主軸方向とケーブルの主軸方向とを一致させて、コード21をケーブルに印刷することを想定している。
【0012】
検出部13は、取得部11により取得された画像から、コードの一部を含む複数の局所領域を検出する。具体的には、検出部13は、コード(パタン)の一部を形成する模様を含む局所領域を検出対象のオブジェクトとする検出器を用いて、取得部11により取得された画像から複数の局所領域を検出する。この検出器は、検出対象の模様を含む多数のサンプル画像を用いた機械学習を予め行っておくことで生成できる。
【0013】
図3は、第1実施形態の検出部13の詳細の一例を示す構成図である。図3に示すように、検出部13は、検出器記憶部13Aと、特徴量算出部13Bと、量子化部13Cと、識別部13Dとを、含む。
【0014】
検出器記憶部13Aは、複数の画素領域を有する特徴領域とサンプル画像中の特徴領域の特徴量である学習特徴量を量子化して得られる量子化学習特徴量との組を、予め複数個選択して得られる組み合わせ、及びサンプル画像が検出対象のオブジェクトであるか否かを示す情報、を有する検出器を記憶する。この検出器は、予めサンプル画像に関して学習することで得られる。
【0015】
特徴量算出部13Bは、取得部11により取得された画像中で上記組み合わせに属する各特徴領域に対応する領域の特徴量である入力特徴量を、特徴領域の画素領域の各々に異なる重みを付けた重み付け和又は重み付け和の絶対値を求めることにより算出する。
【0016】
量子化部13Cは、特徴量算出部13Bにより算出された入力特徴量を量子化して量子化入力特徴量を得る。
【0017】
識別部13Dは、量子化部13Cにより得られた量子化入力特徴量を、検出器記憶部13Aに記憶されている検出器に適用して、取得部11により取得された画像内に検出対象のオブジェクト(局所領域)が含まれているか否かを識別する。
【0018】
図4は、第1実施形態の検出部13により検出された複数の局所領域23の一例を示す図である。例えば、取得部11により取得される画像内のコードが、図2に示すコード21のように、コード21の主軸方向に対して白黒の縞模様のパタンが用いられた1次元コードであるとする。この場合、検出部13は、白黒の模様を数本含む局所領域を検出対象のオブジェクトとする検出器を用いて、取得部11により取得された画像から、図4に示すように、白黒の模様を数本含む複数の局所領域23を検出する。この検出器は、白黒の模様を数本含む多数のサンプル画像を用いた機械学習を予め行っておくことで生成できる。機械学習のためのサンプル画像は、実際に画像を撮像した実画像を用いてもよいし、コンピュータグラフィックスにより作成した人工的な画像を用いてもよい。なお図4に示す例では、取得部11により取得された画像内のコード21に歪みが生じている(コード21の主軸が曲がっている)が、これは、コード21が印刷されたケーブル(図示省略)の湾曲に伴う歪みである。
【0019】
統合部15は、検出部13により検出された複数の局所領域を統合してコード領域を得る。具体的には、統合部15は、検出部13により検出された複数の局所領域の位置に応じて複数の局所領域を統合し、1以上のコード領域を得る。例えば、統合部15は、検出部13により検出された複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて局所領域距離を算出し、当該局所領域距離が閾値未満の局所領域を統合し、1以上のコード領域を得る。
【0020】
なお第1実施形態では、統合部15は、複数の局所領域それぞれについて、当該局所領域と当該局所領域以外の他の局所領域それぞれとの局所領域距離を算出し、算出した局所領域距離が閾値未満の局所領域を統合するものとするが、これに限定されるものではない。例えば、統合部15は、複数の局所領域それぞれについて、当該局所領域と当該局所領域に近接する他の局所領域それぞれとの局所領域距離を算出し、算出した局所領域距離が閾値未満の局所領域を統合するようにしてもよい。
【0021】
第1実施形態では、統合部15は、局所領域間の中心距離に基づいて階層的クラスタリングを行って局所領域を統合するものとするが、局所領域の統合手法はこれに限定されるものではない。例えば、1の局所領域の中心位置の2次元座標が(x(1),y(1))、他の局所領域の中心位置の2次元座標が(x(2),y(2))であるとする。この場合、統合部15は、数式(1)を用いて、1の局所領域と他の局所領域との間の局所領域距離を二乗距離Dで表す。
【0022】
D(x(1),y(1),x(2),y(2))=(x(1)−x(2))2+(y(1)−y(2))2 …(1)
【0023】
そして統合部15は、算出した二乗距離D(局所領域距離)が閾値未満であれば両局所領域を統合し、閾値以上であれば両局所領域を統合しない。
【0024】
図5及び図6は、第1実施形態の統合部15により得られたコード領域の一例を示す図である。図5に示す例では、取得部11により取得された画像に含まれるコードがコード21ひとつであるため、統合部15は、複数の局所領域23を統合して1つのコード領域を得ている。一方、図6に示す例では、取得部11により取得された画像に含まれるコードがコード21、31、41の3つであるため、統合部15は、複数の局所領域23を統合したコード領域、複数の局所領域33を統合したコード領域、及び複数の局所領域43を統合したコード領域の3つのコード領域を得ている。このように第1実施形態では、異なるコードの局所領域を統合せずに分離できているが、これは、統合部15が、局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているためである。
【0025】
また統合部15は、検出部13により検出された複数の局所領域の位置に基づいて、コード領域(コード)の主軸を算出する。第1実施形態では、統合部15は、コード領域に統合された局所領域それぞれの中心位置をフィッティングした2次曲線を主軸として算出するものとするが、主軸の算出手法はこれに限定されるものではない。
【0026】
例えば、コード領域に統合された局所領域それぞれの中心位置を(x(i),y(i))、主軸を表す2次曲線をy=ax2+bx+cとする。但し、i=1,2,…,Nであり、Nは、コード領域に統合された局所領域の個数である。この場合、統合部15は、数式(2)に示す関数f(a,b,c)を最小にする変数a,b,cを求めることで、コード領域の主軸を表す2次曲線y=ax2+bx+cを算出する。
【0027】
【数1】
【0028】
これにより、統合部15は、図5に示す例のように、複数の局所領域23を統合したコード領域(コード21)の主軸25を算出する。
【0029】
読取部17は、統合部15により得られたコード領域を読み取る。具体的には、読取部17は、統合部15により得られたコード領域を統合部15により算出された主軸方向に読み取る。例えば、読取部17は、統合部15により得られたコード領域のパタン(コードのパタン)を認識して、コードを復号する。
【0030】
図7〜図10は、第1実施形態の読取部17の読み取り手法の一例を示す説明図である。まず、読取部17は、図7に示すように、統合部15により算出された主軸25上の点(画素)28について法線27を算出し、法線27上の点(画素)のうち点28を中心とする5点(点28及び点29)の輝度値を加算する。第1実施形態では、輝度値を加算する法線27上の点の数を5としたが、輝度値を加算する法線27上の点の数は、これに限定されるものではない。
【0031】
読取部17は、この処理を主軸25上の各点に対して行うことにより、主軸方向を横軸、輝度値を縦軸とするヒストグラムを作成し(図8参照)、このヒストグラムを2値化する(図9参照)。
【0032】
そして読取部17は、2値化したヒストグラムを用いて、各白黒の主軸方向の幅のサイズを算出し、算出した幅のサイズが閾値よりも大きければ1、閾値より小さければ0とする(図10参照)。これにより、読取部17は、統合部15により得られたコード領域のパタンを認識でき、コードを復号する。
【0033】
図11は、第1実施形態の読取装置10で行われる読取処理の手順の流れの一例を示すフローチャートである。
【0034】
まず、取得部11は、画像入力部から、コードを含む画像を取得する(ステップS101)。
【0035】
続いて、検出部13は、取得部11により取得された画像から、コードの一部を含む複数の局所領域を検出する(ステップS103)。
【0036】
続いて、統合部15は、検出部13により検出された複数の局所領域それぞれの位置に基づいて、複数の局所領域を統合してコード領域を得る(ステップS105)。
【0037】
続いて、読取部17は、統合部15により得られたコード領域を読み取る(ステップS107)。
【0038】
以上のように、第1実施形態では、コードが印刷又は貼り付けられた物体の主軸が曲がるなど変形していてコードに歪みが生じていても、コードの局所的な形状がほとんど変わらないことを利用し、コードを含む画像からコードの一部を含む複数の局所領域を検出してコード領域に統合し、統合したコード領域を読み取る。従って第1実施形態によれば、コードに歪みが生じていても、コードを読み取ることができる。
【0039】
また第1実施形態によれば、局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているため、異なるコードの局所領域を統合せずに分離することができる。
【0040】
また第1実施形態では、主軸方向には模様が異なり、主軸方向に対して垂直な方向には模様が一様なパタンが用いられたコードを使用する。このように第1実施形態によれば、主軸方向に対して垂直な方向のコードの模様は一様なので、コードが非平面に印刷又は貼り付けられており、当該垂直な方向においてコードの一部が隠れてしまう場合であっても、コードを読み取ることができる。
【0041】
また第1実施形態において、コンピュータグラフィックスにより作成した人工的な画像をサンプル画像に用いて機械学習を行い、検出器を生成するようにすれば、サンプル画像の作成に伴う各種コスト(労力等)を削減することができる。
【0042】
(第2実施形態)
第2実施形態では、局所領域の方向を考慮して局所領域を統合する例について説明する。以下では、第1実施形態との相違点の説明を主に行い、第1実施形態と同様の機能を有する構成要素については、第1実施形態と同様の名称・符号を付し、その説明を省略する。
【0043】
図12は、第2実施形態の読取装置50の一例を示す構成図である。図12に示すように、第2実施形態の読取装置50では、検出部53及び統合部55が第1実施形態の読取装置10と相違する。
【0044】
検出部53は、検出した複数の局所領域それぞれの方向を更に検出する。具体的には、検出部53は、コード(パタン)の一部を形成する模様を含みかつ当該模様の方向を定義した局所領域を検出対象のオブジェクトとする検出器を用いて、取得部11により取得された画像から複数の局所領域及びその方向を検出する。
【0045】
図13は、第2実施形態の検出部53の検出対象のオブジェクト(局所領域)の一例を示す図である。図13に示す例では、白黒の縞模様が0度の方向を向いている局所領域61、白黒の縞模様が45度の方向を向いている局所領域62、白黒の縞模様が90度の方向を向いている局所領域63、及び白黒の縞模様が135度の方向を向いている局所領域64が、検出対象のオブジェクトとして示されている。この場合、検出部53は、局所領域61を検出対象のオブジェクトとする検出器、局所領域62を検出対象のオブジェクトとする検出器、局所領域63を検出対象のオブジェクトとする検出器、及び局所領域64を検出対象のオブジェクトとする検出器の4つの検出器を用いることで、取得部11により取得された画像から複数の局所領域だけでなくその方向(0度、45度、90度、135度)を検出する。
【0046】
統合部55は、検出部53により検出された複数の局所領域の位置及び方向に応じて複数の局所領域を統合し、1以上のコード領域を得る。例えば、統合部55は、検出部53により検出された複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて第1局所領域距離を算出するとともに当該局所領域の方向と他の局所領域の方向とを用いて第2局所領域距離を算出する。そして統合部55は、第1局所領域距離及び第2局所領域距離に基づく値が閾値未満の局所領域を統合し、1以上のコード領域を得る。
【0047】
第2実施形態では、統合部55は、局所領域間の中心距離及び方向差(角度差)に基づいて階層的クラスタリングを行って局所領域を統合するものとするが、局所領域の統合手法はこれに限定されるものではない。例えば、統合部55は、局所領域の中心位置の2次元座標(x,y)と局所領域の方向(角度)dとで3次元ベクトル(x,y,d)を作り、この3次元ベクトルを用いた何らかの距離尺度に基づいてクラスタリングを行う。なお、距離には、2次元座標及び方向(角度)の3つの要素を同等に扱うユークリッド距離や二乗距離を用いてもよいし、別々の距離尺度を用いて算出した2次元座標の距離と方向(角度)の距離との和を用いるようにしてもよい。
【0048】
例えば、1の局所領域の中心位置及び方向が(x(1),y(1),d(1))、他の局所領域の中心位置及び方向が(x(2),y(2),d(2))であるとする。この場合、統合部55は、数式(3)を用いて、1の局所領域と他の局所領域との間の局所領域距離を二乗距離Dで表す。
【0049】
D(x(1),y(1),d(1),x(2),y(2),d(2))=D1(x(1),y(1),x(2),y(2))+D2(d(1),d(2)) …(3)
【0050】
ここで、D1(x(1),y(1),x(2),y(2))、D2(d(1),d(2))は、それぞれ、数式(4)、(5)を用いて求められる。
【0051】
D1(x(1),y(1),x(2),y(2))=(x(1)−x(2))2+(y(1)−y(2))2 …(4)
【0052】
D2(d(1),d(2))=(d(1)−d(2))2 …(5)
【0053】
そして統合部55は、算出した二乗距離D(局所領域距離)が閾値未満であれば両局所領域を統合し、閾値以上であれば両局所領域を統合しない。
【0054】
図14は、第2実施形態の統合部55により得られたコード領域の一例を示す図である。図14に示す例では、取得部11により取得された画像に含まれるコードがコード21、31の2つであるため、統合部55は、複数の局所領域73を統合したコード領域、及び複数の局所領域83を統合したコード領域の2つのコード領域を得ている。このように第2実施形態では、異なるコードが近接している場合であっても異なるコードの局所領域を統合せずに分離できているが、これは、統合部55が、局所領域の距離及び方向を考慮した局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているためである。
【0055】
なお、統合部55は、第1局所領域距離が第1閾値未満であり、かつ第2局所領域距離が第2閾値未満である局所領域を統合し、1以上のコード領域を得るようにしてもよい。つまり統合部55は、算出した二乗距離D1(第1局所領域距離)が第1閾値未満であり、かつ算出した二乗距離D2(第2局所領域距離)が第2閾値未満であれば両局所領域を統合し、そうでなければ両局所領域を統合しないようにしてもよい。
【0056】
図15は、第2実施形態の読取装置50で行われる読取処理の手順の流れの一例を示すフローチャートである。
【0057】
まず、取得部11は、画像入力部から、コードを含む画像を取得する(ステップS201)。
【0058】
続いて、検出部53は、取得部11により取得された画像から、コードの一部を含む複数の局所領域及びその方向を検出する(ステップS203)。
【0059】
続いて、統合部55は、検出部53により検出された複数の局所領域それぞれの位置及び方向に基づいて、複数の局所領域を統合してコード領域を得る(ステップS205)。
【0060】
続いて、読取部17は、統合部55により得られたコード領域を読み取る(ステップS207)。
【0061】
以上のように第2実施形態では、局所領域の距離及び方向を考慮した局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているため、異なるコードが近接している場合であっても異なるコードの局所領域を統合せずに分離することができる。
【0062】
(ハードウェア構成)
図16は、上記第1〜第2実施形態の読取装置のハードウェア構成の一例を示すブロック図である。図16に示すように、上記各実施形態の読取装置は、CPUなどの制御装置91と、ROM(Read Only Memory)やRAM(Random Access Memory)などの記憶装置92と、HDD(Hard Disk Drive)やSSD(Solid State Drive)などの外部記憶装置93と、ディスプレイなどの表示装置94と、デジタルカメラやボタンなどの各種入力装置95と通信I/F96とを、備えており、通常のコンピュータを利用したハードウェア構成で実現できる。
【0063】
上記各実施形態の読取装置で実行されるプログラムは、ROM等に予め組み込んで提供される。
【0064】
また、上記各実施形態の読取装置で実行されるプログラムを、インストール可能な形式又は実行可能な形式のファイルでCD−ROM、CD−R、メモリカード、DVD、フレキシブルディスク(FD)等のコンピュータで読み取り可能な記憶媒体に記憶されて提供するようにしてもよい。
【0065】
また、上記各実施形態の読取装置で実行されるプログラムを、インターネット等のネットワークに接続されたコンピュータ上に格納し、ネットワーク経由でダウンロードさせることにより提供するようにしてもよい。また、上記各実施形態の読取装置で実行されるプログラムを、インターネット等のネットワーク経由で提供または配布するようにしてもよい。
【0066】
上記各実施形態の読取装置で実行されるプログラムは、上述した各部をコンピュータ上で実現させるためのモジュール構成となっている。実際のハードウェアとしては、例えば、制御装置91が外部記憶装置93からプログラムを記憶装置92上に読み出して実行することにより、上記各部がコンピュータ上で実現されるようになっている。
【0067】
以上説明したとおり、上記各実施形態によれば、歪みが生じたコードであっても読み取ることができる。
【0068】
なお本発明は、上記各実施形態そのままに限定されるものではなく、実施段階ではその要旨を逸脱しない範囲で構成要素を変形して具体化することができる。また上記各実施形態に開示されている複数の構成要素の適宜な組み合わせにより、種々の発明を形成することができる。例えば、実施形態に示される全構成要素からいくつかの構成要素を削除してもよい。さらに、異なる実施形態にわたる構成要素を適宜組み合わせても良い。
【0069】
例えば、上記各実施形態のフローチャートにおける各ステップを、その性質に反しない限り、実行順序を変更し、複数同時に実施し、あるいは実施毎に異なった順序で実施してもよい。
【符号の説明】
【0070】
10、50 読取装置
11 取得部
13、53 検出部
13A 検出器記憶部
13B 特徴量算出部
13C 量子化部
13D 識別部
15、55 統合部
17 読取部
91 制御装置
92 記憶装置
93 外部記憶装置
94 表示装置
95 入力装置
96 通信I/F
【技術分野】
【0001】
本発明の実施形態は、読取装置、方法及びプログラムに関する。
【背景技術】
【0002】
バーコードなどの各種コードは、商品販売、物流、及び生産工程など幅広い分野において、物品の管理情報の表記に用いられている。このようなコードの読み取りには、コードを直接指示して読み取るハンドスキャナやペン入力スキャナ、又は複数方向にビームを走査させていずれかのビームでコードを読み取る定置型スキャナなどが用いられる。
【先行技術文献】
【特許文献】
【0003】
【特許文献1】特開2002−150213号公報
【発明の概要】
【発明が解決しようとする課題】
【0004】
しかしながら、上述したような従来技術では、変形可能な物体にコードが印刷又は貼り付けられている場合、物体の変形に伴いコードに歪みが生じるため、コードを読み取れない場合がある。本発明が解決しようとする課題は、歪みが生じたコードであっても読み取り可能な読取装置、方法及びプログラムを提供することである。
【課題を解決するための手段】
【0005】
実施形態の読取装置は、取得部と、検出部と、統合部と、読取部と、を備える。取得部は、コードを含む画像を取得する。検出部は、画像からコードの一部を含む複数の局所領域を検出する。統合部は、複数の局所領域を統合してコード領域を得る。読取部は、コード領域を読み取る。
【図面の簡単な説明】
【0006】
【図1】第1実施形態の読取装置の例を示す構成図。
【図2】第1実施形態のコードの例を示す図。
【図3】第1実施形態の検出部の詳細例を示す構成図。
【図4】第1実施形態の検出部により検出された複数の局所領域の例を示す図。
【図5】第1実施形態の統合部により得られたコード領域の例を示す図。
【図6】第1実施形態の統合部により得られたコード領域の例を示す図。
【図7】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図8】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図9】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図10】第1実施形態の読取部の読み取り手法の例を示す説明図。
【図11】第1実施形態の読取処理例を示すフローチャート。
【図12】第2実施形態の読取装置の例を示す構成図。
【図13】第2実施形態の検出部の検出対象のオブジェクトの例を示す図。
【図14】第2実施形態の統合部により得られたコード領域の例を示す図。
【図15】第2実施形態の読取処理例を示すフローチャート。
【図16】第1〜第2実施形態の読取装置のハードウェア構成例を示すブロック図。
【発明を実施するための形態】
【0007】
以下、添付図面を参照しながら、実施形態を詳細に説明する。
【0008】
(第1実施形態)
図1は、第1実施形態の読取装置10の一例を示す構成図である。図1に示すように、読取装置10は、取得部11と、検出部13と、統合部15と、読取部17とを、備える。読取装置10の各部は、例えば、CPU(Central Processing Unit)などの処理装置にプログラムを実行させること、即ち、ソフトウェアにより実現してもよいし、IC(Integrated Circuit)などのハードウェアにより実現してもよいし、ソフトウェア及びハードウェアを併用して実現してもよい。
【0009】
取得部11は、画像入力部(図示省略)から入力される画像を取得する。画像入力部は、例えば、デジタルカメラなどの撮像装置により実現でき、撮像した画像を入力する。第1実施形態では、画像入力部が入力する画像、即ち、取得部11が取得する画像は、湾曲など変形可能な物体に印刷又は貼り付けられているコードを撮像した画像を想定している。このため、第1実施形態では、取得部11は、コードを含む画像を取得することになる。なお、物体の変形に伴い歪みが生じているコードを画像入力部が撮像した場合には、取得部11が取得した画像内のコードにも当然歪みが生じている。
【0010】
第1実施形態のコードは、光学的に認識可能なコードであり、局所的に類似した模様が繰り返し並んだパタンが用いられる。具体的には、第1実施形態のコードは、第1方向には模様が異なり、第1方向に対して垂直な第2方向には模様が一様なパタンが用いられる。第1実施形態では、第1方向は、コードが印刷又は貼り付けられる物体の主軸方向を想定しており、以下では、第1方向をコードの主軸方向と称するものとする。物体の主軸とは、例えば、物体の長手方向の中心軸が該当し、コードの主軸とは、例えば、コードの主軸方向(第1方向)での中心軸が該当する。
【0011】
図2は、第1実施形態のコード21の一例を示す図である。図2に示す例では、コード21は、コード21の主軸方向に対して白黒の縞模様のパタンが用いられた1次元のコードとなっている。なお図2に示す例では、ケーブル(図示省略)に印刷されることを想定して、コード21を円筒形状で表しているが、コード21の形状はこれに限定されるものではない。また図2に示す例では、コード21の主軸方向とケーブルの主軸方向とを一致させて、コード21をケーブルに印刷することを想定している。
【0012】
検出部13は、取得部11により取得された画像から、コードの一部を含む複数の局所領域を検出する。具体的には、検出部13は、コード(パタン)の一部を形成する模様を含む局所領域を検出対象のオブジェクトとする検出器を用いて、取得部11により取得された画像から複数の局所領域を検出する。この検出器は、検出対象の模様を含む多数のサンプル画像を用いた機械学習を予め行っておくことで生成できる。
【0013】
図3は、第1実施形態の検出部13の詳細の一例を示す構成図である。図3に示すように、検出部13は、検出器記憶部13Aと、特徴量算出部13Bと、量子化部13Cと、識別部13Dとを、含む。
【0014】
検出器記憶部13Aは、複数の画素領域を有する特徴領域とサンプル画像中の特徴領域の特徴量である学習特徴量を量子化して得られる量子化学習特徴量との組を、予め複数個選択して得られる組み合わせ、及びサンプル画像が検出対象のオブジェクトであるか否かを示す情報、を有する検出器を記憶する。この検出器は、予めサンプル画像に関して学習することで得られる。
【0015】
特徴量算出部13Bは、取得部11により取得された画像中で上記組み合わせに属する各特徴領域に対応する領域の特徴量である入力特徴量を、特徴領域の画素領域の各々に異なる重みを付けた重み付け和又は重み付け和の絶対値を求めることにより算出する。
【0016】
量子化部13Cは、特徴量算出部13Bにより算出された入力特徴量を量子化して量子化入力特徴量を得る。
【0017】
識別部13Dは、量子化部13Cにより得られた量子化入力特徴量を、検出器記憶部13Aに記憶されている検出器に適用して、取得部11により取得された画像内に検出対象のオブジェクト(局所領域)が含まれているか否かを識別する。
【0018】
図4は、第1実施形態の検出部13により検出された複数の局所領域23の一例を示す図である。例えば、取得部11により取得される画像内のコードが、図2に示すコード21のように、コード21の主軸方向に対して白黒の縞模様のパタンが用いられた1次元コードであるとする。この場合、検出部13は、白黒の模様を数本含む局所領域を検出対象のオブジェクトとする検出器を用いて、取得部11により取得された画像から、図4に示すように、白黒の模様を数本含む複数の局所領域23を検出する。この検出器は、白黒の模様を数本含む多数のサンプル画像を用いた機械学習を予め行っておくことで生成できる。機械学習のためのサンプル画像は、実際に画像を撮像した実画像を用いてもよいし、コンピュータグラフィックスにより作成した人工的な画像を用いてもよい。なお図4に示す例では、取得部11により取得された画像内のコード21に歪みが生じている(コード21の主軸が曲がっている)が、これは、コード21が印刷されたケーブル(図示省略)の湾曲に伴う歪みである。
【0019】
統合部15は、検出部13により検出された複数の局所領域を統合してコード領域を得る。具体的には、統合部15は、検出部13により検出された複数の局所領域の位置に応じて複数の局所領域を統合し、1以上のコード領域を得る。例えば、統合部15は、検出部13により検出された複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて局所領域距離を算出し、当該局所領域距離が閾値未満の局所領域を統合し、1以上のコード領域を得る。
【0020】
なお第1実施形態では、統合部15は、複数の局所領域それぞれについて、当該局所領域と当該局所領域以外の他の局所領域それぞれとの局所領域距離を算出し、算出した局所領域距離が閾値未満の局所領域を統合するものとするが、これに限定されるものではない。例えば、統合部15は、複数の局所領域それぞれについて、当該局所領域と当該局所領域に近接する他の局所領域それぞれとの局所領域距離を算出し、算出した局所領域距離が閾値未満の局所領域を統合するようにしてもよい。
【0021】
第1実施形態では、統合部15は、局所領域間の中心距離に基づいて階層的クラスタリングを行って局所領域を統合するものとするが、局所領域の統合手法はこれに限定されるものではない。例えば、1の局所領域の中心位置の2次元座標が(x(1),y(1))、他の局所領域の中心位置の2次元座標が(x(2),y(2))であるとする。この場合、統合部15は、数式(1)を用いて、1の局所領域と他の局所領域との間の局所領域距離を二乗距離Dで表す。
【0022】
D(x(1),y(1),x(2),y(2))=(x(1)−x(2))2+(y(1)−y(2))2 …(1)
【0023】
そして統合部15は、算出した二乗距離D(局所領域距離)が閾値未満であれば両局所領域を統合し、閾値以上であれば両局所領域を統合しない。
【0024】
図5及び図6は、第1実施形態の統合部15により得られたコード領域の一例を示す図である。図5に示す例では、取得部11により取得された画像に含まれるコードがコード21ひとつであるため、統合部15は、複数の局所領域23を統合して1つのコード領域を得ている。一方、図6に示す例では、取得部11により取得された画像に含まれるコードがコード21、31、41の3つであるため、統合部15は、複数の局所領域23を統合したコード領域、複数の局所領域33を統合したコード領域、及び複数の局所領域43を統合したコード領域の3つのコード領域を得ている。このように第1実施形態では、異なるコードの局所領域を統合せずに分離できているが、これは、統合部15が、局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているためである。
【0025】
また統合部15は、検出部13により検出された複数の局所領域の位置に基づいて、コード領域(コード)の主軸を算出する。第1実施形態では、統合部15は、コード領域に統合された局所領域それぞれの中心位置をフィッティングした2次曲線を主軸として算出するものとするが、主軸の算出手法はこれに限定されるものではない。
【0026】
例えば、コード領域に統合された局所領域それぞれの中心位置を(x(i),y(i))、主軸を表す2次曲線をy=ax2+bx+cとする。但し、i=1,2,…,Nであり、Nは、コード領域に統合された局所領域の個数である。この場合、統合部15は、数式(2)に示す関数f(a,b,c)を最小にする変数a,b,cを求めることで、コード領域の主軸を表す2次曲線y=ax2+bx+cを算出する。
【0027】
【数1】
【0028】
これにより、統合部15は、図5に示す例のように、複数の局所領域23を統合したコード領域(コード21)の主軸25を算出する。
【0029】
読取部17は、統合部15により得られたコード領域を読み取る。具体的には、読取部17は、統合部15により得られたコード領域を統合部15により算出された主軸方向に読み取る。例えば、読取部17は、統合部15により得られたコード領域のパタン(コードのパタン)を認識して、コードを復号する。
【0030】
図7〜図10は、第1実施形態の読取部17の読み取り手法の一例を示す説明図である。まず、読取部17は、図7に示すように、統合部15により算出された主軸25上の点(画素)28について法線27を算出し、法線27上の点(画素)のうち点28を中心とする5点(点28及び点29)の輝度値を加算する。第1実施形態では、輝度値を加算する法線27上の点の数を5としたが、輝度値を加算する法線27上の点の数は、これに限定されるものではない。
【0031】
読取部17は、この処理を主軸25上の各点に対して行うことにより、主軸方向を横軸、輝度値を縦軸とするヒストグラムを作成し(図8参照)、このヒストグラムを2値化する(図9参照)。
【0032】
そして読取部17は、2値化したヒストグラムを用いて、各白黒の主軸方向の幅のサイズを算出し、算出した幅のサイズが閾値よりも大きければ1、閾値より小さければ0とする(図10参照)。これにより、読取部17は、統合部15により得られたコード領域のパタンを認識でき、コードを復号する。
【0033】
図11は、第1実施形態の読取装置10で行われる読取処理の手順の流れの一例を示すフローチャートである。
【0034】
まず、取得部11は、画像入力部から、コードを含む画像を取得する(ステップS101)。
【0035】
続いて、検出部13は、取得部11により取得された画像から、コードの一部を含む複数の局所領域を検出する(ステップS103)。
【0036】
続いて、統合部15は、検出部13により検出された複数の局所領域それぞれの位置に基づいて、複数の局所領域を統合してコード領域を得る(ステップS105)。
【0037】
続いて、読取部17は、統合部15により得られたコード領域を読み取る(ステップS107)。
【0038】
以上のように、第1実施形態では、コードが印刷又は貼り付けられた物体の主軸が曲がるなど変形していてコードに歪みが生じていても、コードの局所的な形状がほとんど変わらないことを利用し、コードを含む画像からコードの一部を含む複数の局所領域を検出してコード領域に統合し、統合したコード領域を読み取る。従って第1実施形態によれば、コードに歪みが生じていても、コードを読み取ることができる。
【0039】
また第1実施形態によれば、局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているため、異なるコードの局所領域を統合せずに分離することができる。
【0040】
また第1実施形態では、主軸方向には模様が異なり、主軸方向に対して垂直な方向には模様が一様なパタンが用いられたコードを使用する。このように第1実施形態によれば、主軸方向に対して垂直な方向のコードの模様は一様なので、コードが非平面に印刷又は貼り付けられており、当該垂直な方向においてコードの一部が隠れてしまう場合であっても、コードを読み取ることができる。
【0041】
また第1実施形態において、コンピュータグラフィックスにより作成した人工的な画像をサンプル画像に用いて機械学習を行い、検出器を生成するようにすれば、サンプル画像の作成に伴う各種コスト(労力等)を削減することができる。
【0042】
(第2実施形態)
第2実施形態では、局所領域の方向を考慮して局所領域を統合する例について説明する。以下では、第1実施形態との相違点の説明を主に行い、第1実施形態と同様の機能を有する構成要素については、第1実施形態と同様の名称・符号を付し、その説明を省略する。
【0043】
図12は、第2実施形態の読取装置50の一例を示す構成図である。図12に示すように、第2実施形態の読取装置50では、検出部53及び統合部55が第1実施形態の読取装置10と相違する。
【0044】
検出部53は、検出した複数の局所領域それぞれの方向を更に検出する。具体的には、検出部53は、コード(パタン)の一部を形成する模様を含みかつ当該模様の方向を定義した局所領域を検出対象のオブジェクトとする検出器を用いて、取得部11により取得された画像から複数の局所領域及びその方向を検出する。
【0045】
図13は、第2実施形態の検出部53の検出対象のオブジェクト(局所領域)の一例を示す図である。図13に示す例では、白黒の縞模様が0度の方向を向いている局所領域61、白黒の縞模様が45度の方向を向いている局所領域62、白黒の縞模様が90度の方向を向いている局所領域63、及び白黒の縞模様が135度の方向を向いている局所領域64が、検出対象のオブジェクトとして示されている。この場合、検出部53は、局所領域61を検出対象のオブジェクトとする検出器、局所領域62を検出対象のオブジェクトとする検出器、局所領域63を検出対象のオブジェクトとする検出器、及び局所領域64を検出対象のオブジェクトとする検出器の4つの検出器を用いることで、取得部11により取得された画像から複数の局所領域だけでなくその方向(0度、45度、90度、135度)を検出する。
【0046】
統合部55は、検出部53により検出された複数の局所領域の位置及び方向に応じて複数の局所領域を統合し、1以上のコード領域を得る。例えば、統合部55は、検出部53により検出された複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて第1局所領域距離を算出するとともに当該局所領域の方向と他の局所領域の方向とを用いて第2局所領域距離を算出する。そして統合部55は、第1局所領域距離及び第2局所領域距離に基づく値が閾値未満の局所領域を統合し、1以上のコード領域を得る。
【0047】
第2実施形態では、統合部55は、局所領域間の中心距離及び方向差(角度差)に基づいて階層的クラスタリングを行って局所領域を統合するものとするが、局所領域の統合手法はこれに限定されるものではない。例えば、統合部55は、局所領域の中心位置の2次元座標(x,y)と局所領域の方向(角度)dとで3次元ベクトル(x,y,d)を作り、この3次元ベクトルを用いた何らかの距離尺度に基づいてクラスタリングを行う。なお、距離には、2次元座標及び方向(角度)の3つの要素を同等に扱うユークリッド距離や二乗距離を用いてもよいし、別々の距離尺度を用いて算出した2次元座標の距離と方向(角度)の距離との和を用いるようにしてもよい。
【0048】
例えば、1の局所領域の中心位置及び方向が(x(1),y(1),d(1))、他の局所領域の中心位置及び方向が(x(2),y(2),d(2))であるとする。この場合、統合部55は、数式(3)を用いて、1の局所領域と他の局所領域との間の局所領域距離を二乗距離Dで表す。
【0049】
D(x(1),y(1),d(1),x(2),y(2),d(2))=D1(x(1),y(1),x(2),y(2))+D2(d(1),d(2)) …(3)
【0050】
ここで、D1(x(1),y(1),x(2),y(2))、D2(d(1),d(2))は、それぞれ、数式(4)、(5)を用いて求められる。
【0051】
D1(x(1),y(1),x(2),y(2))=(x(1)−x(2))2+(y(1)−y(2))2 …(4)
【0052】
D2(d(1),d(2))=(d(1)−d(2))2 …(5)
【0053】
そして統合部55は、算出した二乗距離D(局所領域距離)が閾値未満であれば両局所領域を統合し、閾値以上であれば両局所領域を統合しない。
【0054】
図14は、第2実施形態の統合部55により得られたコード領域の一例を示す図である。図14に示す例では、取得部11により取得された画像に含まれるコードがコード21、31の2つであるため、統合部55は、複数の局所領域73を統合したコード領域、及び複数の局所領域83を統合したコード領域の2つのコード領域を得ている。このように第2実施形態では、異なるコードが近接している場合であっても異なるコードの局所領域を統合せずに分離できているが、これは、統合部55が、局所領域の距離及び方向を考慮した局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているためである。
【0055】
なお、統合部55は、第1局所領域距離が第1閾値未満であり、かつ第2局所領域距離が第2閾値未満である局所領域を統合し、1以上のコード領域を得るようにしてもよい。つまり統合部55は、算出した二乗距離D1(第1局所領域距離)が第1閾値未満であり、かつ算出した二乗距離D2(第2局所領域距離)が第2閾値未満であれば両局所領域を統合し、そうでなければ両局所領域を統合しないようにしてもよい。
【0056】
図15は、第2実施形態の読取装置50で行われる読取処理の手順の流れの一例を示すフローチャートである。
【0057】
まず、取得部11は、画像入力部から、コードを含む画像を取得する(ステップS201)。
【0058】
続いて、検出部53は、取得部11により取得された画像から、コードの一部を含む複数の局所領域及びその方向を検出する(ステップS203)。
【0059】
続いて、統合部55は、検出部53により検出された複数の局所領域それぞれの位置及び方向に基づいて、複数の局所領域を統合してコード領域を得る(ステップS205)。
【0060】
続いて、読取部17は、統合部55により得られたコード領域を読み取る(ステップS207)。
【0061】
以上のように第2実施形態では、局所領域の距離及び方向を考慮した局所領域距離が閾値未満の局所領域を統合し、局所領域距離が閾値以上の局所領域を統合しないようにしているため、異なるコードが近接している場合であっても異なるコードの局所領域を統合せずに分離することができる。
【0062】
(ハードウェア構成)
図16は、上記第1〜第2実施形態の読取装置のハードウェア構成の一例を示すブロック図である。図16に示すように、上記各実施形態の読取装置は、CPUなどの制御装置91と、ROM(Read Only Memory)やRAM(Random Access Memory)などの記憶装置92と、HDD(Hard Disk Drive)やSSD(Solid State Drive)などの外部記憶装置93と、ディスプレイなどの表示装置94と、デジタルカメラやボタンなどの各種入力装置95と通信I/F96とを、備えており、通常のコンピュータを利用したハードウェア構成で実現できる。
【0063】
上記各実施形態の読取装置で実行されるプログラムは、ROM等に予め組み込んで提供される。
【0064】
また、上記各実施形態の読取装置で実行されるプログラムを、インストール可能な形式又は実行可能な形式のファイルでCD−ROM、CD−R、メモリカード、DVD、フレキシブルディスク(FD)等のコンピュータで読み取り可能な記憶媒体に記憶されて提供するようにしてもよい。
【0065】
また、上記各実施形態の読取装置で実行されるプログラムを、インターネット等のネットワークに接続されたコンピュータ上に格納し、ネットワーク経由でダウンロードさせることにより提供するようにしてもよい。また、上記各実施形態の読取装置で実行されるプログラムを、インターネット等のネットワーク経由で提供または配布するようにしてもよい。
【0066】
上記各実施形態の読取装置で実行されるプログラムは、上述した各部をコンピュータ上で実現させるためのモジュール構成となっている。実際のハードウェアとしては、例えば、制御装置91が外部記憶装置93からプログラムを記憶装置92上に読み出して実行することにより、上記各部がコンピュータ上で実現されるようになっている。
【0067】
以上説明したとおり、上記各実施形態によれば、歪みが生じたコードであっても読み取ることができる。
【0068】
なお本発明は、上記各実施形態そのままに限定されるものではなく、実施段階ではその要旨を逸脱しない範囲で構成要素を変形して具体化することができる。また上記各実施形態に開示されている複数の構成要素の適宜な組み合わせにより、種々の発明を形成することができる。例えば、実施形態に示される全構成要素からいくつかの構成要素を削除してもよい。さらに、異なる実施形態にわたる構成要素を適宜組み合わせても良い。
【0069】
例えば、上記各実施形態のフローチャートにおける各ステップを、その性質に反しない限り、実行順序を変更し、複数同時に実施し、あるいは実施毎に異なった順序で実施してもよい。
【符号の説明】
【0070】
10、50 読取装置
11 取得部
13、53 検出部
13A 検出器記憶部
13B 特徴量算出部
13C 量子化部
13D 識別部
15、55 統合部
17 読取部
91 制御装置
92 記憶装置
93 外部記憶装置
94 表示装置
95 入力装置
96 通信I/F
【特許請求の範囲】
【請求項1】
コードを含む画像を取得する取得部と、
前記画像から前記コードの一部を含む複数の局所領域を検出する検出部と、
前記複数の局所領域を統合してコード領域を得る統合部と、
前記コード領域を読み取る読取部と、
を備える読取装置。
【請求項2】
前記統合部は、前記複数の局所領域の位置に基づいて前記コード領域の主軸を算出し、
前記読取部は、前記主軸方向に前記コード領域を読み取る請求項1に記載の読取装置。
【請求項3】
前記統合部は、前記複数の局所領域の位置に応じて前記複数の局所領域を統合し、1以上のコード領域を得る請求項1又は2に記載の読取装置。
【請求項4】
前記統合部は、前記複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて局所領域距離を算出し、当該局所領域距離が閾値未満の局所領域を統合し、前記1以上のコード領域を得る請求項3に記載の読取装置。
【請求項5】
前記検出部は、前記複数の局所領域それぞれの方向を更に検出し、
前記統合部は、前記複数の局所領域の位置及び前記方向に応じて前記複数の局所領域を統合し、1以上のコード領域を得る請求項1又は2に記載の読取装置。
【請求項6】
前記統合部は、前記複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて第1局所領域距離を算出するとともに前記局所領域の方向と前記他の局所領域の方向とを用いて第2局所領域距離を算出し、当該第1局所領域距離及び当該第2局所領域距離に基づく値が閾値未満の局所領域を統合し、前記1以上のコード領域を得る請求項5に記載の読取装置。
【請求項7】
前記統合部は、前記複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて第1局所領域距離を算出するとともに前記局所領域の方向と前記他の局所領域の方向とを用いて第2局所領域距離を算出し、当該第1局所領域距離が第1閾値未満であり、かつ当該第2局所領域距離が第2閾値未満である局所領域を統合し、前記1以上のコード領域を得る請求項5に記載の読取装置。
【請求項8】
前記コードは、前記主軸方向には模様が異なり、前記主軸方向に対して垂直な方向には、模様が一様なパタンであり、
前記読取部は、前記コード領域の前記パタンを認識して、前記コードを復号する請求項1〜7のいずれか1つに記載の読取装置。
【請求項9】
取得部が、コードを含む画像を取得する取得ステップと、
検出部が、前記画像から前記コードの一部を含む複数の局所領域を検出する検出ステップと、
統合部が、前記複数の局所領域を統合してコード領域を得る統合ステップと、
読取部が、前記コード領域を読み取る読取ステップと、
を含む読取方法。
【請求項10】
コードを含む画像を取得する取得ステップと、
前記画像から前記コードの一部を含む複数の局所領域を検出する検出ステップと、
前記複数の局所領域を統合してコード領域を得る統合ステップと、
前記コード領域を読み取る読取ステップと、
をコンピュータに実行させるためのプログラム。
【請求項1】
コードを含む画像を取得する取得部と、
前記画像から前記コードの一部を含む複数の局所領域を検出する検出部と、
前記複数の局所領域を統合してコード領域を得る統合部と、
前記コード領域を読み取る読取部と、
を備える読取装置。
【請求項2】
前記統合部は、前記複数の局所領域の位置に基づいて前記コード領域の主軸を算出し、
前記読取部は、前記主軸方向に前記コード領域を読み取る請求項1に記載の読取装置。
【請求項3】
前記統合部は、前記複数の局所領域の位置に応じて前記複数の局所領域を統合し、1以上のコード領域を得る請求項1又は2に記載の読取装置。
【請求項4】
前記統合部は、前記複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて局所領域距離を算出し、当該局所領域距離が閾値未満の局所領域を統合し、前記1以上のコード領域を得る請求項3に記載の読取装置。
【請求項5】
前記検出部は、前記複数の局所領域それぞれの方向を更に検出し、
前記統合部は、前記複数の局所領域の位置及び前記方向に応じて前記複数の局所領域を統合し、1以上のコード領域を得る請求項1又は2に記載の読取装置。
【請求項6】
前記統合部は、前記複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて第1局所領域距離を算出するとともに前記局所領域の方向と前記他の局所領域の方向とを用いて第2局所領域距離を算出し、当該第1局所領域距離及び当該第2局所領域距離に基づく値が閾値未満の局所領域を統合し、前記1以上のコード領域を得る請求項5に記載の読取装置。
【請求項7】
前記統合部は、前記複数の局所領域それぞれについて当該局所領域の位置と他の局所領域の位置とを用いて第1局所領域距離を算出するとともに前記局所領域の方向と前記他の局所領域の方向とを用いて第2局所領域距離を算出し、当該第1局所領域距離が第1閾値未満であり、かつ当該第2局所領域距離が第2閾値未満である局所領域を統合し、前記1以上のコード領域を得る請求項5に記載の読取装置。
【請求項8】
前記コードは、前記主軸方向には模様が異なり、前記主軸方向に対して垂直な方向には、模様が一様なパタンであり、
前記読取部は、前記コード領域の前記パタンを認識して、前記コードを復号する請求項1〜7のいずれか1つに記載の読取装置。
【請求項9】
取得部が、コードを含む画像を取得する取得ステップと、
検出部が、前記画像から前記コードの一部を含む複数の局所領域を検出する検出ステップと、
統合部が、前記複数の局所領域を統合してコード領域を得る統合ステップと、
読取部が、前記コード領域を読み取る読取ステップと、
を含む読取方法。
【請求項10】
コードを含む画像を取得する取得ステップと、
前記画像から前記コードの一部を含む複数の局所領域を検出する検出ステップと、
前記複数の局所領域を統合してコード領域を得る統合ステップと、
前記コード領域を読み取る読取ステップと、
をコンピュータに実行させるためのプログラム。
【図1】
【図2】
【図3】
【図4】
【図5】
【図6】
【図7】
【図8】
【図9】
【図10】
【図11】
【図12】
【図13】
【図14】
【図15】
【図16】
【図2】
【図3】
【図4】
【図5】
【図6】
【図7】
【図8】
【図9】
【図10】
【図11】
【図12】
【図13】
【図14】
【図15】
【図16】
【公開番号】特開2013−101481(P2013−101481A)
【公開日】平成25年5月23日(2013.5.23)
【国際特許分類】
【出願番号】特願2011−244642(P2011−244642)
【出願日】平成23年11月8日(2011.11.8)
【出願人】(000003078)株式会社東芝 (54,554)
【Fターム(参考)】
【公開日】平成25年5月23日(2013.5.23)
【国際特許分類】
【出願日】平成23年11月8日(2011.11.8)
【出願人】(000003078)株式会社東芝 (54,554)
【Fターム(参考)】
[ Back to top ]