JP5391637B2 - データ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラム - Google Patents

データ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラム Download PDF

Info

Publication number
JP5391637B2
JP5391637B2 JP2008264442A JP2008264442A JP5391637B2 JP 5391637 B2 JP5391637 B2 JP 5391637B2 JP 2008264442 A JP2008264442 A JP 2008264442A JP 2008264442 A JP2008264442 A JP 2008264442A JP 5391637 B2 JP5391637 B2 JP 5391637B2
Authority
JP
Japan
Prior art keywords
data
subset
class
similarity
attribute
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.)
Expired - Fee Related
Application number
JP2008264442A
Other languages
English (en)
Other versions
JP2010092432A (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.)
NEC Corp
Original Assignee
NEC 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 NEC Corp filed Critical NEC Corp
Priority to JP2008264442A priority Critical patent/JP5391637B2/ja
Publication of JP2010092432A publication Critical patent/JP2010092432A/ja
Application granted granted Critical
Publication of JP5391637B2 publication Critical patent/JP5391637B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Description

本発明は、データ間の類似度を計算するデータ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラムに関する。
小売店では、POS(Point of Sales)システムが用いられており、収集された商品の売上データは様々に活用されている。そして、顧客の特徴に基づいて顧客を分類して、売上データを用いて種々の分析を行うシステムが提案されている。例えば、特許文献1には、分析者の意志に従って顧客を分類し、顧客の購買履歴状況を確認可能とするシステムが記載されている。
また、特許文献2には、POSデータを用いて消費者の併売傾向を把握するシステムが記載されている。
また、特許文献3には、各種カテゴリにおける複数の商品を関連づけて登録するための複数の仮想BOXを有するデータベースを備え、顧客に対する推奨商品グループを提示できるシステムが記載されている。
また、データの類似度を求める装置が特許文献4に記載されている。特許文献4に記載された装置は、予め保持されている事例と、与えられた事例(クエリ)との類似度である事例間類似度を計算する。また、保持されている事例(例えば、ある地点の気象データ)にはクラス(例えば、気象データ計測時点から3時間後の天気)が定められている。特許文献4に記載された装置は、保持されている事例から相関ルールを導出する。相関ルールは、条件(事例)に応じた結論(クラス)を導くルールである。そして、相関ルールを用いて、事例間類似度から総合類似度を計算する。
特許文献4には、「A,A,・・・,A→B」という形式で表される相関ルールが記載されている。そして、「A,A,・・・,A,B」はアイテム集合と称されている。また、アイテム集合A,A,・・・,A,Bを含むレコード数の全レコードに対する比率を、相関ルールの支持度と呼び、アイテム集合A,A,・・・,Aを含むレコードの中で、アイテムBを含むレコードの割合を相関ルールの確信度と呼ぶ。特許文献4に記載された装置は、支持度および相関度が予め定められた各々の下限値以上となるような相関ルールを抽出する。
また、自動的にデータを分類する装置が特許文献5に記載されている。特許文献5に記載されたデータ分類装置は、注目パターンデータとの類似度の高い順に複数のパターンデータを取りだし、近傍クラスタを決定する。
また、ルールを用いて予測を行う装置として、特許文献6に記載された装置がある。特許文献6に記載された装置は、ある地域(第1の地域)に生じた事象から論理規則を発生し、その規則を他の地域(第2の地域)に適用して、第2の地域でその事象が生じる傾向を予測する。
特開平9−101984号公報(段落0014−0050) 特開2007−94592号公報(段落0024) 特開2003−337886号公報(段落0010,0015,0016) 特開2002−149697号公報(段落0018−0065) 特開2003−256443号公報(段落0090−0093) 特開2004−126757号公報(段落0033,0051)
特許文献1に記載されたシステムでは、システムのユーザである分析者が、手動で顧客を分類する必要があった。そのため、顧客の購買行動から顧客の分類を自動的に行うことができなかった。また、特許文献3に記載された装置においても、各種カテゴリにおける複数の商品の関連付けを、顧客自身や店員等の商品観察者が行う必要があった。
データの分類を行うために、データ間の類似度を計算し、その類似度を用いてデータを分類することが考えられる。特許文献4に記載された装置は、相関ルールを導出し、総合類似度を計算する。しかし、特許文献4に記載された装置にように相関ルールを導出すると、関連のある属性(特許文献4におけるアイテム)がデータ中に多く存在する場合に、それらの関連のある属性の影響を強く受けてしまい、適切な類似度計算を行えない。
例えば、図12に示すデータ番号1〜10の10個のデータが与えられているとする。図12に示すデータにおいて、データ番号1〜4およびデータ番号6は、属性b,c,d,eの値が共通であり、データの類別を表すクラスも共通である。従って、データの属性値を条件部としてクラスを結論部とする相関ルールを抽出する場合、多くのデータ間で属性値の組み合わせが共通となっている属性b,c,d,eの影響を強く受けてしまう。この結果、類似度も、関連のある特定の属性に影響されてしまう。すなわち、ある属性の属性値がある値に合致しているデータ間の類似度が比較的高くなり、合致していないデータ間の類似度は比較的低くなる傾向が出てしまう。
そこで、本発明は、データを分類するためにデータ間の類似度を求める際に、データ中に互いに関連のある属性が多く存在してもそれらの関連のある属性の影響を強く受けることなく類似度を求めることができるデータ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラムを提供することを目的とする。
本発明によるデータ類似度計算システムは、データの特徴を示す属性とデータの類別を示すクラスとを含むデータの集合から、データの重複を許してその集合の部分集合を複数回生成する部分集合生成手段と、部分集合が生成される毎に、属性からクラスを判定するルールである分類器を、部分集合に基づいて生成する分類器生成手段と、分類器が生成される毎に、分類器を用いて、部分集合に属する個々のデータのクラスを判定するクラス判定手段と、データの集合の部分集合が生成され、クラス判定手段がその部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ同士の類似度に値を加算する類似度算出手段とを備えることを特徴とする。
本発明によるデータ類似度計算方法は、部分集合生成手段が、データの特徴を示す属性とデータの類別を示すクラスとを含むデータの集合から、データの重複を許してその集合の部分集合を複数回生成する部分集合生成ステップと、分類器生成手段が、部分集合が生成される毎に、属性からクラスを判定するルールである分類器を、部分集合に基づいて生成する分類器生成ステップと、クラス判定手段が、分類器が生成される毎に、分類器を用いて、部分集合に属する個々のデータのクラスを判定するクラス判定ステップと、類似度算出手段が、データの集合の部分集合が生成され、クラス判定ステップでその部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ同士の類似度に値を加算する類似度算出ステップとを含むことを特徴とする。
本発明によるデータ類似度計算プログラムは、コンピュータに、データの特徴を示す属性とデータの類別を示すクラスとを含むデータの集合から、データの重複を許してその集合の部分集合を複数回生成する部分集合生成処理、部分集合が生成される毎に、属性からクラスを判定するルールである分類器を、部分集合に基づいて生成する分類器生成処理、分類器が生成される毎に、分類器を用いて、部分集合に属する個々のデータのクラスを判定するクラス判定処理、および、データの集合の部分集合が生成され、クラス判定処理でその部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ同士の類似度に値を加算する類似度算出処理を実行させることを特徴とする。
本発明によれば、データを分類するためにデータ間の類似度を求める際に、データ中に互いに関連のある属性が多く存在してもそれらの関連のある属性の影響を強く受けることなく類似度を求めることができる。
以下、本発明の実施形態を図面を参照して説明する。
ここでは、商品やサービスの顧客に関するデータ間の類似度を求める場合を例にして本発明の実施形態を説明する。なお、有料で商品やサービスを利用する者だけでなく、無料で商品やサービスを利用する者や、今後商品やサービスを利用すると思われる人も顧客と呼ぶ。無料の場合は、売価は0とする。また、商品またはサービスの概念としては、製品等の完成品だけでなく、製品の機能を維持するための最小単位も含まれる。さらに、ある商品またはサービスのカテゴリを1つの商品と考えて適用することもできる。
実施形態1.
図1は、本発明の第1の実施形態の例を示すブロック図である。本発明によるデータ類似度計算システム1は、部分集合生成部11と、分類器生成部12と、自己評価部13と、類似度算出部14とを備える。
部分集合生成部11は、データの集合から、その集合の部分集合を生成する。データの集合は、例えば、データ類似度計算システム1に設けられたキーボード等の入力装置(図示せず)を介して入力されればよいが、データの集合の入力態様は特に限定されない。以下、データの集合とは、データ全体の集合を意味する。
データの集合に含まれる個々のデータは、データの特徴を示す属性と、データの類別を示すクラスとを含む。ここでは、少なくとも顧客の特徴または販売条件をデータの特徴とし、顧客の行動をクラスとする場合を例にして説明する。図2は、データの例を示す説明図である。図2に示す例では、「天気」、「気温」、「湿度」、「風が強いか否か」を属性とする場合を示している。これらの属性は、販売条件であるが、「年齢」、「性別」等の顧客の特徴を属性としてもよく、顧客の特徴および販売条件がいずれも属性となっていてもよい。また、図2に示す例では、顧客の行動は、「購入する」と「購入しない」の2種類であるものとし、データも「購入する」および「購入しない」という2種類のクラスに類別される場合を例にする。図2に例示するデータは、属性が示す条件の下で、ある商品またはサービスを顧客が購入したか否かを表している。例えば、図1に示す1番目のデータは、「晴れ」、気温「29度」、湿度「85%」、「風が強くない」という条件の下で、顧客が購入しなかったということを表している。
部分集合生成部11は、このようなデータの集合から一部のデータを選択することで、データの集合の部分集合を生成する。また、部分集合生成部11は、部分集合を複数回生成する。このとき、データの重複を許して部分集合を生成する。すなわち、部分集合生成部11によって生成されたある部分集合と別の部分集合に、同じデータが属していてもよい。
分類器生成部12は、データの集合の部分集合が生成される毎に、その部分集合に基づいて分類器を生成する。分類器は、属性からクラスを判定するルールである。部分集合と、その部分集合に基づいて生成された分類器とが対応する。
自己評価部13は、分類器が生成される毎に、生成された分類器を用いて、その分類器に対応する部分集合に属する個々のデータのクラスを判定する。この判定は、分類器を用いて、個々のデータに含まれる属性からクラスを予測する処理であるということもできる。なお、自己評価部13が判定したクラス(換言すれば、予測したクラス)と、データにおいて予め定められたクラスとが合致するとは限らない。
類似度算出部14は、自己評価部13で判定されたクラスに基づいて、部分集合に属する個々のデータ間の類似度を算出する。データの集合に属する任意のデータ同士の組み合わせに対して、予め類似度の初期値0が設定される。類似度算出部14は、部分集合生成部11によって部分集合が生成され、自己評価部13がその部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ間の類似度に値を加算していくことによって、各データ間の類似度を算出する。
部分集合生成部11、分類器生成部12、自己評価部13および類似度算出部14は、例えば、プログラム(データ類似度計算プログラム)に従って動作するCPUによって実現される。その場合、プログラムは、例えばデータ類似度計算システム1が備えるプログラム記憶装置(図示せず)に記憶され、CPUがプログラムを読み込み、そのプログラムに従って部分集合生成部11、分類器生成部12、自己評価部13および類似度算出部14として動作すればよい。
次に、動作について説明する。
図3は、第1の実施形態のデータ類似度計算システムの処理経過の例を示すフローチャートである。例えば、データ類似度計算システム1に設けられたキーボード等の入力装置(図示せず)を介して、データの集合が入力されると、データ類似度計算システムは以下のように動作する。ただし、データの集合に属する個々のデータ(個別データと称する)の数をNとする。また、データの集合の部分集合を生成する回数をTとする。Tは、例えば、100、500、1000等の数であるが、Tはこれらの値に限定されない。また、部分集合生成部11が1つの部分集合に属する個別データとしてデータの集合から選択する個別データの数をMとする。Mは、例えば、Nの1%、5%、または10%等の値とすればよいが、Mはこれらの値に限定されない。部分集合の生成を繰り返す繰り返し回数であるTや、部分集合に含める個別データ数であるMは、それぞれ、キーボード等の入力装置(図示せず)を介して、データ類似度計算システムのユーザによって入力されてもよい。あるいは、他の態様でT,Mが指定されてもよい。
また、データの集合に属する個別データを順番に指定するための第1の変数をiとし、第2の変数をjとする。iは、1≦i≦Nを満たす整数であり、同様に、jは、1≦j≦Nを満たす整数である。i,jを指定することでそれぞれ個別データを指定することができ、i,jの組み合わせによって一対の個別データの組を指定することができる。i,jによって指定される1対の個別データの類似度をSim(i,j)と記す。
最初に、部分集合生成部11は、1≦i≦Nの範囲のiと、1≦j≦Nの範囲のjとによって定められるiとjの組み合わせを順次定め、その各組み合わせに応じた各類似度Sim(i,j)を0に初期化する(ステップA1)。すなわち、i番目の個別データとj番目の個別データとの類似度となるSim(i,j)を、i,jの組み合わせ毎に0に初期化する。換言すれば、部分集合生成部11は、データの集合に属する全ての個別データから得られる一対の個別データの各組について、個別データ間の類似度を0に初期化する。
次に、部分集合生成部11は、データの集合から部分集合を生成した回数を表す変数tを0に初期化する(ステップA2)。
続いて、部分集合生成部11は、変数tと、Tとを比較し、tがT未満であるか否かを判定する(ステップA3)。変数tがT以上であるならば(ステップA3におけるNo)、処理を終了する。また、変数tがT未満であるならば(ステップA3におけるYes)、部分集合生成部11は、データの集合からM個の個別データを選択することによって部分集合を生成する(ステップA4)。すなわち、部分集合の要素となるM個の個別データをデータの集合から選択すればよい。ステップA4の処理はtの値がインクリメントされる毎に行われるが、2回目以降の部分集合の生成時において、新たに生成する部分集合に属する個別データと、既に生成された部分集合に属する個別データとが重複していてもよい。このように、部分集合生成部11は、部分集合同士での個別データの重複を許して部分集合を生成する。
ステップA4において、データの集合から個別データを選択する際に、例えば、個別データをランダムサンプリングしてもよい。すなわち、部分集合生成部11は、データの集合から1個の個別データをランダムに選択することをM回繰り返すことによって、M個の個別データを選択してもよい。
ただし、M個の個別データの選択方法はランダムサンプリングに限定されない。例えば、部分集合生成部11は、最初にステップA4を実行するときには、1番目からM番目までの個別データを選択し、次にステップA4を実行するときには、M+1番目から2・M番目までの個別データを選択するというように、個別データに予め定められた順番に従って、ステップA4毎にM個ずつ個別データを選択してもよい。
なお、部分集合に含める個別データは、データの集合に属する個別データに含まれる属性のうち一部の属性と、クラスを抽出したデータであってもよい。例えば、図2に示す例では、個別データには「天気」、「天候」、「湿度」、「風が強いか否か」という4つの属性が含まれているが、部分集合に含める個別データを選択するときには、この4つの個別データのうちの一部(例えば、「天気」、「天候」のみ)と、クラスとを抽出し、その属性およびクラスからなるデータを部分集合の要素としてもよい。データの集合に属する個別データに含まれる属性がA個であるとき、部分集合に属する個別データに含まれる属性をいくつにするか、また、どの属性を部分集合に属する個別データに含めるかについては、例えば、キーボード等の入力装置(図示せず)を介して、データ類似度計算システムのユーザによって入力されてもよいし、他の態様で指定されてもよい。
ステップA4の後、分類器生成部12は、直前のステップA4で生成された部分集合に基づいて分類器を生成する(ステップA5)。分類器として、例えば決定器やサポートベクタマシンを生成すればよい。どのような分類器を用いるかについては、キーボード等の入力装置(図示せず)を介して、データ類似度計算システムのユーザによって入力されてもよいし、他の態様で指定されてもよい。
以下、分類器として決定木を用いる場合を例にして、分類器の具体例を説明する。本例では、「購入する、購入しない」をクラスとし、「天気」、「気温」、「湿度」、「風が強いか否か」を属性とする場合を例にして説明する。また、ここでは、図2に示す14個の個別データからなる部分集合が生成されている場合を例にする。図4は、分類器の例を示す説明図であり、ここでは、決定木を分類器としている。図2に示すような既知の属性およびクラスの組み合わせがあれば、その既知の属性およびクラスから決定木を生成することができる。以下の説明において、属性の値(すなわち属性値)に応じて、決定木におけるノードを枝分かれさせることを分割という。
図2に示す例では、各行が、「購入する」または「購入しない」というクラスが付された個別データに相当する。また、説明を簡単にするため、「購入する」というクラスを正(+)のクラスと表し、「購入しない」というクラスを負(−)のクラスと表す場合がある。決定木では、クラス毎(例えば、「購入する(正)」、「購入しない(負)」というクラス毎)に個別データ数をまとめた情報をノードとする。例えば、図2に示すルートのノードでは、「する:9,しない:5」という情報をノードとしている。
分類器生成部12は、ステップA4で生成された部分集合が与えられると、どの属性で最初にルートのノードを分割させるかを決定する。また、個別データに含まれている属性の個数をR個とした場合、各属性を属性1〜Rとする。このとき、分類器生成部12は、属性1〜Rの各属性について、分割時の評価値を計算し、その評価値が最大の属性を、分割に最も適した属性として選択する。ここでは、分割前のノードのエントロピーと、分割後のエントロピーの差を評価値とする場合を例にするが、他の計算方法で評価値を求めてもよい。ノードのエントロピーは、クラスが正(+)の個別データの割合をqとし、クラスが負(−)の個別データの割合を1−qとすると、−qlogq−(1−q)log(1−q)で表される。分割後のノードのエントロピーは、分割後の各ノードのエントロピーの加重平均である。
例えば、ステップA4で生成された部分集合において、「正」が9データあり、「負」が5データあるとするとルートのノードは「正:9,負:5」となる。この場合、正(+)のデータが9データあり、負(−)のデータが5データあるので、ルートのノードのエントロピーは、−(9/14)×log(9/14)−(5/14)×log(5/14)=0.940となる。ただし、本例ではlogの底を2とする。
分類器生成部12は、一つの属性でルートのノードを分割して得られるノードを求める。すなわち、その属性の属性値毎に、正および負の個別データ数を表す情報(ノード)を生成する。例えば、その属性1のとり得る値が「0」または「1」であり、属性1の値が「0」のときには、正が5データあり、負が2データあるとし、属性1の値が「1」のときには、正が0データあり、負が7データあるとする。この場合、属性1の値が「0」か「1」かで分岐するノードとして、「正:5,負:2」というノードと、「正:0,負:7」というノードとを生成する。分類器生成部12は、分割後の各ノードのエントロピーを計算し、分割後の各ノードにおける正または負としてカウントされる個別データ数に応じて各ノードのエントロピーの加重平均を求める。上記の例では「正:5,負:2」というノードにおいても、「正:0,負:7」というノードにおいても個別データの総数は7であるので、加重平均を行う際の重み付け係数は各ノードでいずれも(7/14)となる。従って、本例の場合、分類器生成部12は、分割後のエントロピーを以下のように計算する。
(7/14)×{−(5/7)×log(5/7)−(2/7)×log(2/7)}
+(7/14)×{−(0/7)×log(0/7)−(7/7)×log(7/7)}
=0.432
ただし、logの係数が0となる場合、その項の値は0とする。上記の例では、−(0/7)×log(0/7)の値は0としている。
従って、本例の場合、分類器生成部12は、属性1で分割した場合の評価値を、0.940−0.432=0.508と計算する。
分類器生成部12は、属性1だけでなく、他の属性についても同様に、その属性で分割したときの評価値を計算し、評価値が最大となる属性で分割すると決定する。このようにして、ルートのノードを分割する属性を決定する。
なお、上記の属性1の例では、属性1のとり得る値が「0」または「1」の二つだけである場合を示した。属性値が年齢であり、その値が20,21,22のように連続する値の場合には、どの属性値で分割させるのかも決める。この場合、分類器生成部12は、各属性値間の中間値をしきい値とし、各しきい値毎に、その「しきい値以下」および「そのしきい値より大」とに分割させた場合の評価値を求める。そして、評価値が最大となる場合を選択することによって、どの属性値で分割させるのかも決定する。例えば、属性値が20,21,22,・・・と連続する場合では、「20.5以下」および「20.5より大」で分割した場合の評価値、「21.5以下」および「21.5より大」で分割した場合の評価値等をそれぞれ計算し、評価値が最も高くなるように分割すればよい。
分類器生成部12は、分割後の各ノードについても、上記と同様の処理を行い、次にどの属性で分割するのかを決定する処理を順次、繰り返す。また、分類器生成部12は、所定の条件が満たされたときには、ノードの分割を停止する。所定の条件とは、例えば、「ノードにおける個別データのクラスが全て同じになる」という条件や、「ノードにおける正または負としてカウントされる個別データ数が所定数(例えば2)以下になる」という条件を用いてよい。前者の条件を採用すると、ノードにおける個別データが全て正または負になると、そのノードの分割を継続しない。このように、分類器生成部12は、ルートのノードから順次、分割を繰り返し、木構造の決定木を生成する。
また、分類器生成部12は、上記のように、木構造の決定木を生成した後、その決定木に対する枝刈りを行う。決定木において、分割されて生成された最終的なノードを葉と呼ぶ。ある葉に分類されたデータ数がDであるとする(すなわち、正または負としてカウントされる個別データ数がDであるとする)。この葉に分類されたDデータ中、Eデータが誤りであるとする。この仮定では、D回の試行中、誤りという事象をE回観測したとみなし、大きさDの標本で、誤りという事象が起きる確率がrである二項分布と考えることができる。予め与えられた信頼度CFに対して、rの上限をU_CF(E,D)と表すことにすると、Dデータでの誤りの発生する期待値は、D×U_CF(E,D)となる。分類器生成部12は、子のノードが全て葉である親のノードに対し、親における誤りの期待値(誤りの発生する期待値)と、子である葉の誤りの期待値の合計とを比較する。そして、子での期待値の合計の方が親の誤りの期待値よりも大きければ、分類器生成部12は、葉を縮退して、その親を葉とする。分類器生成部12は、この処理を順次繰り返すことで、決定木全体の葉の枝刈りを行う。
葉を縮退する場合、分類器生成部12は、葉を削除して、その削除した葉の親のノードを葉とすればよい。例えば、図4に例示する決定木において、「湿度」という属性の値に応じて分割したノードを縮退する場合、分類器生成部12は、湿度の属性値が70%以下となっている個別データ数を表すノード「する:2,しない:0」と、湿度の属性値が70%より高くなっている個別データ数を表すノード「する:0,しない:3」とを削除して、その2つのノードの親ノード「する:2,しない:3」を葉とすればよい。
分類器として決定木を生成する場合、例えば、上記のように、決定木を定めて枝刈りを行うことで、決定木を生成すればよい。
分類器生成部12は、ステップA4で生成された部分集合に属するデータのうち、特定のクラスのデータを重く加重してから決定木を生成してもよい。ここで、加重とは、データに対する重みを設定することである。例えば、部分集合に属するデータのうち、予め定められた特定のクラスの個別データの数が数倍になるように、そのクラスの個別データの複製を作成することで、加重を行ってもよい。なお、特定のクラスの個別データ数を何倍にするかは予め定めておけばよい。そして、特定のクラスの個別データ数を増やすように、そのクラスの個別データを複製した後に、分類器を生成してもよい。加重の対象とするクラスおよび加重量(例えば、データを何倍に増やすか等)は、キーボード等の入力装置(図示せず)を介してデータ類似度計算システムのユーザにより入力されてもよいし、他の様態で指定されてもよい。
ステップA5で分類器が生成されると、自己評価部13は、その分類器を用いて、ステップA3で生成された部分集合に属する個々のデータのクラスを判定する(ステップA6)。ここでも、分類器が決定木である場合を例にして説明する。分類器となる決定木を生成した場合、その決定木と、既知の属性(部分集合に属する個別データの属性)とから、クラスを予測する。このとき、自己評価部13は、決定木のルートのノードを起点として、ノードを分割する際に用いた属性に関して個別データの属性値を参照し、その属性値に応じて子ノードを辿る。自己評価部13は、子ノードを辿っていき、葉のノードまで辿ったならば、葉のノードでカウント数の多い方のクラスを、分類器を用いた判定の結果とすればよい。
図5は、分類器から判定されたクラスの例を示す説明図である。図5に示す各属性の属性値は、図2に示す各属性値と同一である。また、図5では、図4に例示する決定木(分類器)を用いて、その属性値からクラスを判定した結果を示している。例えば、個別データにおける属性「天気」の属性値が「雨」であるとする。すると、ルートのノードから、「する:3、しない:2」という子ノードを辿る(図4参照)。そのノードが葉であるので、自己評価部13は、「する:3、しない:2」というカウント数により、「購入しない」というクラスであると判定する。このように判定した結果、図5に示す6番目および最後の個別データのクラスの判定結果は、図2に示す元のクラスと異なっている(図2、図5参照)。
ステップA6で部分集合に属する各個別データのクラスが判定された後、類似度算出部14は、データの集合に属する個別データを順番に指定するための第1の変数iを1に初期化する(ステップA7)。続いて、類似度算出部14は、変数iの値が個別データの総数N以下であるか否かを判定する(ステップA8)。変数iの値がNを超えていれば(ステップA8におけるNo)、変数tを1インクリメントし(ステップA8)、その後、データ類似度計算システムはステップA3以降の処理を再度繰り返す。
変数iの値がN以下であるならば(ステップA8におけるYes)、類似度算出部14は、変数iによって定まるi番目の個別データが、直近のステップA4で生成された部分集合に含まれているか否かを判定する(ステップA10)。i番目のデータが部分集合に含まれていないならば(ステップA10におけるNo)、類似度算出部14は、変数iを1インクリメントし(ステップA11)、ステップA8以降の処理を再度繰り返す。
i番目のデータが部分集合に含まれているならば(ステップA10におけるYes)、データの集合に属する個別データを順番に指定するための第2の変数jの値をi+1に設定する(ステップA12)。すなわち、jにi+1を代入する。
ステップA12の後、類似度算出部14は、変数jの値がN以下であるか否かを判定する(ステップA13)。変数jの値がNを超えていれば(ステップA13におけるNo)、類似度算出部14は、変数iを1インクリメントし(ステップA11)、ステップA8以降の処理を再度繰り返す。
変数jの値がN以下であるならば(ステップA13におけるYes)、類似度算出部14は、変数jによって定まるj番目の個別データが、直近のステップA4で生成された部分集合に含まれているか否かを判定する(ステップA14)。j番目の個別データが部分集合に含まれていないならば(ステップA14におけるNo)、類似度算出部14は、変数jを1インクリメントし(ステップA17)、ステップA13以降の処理を繰り返す。
j番目の個別データが部分集合に含まれているならば(ステップA14におけるYes)、類似度算出部14は、i番目の個別データの属性から判定されたクラス(PredCと記す)と、j番目の個別データの属性から判定されたクラス(PredCと記す)とをとを比較し、両者が同じクラスであるか否かを判定する(ステップA15)。PredCおよびPredCは、直近のステップA6で、i番目およびj番目の個別データについて、分類器を用いて属性から判定されたクラスである。PredCとPredCとが同じクラスであるということは、i番目の個別データおよびj番目の個別データが、同一のクラスと判定されたデータ同士であるということを意味する。
PredCとPredCとが異なっていれば(ステップA15におけるNo)、類似度算出部14は、変数jを1インクリメントし(ステップA17)、ステップA13以降の処理を繰り返す。
PredCとPredCとが同じクラスであれば(ステップA15におけるYes)、i番目の個別データとj番目の個別データの類似度Sim(i,j)に所定数を加算する(ステップA16)。本例では、この所定数を1とし、ステップA16でSim(i,j)に1を加算する場合を例にする。ステップA16の後、類似度算出部14は、変数jを1インクリメントし(ステップA17)、ステップA13以降の処理を繰り返す。
上記のように、1つの部分集合が生成されたとき、その部分集合に属している1対の個別データであって、PredCとPredCとが同じクラスとなっている個別データ間の類似度Sim(i,j)の値を1増加させていく。また、一方あるいは両方が部分集合に属していない個別データ同士の場合には、ステップA16に移行しないので、その個別データ間の類似度は増加しない。また、部分集合に属している1対の個別データであっても、属性から判定されたクラスが異なる場合にも、ステップA16に移行せず、その個別データ間の類似度は増加しない。
そして、データ類似度計算システムは、変数tをインクリメントして(ステップA8)、部分集合を生成すると(ステップA4)、ステップA5以降の処理を実行する。このとき、各個別データの組について一律にステップA16の処理を実行するわけではない。個別データの重複を許して部分集合の生成を複数回生成したときに、ステップA16が行われた回数の多い個別データの組については、Sim(i,j)の値も大きくなる。一方、ステップA16が行われた回数の少ない個別データの組については、Sim(i,j)の初期値からの増加量は少ない。部分集合の生成回数tが上限値Tに達したときにおける各データの対毎のSim(i,j)が、対をなす個別データ間の類似度となる。
また、上記の第1の実施の形態では、二つのデータがいずれも部分集合に属し、その二つのデータに対して判定されたクラスが同一であるという条件が満たされたときに、その二つのデータ類似度Sim(i,j)に対して所定値を加算する。この条件だけでなく、さらに、二つのデータに対して判定されたクラスが特定のクラス(例えば、「購入する」)であるという条件を満たしている場合に、二つのデータ類似度Sim(i,j)に対して所定値を加算し、他の場合には、Sim(i,j)への加算を行わなくてもよい。この場合、二つのデータに対するクラスの判定結果が同一であっても、そのクラスが特定のクラス出ない場合、類似度に対する加算を行わない。
上記のように類似度を求める場合、類似度算出部14は、ステップA15において、PredCとPredCとが同一であり、かつ、PredCおよびPredCが特定のクラス(例えば、「購入する」)であるか否かを判定すればよい。そして、この条件を満たしている場合に、ステップA16を行い、満たしていない場合には、ステップA17に移行すればよい。
次に、第1の実施形態の効果について説明する。
第1の実施形態によれば、与えられたデータの集合に属するデータ同士の組に対して、それぞれ類似度の初期値を定める。そして、そのデータの集合から部分集合を生成し、その部分集合に含まれる各データに定められている属性(例えば、顧客の特徴や販売条件)およびクラスから、分類器を生成する。さらに、分類器を用いて、その属性からクラスを判定し、部分集合に含まれているデータ同士であって、判定されたクラスが同じデータの類似度に所定値を加算する。上記の部分集合生成以後の処理を複数回繰り返すことで、各データ同士の類似度を決定する。本願発明では、このような処理によって、自動的に、各データ間の類似度を算出することができる。
また、本実施形態において、部分集合生成時(ステップA4)では、個別データを予め定められた数Mだけ選択すればよく、既に生成された部分集合に属している個別データを重複を許して選択する。例えば、ランダムサンプリングを行ってもよい。このように、M個の個別データを選択することを複数回行って、類似度を生成する。また、類似度が求まれば、類似度に基づいて個別データを分類することができる。特許文献1に記載されたシステムのように、分析者が手動で顧客の分類を行う場合には、顧客の分類に対する特別なスキルが必要となったり、試行錯誤して分析を行って手間がかかったりすることがあるが、上記のように類似度を求めれば、システムのユーザに特別なスキルがなくても、ユーザの手間をかけずに、分類に用いるための類似度を算出することができる。
また、各データが個々の顧客に対応し、データの属性が顧客の特徴や販売条件であり、データに「購入する」または「購入しない」というクラスが与えられている場合、商品またはサービスに対する顧客の行動(購入したか否か)に基づいて、データの類似度を求めることができる。また、データが顧客に対応しているので、顧客同士の類似度ということもできる。
以下に示す効果の説明では、データの属性が顧客の特徴であり、データと顧客が対応していて、データのクラスが顧客の購入行動(例えば「購入する」または「購入しない」)である場合を例にして説明する。
重複を許したランダムサンプリングにより部分集合を生成した場合、個々のデータ(本例では個々の顧客)は、部分集合にM/Nの確率で選択されることとなる。すなわち、M/Nの確率で部分集合に含められることになる。他のデータ(他の顧客)も、同様の確率で部分集合に含められる。データを組み合わせて得られる各データの組は、同じ確率で部分集合に属することとなる。従って、部分集合を作成する回数Tが十分大きく、仮に、元のクラスとステップA6で判定されたクラスが全て同一であれば、データ間の類似度はほぼ同じとなり、クラスが同一のデータを細かく分類することはできない。例えば、「購入する」というクラスのデータを細かく分類したり、「購入しない」というクラスのデータを細かく分類したりすることはできない。また、「購入する」というクラスのデータ(商品等を購入した顧客)と、「購入しない」というクラスのデータ(商品等を購入しなかった顧客)との類似度は0となる。これに対し、本発明の第1の実施形態では、部分集合に属する各個別データから分類器を生成し、その分類器を用いて、個別データの属性からクラスを判定することで、元のクラスと、判定後のクラスとがことなる場合を生じさせる機会を積極的に設けている。そして、判定後のクラスを用いて、個別データの類似度を求めることで、i番目のデータとj番目のデータからなる各組に対して、それぞれ類似度Sim(i,j)を定めることができる。
また、本発明では、互いに関連のある属性が多く存在しても、それらの関連ある属性の影響を強く受けることなく類似度を算出できる。例えば、図12に示すデータ番号1〜10の10個のデータが与えられているとする。図12に示すデータ番号{1,2,7,9,10}のデータを部分集合とすると、例えば、分類器として「属性aの値が1ならばクラスは『購入する』であり、属性aの値が2ならばクラスは『購入しない』である」という決定木が生成され、データ番号{1,2}のデータ間の類似度や、データ番号{7,9,10}の各データ間の類似度が加算される。また、例えば、データ番号{1,2,6,7,9,10}のデータを部分集合とする。この場合、例えば、分類器として「属性bの値が1ならばクラスは『購入する』であり、属性bの値が2ならばクラスは『購入しない』である」という決定木が生成され、データ番号{1,2,6}の各データ間の類似度や、データ番号{7,9,10}の各データ間の類似度が加算される。
一般に、決定木には複数の属性が現れるが、属性に互いに関連性がある場合、決定木に現れる属性の数は減る。上記のデータ番号{1,2,6,7,9,10}を部分集合とする場合を例にすると、属性bを用いて個別データを2つに分類した場合と、属性c、d、あるいはeを用いて個別データを2つに分類した場合とで、個別データの分類のされ方が全く同一になる。よって、属性bで分割した後、属性c、d、あるいはeで分割することはない。具体例を挙げると、データ番号{1,2,6,7,9,10}のデータを属性bで分割すると、属性bの値が1のノードにはデータ番号{1,2,6}のデータが含まれ、属性bの値が2のノードにはデータ番号{7,9,10}が含まれる。データ番号{1,2,6}のノードをcで分割する場合、そのデータ番号{1,2,6}のデータは全て属性cの値が1となり、属性cの値が2となるデータはない。属性bの値が2のノードでも、属性cの値が一方に偏っている。属性bでの分割後、属性dやeで分割する場合も同様である。
このように、属性に互いに関連性がある場合、決定木に現れる属性の数が減り、関連のある属性の影響を強く受けることがなくなる。上記のデータ番号{1,2,6,7,9,10}を部分集合とする例では、例えば、決定木には属性bが現れるが、属性bと同時に他の属性c、d、eは決定木に現れず、属性bに関連する属性c、d、eに影響されることがない。そのため、データに関連ある属性が多く存在していても、それらの関連のある属性の影響を強く受けることなく、類似度を求めることができる。
また、二つのデータがいずれも部分集合に属し、その二つのデータに対して判定されたクラスが同一であるという条件だけでなく、さらに、その二つのデータに対して判定されたクラスが特定のクラス(例えば、「購入する」)であるという条件を満たしているときにのみ、その二つのデータの類似度Sim(i,j)への加算(ステップA16)を行う場合、以下の効果が得られる。すなわち、特定のクラスのデータの持つ特徴の違いを重視して類似度を算出できる。ここでも、データと顧客とが対応している場合を例にして説明する。ステップA16に移行する条件として、二つのデータに対して判定されたクラスが特定のクラスであるという条件も加えると、特定のクラスの顧客が持つ特徴の違いを重視して類似度を算出できる。例えば、商品またはサービスを購入した顧客が複数の特徴のいずれかを持っていて、まだその商品またはサービスを購入していないが、既に購入済みの顧客と特徴が近い顧客(購入の見込みのある顧客)が複数の特徴のうちのいずれかを持っていそうな場合がある。そのような場合において、購入していない顧客との類似度は重視せず、購入した顧客との類似度を重視したいと分析者が考える場合がある。そのような場合、ステップA6で「購入する」という特定のクラスであると判定された顧客のデータと、ステップA6で「購入する」と判定された「購入の見込みのある顧客」のデータとの類似度について加算して、「購入する」というクラスの顧客が持つ特徴の違いを重視して類似度を算出することができる。
また、分類器生成部12は、分類器を作成するときに、ステップA4で生成された部分集合に属するデータのうち、予め与えられたクラスが特定のクラスとなっているデータに対して加重を行ってから、分類器を作成してもよい。例えば、部分集合に属するデータのうち、予め与えられたクラスが「購入する」となっているクラスのデータのデータ数が、指定された分だけ増えるように、そのデータの複製を作成して、その複製したデータも用いて分類器を生成してもよい。そのような分類器を用いて類似度を算出すれば、その類似度に基づいてデータを分類する場合、特定のクラス以外のクラスのデータが持つ特徴の違いを重視してクラスタ(グループ)に分類することができる。例えば、「購入する」というクラスの顧客(データ)と、「購入しない」というクラスの顧客の数が同じくらいであるとする。データに加重を行わない場合には、いずれのクラスのデータも混ざったクラスタが生成されがちになる。特定のクラスのデータを重く加重すると、特定のクラスのデータの間の類似度がどの組み合わせでも高くなることで1つのクラスタとなる。一方、特定のクラス以外のクラスのデータは、そのように類似度が高くなることはなく、1つのクラスタにまとめられずに、複数のクラスタに分類することができる。なお、類似度を用いてデータをクラスタ(グループ)に分類する処理については、第2の実施形態で説明する。
実施形態2.
図6は、本発明の第2の実施形態の例を示すブロック図である。第2の実施形態のデータ類似度計算システム20は、部分集合生成部11と、分類器生成部12と、自己評価部13と、類似度算出部14と、類似度クラスタリング部21とを備える。第1の実施形態と同様の構成要素については、図1と同一の符号を付し、詳細な説明を省略する。第2の実施形態のデータ類似度計算システム20は、第1の実施形態と同様に、データの集合に属する個別データ間の類似度を計算した後、その類似度を用いて個別データを分類する。従って、第2の実施形態のデータ類似度計算システム20は、分類システムと称することができる。以下、本実施形態において、個別データのグループをクラスタと記す。
類似度クラスタリング部21は、類似度算出部14が求めた個別データ間の類似度に基づいて、データの集合に属する個別データを複数のクラスタに分類する。類似度クラスタリング部21には、目標とするクラスタ数が入力され、類似度クラスタリング部21は、そのクラスタ数になるように個別データを分類する。目標とするクラスタ数は、データ類似度計算システム20に設けられるキーボード等の入力装置(図示せず)を介して、データ類似度計算システムのユーザによって入力されてもよい。あるいは、他の態様でクラスタ数が指定されてもよい。
部分集合生成部11、分類器生成部12、自己評価部13、類似度算出部14および類似度クラスタリング部21は、例えば、プログラム(データ類似度計算プログラム)に従って動作するCPUによって実現される。その場合、CPUがプログラムに従って、部分集合生成部11、分類器生成部12、自己評価部13、類似度算出部14および類似度クラスタリング部21として動作すればよい。
次に、第2の実施形態の動作について説明する。
データ集合に属する各個別データ間の類似度を求める処理は、第1の実施形態と同様である。部分集合生成部11、分類器生成部12、自己評価部13および類似度算出部14がそれぞれ第1の実施形態と同様に動作し、例えば、図3に示す処理を行って、i,jの組毎に、個別データ間の類似度Sim(i,j)を求めればよい。
それぞれの個別データ間の類似度Sim(i,j)が算出された後、類似度クラスタリング部21は、個別データの各組における類似度を用いて、個別データをクラスタリングする(すなわち分類する)。
類似度が与えられたときのクラスタリング方法には、様々な方法がある。例えば、階層的クラスタリング法として最短距離法、最長距離法、郡平均法、ウォード法等があり、非階層的クラスタリング法としてK平均法等がある。類似度クラスタリング部21は、いずれの方法で個別データを分類してもよい。また、どの方法でクラスタリングを行うかの指定が、キーボード等の入力装置を介してデータ類似度計算システムのユーザにより入力されてもよい。あるいは、他の態様で指定されてもよい。
以下、最短距離法によって個別データをクラスタリングする場合を例にして、個別データのクラスタリング処理を説明する。図7は、最短距離法によって個別データをクラスタリングする処理経過の例を示すフローチャートである。なお、以下の説明では、目標とするクラスタ数をK個とする。目標とするクラスタ数Kは、例えば、キーボード等の入力装置を介して、予め類似度クラスタリング部21に入力される。
類似度クラスタリング部21は、データの集合に属する個別データをそれぞれ1個だけ含むクラスタを、各個別データ毎に定める(ステップB1)。従って、類似度クラスタリング部21は、ステップB1において、データの集合に属する個別データの総数Nと等しいN個のクラスタを定めることになる。このN個のクラスタに属する個別データは、クラスタ毎に異なっている。ステップB1の後、ステップB2に移行する。
ステップB2では、類似度クラスタリング部21は、二つのクラスタからなるクラスタの各組についてそれぞれ、クラスタ間の類似度を求め、最もクラスタ間の類似度が高い二つのクラスタを特定し、その二つのクラスタを一つのクラスタに併合する(ステップB2)。ステップB2に移行した時点でのクラスタ数をLとすると、L個のクラスタから二つのクラスタを取り出す個の組毎に、クラスタ間の類似度を求め、最もクラスタ間の類似度が高い二つのクラスタを一つのクラスタに併合すればよい。なお、最初にステップB1からステップB2に移行したときには、L=Nである。
また、二つのクラスタからなる組において、その二つのクラスタ間の類似度を定める方法の例を以下に示す。類似度を求める対象となる二つのクラスタの一方をCと記し、他方をCと記す。また、その二つのクラスタC,C間の類似度をS(C,C)と記す。類似度クラスタリング部21は、例えば、Cに属する個別データと、Cに属する個別データとの各組み合わせにおける個別データ間の類似度のうち、最大値をC,C間の類似度をS(C,C)と定めればよい。すなわち、Cから取り出した一つの個別データをxとし、Cから取り出した一つの個別データをxとし、x,xの類似度をS(x,x)とすると、類似度クラスタリング部21は、式(1)に示すようにS(x,x)の最大値をS(C,C)と定めればよい。
Figure 0005391637
また、二つのクラスタを一つのクラスタに併合するとは、二つのクラスタに属する各個別データを一つのクラスタにまとめることである。二つのクラスタを一つのクラスタに併合することにより、クラスタの総数が1つ減少する。
ステップB2で二つのクラスタを一つのクラスタに併合した後、類似度クラスタリング部21は、クラスタ数が目標数Kになったか否かを判定する(ステップB3)。クラスタ数が目標数Kまで減っていなければ(ステップB3におけるNo)、ステップB2以降の処理を繰り返す。クラスタ数が目標数Kとなっていれば(ステップB3におけるYes)、K個のクラスタが得られ、個別データがK個に分類されているので、処理を終了する。
第2の実施形態によれば、データの集合に含まれる個別データを目標数のクラスタに分類することができる。
例えば、データの属性が顧客の特徴であり、データと顧客が対応していて、データのクラスが顧客の購入行動(「購入する」または「購入しない」等)を表している場合、商品またはサービスに対する顧客の購入行動に応じて、自動的に顧客を分類することができる。
また、図7に例示するように、最初に各個別データをそれぞれ別々のクラスタに振り分け、クラスタの数が目標数となるまでクラスタを併合させていけば、目標数のクラスタに個別データを分類することができる。すなわち、特定のクラスタに個別データが集まってしまい個別データのクラスタ数が目標数に達しないということを防止することができる。
実施形態3.
図8は、本発明の第3の実施形態の例を示すブロック図である。第3の実施形態のデータ類似度計算システム30は、部分集合生成部11と、分類器生成部12と、自己評価部13と、類似度算出部14と、類似度クラスタリング部21と、属性データ分類部31と、関連性算出部32とを備える。第1の実施形態や第2の実施形態と同様の構成要素については、図1、図6と同一の符号を付し、詳細な説明を省略する。第3の実施形態のデータ類似度計算システム30は、第2の実施形態と同様に類似度を用いて個別データを分類するので、分類システムと称することができる。なお、本実施の形態においても、類似度クラスタリング部21によって分類された個別データのグループをクラスタと記す。また、第3の実施形態のデータ類似度計算システム30は、類似度算出に対する属性の関連度を算出する。類似度算出に対する属性の関連度とは、類似度算出に対する属性の関連性の度合い(換言すれば、類似度算出に対して属性が影響を与える度合い)を示す数値である。
属性データ分類部31には、属性およびその属性値に基づく分類方法を指定する情報(以下、分類方法指定情報と記す)が入力され、属性データ分類部31は、指定された分類方法に従って、個別データを分類する。分類方法指定情報によって、属性データ分類部31による個別データの分類数も定まる。分類方法指定情の例として、「属性名Aの属性値がThres以上である個別データをグループ1に分類し、属性名Aの属性値がThres未満である個別データをグループ2に分類する。」などの情報が挙げられる。この場合、個別データは、二つのグループ1,2に分類されることになる。分類方法指定情報は、例えば、キーボード等の入力装置(図示せず)を介して属性データ分類部31に入力されるが、他の態様で入力されてもよい。
関連性算出部32は、類似度クラスタリング部21によって分類されたクラスタ(グループ)と、属性データ分類部31によって分類されたグループとの関係に基づいて、類似度算出に対する属性の関連度(以下、単に属性の関連度と記す)を求める。この属性は、分類方法指定情報で指定された属性である。
部分集合生成部11、分類器生成部12、自己評価部13、類似度算出部14、類似度クラスタリング部21、属性データ分類部31および関連性算出部32は、例えば、プログラム(データ類似度計算プログラム)に従って動作するCPUによって実現される。その場合、CPUがプログラムに従って、部分集合生成部11、分類器生成部12、自己評価部13、類似度算出部14、類似度クラスタリング部21、属性データ分類部31および関連性算出部32として動作する。
次に、第3の実施形態の動作について説明する。
類似度クラスタリング部21が個別データを分類するまでの動作は、第2の実施形態と同様である。部分集合生成部11、分類器生成部12、自己評価部13および類似度算出部14は、第1および第2の実施形態と同様に動作し、例えば、図3に示す処理を行って、i,jの組毎に、個別データ間の類似度Sim(i,j)を求めればよい。その後、類似度クラスタリング部21は、第2の実施形態と同様に、指定されたクラスタ数に個別データを分類する。
図9は、類似度クラスタリング部21による分類後に属性の関連度を求める動作の例を示すフローチャートである。ここでは、類似度クラスタリング部21によってグループ分けされるクラスタ数と、属性データ分類部31によってグループ分けされるグループ数が等しい場合を例に説明する。本例では、類似度クラスタリング部21がデータの集合に属する個別データを二つのクラスタに分類するものとする。また、属性データ分類部31には、例えば、「属性名Aの属性値がThres以上である個別データをグループ1に分類し、属性名Aの属性値がThres未満である個別データをグループ2に分類する。」という分類方法指定情報が入力され、属性データ分類部31が個別データを2つのグループに分類するものとする。
また、以下の説明において、変数kは、類似度クラスタリング部21によってグループ分けされるクラスタを指定するための変数であり、本例では、kの取り得る値は1または2である。また、変数lは、属性データ分類部31によってグループ分けされたグループを指定するための変数であり、本例では、lの取り得る値は1または2である。
属性データ分類部31は、まず、k=1,2、l=1,2によって決まるkとlの組み合わせを順次定め、k,lの組み合わせと一対一に対応する変数N[k][l]を全て0に初期化する(ステップC1)。N[k][l]は、k番目のクラスタに属している個別データであって、l番目のグループにも属している個別データの数を表す。
属性データ分類部31は、個別データを指定するための変数iを1に初期化する(ステップC2)。
次に、属性データ分類部31は、変数kの値を、個別データi(すなわち、i番目の個別データ)が属するクラスタのクラスタ番号とする(ステップC3)。なお、例えば類似度クラスタリング部21は、分類の結果得られたK個のクラスタに対して、クラスタを識別するための番号1〜Kを割り当てる。個々のクラスタに割り当てられた番号がクラスタ番号である。ステップC3では、変数kに、データiが属するクラスタのクラスタ番号を代入すればよい。本例ではクラスタ数は2であるので、クラスタ番号は1または2である。
次に、属性データ分類部31は、個別データiの属性値(分類方法指定情報で指定された属性の属性値)に応じて、個別データiをどのグループに含めるかを判定する(ステップC4)。すなわち、分類方法指定情報に従って、個別データiに対する分類を行う。本例では、「属性名Aの属性値がThres以上である個別データをグループ1に分類し、属性名Aの属性値がThres未満である個別データをグループ2に分類する。」という分類方法指定情報に従って、個別データiの属性Aの属性値がThres以上であるか否かを判定する。個別データiの属性Aの属性値がThres以上であるならば(すなわち、個別データiをグループ1に分類すると判定したならば)、変数lの値を1に設定する(ステップC5)。また、個別データiの属性Aの属性値がThres未満であるならば(すなわち、個別データiをグループ2に分類すると判定したならば)、変数lの値を2に設定する(ステップC6)。
ステップC5またはステップC6の後、ステップC3で定められたkと、ステップC5またはステップC6で定められたlとの組み合わせに対応するN[k][l]の値を1インクリメントする(ステップC7)。例えば、ステップC5からステップC7に移り、N[k][1]を1インクリメントした場合、k番目のクラスタに属している個別データであって、1番目のグループに属している個別データを一つカウントして、そのカウント値を1増加させたことになる。また、ステップC6からステップC7に移り、N[k][2]を1インクリメントした場合、k番目のクラスタに属している個別データであって、2番目のグループに属している個別データを一つカウントして、そのカウント値を1増加させたことになる。
次に、属性データ分類部31は、変数iの値を1インクリメントする(ステップC8)。そして、属性データ分類部31は、変数iの値が個別データの総数N以下であるか否かを判定し(ステップC9)、iの値がN以下であれば(ステップC9におけるYes)、ステップC3以降の処理を再度行う。従って、1番目からN番目までの各個別データに対してステップC3以降の処理を行うことになり、k番目のクラスタに属している個別データであって、l番目のグループにも属している個別データの数N[k][l]が、k,lの組み合わせ毎に求められる。
iの値がNを超えていれば(ステップC9におけるNo)、ステップC10に移行する。
ステップC10において、関連性算出部32は、N[k][l]を用いて、類似度クラスタリング部による分類と属性データ分類部による分類との独立性を検定し、p値を算出する(ステップC10)。このp値を、分類方法指定情報で指定された属性の関連度とすることができる。
関連性算出部32は、例えば、類似度クラスタリング部21が行った分類と属性データ分類部31が行った分類とが独立であるという仮説によりp値を求める。この場合、関連性算出部32は、まずk,lの各組み合わせに関して、N[k][l]の期待値(E[k][l]と記す)を計算する。上記の仮説のもとでは、関連性算出部32は、以下に示す式(2)の計算によって各N[k][l]の期待値E[k][l]を求めればよい。
Figure 0005391637
そして、N[k][l]およびE[k][l]を用いて、以下に示す式(3)の計算によりχ を計算すると、χ はχ分布に従う。
Figure 0005391637
そこで、関連性算出部32は、式(3)の計算によりχ を求め、χ分布表を参照してp値を決定すればよい。このp値が、分類方法指定情報で指定された属性の関連度である。なお、χ分布表は、例えば、予めデータ類似度計算システム30が備える記憶装置(図示せず)に記憶させておけばよい。
χ分布表からp値を決定する際に用いる自由度は、類似度クラスタリング部21によって分類されるクラスタ数−1である。従って、本例では、クラスタ数=2であるので、自由度は、2−1=1とすればよい。
図10は、χ分布表の例を示す説明図である。図10では、自由度をνで表し、ν=1,2,3の場合を例示しているが、ν=4以上の場合も含めておく。図10に示すχ分布表の最上段の値「0.7」、「0.5」、「0.3」、「0.2」、「0.1」等はp値である。例えば、式(3)でχ を計算した結果、関連性算出部32は、χ ≒1.07であったとする。本例では、χ は、自由度1のχ分布に従うので、自由度1におけるχ ≒1.07に応じたp値“0.3”をχ分布表から特定し、そのp値“0.3”を、類似度算出に対する属性Aの関連度とすればよい。
以上のように、属性Aの関連度を求めることができる。他の属性の関連度も、分類方法指定情報を入力して求めることができる。
また、関連性算出部32は、例えば、χ を計算した後に以下に示す式(4)の計算を行って、クラメールの関連係数を求め、そのクラメールの関連係数を、類似度算出に対する属性の関連度としてもよい。
Figure 0005391637
クラメールの連関係数は、0から1までの数値であり、1に近いほど強く関連していることを示す。
また、関連性算出部32が類似度算出に対する属性の関連度を求めた後、その属性の関連度を、ディスプレイ装置またはプリンタ装置等の出力装置(図示せず)に出力させてから、終了してもよい。ユーザが入力装置(図示せず)を介して、属性を指定した分類方法指定情報を入力し、データ類似度計算システム30がその属性の関連を求めてもよい。そして、関連性算出部32は、そのようにして求めた各属性の関連度をディスプレイ装置またはプリンタ装置等の出力装置(図示せず)に出力させる際、表形式やグラフ形式で出力させてもよい。
次に、第3の実施形態の効果について説明する。
本発明によれば、類似度によるクラスタリングと属性値との関連の度合いを調べることができる。例えば、商品またはサービスに対する顧客の行動に応じて算出した類似度によるクラスタリングと属性値との関連を調べることができる。具体例を挙げると、例えば、類似度によるクラスタリングと男女(性別)との関連性が高いかどうかを調べることができ、商品またはサービスに対する顧客の行動に応じて、顧客を分類する際に関連のある顧客の特徴や販売条件を抽出することができる。これにより、商品またはサービスの今後ターゲットとすべき顧客等を分析することができる。
次に、本発明の概要について説明する。図11は、本発明の概要を示すブロック図である。本発明のデータ類似度計算システム80は、部分集合生成手段81と、分類器生成手段82と、クラス判定手段83と、類似度算出手段84とを備える。
部分集合生成手段81(例えば、部分集合生成部11)は、データの特徴を示す属性とデータの類別を示すクラスとを含むデータの集合から、データの重複を許してその集合の部分集合を複数回生成する。
分類器生成手段82(例えば、分類器生成部12)は、部分集合が生成される毎に、属性からクラスを判定するルールである分類器(例えば、決定木)を、部分集合に基づいて生成する。
クラス判定手段83(例えば、自己評価部13)は、分類器が生成される毎に、分類器を用いて、部分集合に属する個々のデータのクラスを判定する。
類似度算出手段84(例えば、類似度算出部14)は、データの集合の部分集合が生成され、クラス判定手段がその部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ同士の類似度に値を加算する。
本発明によれば、データの重複を許して、データの集合から部分集合を複数回生成し、部分集合毎に、分類器を生成して、部分集合に属するデータのクラスを判定する。そして、この判定結果を用いて類似度を計算するので、データ中に互いに関連のある属性が多く存在してもそれらの関連のある属性の影響を強く受けることなく、データの類似度を求めることができる。
また、上記の実施形態には、データ同士の類似度に基づいて、データの集合に属するデータを複数のグループに分類するデータグループ化手段(例えば、類似度クラスタリング部21)を備える構成が開示されている。そのような構成によれば、データの集合に含まれる個別データを分類することができる。
また、上記の実施形態には、データグループ化手段が、データの集合に属する個々のデータをそれぞれ別々のグループに分類し、互いに異なる二つのグループに属するデータ同士の類似度を求め、類似度が最大となる二つのグループを併合することを繰り返し、グループの総数を目標数まで減少させる構成が開示されている。そのような構成によれば、データの集合に含まれる個別データを目標数のグループに分類することができる。
また、上記の実施形態には、データ集合に属するデータを、特定の属性の属性値に応じて、グループに分類する属性データ分類手段(属性データ分類部31)と、データグループ化手段によって分類されたデータのグループと、属性データ分類手段によって分類されたデータのグループとの関係に基づいて、類似度算出に対する特定の属性の関連度を計算する関連度計算手段(関連性算出部32)とを備える構成が開示されている。そのような構成によれば、類似度を用いて分類を行った結果と属性値との関連の度合いを調べることができる。
また、上記の実施形態には、部分集合生成手段81が、データの集合からデータをランダムサンプリングすることによって、集合の部分集合を生成する構成が開示されている。
また、上記の実施形態には、類似度算出手段84が、クラス判定手段83によって特定のクラスと判定されたデータ同士の類似度に対してのみ値を加算する構成が開示されている。そのような構成によれば、特定のクラスのデータの持つ特徴の違いを重視して類似度を算出できる。
また、上記の実施形態には、分類器生成手段82が、部分集合に属するデータのうち所与のクラスが特定のクラスであるデータを加重して分類器を生成する構成が開示されている。そのような構成によれば、得られた類似度に基づいてデータを分類するときに、特定のクラス以外のクラスのデータが持つ特徴の違いを重視してグループに分類することができる。
また、上記の実施形態には、部分集合生成手段81が、少なくとも顧客の特徴または販売条件を属性とし顧客の行動をクラスとするデータの集合から、その集合の部分集合を生成する構成が開示されている。
本発明は、データの集合に属する各データ間の類似度を求めるデータ類似度計算システムや、データ間の類似度を計算してデータを分類する分類システムに好適に適用される。
本発明の第1の実施形態の例を示すブロック図である。 データの例を示す説明図である。 第1の実施形態のデータ類似度計算システムの処理経過の例を示すフローチャートである。 分類器の例を示す説明図である。 分類器から判定されたクラスの例を示す説明図である。 本発明の第2の実施形態の例を示すブロック図である。 最短距離法によって個別データをクラスタリングする処理経過の例を示すフローチャートである。 本発明の第3の実施形態の例を示すブロック図である。 属性の関連度を求める動作の例を示すフローチャートである。 χ分布表の例を示す説明図である。 本発明の概要を示すブロック図である。 データの例を示す説明図である。
符号の説明
11 部分集合生成部
12 分類器生成部
13 自己評価部
14 類似度算出部
21 類似度クラスタリング部
31 属性データ分類部
32 関連性算出部

Claims (24)

  1. データの特徴を示す属性とデータの類別を示すクラスとを含むデータの集合から、データの重複を許して前記集合の部分集合を複数回生成する部分集合生成手段と、
    部分集合が生成される毎に、属性からクラスを判定するルールである分類器を、前記部分集合に基づいて生成する分類器生成手段と、
    分類器が生成される毎に、分類器を用いて、前記部分集合に属する個々のデータのクラスを判定するクラス判定手段と、
    データの集合の部分集合が生成され、クラス判定手段が当該部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ同士の類似度に値を加算する類似度算出手段とを備える
    ことを特徴とするデータ類似度計算システム。
  2. データ同士の類似度に基づいて、データの集合に属するデータを複数のグループに分類するデータグループ化手段を備える
    請求項1に記載のデータ類似度計算システム。
  3. データグループ化手段は、データの集合に属する個々のデータをそれぞれ別々のグループに分類し、互いに異なる二つのグループに属するデータ同士の類似度を求め、前記類似度が最大となる二つのグループを併合することを繰り返し、グループの総数を目標数まで減少させる
    請求項2に記載のデータ類似度計算システム。
  4. データ集合に属するデータを、特定の属性の属性値に応じて、グループに分類する属性データ分類手段と、
    データグループ化手段によって分類されたデータのグループと、属性データ分類手段によって分類されたデータのグループとの関係に基づいて、類似度算出に対する前記特定の属性の関連度を計算する関連度計算手段とを備える
    請求項2または請求項3に記載のデータ類似度計算システム。
  5. 部分集合生成手段は、データの集合からデータをランダムサンプリングすることによって、前記集合の部分集合を生成する
    請求項1から請求項4のうちのいずれか1項に記載のデータ類似度計算システム。
  6. 類似度算出手段は、クラス判定手段によって特定のクラスと判定されたデータ同士の類似度に対してのみ値を加算する
    請求項1から請求項5のうちのいずれか1項に記載のデータ類似度計算システム。
  7. 分類器生成手段は、部分集合に属するデータのうち所与のクラスが特定のクラスであるデータを加重して分類器を生成する
    請求項1から請求項6のうちのいずれか1項に記載のデータ類似度計算システム。
  8. 部分集合生成手段は、少なくとも顧客の特徴または販売条件を属性とし顧客の行動をクラスとするデータの集合から、当該集合の部分集合を生成する
    請求項1から請求項7のうちのいずれか1項に記載のデータ類似度計算システム。
  9. 部分集合生成手段が、データの特徴を示す属性とデータの類別を示すクラスとを含むデータの集合から、データの重複を許して前記集合の部分集合を複数回生成する部分集合生成ステップと、
    分類器生成手段が、部分集合が生成される毎に、属性からクラスを判定するルールである分類器を、前記部分集合に基づいて生成する分類器生成ステップと、
    クラス判定手段が、分類器が生成される毎に、分類器を用いて、前記部分集合に属する個々のデータのクラスを判定するクラス判定ステップと、
    類似度算出手段が、データの集合の部分集合が生成され、クラス判定ステップで当該部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ同士の類似度に値を加算する類似度算出ステップとを含む
    ことを特徴とするデータ類似度計算方法。
  10. データグループ化手段が、データ同士の類似度に基づいて、データの集合に属するデータを複数のグループに分類するデータグループ化ステップを含む
    請求項9に記載のデータ類似度計算方法。
  11. データグループ化手段が、データグループ化ステップで、データの集合に属する個々のデータをそれぞれ別々のグループに分類し、互いに異なる二つのグループに属するデータ同士の類似度を求め、前記類似度が最大となる二つのグループを併合することを繰り返し、グループの総数を目標数まで減少させる
    請求項10に記載のデータ類似度計算方法。
  12. 属性データ分類手段が、データ集合に属するデータを、特定の属性の属性値に応じて、グループに分類する属性データ分類ステップと、
    関連度計算手段が、データグループ化ステップで分類されたデータのグループと、属性データ分類ステップで分類されたデータのグループとの関係に基づいて、類似度算出に対する前記特定の属性の関連度を計算する関連度計算ステップとを備える
    請求項10または請求項11に記載のデータ類似度計算方法。
  13. 部分集合生成手段が、部分集合生成ステップで、データの集合からデータをランダムサンプリングすることによって、前記集合の部分集合を生成する
    請求項9から請求項12のうちのいずれか1項に記載のデータ類似度計算方法。
  14. 類似度算出手段が、類似度算出ステップで、クラス判定ステップで特定のクラスと判定されたデータ同士の類似度に対してのみ値を加算する
    請求項9から請求項13のうちのいずれか1項に記載のデータ類似度計算方法。
  15. 分類器生成手段が、分類器生成ステップで、部分集合に属するデータのうち所与のクラスが特定のクラスであるデータを加重して分類器を生成する
    請求項9から請求項14のうちのいずれか1項に記載のデータ類似度計算方法。
  16. 部分集合生成手段が、部分集合生成ステップで、少なくとも顧客の特徴または販売条件を属性とし顧客の行動をクラスとするデータの集合から、当該集合の部分集合を生成する
    請求項9から請求項15のうちのいずれか1項に記載のデータ類似度計算方法。
  17. コンピュータに、
    データの特徴を示す属性とデータの類別を示すクラスとを含むデータの集合から、データの重複を許して前記集合の部分集合を複数回生成する部分集合生成処理、
    部分集合が生成される毎に、属性からクラスを判定するルールである分類器を、前記部分集合に基づいて生成する分類器生成処理、
    分類器が生成される毎に、分類器を用いて、前記部分集合に属する個々のデータのクラスを判定するクラス判定処理、および、
    データの集合の部分集合が生成され、クラス判定処理で当該部分集合に属する個々のデータのクラスを判定したときに、同一のクラスと判定されたデータ同士の類似度に値を加算する類似度算出処理
    を実行させるためのデータ類似度計算プログラム。
  18. コンピュータに、
    データ同士の類似度に基づいて、データの集合に属するデータを複数のグループに分類するデータグループ化処理
    を実行させる請求項17に記載のデータ類似度計算プログラム。
  19. コンピュータに、
    データグループ化処理で、データの集合に属する個々のデータをそれぞれ別々のグループに分類させ、互いに異なる二つのグループに属するデータ同士の類似度を求めさせ、前記類似度が最大となる二つのグループを併合することを繰り返させ、グループの総数を目標数まで減少させる
    請求項18に記載のデータ類似度計算プログラム。
  20. コンピュータに、
    データ集合に属するデータを、特定の属性の属性値に応じて、グループに分類する属性データ分類処理、および、
    データグループ化処理で分類されたデータのグループと、属性データ分類処理で分類されたデータのグループとの関係に基づいて、類似度算出に対する前記特定の属性の関連度を計算する関連度計算処理
    を実行させる請求項18または請求項19に記載のデータ類似度計算プログラム。
  21. コンピュータに、
    部分集合生成処理で、データの集合からデータをランダムサンプリングすることによって、前記集合の部分集合を生成させる
    請求項17から請求項20のうちのいずれか1項に記載のデータ類似度計算プログラム。
  22. コンピュータに、
    類似度算出処理で、クラス判定処理で特定のクラスと判定されたデータ同士の類似度に対してのみ値を加算させる
    請求項17から請求項21のうちのいずれか1項に記載のデータ類似度計算プログラム。
  23. コンピュータに、
    分類器生成処理で、部分集合に属するデータのうち所与のクラスが特定のクラスであるデータを加重して分類器を生成させる
    請求項17から請求項22のうちのいずれか1項に記載のデータ類似度計算プログラム。
  24. コンピュータに、
    部分集合生成処理で、少なくとも顧客の特徴または販売条件を属性とし顧客の行動をクラスとするデータの集合から、当該集合の部分集合を生成させる
    請求項17から請求項23のうちのいずれか1項に記載のデータ類似度計算プログラム。
JP2008264442A 2008-10-10 2008-10-10 データ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラム Expired - Fee Related JP5391637B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2008264442A JP5391637B2 (ja) 2008-10-10 2008-10-10 データ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラム

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2008264442A JP5391637B2 (ja) 2008-10-10 2008-10-10 データ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラム

Publications (2)

Publication Number Publication Date
JP2010092432A JP2010092432A (ja) 2010-04-22
JP5391637B2 true JP5391637B2 (ja) 2014-01-15

Family

ID=42255051

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2008264442A Expired - Fee Related JP5391637B2 (ja) 2008-10-10 2008-10-10 データ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラム

Country Status (1)

Country Link
JP (1) JP5391637B2 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11907991B2 (en) 2018-08-21 2024-02-20 Walmart Apollo, Llc Method and system for item line assignment

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2016139939A1 (ja) * 2015-03-03 2016-09-09 日本電気株式会社 分析装置、分析方法及びコンピュータ読み取り可能記録媒体
JP6670572B2 (ja) * 2015-09-29 2020-03-25 株式会社エヌ・ティ・ティ・データ 情報処理装置、情報処理方法、およびプログラム
WO2017122437A1 (ja) * 2016-01-12 2017-07-20 ソニー株式会社 情報処理装置、情報処理システム、および情報処理方法、並びにプログラム
JP6538762B2 (ja) * 2017-06-27 2019-07-03 株式会社東芝 類似度計算装置及び類似度計算方法
JP6637206B1 (ja) * 2019-03-20 2020-01-29 株式会社 日立産業制御ソリューションズ クラスタ分割評価装置、クラスタ分割評価方法及びクラスタ分割評価プログラム
CN111026966B (zh) * 2019-12-06 2023-12-22 创新奇智(成都)科技有限公司 基于用户和产品画像及两者关联程度的搜索推荐排序方法

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2002149697A (ja) * 2000-11-07 2002-05-24 Mitsubishi Electric Corp 類似事例検索装置
JP2005078240A (ja) * 2003-08-29 2005-03-24 Mamoru Tanaka データマイニングによる知識抽出法
JP4041081B2 (ja) * 2004-03-23 2008-01-30 東芝ソリューション株式会社 分割クラスタリング装置及び分割データ数決定方法

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11907991B2 (en) 2018-08-21 2024-02-20 Walmart Apollo, Llc Method and system for item line assignment

Also Published As

Publication number Publication date
JP2010092432A (ja) 2010-04-22

Similar Documents

Publication Publication Date Title
US20220391767A1 (en) System and method for relational time series learning with the aid of a digital computer
JP5391637B2 (ja) データ類似度計算システム、データ類似度計算方法およびデータ類似度計算プログラム
CN108898479B (zh) 信用评价模型的构建方法及装置
US20080097937A1 (en) Distributed method for integrating data mining and text categorization techniques
Kim et al. Ordinal classification of imbalanced data with application in emergency and disaster information services
JP5104496B2 (ja) 普及予測システム、方法およびプログラム、並びに影響度推定システム、方法およびプログラム
CN112559900B (zh) 产品推荐方法、装置、计算机设备和存储介质
US6563952B1 (en) Method and apparatus for classification of high dimensional data
Alghobiri A comparative analysis of classification algorithms on diverse datasets
Lumauag et al. An enhanced recommendation algorithm based on modified user-based collaborative filtering
Hadju et al. Sentiment analysis of indonesian e-commerce product reviews using support vector machine based term frequency inverse document frequency
AL-Bakri et al. Multi label restaurant classification using support vector machine
US12095781B2 (en) Hidden Markov model based data ranking for enhancement of classifier performance to classify imbalanced dataset
CN111309577A (zh) 一种面向Spark的批处理应用执行时间预测模型构建方法
US7272583B2 (en) Using supervised classifiers with unsupervised data
TW201011575A (en) Recommendation apparatus and method of integrating rough sets and multiple-characteristic exploration
CN113837266A (zh) 一种基于特征提取和Stacking集成学习的软件缺陷预测方法
JP4194697B2 (ja) 分類ルール探求式クラスター分析装置
CN117708222A (zh) 面向客户细分的关联规则挖掘方法
Deng et al. Sampling method based on improved C4. 5 decision tree and its application in prediction of telecom customer churn
CN111753992A (zh) 筛选方法和筛选系统
JP4234841B2 (ja) データ分析装置
KR102299618B1 (ko) 리뷰 광고 매칭 장치 및 방법
CN113962565A (zh) 一种基于大数据的项目评分方法、系统和可读存储介质
Romeu On operations research and statistics techniques: Keys to quantitative data mining

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20110908

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20130307

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20130319

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130513

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20130930

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

LAPS Cancellation because of no payment of annual fees