JP2010231675A - コード列検索装置、検索方法及びプログラム - Google Patents

コード列検索装置、検索方法及びプログラム Download PDF

Info

Publication number
JP2010231675A
JP2010231675A JP2009080726A JP2009080726A JP2010231675A JP 2010231675 A JP2010231675 A JP 2010231675A JP 2009080726 A JP2009080726 A JP 2009080726A JP 2009080726 A JP2009080726 A JP 2009080726A JP 2010231675 A JP2010231675 A JP 2010231675A
Authority
JP
Japan
Prior art keywords
code
search
string
code string
range
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
JP2009080726A
Other languages
English (en)
Other versions
JP4464459B1 (ja
Inventor
Toshio Shinjo
敏男 新庄
Mitsuhiro Kokubu
光裕 國分
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.)
S Grants Co Ltd
Original Assignee
S Grants Co Ltd
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 S Grants Co Ltd filed Critical S Grants Co Ltd
Priority to JP2009080726A priority Critical patent/JP4464459B1/ja
Priority to PCT/JP2009/006922 priority patent/WO2010116435A1/ja
Priority to EP09842945A priority patent/EP2416258A4/en
Priority to CN2009801595558A priority patent/CN102449624B/zh
Application granted granted Critical
Publication of JP4464459B1 publication Critical patent/JP4464459B1/ja
Publication of JP2010231675A publication Critical patent/JP2010231675A/ja
Priority to US13/064,487 priority patent/US9009655B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/903Querying
    • G06F16/90335Query processing
    • G06F16/90344Query processing by using string matching techniques

Landscapes

  • Engineering & Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Computational Linguistics (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

【課題】任意のコード列の検索を行うことができ、従来よりも短時間で作成することのできる索引のデータ構造を求め、それを用いたコード列検索手法を提供する。
【解決手段】検索対象のコード列を1コードずつ重複させて複数ブロックに分割し、分割されたコード列ブロックに対してコード毎のコードIDの範囲を格納したコード別ID範囲表と各コードIDの次に位置する次コードIDを格納したID関係表を作成し、コード別ID範囲表から検索コード列を構成するコードのコードIDの範囲を読み出し、検索コード列の先頭コードのコードID範囲に含まれるコードIDに対応して格納された次コードIDをID関係表から読み出し、該次コードに対応して格納された次コードIDを順次ID関係表から読み出すとともに、ID関係表から読み出した次コードIDがコード別ID範囲読出表から読み出したコードIDの範囲に含まれるか照合する。
【選択図】図3A

Description

本発明は、ビット列で構成される文字コードあるいは文字コード列を検索する文字列検索のように、コンピュータにより、ビット列で構成されるコードあるいはコード列を検索するコード列検索に関するものである。
近年、ビジネス文書を作成するためにワードプロセッサを使用することが通例となり、またインターネットが普及したことにより、ビット列からなる文字コードを用いた、コンピュータで処理可能な電子文書が世の中に大量に存在するようになっている。そのため、これら大量の電子文書の中からコンピュータを利用して必要なものを探し出すために、各種の文字列検索手法が開発されている。
これらの文字列検索手法においては、高速な検索を実現するために予め索引を作成することが一般的である。索引としては、例えば、文書中の単語を抽出し、単語毎にそれの含まれている文書名を対応付けた転置インデックスがよく知られている。この転置インデックスはサイズが比較的小さく、検索が高速であり、インデックスの構成も簡単であるという特徴を持っている。しかしながら、単語の抽出が難しい言語もある。また、複数の単語の組み合わせの検索を行おうとすると、文書中の単語位置を突き合わせる処理が必要になるという欠点も存在する。そして、一文中の任意の文字列を検索することも難しい。
そこで、任意の文字列を検索可能とする接尾辞配列という索引が開発されている。下記特許文献1及び非特許文献1には、接尾辞配列とそれを用いた検索手法が開示されている。
図1は、上述の接尾辞配列に関する従来の検索方法の例を説明するものである。図1の(a)に例示するのは、検索対象の文字列である。図に示すように、文字列10は、アルファベットの文字A、B、C、Eと区切り文字$で構成されている。文字Aは文字列10の文字位置1、4、7に位置している。文字Bは文字列10の文字位置2、5に位置している。文字Cは文字列10の文字位置6、8に位置している。文字Eは文字列10の文字位置3に位置している。区切り文字$は、文字列10の末尾の位置である文字位置9に位置している。
図1の(b)に示すのは、文字位置順の接尾辞20、辞書順の接尾辞20a及び接尾辞配列30である。
文字列10は、図1の(b)に示すようにその部分文字列として9の接尾辞を持つと考えることができる。各接尾辞の先頭文字の文字位置順に接尾辞を並べた文字位置順の接尾辞20を辞書順にソートすることにより、辞書順の接尾辞20aが得られる。このとき、辞書順に並べ替えた接尾辞の先頭文字の文字位置を配列に格納することにより、接尾辞配列30が得られる。この接尾辞配列により、検索文字列のパターンと一致する検索対象文字列中の部分文字列の先頭の文字位置を求めることができる。
図1の(c)に示すのは、圧縮接尾辞配列による文字列検索の概念を説明するものであり、検索文字列40と接尾辞配列30に対応する圧縮接尾辞配列(概念図)50が示されている。圧縮接尾辞配列(概念図)50の配列番号(i)には、次の配列番号(Ψ)が格納されている。次の配列番号(Ψ)は、接尾辞配列30の配列番号(i)に格納された文字位置に1を加えた文字位置が格納された接尾辞配列30の配列番号である。
配列に格納するものを文字位置から次の配列番号(Ψ)に変更することにより、文字毎に格納される値は図に示すように昇順になる。したがって、各配列要素に格納する値は次の配列番号(Ψ)そのものではなく1つ前の配列要素に格納された値の増分とすることができるのでビット幅を狭くすることができ、情報量を圧縮することができる。
検索の概念については、例示された検索文字列40の各文字から圧縮接尾辞配列(概念図)50の配列番号(i)への点線の矢印と配列番号(i)の太字で示す3、6、9と次の配列番号(Ψ)の太字で示す6、9との間の矢印の検索ステップで示している。すなわち、検索文字列40の先頭の文字Aに対応する配列番号から例えば3が選ばれ、配列番号3の次の配列番号6が検索文字列40の2番目の文字Bに対応する配列番号であり、配列番号6の次の配列番号9が検索文字列40の3番目の文字Eに対応する配列番号であることにより、検索対象の文字列10が検索文字列40による検索でヒットすることがわかる。
特許第3、672、242号公報
定兼、「圧縮接尾辞に関する考察」、電子情報通信学会技術研究報告(2000-7-19)Vol.100,No.226,p49-56
文字列検索に圧縮接尾辞配列を用いることにより、任意の文字列の検索を行うことができ、配列の容量も削減することができる。しかし、圧縮接尾辞配列を作成するには、その前に検索対象の文字列から接尾辞を作成しその接尾辞を辞書順にソートして接尾辞配列を作成する必要があり、検索対象の文字列から圧縮接尾辞配列を作成する処理時間が大きなものとなる。
そこで本発明の解決しようとする課題は、文字列に限らず、任意のコード列の検索を行うことができる索引データの作成時間を従来のものよりも短縮することである。そして、本発明の目的は、任意のコード列の検索を行うことができ、従来よりも短時間で作成することのできる索引のデータ構造を求め、それを用いたコード列検索手法を提供することである。
本発明によれば、検索対象コード列をいくつかのブロック(以下、コード列ブロックということがある。)に分割する。提案するブロック分割は、隣り合うコード列ブロックの末尾に位置するコードと先頭に位置するコードを重複させるものである。そして、コード列ブロック毎に、コード列ブロックに位置する全ての各コードを一意に識別するコードIDが、異なるコードの値(以下、誤解の恐れのない場合には、単にコードという場合がある。また、逆に異なるコード値であることを強調して、コード種別ということもある。)間でコードIDの範囲が重ならないように、上記全ての各コードに付与されるものとする。例えばコード毎にコード列ブロック中に出現する順に昇順のコードIDを付与することを、コード種別毎に最初のコードIDの値をそれまで付与されたコードIDより大きい値として繰り返すことにより、上記コードIDの付与を実現することができる。
そして本発明によれば、各コード列ブロックに対応してコード毎にそのコードIDの範囲を格納したコード別ID範囲表と各コードIDの次に位置するコードIDである次コードIDを格納したID関係表を作成し、コード別ID範囲表とID関係表を用いてコード列検索を実施する。
本発明の、検索コード列による検索対象コード列のコード列検索によれば、先頭のコード列ブロックのコード別ID範囲表から検索コード列を構成するコードのコードIDの範囲を読み出し、検索コード列の先頭のコードのコードID範囲に含まれるコードIDに対応して格納された次コードIDをコード列ブロック毎に作成されたID関係表から読み出すとともに、該次のコードに対応して格納された次コードIDを順次ID関係表から読み出し、ID関係表から読み出した次コードIDがコード別ID範囲読出表から読み出したコードIDの範囲に含まれるか照合し、この照合を後続のコード列ブロックに対して同様に行う。
本発明によれば、簡単な構造のコード別ID範囲表とID関係表を用いて検索を実施することができるので、接尾辞配列を作成する必要がなく、コンピュータの索引作成の処理負担を小さくすることができる。
接尾辞配列に関する従来の検索方法の例を説明する図である。 本発明の一実施の形態における索引用のデータ構造を作成するための機能ブロックを説明する図である。 本発明の一実施の形態におけるコード列検索のための機能ブロックを説明する図である。 本発明の一実施の形態におけるハードウェア構成例を説明する図である。 本発明の一実施形態における索引データの構造を説明する図である。 本発明の一実施の形態におけるコード列検索の概念を説明する図である。 本発明の一実施形態におけるコード列ブロックの索引データを作成する前段の処理フローを説明する図である。 本発明の一実施形態におけるコード列ブロックの索引データを作成する後段の処理フローを説明する図である。 本発明の一実施形態におけるコード列ブロックの索引データを作成する処理の概略フローを説明する図である。 本発明の一実施形態における検索対象のコード列に含まれるコードのコード種別毎の出現回数を計数する処理フローを説明する図である。 本発明の一実施形態における出現回数をもとにコード別ID範囲表のコードID範囲を設定する処理フローを説明する図である。 本発明の一実施形態における検索対象コード列に含まれるコードをもとにID関係表を完成させる処理フローを説明する図である。 本発明の一実施形態におけるコード列検索の処理全体の概略フローを説明する図である。 本発明の一実施形態における、あるコード列ブロックを検索開始位置とするコード列検索の前段の処理フローを説明する図である。 本発明の一実施形態における、あるコード列ブロックを検索開始位置とするコード列検索の後段の処理フローを説明する図である。 本発明の一実施の形態における完全一致検索の処理フローを説明する図である。 本発明の一実施の形態における前方一致検索の処理フローを説明する図である。 本発明の一実施の形態における任意コードを含む検索の処理フローを説明する図である。 本発明の一実施の形態における次のコード列ブロックの検索の前段の処理フローを説明する図である。 本発明の一実施の形態における次のコード列ブロックの検索の後段の処理フローを説明する図である。 本発明の一実施の形態における先頭のコード列ブロックからの検索の処理の流れを説明する図である。 本発明の一実施の形態における次のコード列ブロックの検索へ移行する流れを説明する図である。 本発明の一実施の形態における先頭から2番目のコード列ブロックからの検索の処理の流れを説明する図である。
以下、本発明を実施するための最良の形態を、図面を参照しながら説明する。
図2Aは、本発明の一実施の形態における索引用のデータ構造を作成するための機能ブロックを説明する図である。索引データ作成管理手段104は、索引データ作成手段105による検索対象コード列を分割したブロック(コード列ブロック)毎の索引データの作成を管理し、索引データ管理表を作成する。索引データ作成手段105は、検索対象コード列読出手段101、コード別ID範囲表生成手段102及びID関係表生成手段103を含む。
検索対象コード列が検索対象コード列読出手段101で読み出され、コード別ID範囲表生成手段102とID関係表生成手段103に渡される。コード別ID範囲表生成手段102は、コード毎にそのコードIDの範囲を格納したコード別ID範囲表を作成し、ID関係表生成手段103は、各コードIDの次に位置するコードIDである次コードIDを格納したID関係表を生成する。
図2Bは、本発明の一実施の形態におけるコード列検索を行うための機能ブロックを説明する図である。コード列検索管理手段115は、コード列検索手段116による検索対象コード列のコード列ブロック毎の検索を管理する。コード列検索手段116は、検索コード列読出手段111、コード別ID範囲読出手段112、ID関係読出手段113及びコードID照合手段114を含む。
検索コード列が検索コード列読出手段111で読み出され、コード別ID範囲読出手段112に渡される。コード別ID範囲読出手段112は、コード別ID範囲表生成手段102で生成されたコード別ID範囲表より、検索コード列読出手段111から渡された検索コード列を構成するコードのコードIDの範囲を読み出してID関係読出手段113とコードID照合手段114に渡す。
ID関係読出手段113は、コード別ID範囲読出手段112から渡された検索コード列の先頭のコードのコードID範囲に含まれるコードIDに対応して格納された次コードIDを、ID関係表生成手段103で生成されたID関係表から読み出すとともに、該次のコードに対応して格納された次コードIDを順次ID関係表から読み出してコードID照合手段114に渡す。
コードID照合手段114は、ID関係読出手段113から渡された次コードIDがコード別ID範囲読出手段から渡されたコードIDの範囲に含まれるか照合し、検索結果を出力する。
図2Cは、本発明の一実施の形態におけるハードウェア構成例を説明する図である。
本発明の検索装置による検索処理及び索引生成処理は中央処理装置302及びキャッシュメモリ303を少なくとも備えたデータ処理装置301によりデータ格納装置308を用いて実施される。索引データ管理表321の格納領域と、コード列ブロックに対応するコード別ID範囲表309とID関係表310を格納する索引データの格納領域324を含むデータ格納装置308は、主記憶装置305または外部記憶装置306で実現することができ、あるいは通信装置307を介して接続された遠方に配置された装置を用いることも可能である。
図2A及び図2Bを参照して説明した索引でデータ検索手段116等の各機能ブロックは、図2Cに例示するハードウェアと後に説明するステップを備えたソフトウェアにより実現可能である。
図2Cの例示では、主記憶装置305、外部記憶装置306及び通信装置307が一本のバス304によりデータ処理装置301に接続されているが、接続方法はこれに限るものではない。また、主記憶装置305をデータ処理装置301内のものとすることもできる。
また、特に図示されてはいないが、処理の途中で得られた各種の値を後の処理で用いるためにそれぞれの処理に応じた一時記憶領域が用いられることは当然である。以下の説明では、一時記憶領域に格納されたあるいは設定された値を一時記憶領域の名前で呼ぶことがある。
次に、本発明の一実施態様における検索手法の概要を説明する。
図3Aは、本発明の一実施の形態における索引データの構造を説明する図である。図3Aの(a)に示すのは、索引データを作成する対象となる検索対象のコード列の例である。例示された検索対象コード列10aは、コードA、B、E、A、B、C、A、・・・、C、Bの英文字の文字コードから構成されている。それぞれの文字コードの下に記載されたP1〜P8、・・・、Pn−1、Pnは、検索対象コード列10aにおけるコードの位置を表している。コード位置ポインタ11は、検索対象コード列10aにおけるコードの位置を示すポインタであり、図の例ではコード位置P1を指している。
図に示す例では、検索対象コード列10aは4つのコード毎に、前方のコード列ブロックの末尾位置のコードと後方のコード列ブロックの先頭位置のコードが重複するように分割されている。したがって、先頭のコード列ブロック15aは、コード列ポインタ11の指すコード位置P1に位置するコードA、コード位置P2に位置するコードB、コード位置P3に位置するコードE、コード位置P4に位置するコードAで構成される。矢印12で示すように、2番目のコード列ブロック15bの先頭位置は、先頭のコード列ブロック15aの末尾位置と等しいP4であり、コードAは先頭のコード列ブロック15aと2番目のコード列ブロック15bの双方に含まれる。2番目のコード列ブロック15bは、図の太線の枠内に示すように、矢印12で示す先頭位置であるコード位置P4に位置するコードA、コード位置P5に位置するコードB、コード位置P6に位置するコードC、矢印13で示す末尾位置であるコード位置P7に位置するコードAで構成される。矢印14で示すコード位置Pnは、終端位置と定義する。最後のコード列ブロックだけは、2つのコードで構成されている。
個々のコード列ブロックに対して、索引データとして、コード別ID範囲表とID関係表が生成される。
図3Aの(b)に示すのは、コード列検索のための索引のデータ構造例であり、図3Aの(a)に示す検索対象コード列とそのコード列ブロックに対応して生成される索引データ管理表321と、先頭のコード列ブロック15aに対応する索引データの格納領域324aに格納されたコード別ID範囲表309aとID関係表310a、2番目のコード列ブロック15bに対応する索引データの格納領域324bに格納されたコード別ID範囲表309bとID関係表310b、3番目のコード列ブロックに対応する索引データの格納領域324c、及び最後のコード列ブロックに対応する索引データの格納領域324dに格納されたコード別ID範囲表309dとID関係表310dが例示されている。索引データの格納領域324cに格納された索引データの表記は省略されている。なお、以下においては、「コード別ID範囲表309」、「ID関係表310」のように表記してコード列ブロックに共通事項を説明することがある。また、他の符号についても同様に表記する場合がある。
コード別ID範囲表309のエントリは、索引データを作成する対象である検索対象コード列に出現する異なるコードの種別毎に作成される。コード別ID範囲表309の左側に表示しているように、図に示す例では、アルファベットのうち、コードA〜Eからなるコード列である検索対象コード列が索引データを作成する対象であり、各コードに対応してエントリが作成されている。コード種別ポインタ311は、コード別ID範囲表309のエントリを指すポインタである。図の先頭のコード列ブロックに対応するコード別ID範囲表309aの例では、コード種別ポインタ311aがコードAに対応するエントリを指している。同様に、2番目のコード列ブロックに対応するコード別ID範囲表309bの例では、コード種別ポインタ311bがコードAに対応するエントリを指している。また、最後のコード列ブロックに対応するコード別ID範囲表309dの例では、コード種別ポインタ311dがコードAに対応するエントリを指している。
なお、各コードはビット列で構成されることから、そのビット列のビット値により表現される値を持つ。したがって、コード別ID範囲表309の各コードに対応するエントリの位置は各コードの値と対応付けることができることは明らかである。つまり、コード種別ポインタ311のとる値をコードそのものとすることもできる。そこで、以下の説明においては、各コードに対応するエントリを、各コードの指すエントリと表記することがある。
コード別ID範囲表309aの下側に表示しているように、コード別ID範囲表309aのエントリは、設定表示、出現回数、先頭コードID、末尾コードID、コード別IDカウンタの項目で構成されている。
設定表示は、対応するコード列ブロックにそのコードが出現するかを1あるいは0で示すものである。コード別ID範囲表309aの例では、先頭のコード列ブロックにはコードCとコードDが出現しないので、コードCとコードDのエントリは0であり、他のエントリは1である。コード別ID範囲表309bの例では、2番目のコード列ブロックにはコードDとコードEが出現しないので、コードDとコードEのエントリは0であり、他のエントリは1である。コード別ID範囲表309Dの例では、最後のコード列ブロックにはコードBとコードCしか出現しないので、コードBとコードCのエントリは1であり、他のエントリは0である。
出現回数は、対応するコード列ブロックにそのコードが出現する回数である。コード別ID範囲表309aの例では、コードAからコードEに対して、2、1、0、0、1が格納されている。コード別ID範囲表309bの例では、コードAからコードEに対して、2、1、1、0、0が格納されている。コード別ID範囲表309dの例では、コードAからコードEに対して、0、1、1、0、0が格納されている。
先頭コードID及び末尾コードIDは、コード別のコードIDの範囲を示すものである。コードIDは、コード間で重ならないように、コード毎にコード列ブロック中の出現順に付与されたものである。
コード別ID範囲表309aの例では、コードAについては出現回数が2であるのでコードIDの範囲はID1からID2であり、次のコードBについては出現回数が1であるので先頭コードと末尾コードは共にID3である。コードC及びコードDについては出現回数が0であるから、先頭コードIDと末尾コードIDは共に未設定である。コードEについては出現回数が1であるので先頭コードと末尾コードは共にID4である。
以下同様に、コード別ID範囲表309bの例では、コードAの先頭コードはID1、末尾コードはID2であり、コードBの先頭コードと末尾コードは共にID3、コードCの先頭コードと末尾コードは共にID4である。
また、コード別ID範囲表309dの例では、コードBの先頭コードと末尾コードは共にID1、コードCの先頭コードと末尾コードは共にID2である。
なお、ID1等の値は具体的には1から始まる整数値とすることが好適であるが、それに限ることなく、コード別のID範囲を識別することのできるものであればよい。また、図の例では、コードIDの範囲を先頭コードIDと末尾コードIDで示しているが、可変長データとなることをいとわなければ、すべてのコードIDを列挙することで示すこともできる。
コード別IDカウンタは、コード別ID範囲表を生成したのちID関係表を生成するときに必要なカウンタであり、索引データとして必要なものではない。したがって、異なるコードの種別毎にコード別ID範囲表とは別のカウンタとして設けることもできる。
ID関係表310のエントリは、コード列ブロックのコードに対してつけられたコードID毎に作成される。ID関係表310の左側に表示しているように、図に示す例では最後のコード列ブロックのリンク表310dを除いて、コードID1〜コードID4に対応してエントリが作成されている。各エントリは、コード位置と次コードIDの項目から構成されている。コードIDポインタ312は、ID関係表310のエントリを指すポインタであり、図の例では、いずれのID関係表310においてもID1を指している。
各コードIDのエントリのコード位置は、そのコードIDのコードの位置する検索対象コード列10aにおけるコード位置である。ID関係表310aでは、ID1に対してP1、ID2に対してP4、ID3に対してP2、ID4に対してP3が格納されている。
図の点線の矢印313a(A)で示すように、ID関係表310aの1〜2番目のエントリはコードAに対応するものである。同様に、点線の矢印313a(B)で示すように、3番目のエントリはコードBに、点線の矢印313a(E)で示すように、4番目のエントリはコードEに対応する。
各コードIDのエントリの次コードIDは、コード列ブロックにおけるそのコードIDのコードの次に位置するコードのコードIDである。なお、コード列ブロックの末尾位置のコードに対しては、先頭位置のコードのコードIDが格納される。したがって、ID関係表310aでは、次コードIDとして、ID1に対してID3、ID2に対してID1、ID3に対してID4、ID4に対してID2が格納されている。
ID関係表310bでは、ID1に対してP4、ID2に対してP7、ID3に対してP5、ID4に対してP3が格納されている。
図の点線の矢印313b(A)で示すように、ID関係表310bの1〜2番目のエントリはコードAに対応するものである。同様に、点線の矢印313b(B)で示すように、3番目のエントリはコードBに、点線の矢印313b(C)で示すように、4番目のエントリはコードCに対応する。
また、次コードIDとして、ID1に対してID3、ID2に対してID1、ID3に対してID4、ID4に対してID2が格納されている。
ID関係表310dでは、ID1に対してPn、ID2に対してPn−1が格納されている。
図の点線の矢印313d(B)で示すように、ID関係表310dの1番目のエントリはコードBに対応するものである。同様に、点線の矢印313d(C)で示すように、2番目のエントリはコードCに対応する。
また、次コードIDとして、ID1に対してID2、ID2に対してID1が格納されている。
ID関係表310は、コードIDで表した2つのコードがコード列ブロックにおいて連続した位置関係にあることを索引データとして保持している。前方のコード列ブロックの末尾位置のコードと後方のコード列ブロックの先頭位置のコードの重複関係は、索引データ管理表321に各コード列ブロックの先頭コードIDをもつことで管理される。
図に示すように、索引データ管理表321は、コード列ブロック毎のエントリを有し、各エントリは設定表示、先頭コードID、索引データポインタの項目から構成されている。索引データ管理ポインタ322は、索引データ管理表のエントリを指すポインタである。図の例では、索引データ管理ポインタ322は、先頭のコード列ブロック15aに対応するエントリ1を指している。
索引データ管理表321の設定表示には、エントリ1からエントリmまで1が設定され、それ以外のエントリの設定表示は0である。エントリmは最後のコード列ブロックに対応するものである。また、索引データ管理表321の先頭コードIDとして、エントリ1にはID1が、エントリ2にはID1が、エントリmにはID2が設定されている。
索引データポインタは、点線の矢印344a、344b、344c、344dが示すように、それぞれ対応するコード列ブロックの索引データの格納領域324a、324b、324c、324dを指している。
ID関係表310を図1の(c)に示す従来例の圧縮接尾辞配列50と比較すると、圧縮接尾辞配列50では文字毎に次の配列番号がソートされているのに対して、ID関係表310では異なるコードの種別毎にコード位置がソートされている。したがって、同一コードを逐次検索する場合には、キャッシュ効果により高速化を図ることができる。
図3Bは、本発明の一実施の形態におけるコード列検索の概念を説明する図である。
検索対象コード列は、図3Aに例示した検索対象コード列10aとし、図3Aに示すようにコード列ブロックに分割されているものとする。また、検索コード列は図3Bに示す検索コード列40aとして、コード列検索の概念を説明する。検索対象コード列10aのコード列ブロックに対応して、コード別ID範囲表309とID関係表310が生成されており、また索引データ管理表321が生成されているものとする。
検索を開始する前に、矢印348aで示す索引データ管理表の先頭のエントリ321(1)が読み出され、点線の矢印344aが示すように索引データポインタ342aにより索引データの格納領域324a内に格納されたコード別ID範囲表309aとID関係表310aが取得される。さらに、点線の矢印345aで示すように、先頭コードID341aに格納されたID1が読み出されて、一時記憶領域である先頭コードID346aに設定されている。
検索コード列40aには、図に示すように、先頭からコードE、コードA、コードB、コードCが位置している。そこで、図に点線の矢印331aで示すように、1番目のコード332aであるコードEが読み出される。次に点線の矢印333aで示すように、先頭のコード列ブロックに対応するコード別ID範囲表309aのコードEに対応するエントリ309a(E)が読み出される。(もし、先頭のコード列ブロックに検索コード列40aの先頭のコードが存在しなければ、その先頭のコードが存在するコード列ブロックに対応する索引データまで読み飛ばす。)
そして点線の矢印334aで示すように、エントリ309a(E)からID範囲336aに含まれるコードID、図の例ではコードID4が読み出され、読み出されたコードID4に対応するエントリ310a(4)がID関係表310aから読み出される。
一方、コード列ID範囲表309aに設定されている先頭のコードであるコードAの先頭コード、ID1が一時記憶領域である先頭コードID346aに設定されている。
そして、双方向の点線の矢印347aで示すように、コードID4に対応するエントリ310a(4)の次コードIDであるID2と先頭コードID346aに設定されているID1が比較され、次コードIDは先頭コードID以外であると判定される。
次に点線の矢印331bで示すように、2番目のコード332bであるコードAが読み出される。先に述べた双方向の点線の矢印347aでの判定が先頭コードID以外であったことから、点線の矢印333bで示すように、1番目のコードEの場合と同じコード別ID範囲表309aのコードAに対応するエントリ309a(A)が読み出される。そして、双方向の点線の矢印335bで示すように、ID関係表310aのコードID4に対応するエントリ310a(4)の次コードID337aであるID2が、コード別ID範囲表309aのコードAに対応するエントリ309a(A)のコードIDの範囲336b(ID1〜ID2)に含まれるかを判定する。図の例では、この判定はイエスになる。このことは、コードE、コードAのコードの並びが、検索対象コード列10aの先頭のコード列ブロックに存在することを意味している。また、ID関係表310aから読み出されたコードID4に対応するエントリ310a(4)のコード位置338aがP3であることから、そのコードE、コードAのコードの並びの先頭位置がP3であることが分かる。
さらに点線の矢印334bで示すように、次コードID337aであるID2に対応するエントリ310a(2)の次コードID337bであるID1が読み出される。そして、双方向の点線の矢印347bに示すように、この読み出されたID1と、先に先頭コードID346aに設定されたID1の比較がおこなわれ、次コードIDと先頭コードIDが等しいことが判定される。すなわち、2番目のコード332bであるコードAと照合する先頭のコード列ブロックのコードID2のコードAは、先頭のコード列ブロックの末尾位置に位置するものであることが判定される。
すると、点線の矢印348bで示すように索引データ管理表の2番目のエントリ321(2)が読み出され、点線の矢印344bが示すように索引データポインタ342bにより索引データの格納領域324bがアクセスされ、コード別ID範囲表309bとID関係表310bが取得される。
また、索引データ管理表の2番目のエントリ321(2)の先頭コードID341bに格納されたID1が点線の矢印345bで示すように一時記憶領域である先頭コードID346bに設定される。そして、点線の矢印334cで示すように、先頭コードID346bに設定されたID1に対応するエントリ310b(1)がID関係表310bから読み出される。
一方、点線の矢印331cで示すようにコードBが3番目のコード332cとして読み出されると、点線の矢印333cで示すように、コード別ID範囲表309bのコードBに対応するエントリ309b(B)が読み出される。そして、双方向の点線の矢印335cで示すように、ID関係表310bのコードID1に対応するエントリ310b(1)の次コードID337cであるID3が、コード別ID範囲表309bのコードBに対応するエントリ309b(B)のコードIDの範囲336c(ID3〜ID3)に含まれるかを判定する。図の例では、この判定はイエスになる。したがって、検索対象コード列10aは検索コード列EABでヒットすることがわかる。
この判定に続いて、点線の矢印334dで示すように、次コードID337cであるID3に対応するエントリ310b(3)の次コードID337dであるID4が読み出される。そして、双方向の点線の矢印347dに示すように、この読み出されたID1と、先に先頭コードID346bに設定されたID1の比較がおこなわれ、次コードIDと先頭コードIDが等しくないことが判定される。
そこで、次に点線の矢印331dで示すように、4番目のコード332dであるコードCが読み出される。また、点線の矢印333dで示すように、3番目のコードBの場合と同じコード別ID範囲表309bのコードCに対応するエントリ309b(C)が読み出される。そして、双方向の点線の矢印335dで示すように、ID関係表310bのコードID3に対応するエントリ310b(3)の次コードID337dであるID4が、点線の矢印333dで示すコードCに対応するエントリ309b(C)のコードIDの範囲336d(ID4〜ID4)に含まれるかを判定する。図の例では、この判定はイエスになることから、検索対象コード列10aは検索コード列EABCでヒットすることがわかる。
この判定に続いて、点線の矢印334eで示すように、次コードID337dであるID4に対応するエントリ310b(4)の次コードID337eであるID2が読み出される。そして、双方向の点線の矢印347eに示すように、この読み出されたID2と、先に先頭コードID346bに設定されたID1の比較がおこなわれ、次コードIDと先頭コードIDが等しくないことが判定される。
そして、ID関係表310aから読み出されたコードID2に対応するエントリ310a(2)のコード位置338bがP4であること、ID関係表310bから読み出されたコードID3に対応するエントリ310b(3)のコード位置338dはP5であること、コードID4に対応するエントリ310b(4)のコード位置338eはP6であることから、上述のヒット位置はコード位置P3、P4、P5、P6であることが分かる。
検索コード列40aの図示しない5番目のコードについても、点線の矢印334fに示すように、次コードID337eであるID2に対応するID関係表310のエントリの次コードIDが読み出され、5番目のコードのコード種別の指すコード別ID範囲表309のエントリのコードIDの範囲内であるかの判定等が繰り返される。
以上のようにして、本発明の一実施の形態によるコード列検索が実施される。
次に、本発明の一実施の形態における索引データの作成処理を説明する。索引データは、図3Aの(b)に例示するように、索引データ管理表と、各コード列ブロックに対応する索引データの格納領域に格納されるコード別ID管理表とID関係表から構成される。
図4A及び図4Bは、本発明の一実施形態における索引データを作成する処理のフローを説明する図である。図4A及び図4Bに示す索引データの作成処理フローは、初期処理のものと、各コード列ブロックに対応する索引データ(以下、各コード列ブロックに対応するブロック索引データ、あるいは単にブロック索引データということがある。)の作成処理を順次実行するフローから構成される。
図4Aは、本発明の一実施形態における索引データを作成する処理、すなわち、各コード列ブロックに対応するブロック索引データを順次作成する処理の前段の処理フローを説明する図である。この前段の処理は、先に述べた初期処理である。
図4Aに示すように、ステップS401において、検索対象コード列を設定する。検索対象コード列の設定は、データ格納装置に格納された検索対象となるコード列の集合から、1つのコード列を図2Aに例示する検索対象コード列読出手段111で読み出して、図示しない検索対象コード列設定エリアに設定することを意味する。なお、上述の検索対象コード列設定エリアは、先に述べた「処理の途中で得られた各種の値を後の処理で用いるためにそれぞれの処理に応じた一時記憶装置」の1つである。以下の説明では、「図示しない検索対象コード列設定エリアに設定する」のような表現に変えて、「検索対象コード列として設定する」あるいは単に「検索対象コード列に設定する」のように記述することもある。検索対象コード列以外についても同様である。
次にステップS402において、索引データ管理表の格納領域を取得するとともに、索引データ管理ポインタを索引データ管理表の先頭エントリに位置付ける。ステップS403に進み、検索対象コード列を分割したコード列ブロックの最大コード数を設定する。図3Aに示す例では、最大コード数は4である。次のステップS404では、コード列の先頭位置に、検索対象のコード位置の先頭位置を設定する。さらにステップS405ではコード列の終端位置に、検索対象のコード列の終端位置を設定し、図4Bに示すステップS406に移行する。
以上で索引データ作成処理の初期処理が終了する。図3Aの例示では、検索対象コード列10aが設定され、索引データ管理ポインタ322は索引データ管理用321の先頭のエントリに位置付けられ、最大コード数には4が、コード列の先頭位置にはP1が、コード列の終端位置にはPnが設定される。
図4Bは、各コード列ブロックに対応するブロック索引データを順次作成する処理の後段の処理フローを説明する図である。
図に示すように、ステップS406において、残りコード数に、コード列の終端位置からコード列の先頭位置を減じた値を設定し、ステップS407で、残りコード数は最大コード数より大きいか判定する。
残りコード数が最大コード数より大きければステップS408に進み、コード列の末尾位置に、コード列の先頭位置から最大コード数分だけ移動した位置を設定する。また、残りコード数が最大コード数より大きくなければステップS409に進み、コード列の末尾位置に、コード列の終端位置を設定する。
上述のステップS406〜ステップS409の処理は、後述の各コード列ブロックに対応する索引データの作成処理の終了を、ステップS408あるいはステップS409で設定したコード列の末尾位置で判定するために行われる。
次にステップS410において、現在索引データ作成対象となっているコード列ブロックの索引データの格納領域を確保するとともに、該格納領域のポインタを取得し、ステップS411に進む。索引データ作成対象のコード列ブロックは、ステップS404あるいは後述のステップS415で設定されるコード列の先頭位置に位置するコードから始まるものである。
ステップS411では、現在索引データ作成対象となっているコード列ブロックの索引データを作成し、ステップS410で確保した格納領域に格納するとともに、最先頭コードIDを取得する。ステップS411の処理の詳細、及び最先頭コードIDについては、後に図4C、及び図5A〜図5Cを参照して説明する。
次にステップS412で、索引データポインタの指す索引データ管理表の設定表示に「あり」を、先頭コードIDに最先頭コードIDを、索引データポインタにステップS410で取得したポインタを、それぞれ設定する。なお、最先頭コードIDは、ステップS411の処理において設定されているものである。
次にステップS413で、コード列の末尾位置はコード列の終端位置か判定する。コード列の末尾位置がコード列の終端位置であれば索引データの作成は完了しているので処理を終了する。コード列の末尾位置がコード列の終端位置でなければ、ステップS414へ進み、索引データ管理ポインタを索引データ管理表の次のエントリに位置付け、ステップS415でコード列の先頭位置に、コード列の末尾位置を設定してステップS406に戻る。
以上のステップS406〜ステップS415のループ処理を、ステップS413においてコード列の末尾位置がコード列の終端位置を指していると判定されるまで繰り返し、該判定が得られると全てのコード列に対する索引データの作成が完了しているので、索引データ作成の処理を終了する。
次に、図4Bに示すステップS411の詳細な説明として、本発明の一実施の形態におけるブロック索引データの作成処理を説明する。このブロック索引データの作成処理はどのコード列ブロックに対しても同じであり、コード列ブロックも一つのコード列であることから、以下の説明においては、現在索引データ作成の対象となっているコード列ブロックを、検索対象コード列、あるいは検索対象のコード列という場合もある。
図4Cは、本発明の一実施形態におけるブロック索引データを作成する処理の概略フローを説明する図である。
まず、ステップS420において、検索対象のコード種別数をもとにコード別ID範囲表の領域を確保すると共に、検索対象コード列に含まれるコードを順次読み出してコード種別毎の出現回数とコードの総数を求める。図3Aに示す先頭のコード列ブロックの場合のコードの総数は、図4Aに示すステップS403で設定した最大コード数と等しい4である。
ステップS420の処理の詳細は、後に図5Aを参照して説明する。
次に、ステップS430で、コード種別毎の出現回数をもとに、コード別ID範囲表にコード種別毎のコードIDの範囲を設定する。ステップS430の処理の詳細は、後に図5Bを参照して説明する。
次にステップS440で、コード総数をもとにID関係表の領域を確保すると共に、コード別ID範囲表を参照しながら、検索対象コード列に含まれるコードを順次読み出してID関係表を完成させ、処理を終了する。ステップS440の処理の詳細は、後に図5Cを参照して説明する。
図5Aは、図4Bに示すステップS420の処理の詳細なフローを示すものであり、検索対象のコード列に含まれるコードのコード種別毎の出現回数を計数する処理フローを説明する図である。
図に示すように、ステップS501において、検索対象コード列を設定する。検索対象コード列の設定は、現在索引データ作成の対象となっているコード列ブロックを、図示しない検索対象コード列設定エリアに設定することを意味する。なお、上述の検索対象コード列設定エリアは、先に述べた「処理の途中で得られた各種の値を後の処理で用いるためにそれぞれの処理に応じた一時記憶装置」の1つである。以下の説明では、「図示しない検索対象コード列設定エリアに設定する」のような表現に変えて、「検索対象コード列として設定する」あるいは単に「検索対象コード列に設定する」のように記述することもある。検索対象コード列以外についても同様である。
次にステップS502において、コードの種別数を設定する。コードの種別数は、コード体系により決定されるものであり、予め与えられるものとする。次にステップS503に進み、図4Bに示すステップS410で確保した領域内に、ステップS502で設定したコードの種別数をもとにコード別ID範囲表の格納領域を確保し、出現回数を0に初期化する。続いてステップS504でコード位置ポインタに、ステップS501で設定したコード列の先頭位置を設定し、ステップS505でコード数カウンタに値0を設定する。以上のステップS501〜ステップS505の処理は、初期処理である。
初期処理に続いてステップS506に進み、コード列より、コード位置ポインタの指すコードを取り出す。次にステップS507で、取り出したコードのコード種別に対応するコード別ID範囲表のエントリ(以下、コードの指すコード別ID範囲表ということがある。)の出現回数に値1を加え、ステップS508でコード数カウンタに値1を加えてステップS509に進む。
ステップS509では、コード位置ポインタが、図4BのステップS408あるいはステップS409で設定されたコード列の末尾位置であるか判定し、末尾位置でなければステップS510でコード位置ポインタを次のコード位置に進めてステップS506に戻る。コード位置ポインタがコード列の末尾位置であれば、ステップS511でコード総数にコード数カウンタを設定して処理を終了する。
以上の処理により、コード別ID範囲表の出現回数が設定されると共に、コード総数が設定される。
図5Bは、図4Cに示すステップS430の処理の詳細なフローを示すものであり、図5Aに示す処理により設定された出現回数をもとにコード種別毎のコードID範囲を設定する処理フローを説明する図である。
まずステップS521において、コード種別ポインタに、コード別ID範囲表の先頭位置を設定し、次にステップS522において、コードIDカウンタに初期値を設定する。次にステップS523に進み、コード種別ポインタの指すコード別ID範囲表より、出現回数を取り出し、ステップS524で、取り出した出現回数が0か判定する。
出現回数が0でなければ、ステップS525でコード種別ポインタの指すコード別ID範囲表の設定表示に「あり」を設定すると共に、先頭コードIDとコード別IDカウンタにコードIDカウンタの値を設定する。次にステップS526でコードIDカウンタに出現回数を加え、ステップS527でコード種別ポインタの指すコード別ID範囲表の末尾コードIDに、コードIDカウンタの値より1を減じた値を設定してステップS529に進む。
一方、ステップS524の判定で出現回数が0となった場合は、ステップS528でコード種別ポインタの指すコード別ID範囲表の設定表示に「なし」を設定し、ステップS528aでコード種別ポインタの指すコード別ID範囲表の先頭コードIDと末尾コードIDに未設定IDを設定してステップS529に進む。未設定IDとしては、0や−1を使うことができる。
ステップS529では、コード種別ポインタはコード別ID範囲表の終端位置であるか判定し、終端位置でなければステップS530でコード種別ポインタを、コード別ID範囲表の次のコード種別の位置に進めてステップS523に戻る。終端位置であれば、コード別ID範囲表の設定は完了しているので、処理を終了する。
図5Cは、図4Cに示すステップS430の処理の詳細なフローを示すものであり、検索対象コード列に含まれるコードをもとにID関係表を完成させる処理フローを説明する図である。
まずステップS541で、図4BのステップS410で確保した格納領域内に、図5Bに示す処理により求めたコード総数をもとにID関係表の格納領域を確保し、ステップS542で、コード位置ポインタに、検索対象コード列の先頭位置を設定する。次にステップS543で、検索対象コード列より、コード位置ポインタの指すコードを取り出す。そして、ステップS544で、コードの指すコード別ID範囲表のコード別IDカウンタを読み出し、コードIDポインタに設定する。次にステップS545で、最先頭コードIDに、コードIDポインタを設定し、ステップS546に進む。
ステップS546では、コード位置ポインタは、図4BのステップS408あるいはステップS409で設定されたコード列の末尾位置か判定し、コード列の末尾位置でなければ、ステップS547〜ステップS554の処理を実行し、該当するコードIDの指すID関係表のコード位置と次コードIDを設定してステップS546に戻る。
まずステップS547では、コードIDポインタの指すID関係表のコード位置に、コード位置ポインタを設定する。
次にステップS550で、ステップS543あるいは後記ステップS552で取り出したコードの指すコード別ID範囲表のコード別IDカウンタに1を加え、ステップS551で、コード位置ポインタを次のコード位置に進める。
次にステップS552において検索対象コード列より、コード位置ポインタの指すコードを取り出し、ステップS553で、該取り出したコードの指すコード別ID範囲表のコード別IDカウンタを読み出し、コードIDカウンタの指すID関係表の次コードIDに設定する。
次にステップS554において、ステップS553で読み出したコード別IDカウンタをコードIDカウンタに設定してステップS546に戻る。以上のステップS546〜ステップS554の処理をコード位置ポインタが検索対象コード列の末尾位置を指すまで繰り返し、コード位置ポインタが検索対象コード列の末尾位置、または、終端位置になるとステップS555に分岐する。ステップS555では、コードIDポインタの指すID関係表の、コード位置にコード位置ポインタを、次コードIDにステップS545で設定した最先頭コードIDを設定して処理を終了する。
なお、上述の説明のとおり、検索対象コード列の先頭から順次ID関係表を作成していくこと、コードIDの範囲はコード種別毎に分離されていることから、ID関係表にコードIDに対応して格納された次コードIDとコード位置は、同一種別のコードのコードID順に連続してコード位置順で格納されることは明らかである。
以上図4A〜図5Cを参照して詳細に説明した処理により、本発明の一実施の形態におけるコード列検索のための索引データが作成される。
次に、図6〜図9Bを参照して、本発明の一実施の形態におけるコード列検索の処理を説明する。本発明の一実施の形態におけるコード列検索は、先に図3Bを参照してその概念を説明したとおり、まず検索コード列の先頭コードと一致する検索対象コード列中のコードとその位置であるコード位置を求め、次に求めたコード位置からの検索対象コード列中のコードと検索コード列中のコードとの1コード毎の照合を、コード列ブロック対応に作成されたコード別ID範囲表とID関係表を用いて行うものである。
そこで、図6〜図9Bを参照した具体的説明に入る前に、本発明の一実施の形態におけるコード列検索処理の処理フローの概要と各図面に記載した処理の関係について説明する。
本発明の一実施の形態におけるコード列検索の処理フローは、3重のループを有する。
最外側のループは、コード列ブロック毎のループである。検索対象コード列の先頭のコード列ブロックから終端のコード列ブロックまで検索コード列による検索を繰り返す。この最外側のループの制御フローは、図6に示されている。
次の内側のループは、検索コード列の先頭コードのコードID毎のループである。あるコード列ブロックにおいて、検索コード列の先頭コードのコードIDの範囲に亘って検索コード列による検索を繰り返す。このループの制御フローは図7A及び図7Bに示されている。
最内側のループは、検索コード列の1コード毎のコード列ブロックとの照合のループである。検索コード列の先頭のコードから末尾のコードまでの1コード毎の照合が繰り返される。この最内側のループの制御フローは、完全一致検索に関しては図8Aに、前方一致検索に関しては図8Bに、任意コードを含む検索に関しては図8Cに示されている。
本発明の一実施の形態におけるコード列検索処理の処理フローによれば、最外側のループ処理のコード列ブロック毎に次の内側のループ処理が呼び出され、検索コード列の先頭コードのコードID毎に最内側のループ処理が呼び出されてコード列ブロック中の各コードと検索コード列の先頭のコードから末尾のコードまでの1コード毎の照合が繰り返される。
そして、本発明においては、検索対象コード列がコード列ブロック毎に分割されており、最内側のループ処理において、上記1コード毎の照合を繰り返しているとき、検索コード列の末尾のコードの照合が終わらないうちに、当該コード列ブロックの末尾位置に至ることがありうる。すると、次のコード列ブロックに亘っての上記1コード毎の照合の繰り返しを継続する必要がある。
この1コード毎の照合の繰り返しの継続を実現するのが図9A及び図9Bにその処理フローを示す次のコード列ブロックに対する検索処理である。この検索処理は最内側のループ処理により呼び出されるが、1コード毎の照合の繰り返しのために再帰的に当該最内側のループ処理を呼び出す。
図6は、先に述べたとおりのものであり、したがって、本発明の一実施の形態におけるコード列検索の処理全体の概略フローを説明する図である。図6に示すフローは、初期処理と、検索対象コード列のうち検索を開始するコード列ブロックを先頭から次のコード列ブロックに順次切り替えて検索するループ処理からなるものである。
まず、ステップS601において、検索コード列を設定する。この検索コード列の設定は、図2Bに示す検索コード列読出手段111により読み出された検索コード列を一時記憶領域に設定することにより行われ、その設定された検索コード列の先頭位置は与えられているものとする。
次にステップS602において、一時記憶領域である検索開始位置の索引データ管理ポインタに、索引データ管理表の先頭のエントリ位置を設定する。
以上で先に述べた初期処理が終了する。
次にステップS603に進み、検索開始位置の索引データポインタの指す索引データ管理表のエントリを取り出し、ステップS604において、該取り出したエントリの設定表示は「あり」であるかを判定する。設定表示が「あり」であればステップS605に進み、設定表示が「あり」でなければ全ての検索は終了しているので、処理を終了する。
ステップS605では、ステップS603で取り出したエントリの索引データポインタを取り出し、索引データポインタの指す索引データの格納領域内に格納されたコード別ID範囲表とID関係表を取得する。このコード別ID範囲表とID関係表の取得は、図5Aに示すステップS503及び図5Cに示すステップS541においてそれぞれコード別ID範囲表とID関係表の格納領域を確保したときにそれらの先頭アドレスを指すそれぞれのポインタを設定しておき、それらのポインタを利用することで実現することができる。
次にステップS606において、ステップS603で取り出したエントリの先頭コードIDを取り出し、検索開始位置の先頭コードIDに設定する。
次にステップS608において、ステップS605で取得したコード別ID範囲表とID関係表をもとに、該当するコード列ブロックを検索する。ステップS608の処理の詳細は、後に図7A及び図7Bを参照して説明する。
次にステップS609で、検索開始位置の索引管理データポインタに索引データ管理表の次のエントリ位置を設定してステップS603に戻る。
上述のステップS603〜ステップS609のループ処理を、ステップS609において検索開始位置の索引データ管理ポインタを更新しながらステップ604で索引データ管理表のエントリの設定表示が「あり」ではないと判定されるまで繰り返す。
なお、上述のステップS602、S609の検索開始位置の索引データ管理ポインタの設定処理及びステップS606の先頭コードIDの設定処理は、先に述べたように検索を開始するコード列ブロックから次のコード列ブロックに亘って1コード毎の照合が行われる場合があるので、検索を開始するコード列ブロックに係わる索引データ管理ポインタ及び先頭コードIDを退避するためのものである。この先頭コードIDは、後に図8Aを参照して説明するように、コードの照合が現在のコード列ブロックの末尾にまで至り、次のコード列ブロックのコードとの照合に進む判定に用いられる。
次に、図7A及び図7Bを参照して、図6に示すステップS608の検索処理について詳細に説明する。
図7Aは、本発明の一実施の形態における、あるコード列ブロックを検索開始位置のコード列ブロックとして行われるコード列検索の前段の処理フローを説明する図である。
まず、ステップS701において、検索先頭位置に、検索コード列の先頭位置を設定し、ステップS702で、検索末尾位置に、検索コード列の末尾位置を設定する。
次にステップS703で、検索先頭位置の指す検索コード列より検索コードを取り出し、検索先頭位置の検索コードに設定する。ステップS704で、検索先頭位置の検索コードの指すコード別ID範囲表より、設定表示を取り出し、ステップS705で該取り出した設定表示は「あり」であるか判定する
設定表示が「あり」でなければ、検索先頭位置の検索コードが検索対象コード列中に存在しないということであるから、検索処理を終了する。
ステップS705での判定が設定表示は「あり」であれば、ステップS706に進み、検索先頭位置の検索コードの指すコード別ID範囲表より先頭コードIDを取り出し、検索開始コードIDに設定する。次にステップS707で、検索先頭位置の検索コードの指すコード別ID範囲表より末尾コードIDを取り出して検索終了コードIDに設定する。
ステップS706の処理は、先に述べた検索コード列の先頭コードのコードID毎のループ処理における処理中のコードIDである検索開始コードIDを、コードIDの範囲の先頭コードIDに初期設定するものであり、ステップ707の処理は、処理対象のコードIDの終端を識別可能とするためのものである。
ステップS707に引き続き、図7Bに示すステップS711に進む。
図7Bは、本発明の一実施の形態における、あるコード列ブロックを検索開始位置のコード列ブロックとして行われるコード列検索の後段の処理フローを説明する図である。
ステップS711では、検索進行位置にステップS701で設定した検索先頭位置を設定する。検索進行位置は、先に述べた図8A等に示す検索コード列の1コード毎のコード列ブロックとの照合ループにおける、照合対象のコードのコード位置を示すものであり、ステップS711では、検索先頭位置、すなわち検索コード列の先頭位置に初期設定される。
次にステップS712において、索引データ管理ポインタに、図6に示すステップS602で設定した検索開始位置の索引データ管理ポインタを設定し、ステップS713で一時記憶領域である先頭コードIDに、図6に示すステップS607で設定した検索開始位置の先頭コードIDを設定する。さらにステップS714において、検索開始コードIDを退避してステップS715に進む。
ここで検索開始コードIDを退避するのは、ステップS715の処理において、先に述べたように複数のコード列ブロックに亘ってコード列の照合が行われる可能性がある。その場合には再帰的に図8A等の処理が呼び出され、その際に次のコード列ブロックの先頭のコードの指すコード別ID範囲表(次のコード列ブロックに対応したもの)の先頭コードIDに検索開始コードIDが変更される可能性があるからである。
ステップS715では、先に述べた、コード列ブロック中の各コードと検索コード列の先頭のコードから末尾のコードまでの1コード毎の照合による検索を行う。そして、検索が成功であったか失敗であったかを返す。ステップS715の詳細については、完全一致検索に関しては図8A、前方一致検索に関しては図8B、任意コードを含む検索に関しては図8Cを参照して後に説明する。
次にステップS716において、ステップS714で退避した検索開始コードIDを復元する。そしてステップS717において、検索開始位置の索引データ管理ポインタの指す索引データ管理表のエントリを取り出し、ステップS718で、該取り出したエントリの索引データポインタの指す索引データの格納領域内に格納されたコード別ID範囲表とID関係表を取得する。上記ステップS717とステップS718の処理は、先に述べたように、ステップS715の処理において複数のコード列ブロックに亘ってコード列の照合が行われる可能性があり、その場合には、図6に示すステップS605で取得したコード別ID範囲表とID関係表とは別のコード別ID範囲表とID関係表が用いられているので、図6のステップS602あるいはステップS607で設定した検索開始位置の索引データ管理ポインタを用いて再度コード別ID範囲表とID関係表を取得するものである。
次にステップS719に進み、ステップS715における検索は成功であったか失敗であったかを判定する。失敗であればステップS721に進み、成功であれば、ステップS720で、検索開始コードIDの指すID関係表よりコード位置を取り出し、検索結果コード位置に出力してステップS721に進む。
ステップS721では、検索開始コードIDは検索終了コードIDと一致するか判定し、一致しなければ、ステップS722で、検索開始コードIDを次のコードIDに更新してステップS711に戻る。
検索開始コードIDと検索終了コードIDが一致すれば、現在処理中のコード列ブロックにおける、検索コード列の先頭コードが指すコード別ID範囲表のコードIDの範囲の検索が終了しているので、図6に示す処理に戻る。
次に、図8A、図8B及び図8Cを参照して、図7Bに示すステップS715の処理について詳細に説明する。先に述べたように、検索の態様が完全一致検索であるか、前方一致検索であるか、あるいは任意コードを含む検索であるかによって、ステップS715の処理は、図8A、図8Bあるいは図8Cに例示するものとなる。
図8Aは、本発明の一実施の形態における、完全一致検索の処理フローを説明する図である。
図に示すように、ステップS810でコードIDポインタに検索開始コードIDを設定する。この検索開始コードIDは、図7Aに示すステップS706で初期設定されたか、あるいは図7Bに示すステップS722で更新され設定されたものである。次にステップS811において、コードIDポインタの指すID関係表より次コードIDを取り出し、検索コードIDに設定するとともに、コードIDポインタに設定する。
次にステップS812で検索進行位置は検索末尾位置か判定し、検索末尾位置でなければステップS813に進み、検索末尾位置であれば、1コード毎の照合が検索コード列の末尾まで成功したことになるので、検索成功を返して図7Bに示すループ処理に戻る。
ステップS813では、ステップS811で取り出した次コードIDは先頭コードIDと一致するか判定する。先頭コードIDは、図7Bに示すステップS713で設定したものである。次コードIDと先頭コードIDが一致しなければ、ステップS814に進み、検索進行位置を、検索コード列の次の検索コードの位置に進め、ステップS815で、検索進行位置の指す検索コード列より検索コードを取り出し、ステップS816で、該取り出した検索コードの指すコード別ID範囲表より先頭コードIDと末尾コードIDを取り出す。
そしてステップS817において、ステップS811で設定した検索コードIDがステップS816で取り出した先頭コードIDと末尾コードIDの範囲内か判定し、範囲内であればステップS811に戻り、範囲内でなければ照合が取れなかったコードが存在したことになるので、検索失敗を返して図7Bに示すループ処理に戻る。
一方、ステップS813で、次コードIDと先頭コードIDが一致すると判定されると、ステップS818に進み、次のコード列ブロックを検索する。ステップS818の処理の詳細は、後に図9A及び図9Bを参照して説明する。
次にステップS819において、次のコード列ブロックの検索は成功であるか判定する。成功であれば検索成功を返し、成功でなければ検索失敗を返して図7Bに示すループ処理に戻る。
図8Bは、本発明の一実施の形態における前方一致検索の処理フローを説明する図である。図8Aに示す完全一致検索の処理フローと比較すると、図8Bに示すステップS830〜ステップS838の各ステップで実行する処理自体は、そのステップ番号から20を引いたステップ番号の、図8Aに示すステップS810〜ステップS818の各ステップで実行する処理と同じである。
しかし、図8Aに示す完全一致検索のステップS817では、検索コードIDは先頭コードIDと末尾コードIDの範囲内ではないと判定すると検索失敗を返して図7Bに示す処理に戻るのに対して、図8Bに示す前方一致検索のステップS837では、検索コードIDは先頭コードIDと末尾コードIDの範囲内ではないと判定しても、検索成功を返して図7Bに示すループ処理に戻る。
なお、ステップS831において、コードIDポインタの指すID関係表のエントリより、次コードIDに加えてコード位置を順次取り出しておき、ステップS837において検索コードは索引コードと一致しないと判定したとき、ステップS831で最後に取り出したコード位置を、検索成功と共に検索結果として返してもよい。この最後に取り出したコード位置は、上述の索引コードのコードID範囲に含まれる次コードIDとID関係表の同一エントリに格納されたコード位置である。このコード位置に位置する検索対象コード列のコードまでは、検索コード列の検索コードと一致している。上記最後に取り出したコード位置と、図7Bに示すステップS720で検索開始コードの指すID関係表から取り出すコード位置を検索結果コード位置として出力することにより、検索コード列と前方一致する検索対象コード列のコード位置の範囲を知ることができる。
また、図8Aに示す完全一致検索のステップS818で次のコード列ブロックを検索したのち、ステップS819で次のコード列ブロックの検索は成功であるか判定し、成功であれば検索成功を返し、成功でなければ検索失敗を返して図7Bに示すループ処理に戻るのに対して、図8Bに示す前方一致検索においては、ステップS838で次のコード列ブロックを検索したのち、直ちに検索成功を返して図7Bに示すループ処理に戻る。
これは、図7Aに示すステップS705の判定処理により、検索コード列中の先頭の検索コードが検索対象コード列中に存在することが保証されており、したがって、少なくとも検索コード列の先頭のコードまでは一致するコード列が検索対象コード列に存在するので、検索成功を返して図7Bに示すループ処理に戻る。
上述のステップS837での判定後のリターン種別及びステップS838以降の処理以外に関しては、先に述べたように全て図8Aに示すものと同じであるので、その説明は省略する。
図8Cは、本発明の一実施の形態における任意コードを含む検索の処理フローを説明する図である。ここで任意コードとは、検索対象コード列の任意のコードと照合するコードである。検索コード列が任意コードを含み、任意コード以外の全てのコードが一致するコード列が検索対象コード列に存在すれば、その検索対象コード列は、前記任意コードを含む検索コード列でヒットする。
図8Cに示すフローを図8Aに示す完全一致検索の処理フローと比較すると、図8Cに示すステップS850〜ステップS859の各ステップで実行する処理は、ステップS855aの処理がステップS855とステップS856の間に挿入されている以外は、そのステップ番号から40を引いたステップ番号の、図8Aに示すステップS810〜ステップS819の各ステップで実行する処理と全く同じである。
ステップS855aでは、ステップS855で取り出した検索コードは任意コードか判定する。ステップS855aで任意コードと判定されると、ステップS856及びステップS857のコードIDの範囲の判定処理を経ることなくステップS851に戻る。ステップS855aで任意コードと判定されなければ、ステップS856に進む。
上述のステップS855aでの判定処理以外は、先に述べたように全て図8Aに示すものと同じであるので、その説明は省略する。
次に、図8Aに示すステップS818、図8Bに示すステップS838、あるいは図8Cに示すステップS858の次のコード列ブロックの検索処理について詳細に説明する。
図9Aは、本発明の一実施の形態における次のコード列ブロックの検索の処理フローの前段を説明する図である。
図に示すように、ステップS901で、索引データ管理ポインタに索引データ管理表の次のエントリ位置を設定する。このとき索引データ管理ポインタには、図7Bに示すステップS712において、検索開始位置の索引データ管理ポインタが設定されている。次にステップS902に進み、該索引データ管理ポインタの指す索引データ管理表のエントリを取り出し、ステップS903において、該取り出したエントリの設定表示は「あり」であるかを判定する。
設定表示が「あり」でなければそれ以上コード列ブロックは存在せず、1コード毎の照合が途中で中断されることになるので、検索失敗を返して図8A、図8Bあるいは図8Cの処理に戻る。
一方、ステップS903においてエントリの設定表示は「あり」であると判定されると、図9Bに示すステップS911以降の処理に進み、1コード毎の照合をさらに進める。
図9Bは、本発明の一実施の形態における次のコード列ブロックの検索の処理フローの後段を説明する図である。
ステップS911では、図9Aに示すステップS902で先に取り出したエントリの索引データポインタの指す索引データの格納領域内に格納されたコード別ID範囲表とID関係表を取得する。
次にステップS912において、索引管理表のエントリの先頭コードIDを取り出して一時記憶領域である先頭コードIDに設定し、ステップS913で、その先頭コードIDを検索開始コードIDに設定してステップS914に進む。
ステップS914では、図8A、図8Bあるいは図8Cに示す処理を再帰的に呼び出し、コード列ブロック中の各コードと検索コード列の先頭のコードから末尾のコードまでの1コード毎の照合による検索を行う。そして、検索が成功であったか失敗であったかを返す。
ステップS915では、ステップS914での検索が成功であれば検索成功を、失敗であれば検索失敗を返して、図8A、図8Bあるいは図8Cに示す処理に戻る。
以上、本発明の実施形態について詳細に説明した。以下においては、本発明についての理解をさらに容易にするために、図10A〜図10Cを参照して本発明の一実施の形態におけるコード列検索のうち完全一致検索の処理の流れについて説明する。図10A〜図10Cに例示すものは、検索対象コード列を図3Aに示すもののうち2番目までのコード列ブロックまでのものとし、検索コード列をABCとしたものである。以下において、上記検索対象コード列を、図3Aの表記と同様に、検索対象コード列10aと表記することがある。
図10Aと図10Bは、検索対象コード列の先頭のコード列ブロックからの処理の流れを説明する図であり、図6に示す最外側のループ処理については、1順目のループ処理に相当する。
図10Aは、そのうちの先頭のコード列ブロックを対象とした検索の流れを説明するものである。
図において、符号701aを付した点線で囲ったブロックには、検索コード列ABCの各検索コードを先頭から処理する流れが記載されている。言い換えれば、該ブロック701aは、検索進行位置のコードの変化を示すものである。符号702aを付した点線で囲ったブロックには、その検索進行位置のコードの指すコード別ID範囲表309aのコードIDの範囲と、コード列ブロックの先頭位置にあるコードAの指すコード別ID範囲表309aの先頭コードID742aであるID1が記載されている。符号703aを付した点線で囲ったブロックには、ID関係表310aから順次次コードを求める流れが記載されている。
また、図中括弧書きで示しているのは、図に示す処理の流れに関連する図6〜図9Bに示す処理ステップである。
検索を開始する前の処理として、図の矢印731aに示すように、図6の(以下の説明では、図面番号の表記は省略する。)ステップS603で、索引データ管理表の先頭のエントリ704aが取り出される。そして、図の矢印734aに示すように、ステップS605で該エントリの索引データポインタ733aに基づき索引データの格納領域705a内に格納されたコード別ID範囲表309aとID関係表310aが取得される。そして、点線の矢印735aに示すように、ステップS606で、該エントリ704aの先頭コードID732aに格納された先頭コードIDであるID1が読み出されて、先頭コードID742aに設定される。
最初に検索コード列の先頭に位置するコードAがブロック701aに示すようにステップS703で取り出され、ブロック702aへの矢印723aで示すように、コードAの指すコード別ID範囲表309aの先頭コードIDであるID1がステップS706で取り出されて検索開始コードIDに設定される。また末尾コードIDであるID1がステップS707で取り出されて検索終了コードIDに設定される。
次に、ブロック702aのID1からブロック703aへの矢印724aで示すように、ID1の指すID関係表310aの次コードIDであるID3がステップS810及びステップS811により取り出される。そして、ブロック703aの、ID1の指すID関係表310aの次コードIDであるID3と、ブロック702aの、先頭コードID742aの間の双方向の点線の矢印736aで示すように、ステップS813において、次コードIDであるID3は先頭コードIDであるID1とは異なることが判定される。
すると、ブロック701aのコードAからコードBへの矢印721aに示すように、ステップS814で次のコード位置のコードが処理対象となり、ステップS815でコードBが取り出される。ブロック702aへの矢印723bで示すように、ステップS816でコードBの指すコード別ID範囲表309aの先頭コードIDであるID3と末尾コードIDであるID3がコードID範囲として取り出される。
そして、ブロック703aの、ID1の指すID関係表310aの次コードIDであるID3とブロック702aの、コードBの指すコード別ID範囲表309aのコードID範囲の間の双方向の点線の矢印725bで示すように、ステップS817においてID1の指すID関係表310aの次コードIDであるID3がコードBの指すコード別ID範囲表309aのコードID範囲であることが判定される。
すると次に、ブロック703a内の矢印724bで示すように、ID3の指すID関係表310aの次コードIDであるID4がステップS811で取り出される。そして、ブロック703aの、ID3の指すID関係表310aの次コードIDであるID4と、ブロック702aの、先頭コードID742aの間の双方向の点線の矢印736bで示すように、ステップS813において、次コードIDであるID4は先頭コードIDであるID1とは異なることが判定される。
次にブロック701aのコードBからコードCへの矢印721bに示すように、ステップS814で次のコード位置のコードが処理対象となり、ステップS815でコードCが取り出される。ブロック702aへの矢印723cで示すように、ステップS816でコードCの指すコード別ID範囲表309aの先頭コードIDと末尾コードIDがコードID範囲として取り出される。しかし、図に示すように、コードCは先頭のコード列ブロックには存在せず、先頭コードIDと末尾コードIDには有意なコードIDは格納されていない(図5Bに示すステップS528aで未設定IDが設定されている。)ので、双方向の点線の矢印725cで示すステップS813での判定は、次コードIDはコード範囲の範囲外となり、検索失敗となる。そこで、検索失敗を返して図7Bに示すループ処理に戻る。
つまり、検索対象コード列10aの先頭のコード列ブロックのうち、コードIDがID1であるコードAからのコード列は、検索コード列ABCと一致しないことを示している。これは、検索対象コード列10aの先頭のコード列ブロックのうち、コードIDがID1であるコードAからの3コードのコード列は、図3Aの(a)に示すようにABEであり、ABCではないことに整合している。
図10Bに示すのは、検索コード列ABCの検索開始コードIDを、ステップS722でコードAのID1の次のコードIDであるID2として先頭のコード列ブロックから検索する流れである。図7Bに示すループ処理では、図10Aに示すものは1順目の処理であり、図10Bに示す処理は2順目の処理である。
そして、この2順目の処理においては、検索対象コード列と検索コード列間の照合が先頭のコード列ブロックの次のコード列ブロックに亘って行われる。
図10Bのブロック702a内の矢印に示すように、図7Bに示すループ処理のステップS722において、検索開始コードIDがID1からID2に更新される。そして、ブロック702aのID2からブロック703aへの矢印724cで示すように、ID2の指すID関係表310aの次コードIDであるID1がステップS810及びステップS811により取り出される。また、ブロック703aの、ID2の指すID関係表310aの次コードIDであるID1と、ブロック702aの、先頭コードID742aの間の双方向の点線の矢印736cで示すように、ステップS813において、次コードIDであるID1は先頭コードIDであるID1と一致することが判定される。
すると、点線の矢印737aで示すように、ステップS901において、索引データ管理表の先頭のエントリ704aの次のエントリ704bが取り出される。そして、図の矢印739aに示すように、ステップS911でエントリ704bの索引データポインタ733bに基づき索引データの格納領域705b内に格納されたコード別ID範囲表309bとID関係表310bが取得される。また、エントリ704bの先頭コードID732bに格納された先頭コードIDであるID1が図の矢印738aに示すように、ステップS912で先頭コードID742bに設定される。
続いて矢印724dで示すように、先頭コードID742bに設定されたID1の指すID関係表310bの次コードIDであるID3が、ステップS913及び再帰的に呼び出された図8Aに示す処理のステップS811により取り出される。そして、そのID3と、ブロック702bの、先頭コードID742bの間の双方向の点線の矢印736dで示すように、ステップS813において、次コードIDであるID3は先頭コードIDであるID1と異なることが判定される。
そこで、ブロック701aのコードAからコードBへの矢印721aに示すように、ステップS814で次のコード位置のコードが処理対象とされ、ステップS815で検索コード列から先頭のコードAの次のコードBが取り出される。ブロック702bへの矢印723dで示すように、ステップS816でコードBの指すコード別ID範囲表309bの先頭コードIDであるID3と末尾コードIDであるID3がコードID範囲として取り出される。
そして、ブロック703bの、ID1の指すID関係表310bの次コードIDであるID3とブロック702bの、コードBの指すコード別ID範囲表309bのコードID範囲の間の双方向の点線の矢印725dで示すように、ステップS817においてID1の指すID関係表310bの次コードIDであるID3がコードBの指すコード別ID範囲表309bのコードID範囲であることが判定される。
すると次に、ブロック703b内の矢印724eで示すように、ID3の指すID関係表310bの次コードIDであるID4がステップS811で取り出される。そして、その次コードIDであるID4と、ブロック702bの、先頭コードID742bの間の双方向の点線の矢印736eで示すように、ステップS813において、次コードIDであるID4は先頭コードIDであるID1とは異なることが判定される。
次に、ブロック701aのコードBからコードCへの矢印721bに示すように、ステップS814で次のコード位置のコードが処理対象となり、ステップS815でコードCが取り出される。ブロック702bへの矢印723eで示すように、ステップS816でコードCの指すコード別ID範囲表309bの先頭コードIDであるID4と末尾コードIDであるID4がコードID範囲として取り出される。
そして、ブロック703bの、ID3の指すID関係表310bの次コードIDであるID4とブロック702bの、コードCの指すコード別ID範囲表309bのコードID範囲の間の双方向の点線の矢印725eで示すように、ステップS817においてID2の指すID関係表310bの次コードIDであるID4がコードCの指すコード別ID範囲表309bのコードID範囲であることが判定される。
つまり、検索対象コード列10aのうち、コードIDがID2であるコードAからのコード列は、検索コード列ABCと一致することが示されている。これは、検索対象コード列10aのうち、コードIDがID2であるコードAからのコード列は、図3Aの(a)に示すようにABCであることに整合している。
そこでステップS720で、矢印728aに示すように、符号705aで示す検索結果コード位置に、検索開始コードIDであるID2の指すID関係表310aのコード位置P4を設定する。
そして、検索開始コードIDであるID2は、ステップS707で設定された検索終了コードIDであることから、先頭のコード列ブロックを検索開始位置とする検索は終了し、図6に示すループ処理に戻り、検索開始位置を1つ進めて、すなわち先頭から2番目のコード列ブロックからの検索を行う。
図10Cは、検索対象コード列の2番目のコード列ブロックからの処理の流れを説明する図であり、図6に示す最外側のループ処理については、2順目のループ処理に相当する。以下説明する処理の流れは、先に図10Aを参照して説明したものと同様なものである。
検索を開始する前の処理として、図の矢印731bに示すように、ステップS609で検索開始位置の索引データ管理ポインタの値が更新され、ステップS603で索引データ管理表の先頭のエントリ704bが取り出される。そして、図の矢印734bに示すように、ステップS605で該エントリの索引データポインタ733bに基づき索引データの格納領域705b内に格納されたコード別ID範囲表309bとID関係表310bが取得される。また、矢印735bに示すように、ステップS606で、該エントリ704bの先頭コードID732bに格納された先頭コードIDであるID1が読み出されて、先頭コードID742bに設定される。
2番目のコード列ブロックからの検索の最初に、検索コード列の先頭に位置するコードAがブロック701aに示すようにステップS703で再度取り出される。そして、ブロック702bへの矢印723fで示すように、コードAの指すコード別ID範囲表309bの先頭コードIDであるID1がステップS706で取り出されて検索開始コードIDに設定される。また末尾コードIDであるID2がステップS707で取り出されて検索終了コードIDに設定される。
次に、ブロック702bのID1からブロック703bへの矢印724fで示すように、ID1の指すID関係表310bの次コードIDであるID3がステップS810及びステップS811により取り出される。そして、ブロック703bの、ID1の指すID関係表309bの次コードIDであるID3と、ブロック702bの、先頭コードID742bの間の双方向の点線の矢印736gで示すように、ステップS813において、次コードIDであるID3は先頭コードIDであるID1とは異なることが判定される。
すると、ブロック701aのコードAからコードBへの矢印721aに示すように、ステップS814で次のコード位置のコードが処理対象となり、ステップS815でコードBが取り出される。ブロック702bへの矢印723gで示すように、ステップS816でコードBの指すコード別ID範囲表309bの先頭コードIDであるID3と末尾コードIDであるID3がコードID範囲として取り出される。
そして、ブロック703bの、ID1の指すID関係表310bの次コードIDであるID3とブロック702bの、コードBの指すコード別ID範囲表309bのコードID範囲の間の双方向の点線の矢印725gで示すように、ステップS817においてID1の指すID関係表310bの次コードIDであるID3がコードBの指すコード別ID範囲表309bのコードID範囲内であることが判定される。
すると次に、ブロック703b内の矢印724gで示すように、ID3の指すID関係表310bの次コードIDであるID4がステップS811で取り出される。そして、ブロック703bの、ID3の指すID関係表310bの次コードIDであるID4と、ブロック702bの、先頭コードID742bの間の双方向の点線の矢印736hで示すように、ステップS813において、次コードIDであるID4は先頭コードIDであるID1とは異なることが判定される。
次にブロック701aのコードBからコードCへの矢印721bに示すように、ステップS814で次のコード位置のコードが処理対象となり、ステップS815でコードCが取り出される。ブロック702bへの矢印723hで示すように、ステップS816でコードCの指すコード別ID範囲表309bの先頭コードIDであるID4と末尾コードIDであるID4がコードID範囲として取り出される。
そして、ブロック703bの、ID3の指すID関係表310bの次コードIDであるID4とブロック702bの、コードCの指すコード別ID範囲表309bのコードID範囲の間の双方向の点線の矢印725hで示すように、ステップS817においてID3の指すID関係表310bの次コードIDであるID4がコードCの指すコード別ID範囲表309bのコードID範囲内であることが判定される。
つまり、2番目のコード列ブロック15bのうち、コードIDがID1であるコードAからのコード列は、検索コード列ABCと一致することが示されている。これは、2番目のコード列ブロック15bのうち、コードIDがID1であるコードAからのコード列は、図3Aの(a)に示すようにABCであることに整合している。
そこでステップS720で、矢印728bに示すように、符号705bで示す検索結果コード位置に、検索開始コードIDであるID1の指すID関係表310bのコード位置P4を設定する。
そして、検索開始コードIDであるID1は検索終了コードIDでないことから、図7Bに示すステップS722で検索開始コードIDをID2に更新し、さらに検索動作は続けられる。しかし、その処理は、図10Bを参照して説明したものと同様であるので、その説明は省略する。
以上本発明を実施するための形態について詳細に説明したが、本発明の実施の形態はそれに限ることなく種々の変形が可能であることは当業者に明らかである。
また、本発明のコード列検索装置が、索引データ管理表とコード別ID範囲表とID関係表を格納する記憶手段と、図6〜図9Bに示した処理をコンピュータに実行させるプログラムによりコンピュータ上に構築可能なことは明らかである。
さらに、図4A〜図5Cに示したコード列検索のための索引データを作成する処理とその均等物をコンピュータに実行させるプログラムにより、本発明の索引データ作成装置及び方法が実現可能であることも明らかである。そして、それらのプログラムにより、本発明の索引データを作成する手段等がコンピュータ上に実現される。
したがって、上記プログラム、及びプログラムを記録したコンピュータ読み取り可能な記録媒体は、本発明の実施の形態に含まれる。さらに、本発明のコード列検索のための索引データのデータ構造及びそのデータ構造を有する索引データを記録したコンピュータ読み取り可能な記録媒体も、本発明の実施の形態に含まれる。
以上詳細に説明した本発明が提供する新しい索引データ構造であるコード別ID範囲表とID関係表及びそれらを管理する索引データ管理表を採用することにより、索引データ作成の負荷を軽減すると共に、効率的にコード列検索を行うことが可能となる。
また、本発明によれば、索引データを複数の格納領域に分割して格納することができるので、多量の索引データであっても、利用するハードウェア環境に応じてコード列ブロックの大きさを決定し、索引データへのアクセスやメンテナンスを容易にすることもできる。
10 文字列
10a 検索対象コード列
11 コード位置ポインタ
20 文字位置順の接尾辞
20a 辞書順の接尾辞
30 接尾辞配列
40 検索文字列
40a 検索コード列
50 圧縮接尾辞配列
101 検索対象コード列読出手段
102 コード別ID範囲表生成手段
103 ID関係表生成手段
104 索引データ作成管理手段
105 索引データ作成手段
111 検索コード列読出手段
112 コード別ID範囲読出手段
113 ID関係読出手段
114 コードID照合手段
115 コード列検索管理手段
116 コード列検索手段
301 データ処理装置
302 中央処理装置
303 キャッシュメモリ
304 バス
305 主記憶装置
306 外部記憶装置
307 通信装置
308 データ格納装置
309 コード別ID範囲表
310 ID関係表
311 コード種別ポインタ
312 コードIDポインタ
321 索引データ管理表
322 索引データ管理ポインタ
324 索引データの格納領域

Claims (25)

  1. 検索対象である検索対象コード列を検索コード列により検索するコード列検索装置において、
    前記検索対象コード列を複数に分割した部分コード列であるコード列ブロックであって、該コード列ブロックの末尾のコードと該コード列ブロックの次に位置するコード列ブロックの先頭のコードとを重複させて前記検索対象コード列を複数に分割したコード列ブロック毎に設けられた、
    前記コード列ブロックに位置する全ての各コードを一意に識別するコードIDの範囲であるコードID範囲を同一種別のコード毎に格納したコード別ID範囲表と、
    前記コードIDに対応して、前記コード列ブロックにおいて該コードIDに係るコードの次に位置するコードのコードIDである次コードIDを格納するとともに、前記コードIDに係るコードが前記コード列ブロックの末尾に位置する場合は前記次コードIDとして前記コード列ブロックの先頭のコードのコードIDを格納するID関係表と、
    前記コード列ブロック毎に設けられたコード別ID範囲表とID関係表を参照して前記検索コード列による検索を実行する検索実行部と、
    前記コード列ブロック毎に該コード列ブロックの先頭のコードのコードIDである先頭コードIDを格納した索引データ管理表と、
    前記検索実行部による検索の実行を管理する検索管理部と、
    を備え、
    前記検索実行部は、
    前記検索コード列を読み出す検索コード列読出手段と、
    指定されたコード列ブロックに対応する前記コード別ID範囲表から、前記検索コード列読出手段により読み出された検索コード列の先頭のコードあるいは2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出すコード別ID範囲読出手段と、
    前記コード別ID範囲読出手段により読み出された前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDあるいは前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出し、以後、読み出された次コードIDに対応して格納された次コードIDを順次前記ID関係表から読み出すとともに、該次コードIDが当該コード列ブロックの前記先頭コードIDと等しいか判定するID関係読出手段と、
    前記ID関係読出手段により読み出された次コードIDが当該コード列ブロックの先頭のコードのコードIDと等しくないとき、該次コードIDが前記コード別ID範囲読出手段により読み出されたコードIDの範囲に含まれるか照合するコードID照合手段を備え、
    前記検索管理部は、
    前記検索実行部に先頭のコード列ブロックから前記コード列ブロックを順次指定するとともに、前記ID関係読出手段が、前記読み出した次コードIDが前記コード列ブロックの先頭のコードのコードIDと等しいと判定すると、前記コード列ブロックの次に位置するコード列ブロックを前記検索実行部に指定するものであり、
    前記検索管理部が前記コード列ブロックを順次指定すると、
    前記コード別ID範囲読出手段は、前記検索コード列の先頭のコードからコード毎に、該コードの種別のコードID範囲を順次読み出し、
    前記ID関係読出手段は、最初に、前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出し、
    前記検索管理部が前記コード列ブロックを次に位置するコード列ブロックとして指定すると、
    前記コード別ID範囲読出手段は、前記検索コード列の2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出し、
    前記ID関係読出手段は、最初に、前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出す、
    ことを特徴とするコード列検索装置。
  2. 請求項1に記載のコード列検索装置において、
    前記コードID照合手段は、前記コード別ID範囲読出手段により読み出された、前記検索コード列の先頭のコードのコード種別のコードID範囲に含まれる検索コード列の先頭のコードのコードIDあるいは前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDを第1コードIDとしたとき該第1コードIDに対応して前記ID関係表に格納された前記次コードIDが、前記検索対象コード列において前記第1のコードの次に位置するコードである第2のコードの種別のコードID範囲に含まれるか照合し、以後、前記第1のコードと第2のコードの前記検索コード列における位置が前記コード別ID範囲読出手段及びID関係読出手段の読出動作により更新されると、該位置の更新された第1のコードのコードIDに対応して格納された前記次コードIDが、該位置の更新された第2のコードの種別の前記コードID範囲に含まれるかを照合するものである、
    ことを特徴とするコード列検索装置。
  3. 請求項2に記載のコード列検索装置において、
    前記ID関係表は、前記コードIDに対応して、前記検索対象コード列において該コードIDに係るコードの位置を示すコード位置を格納しており、
    前記コードID照合手段は、前記ID関係読出手段により読み出された次コードIDが前記コード別ID範囲読出手段により読み出されたコードIDの範囲に含まれるかの照合が前記検索コード列の先頭のコードから末尾のコードについてまで成功すると、該先頭のコードのコードIDに対応して前記ID関係表に格納されたコード位置を検索結果コード位置として出力する、
    ことを特徴とするコード列検索装置。
  4. 請求項3に記載のコード列検索装置において、
    前記ID関係表に前記コードIDに対応して格納された次コードIDとコード位置は、同一種別のコードのコードID順に連続してコード位置順で格納されている、
    ことを特徴とするコード列検索装置。
  5. 請求項4に記載のコード列検索装置において、
    前記コードID照合手段は、前記検索コード列の先頭のコードの種別のコードID範囲に含まれる全てのコードIDを前記検索コード列の先頭のコードのコードIDとして、前記ID関係読出手段により読み出された次コードIDが前記コード別ID範囲読出手段により読み出されたコードIDの範囲に含まれるかを照合する、
    ことを特徴とするコード列検索装置。
  6. 請求項5に記載のコード列検索装置において、
    前記コードID照合手段は、前記ID関係読出手段により読み出された次コードIDが前記コード別ID範囲読出手段により読み出されたコードIDの範囲に含まれるかの照合が失敗すると、前記ID関係表の該次コードIDと同一のエントリに格納されたコード位置と、前記先頭のコードのコードIDに対応して前記ID関係表に格納されたコード位置とを、検索結果コード位置として出力する、
    ことを特徴とするコード列検索装置。
  7. 請求項5に記載のコード列検索装置において、
    前記検索コード列は任意のコードと照合する任意コードを含み、
    前記コードID照合手段は、該任意コードを第2のコードとした前記ID関係読出手段により読み出された次コードIDが前記コード別ID範囲読出手段により読み出されたコードIDの範囲に含まれるかの照合に替えて、前記検索コード列において該任意コードの次に位置するコードを前記第2のコードとして前記照合を行う、
    ことを特徴とするコード列検索装置。
  8. 検索対象である検索対象コード列を検索コード列により検索するコード列検索装置であって、前記検索対象コード列を複数に分割した部分コード列であるコード列ブロックであり、該コード列ブロックの末尾のコードと該コード列ブロックの次に位置するコード列ブロックの先頭のコードとを重複させて前記検索対象コード列を複数に分割したコード列ブロック毎に設けられた、前記コード列ブロックに位置する全ての各コードを一意に識別するコードIDの範囲であるコードID範囲を同一種別のコード毎に格納したコード別ID範囲表と、前記コードIDに対応して、前記コード列ブロックにおいて該コードIDに係るコードの次に位置するコードのコードIDである次コードIDを格納するとともに、前記コードIDに係るコードが前記コード列ブロックの末尾に位置する場合は前記次コードIDとして前記コード列ブロックの先頭のコードのコードIDを格納するID関係表と、前記コード列ブロック毎に該コード列ブロックの先頭のコードのコードIDである先頭コードIDを格納した索引データ管理表と、検索実行部と、検索管理部を備えたコード列検索装置によるコード列検索方法において、
    前記検索実行部は、
    前記検索コード列を読み出す検索コード列読出ステップと、
    指定されたコード列ブロックに対応する前記コード別ID範囲表から、前記検索コード列読出ステップで読み出された検索コード列の先頭のコードあるいは2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出すコード別ID範囲読出ステップと、
    前記コード別ID範囲読出ステップで読み出された前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDあるいは前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出し、以後、読み出された次コードIDに対応して格納された次コードIDを順次前記ID関係表から読み出すとともに、該次コードIDが当該コード列ブロックの前記先頭コードIDと等しいか判定するID関係読出ステップと、
    前記ID関係読出ステップで読み出された次コードIDが当該コード列ブロックの先頭のコードのコードIDと等しくないとき、該次コードIDが前記コード別ID範囲読出ステップで読み出されたコードIDの範囲に含まれるか照合するコードID照合ステップと、
    を実行し、
    前記検索管理部は、
    前記検索実行部に先頭のコード列ブロックから前記コード列ブロックを順次指定する検索開始位置指定ステップを実行するとともに、
    前記ID関係読出ステップにおいて、前記読み出した次コードIDが前記コード列ブロックの先頭のコードのコードIDと等しいと判定されると、前記コード列ブロックの次に位置するコード列ブロックを前記検索実行部に指定する次コード列指定ステップを実行するものであり、
    前記検索管理部が前記検索開始位置指定ステップを実行すると、
    前記コード別ID範囲読出ステップでは、前記検索コード列の先頭のコードからコード毎に、該コードの種別のコードID範囲を順次読み出し、
    前記ID関係読出ステップでは、最初に、前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出し、
    前記検索管理部が前記次コード列指定ステップを実行すると、
    前記コード別ID範囲読出ステップでは、前記検索コード列の2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出し、
    前記ID関係読出ステップでは、最初に、前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出す、
    ことを特徴とするコード列検索方法。
  9. 請求項8に記載のコード列検索方法において、
    前記コードID照合ステップは、
    前記コード別ID範囲読出手段により読み出された、前記検索コード列の先頭のコードのコード種別のコードID範囲に含まれる検索コード列の先頭のコードのコードIDあるいは前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDを第1コードIDとしたとき該第1コードIDに対応して前記ID関係表に格納された前記次コードIDが、前記検索対象コード列において前記第1のコードの次に位置するコードである第2のコードの種別のコードID範囲に含まれるか照合し、以後、前記第1のコードと第2のコードの前記検索コード列における位置が前記コード別ID範囲読出ステップ及びID関係読出ステップの読出動作により更新されると、該位置の更新された第1のコードのコードIDに対応して格納された前記次コードIDが、該位置の更新された第2のコードの種別の前記コードID範囲に含まれるかを照合するものである、
    ことを特徴とするコード列検索方法。
  10. 請求項9に記載のコード列検索方法において、
    前記ID関係表は、前記コードIDに対応して、前記検索対象コード列において該コードIDに係るコードの位置を示すコード位置を格納しており、
    前記コードID照合ステップは、前記ID関係読出ステップで読み出された次コードIDが前記コード別ID範囲読出ステップで読み出されたコードIDの範囲に含まれるかの照合が前記検索コード列の先頭のコードから末尾のコードについてまで成功すると、該先頭のコードのコードIDに対応して前記ID関係表に格納されたコード位置を検索結果コード位置として出力する、
    ことを特徴とするコード列検索方法。
  11. 請求項10に記載のコード列検索方法において、
    前記コードID照合ステップは、前記検索コード列の先頭のコードの種別のコードID範囲に含まれる全てのコードIDを前記検索コード列の先頭のコードのコードIDとして、前記ID関係読出ステップで読み出された次コードIDが前記コード別ID範囲読出ステップで読み出されたコードIDの範囲に含まれるかを照合する、
    ことを特徴とするコード列検索方法。
  12. 検索対象である検索対象コード列を検索コード列により検索するコード列検索装置であって、前記検索対象コード列を複数に分割した部分コード列であるコード列ブロックであり、該コード列ブロックの末尾のコードと該コード列ブロックの次に位置するコード列ブロックの先頭のコードとを重複させて前記検索対象コード列を複数に分割したコード列ブロック毎に設けられた、前記コード列ブロックに位置する全ての各コードを一意に識別するコードIDの範囲であるコードID範囲を同一種別のコード毎に格納したコード別ID範囲表と、前記コードIDに対応して、前記コード列ブロックにおいて該コードIDに係るコードの次に位置するコードのコードIDである次コードIDを格納するとともに、前記コードIDに係るコードが前記コード列ブロックの末尾に位置する場合は前記次コードIDとして前記コード列ブロックの先頭のコードのコードIDを格納するID関係表と、前記コード列ブロック毎に該コード列ブロックの先頭のコードのコードIDである先頭コードIDを格納した索引データ管理表と、検索実行部と、検索管理部を備えたコード列検索装置の機能をコンピュータに実現させるコード列検索プログラムにおいて、
    コンピュータに、
    前記検索実行部の機能として、
    前記検索コード列を読み出す検索コード列読出機能、
    指定されたコード列ブロックに対応する前記コード別ID範囲表から、前記検索コード列読出機能により読み出された検索コード列の先頭のコードあるいは2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出すコード別ID範囲読出機能、
    前記コード別ID範囲読出機能により読み出された前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDあるいは前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出し、以後、読み出された次コードIDに対応して格納された次コードIDを順次前記ID関係表から読み出すとともに、該次コードIDが当該コード列ブロックの前記先頭コードIDと等しいか判定するID関係読出機能、
    前記ID関係読出機能により読み出された次コードIDが当該コード列ブロックの先頭のコードのコードIDと等しくないとき、該次コードIDが前記コード別ID範囲読出機能により読み出されたコードIDの範囲に含まれるか照合するコードID照合機能、
    を実現させ、
    前記検索管理部の機能として、
    前記検索実行部に先頭のコード列ブロックから前記コード列ブロックを順次指定する検索開始位置指定機能を実現させるとともに、
    前記ID関係読出機能により、前記読み出した次コードIDが前記コード列ブロックの先頭のコードのコードIDと等しいと判定されると、前記コード列ブロックの次に位置するコード列ブロックを前記検索実行部に指定する次コード列指定機能を実現させるものであり、
    前記検索管理部の機能として、前記検索開始位置指定機能を実現させると
    前記コード別ID範囲読出機能により、前記検索コード列の先頭のコードからコード毎に、該コードの種別のコードID範囲を順次読み出す機能、
    前記ID関係読出機能により、最初に、前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出す機能を、
    前記検索管理部の機能として、前記次コード列指定機能を実現させると、
    前記コード別ID範囲読出機能により、前記検索コード列の2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出す機能、
    前記ID関係読出機能により、最初に、前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出す機能を、
    実現させることを特徴とするコード列検索プログラム。
  13. 請求項12に記載のコード列検索プログラムにおいて、
    前記コードID照合機能は、
    前記コード別ID範囲読出機能により読み出された、前記検索コード列の先頭のコードのコード種別のコードID範囲に含まれる検索コード列の先頭のコードのコードIDあるいは前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDを第1コードIDとしたとき該第1コードIDに対応して前記ID関係表に格納された前記次コードIDが、前記検索対象コード列において前記第1のコードの次に位置するコードである第2のコードの種別のコードID範囲に含まれるか照合する機能と、以後、前記第1のコードと第2のコードの前記検索コード列における位置が前記コード別ID範囲読出機能及びID関係読出機能の読出動作により更新されると、該位置の更新された第1のコードのコードIDに対応して格納された前記次コードIDが、該位置の更新された第2のコードの種別の前記コードID範囲に含まれるかを照合する機能を含む、
    ことを特徴とするコード列検索プログラム。
  14. 請求項13に記載のコード列検索プログラムにおいて、
    前記ID関係表は、前記コードIDに対応して、前記検索対象コード列において該コードIDに係るコードの位置を示すコード位置を格納しており、
    前記コードID照合機能は、前記ID関係読出機能により読み出された次コードIDが前記コード別ID範囲読出機能により読み出されたコードIDの範囲に含まれるかの照合が前記検索コード列の先頭のコードから末尾のコードについてまで成功すると、該先頭のコードのコードIDに対応して前記ID関係表に格納されたコード位置を検索結果コード位置として出力する機能を含む、
    ことを特徴とするコード列検索プログラム。
  15. 請求項14に記載のコード列検索プログラムにおいて、
    前記コードID照合機能は、前記検索コード列の先頭のコードの種別のコードID範囲に含まれる全てのコードIDを前記先頭コードIDとして、前記ID関係読出機能により読み出された次コードIDが前記コード別ID範囲読出機能により読み出されたコードIDの範囲に含まれるかを照合する機能を含む、
    ことを特徴とするコード列検索プログラム。
  16. 請求項12〜請求項15のいずれか1項に記載のコード列検索プログラムを記録したコンピュータ読み取り可能な記録媒体。
  17. 検索対象である検索対象コード列を検索コード列により検索するコード列検索のためのデータ構造において、
    前記検索対象コード列を複数に分割した部分コード列であるコード列ブロックであり、該コード列ブロックの末尾のコードと該コード列ブロックの次に位置するコード列ブロックの先頭のコードとを重複させて前記検索対象コード列を複数に分割したコード列ブロック毎に設けられた、前記コード列ブロックに位置する全ての各コードを一意に識別するコードIDの範囲であるコードID範囲を同一種別のコード毎に格納したコード別ID範囲表と、前記コードIDに対応して、前記コード列ブロックにおいて該コードIDに係るコードの次に位置するコードのコードIDである次コードIDを格納するとともに、前記コードIDに係るコードが前記コード列ブロックの末尾に位置する場合は前記次コードIDとして前記コード列ブロックの先頭のコードのコードIDを格納するID関係表と、前記コード列ブロック毎に該コード列ブロックの先頭のコードのコードIDである先頭コードIDを格納した索引データ管理表と
    を備え、
    検索実行部と、検索管理部を備えたコード列検索装置により、
    前記検索実行部は、
    前記検索コード列を読み出す検索コード列読出ステップと、
    指定されたコード列ブロックに対応する前記コード別ID範囲表から、前記検索コード列読出ステップで読み出された検索コード列の先頭のコードあるいは2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出すコード別ID範囲読出ステップと、
    前記コード別ID範囲読出ステップで読み出された前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDあるいは前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出し、以後、読み出された次コードIDに対応して格納された次コードIDを順次前記ID関係表から読み出すとともに、該次コードIDが当該コード列ブロックの先頭のコードのコードIDと等しいか判定するID関係読出ステップと、
    前記ID関係読出ステップで読み出された次コードIDが当該コード列ブロックの先頭のコードのコードIDと等しくないとき、該次コードIDが前記コード別ID範囲読出ステップで読み出されたコードIDの範囲に含まれるか照合するコードID照合ステップと、
    を実行し、
    前記検索管理部は、
    前記検索実行部に先頭のコード列ブロックから前記コード列ブロックを順次指定する検索開始位置指定ステップを実行するとともに、
    前記ID関係読出ステップにおいて、前記読み出した次コードIDが前記コード列ブロックの先頭のコードのコードIDと等しいと判定されると、前記コード列ブロックの次に位置するコード列ブロックを前記検索実行部に指定する次コード列指定ステップを実行し、
    前記検索管理部が前記検索開始位置指定ステップを実行すると、
    前記コード別ID範囲読出ステップでは、前記検索コード列の先頭のコードからコード毎に、該コードの種別のコードID範囲を順次読み出し、
    前記ID関係読出ステップでは、最初に、前記検索コード列の先頭のコードの種別のコードID範囲に含まれるコードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出し、
    前記検索管理部が前記次コード列指定ステップを実行すると、
    前記コード別ID範囲読出ステップでは、前記検索コード列の2番目のコードからコード毎に、該コードの種別のコードID範囲を順次読み出し、
    前記ID関係読出ステップでは、最初に、前記索引データ管理表に格納された前記指定されたコード列ブロックの先頭コードIDに対応して格納された前記次コードIDを前記指定されたコード列ブロックに対応するID関係表から読み出すことにより、
    前記検索対象コード列の前記検索コード列による検索の実行を可能とする
    ことを特徴とするコード列検索のためのデータ構造。
  18. 請求項17に記載のコード列検索のためのデータ構造において、
    前記ID関係表は、前記コードIDに対応して、前記検索対象コード列において該コードIDに係るコードの位置を示すコード位置を格納しており、
    前記ID関係表から読み出された次コードIDが前記コード別ID範囲読出表から読み出されたコードIDの範囲に含まれるかの照合が前記検索コード列の先頭のコードから末尾のコードについてまで成功すると、該先頭のコードのコードIDに対応して前記ID関係表に格納されたコード位置を検索結果コード位置として出力することを可能とする、
    ことを特徴とするコード列検索のためのデータ構造。
  19. 請求項18に記載のコード列検索のためのデータ構造において、
    前記ID関係表に前記コードIDに対応して格納された次コードIDとコード位置は、同一種別のコードのコードID順に連続してコード位置順で格納されている、
    ことを特徴とするコード列検索のためのデータ構造。
  20. 請求項17〜請求項19のいずれか1項に記載されたデータ構造を有するデータが記録されたコンピュータ読み取り可能な記録媒体。
  21. 検索対象である検索対象コード列を検索コード列により検索するコード列検索のための索引データ作成装置において、
    前記検索対象コード列を複数に分割した部分コード列であるコード列ブロックであって、該コード列ブロックの末尾のコードと該コード列ブロックの次に位置するコード列ブロックの先頭のコードとを重複させて前記検索対象コード列を複数に分割したコード列ブロックを順次読み出し、該読み出したコード列ブロックのコードの種別毎の出現回数を求める検索対象コード列読出手段と
    前記検索対象コード列読出手段が求めたコードの種別毎の出現回数に基づいて、前記コード列ブロックに位置する全ての各コードを一意に識別するコードIDの範囲であるコードID範囲を同一種別のコード毎に格納したコード別ID範囲表を生成するコード別ID範囲表生成手段と、
    前記検索対象コード列読出手段が読み出したコード列ブロックと前記コード別ID範囲表に基づき、前記コードIDに対応して、前記コード列ブロックにおいて該コードIDに係るコードの次に位置するコードのコードIDである次コードIDを格納したID関係表を前記コード列ブロック毎に生成するID関係表生成手段と、
    前記コード列ブロック毎に該コード列ブロックに対応した前記コード別ID範囲表とID関係表を格納する索引データの格納領域を確保するとともに、前記コード列ブロックの先頭のコードのコードIDと前記索引データの格納領域のポインタを前記コード列ブロック毎に格納する索引データ管理表を生成する索引データ作成管理手段と、
    を備えたことを特徴とする索引データ作成装置。
  22. 請求項21に記載の索引データ作成装置において、
    前記ID関係表に前記コードIDに対応して格納された次コードIDとコード位置は、同一種別のコードのコードID順に連続してコード位置順で格納されている、
    ことを特徴とする索引データ作成装置。
  23. 検索対象である検索対象コード列を検索コード列により検索するコード列検索のための索引データ作成装置による索引データ作成方法において、
    前記検索対象コード列を複数に分割した部分コード列であるコード列ブロックであって、該コード列ブロックの末尾のコードと該コード列ブロックの次に位置するコード列ブロックの先頭のコードとを重複させて前記検索対象コード列を複数に分割したコード列ブロックを読み出し、該読み出したコード列ブロックのコードの種別毎の出現回数を求める検索対象コード列読出ステップと
    前記検索対象コード列読出ステップで求めたコードの種別毎の出現回数に基づいて、前記コード列ブロックに位置する全ての各コードを一意に識別するコードIDの範囲であるコードID範囲を同一種別のコード毎に格納したコード別ID範囲表を生成するコード別ID範囲表生成ステップと、
    前記検索対象コード列読出ステップで読み出したコード列ブロックと前記コード別ID範囲表生成ステップで生成されたコード別ID範囲表に基づき、前記コードIDに対応して、前記コード列ブロックにおいて該コードIDに係るコードの次に位置するコードのコードIDである次コードIDを格納したID関係表を生成するID関係表生成ステップと、
    を備え、
    前記検索対象コード列読出ステップ、前記コード別ID範囲表生成ステップ及びID関係表生成ステップを全ての前記コード列ブロックについて繰り返すことを特徴とする索引データ作成方法。
  24. 検索対象である検索対象コード列を検索コード列により検索するコード列検索のための索引データ作成方法をコンピュータに実行させる索引データ作成プログラムにおいて、
    コンピュータに、
    コード列検索のための索引データ作成方法であって、
    前記検索対象コード列を複数に分割した部分コード列であるコード列ブロックであり、該コード列ブロックの末尾のコードと該コード列ブロックの次に位置するコード列ブロックの先頭のコードとを重複させて前記検索対象コード列を複数に分割したコード列ブロックを読み出し、該読み出したコード列ブロックのコードの種別毎の出現回数を求める検索対象コード列読出ステップと
    前記検索対象コード列読出ステップで求めたコードの種別毎の出現回数に基づいて、前記コード列ブロックに位置する全ての各コードを一意に識別するコードIDの範囲であるコードID範囲を同一種別のコード毎に格納したコード別ID範囲表を生成するコード別ID範囲表生成ステップと、
    前記検索対象コード列読出ステップで読み出したコード列ブロックと前記コード別ID範囲表生成ステップで生成されたコード別ID範囲表に基づき、前記コードIDに対応して、前記コード列ブロックにおいて該コードIDに係るコードの次に位置するコードのコードIDである次コードIDを格納したID関係表を生成するID関係表生成ステップと、
    を備え、
    前記検索対象コード列読出ステップ、前記コード別ID範囲表生成ステップ及びID関係表生成ステップを全ての前記コード列ブロックについて繰り返すことを特徴とする索引データ作成方法を実行させることを特徴とする索引データ作成プログラム。
  25. 請求項24に記載の索引データ作成プログラムを記録したことを特徴とするコンピュータ読み取り可能な記録媒体。
JP2009080726A 2008-09-28 2009-03-29 コード列検索装置、検索方法及びプログラム Active JP4464459B1 (ja)

Priority Applications (5)

Application Number Priority Date Filing Date Title
JP2009080726A JP4464459B1 (ja) 2009-03-29 2009-03-29 コード列検索装置、検索方法及びプログラム
PCT/JP2009/006922 WO2010116435A1 (ja) 2009-03-29 2009-12-16 コード列検索装置、検索方法及びプログラム
EP09842945A EP2416258A4 (en) 2009-03-29 2009-12-16 CODE CHAIN DETECTION DEVICE, POLLING PROCEDURE AND PROGRAM
CN2009801595558A CN102449624B (zh) 2009-03-29 2009-12-16 码串检索装置、检索方法
US13/064,487 US9009655B2 (en) 2008-09-28 2011-03-28 Code string search apparatus, search method, and program

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2009080726A JP4464459B1 (ja) 2009-03-29 2009-03-29 コード列検索装置、検索方法及びプログラム

Publications (2)

Publication Number Publication Date
JP4464459B1 JP4464459B1 (ja) 2010-05-19
JP2010231675A true JP2010231675A (ja) 2010-10-14

Family

ID=42306564

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2009080726A Active JP4464459B1 (ja) 2008-09-28 2009-03-29 コード列検索装置、検索方法及びプログラム

Country Status (4)

Country Link
EP (1) EP2416258A4 (ja)
JP (1) JP4464459B1 (ja)
CN (1) CN102449624B (ja)
WO (1) WO2010116435A1 (ja)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5790664B2 (ja) * 2011-01-25 2015-10-07 日本電気株式会社 情報検索装置

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0561910A (ja) * 1991-09-02 1993-03-12 Fujitsu Sooshiaru Sci Raboratori:Kk 全文インデツクス検索方法
JPH05324722A (ja) * 1992-03-24 1993-12-07 Ricoh Co Ltd 文書検索方式
JPH06149882A (ja) * 1992-11-06 1994-05-31 Fujitsu Ltd 全文データベース検索装置
JP2002229987A (ja) * 2001-01-11 2002-08-16 Internatl Business Mach Corp <Ibm> パターン検索方法、パターン検索装置、コンピュータプログラム及び記憶媒体

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0782504B2 (ja) * 1990-11-30 1995-09-06 株式会社テレマティーク国際研究所 情報検索処理方式および検索ファイル作成装置
JPH04242864A (ja) * 1991-01-08 1992-08-31 Chubu Nippon Denki Software Kk 情報検索方式
JPH06162092A (ja) * 1992-11-18 1994-06-10 Fujitsu Ltd 情報検索装置
WO1995034155A2 (en) * 1994-06-06 1995-12-14 Nokia Telecommunications Oy A method for storing and retrieving data and a memory arrangement
JP3552318B2 (ja) * 1995-01-11 2004-08-11 株式会社日立製作所 文書検索方法およびシステム
EP1107126A2 (en) * 1999-12-08 2001-06-13 Hewlett-Packard Company, A Delaware Corporation A fast, efficient, adaptive, hybrid tree
US6931424B1 (en) * 2000-03-21 2005-08-16 Alantro Communications, Inc. Storage efficient minimization logic
JP4271214B2 (ja) * 2006-07-07 2009-06-03 株式会社エスグランツ ビット列検索装置、検索方法及びプログラム
JP4402168B1 (ja) * 2008-09-28 2010-01-20 株式会社エスグランツ コード列検索装置、検索方法及びプログラム
JP4402169B1 (ja) * 2009-02-23 2010-01-20 株式会社エスグランツ コード列検索装置、検索方法及びプログラム

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0561910A (ja) * 1991-09-02 1993-03-12 Fujitsu Sooshiaru Sci Raboratori:Kk 全文インデツクス検索方法
JPH05324722A (ja) * 1992-03-24 1993-12-07 Ricoh Co Ltd 文書検索方式
JPH06149882A (ja) * 1992-11-06 1994-05-31 Fujitsu Ltd 全文データベース検索装置
JP2002229987A (ja) * 2001-01-11 2002-08-16 Internatl Business Mach Corp <Ibm> パターン検索方法、パターン検索装置、コンピュータプログラム及び記憶媒体

Also Published As

Publication number Publication date
WO2010116435A1 (ja) 2010-10-14
EP2416258A4 (en) 2013-02-27
CN102449624A (zh) 2012-05-09
JP4464459B1 (ja) 2010-05-19
EP2416258A1 (en) 2012-02-08
CN102449624B (zh) 2013-12-18

Similar Documents

Publication Publication Date Title
JP4535130B2 (ja) 文字列照合装置および文字列照合プログラム
JP4402169B1 (ja) コード列検索装置、検索方法及びプログラム
JP4160548B2 (ja) 文書要約作成システム、方法、及びプログラム
CN108027816B (zh) 数据管理系统、数据管理方法及记录介质
JP2005165598A (ja) 可変長文字列検索装置及び可変長文字列検索方法並びにプログラム
JP4402168B1 (ja) コード列検索装置、検索方法及びプログラム
JP5190898B2 (ja) コード列検索装置、検索方法及びプログラム
JP4464459B1 (ja) コード列検索装置、検索方法及びプログラム
JP2022103676A (ja) 情報処理装置、情報処理方法、プログラム
WO2010095179A1 (ja) コード列検索装置、検索方法及びプログラム
JPH05225238A (ja) データベース検索システム
JP4429373B1 (ja) コード列検索装置、検索方法及びプログラム
JP5077380B2 (ja) 文字列照合装置および文字列照合プログラム
JPH05101102A (ja) 検索装置
JP3260428B2 (ja) 情報検索処理装置
JP5807592B2 (ja) 符号化方法、符号化装置及びコンピュータプログラム
WO2010035366A1 (ja) コード列検索装置、検索方法及びプログラム
JP4319827B2 (ja) 文書検索プログラム
KR100904835B1 (ko) 문자열 대조 장치 및 문자열 대조 프로그램을 기록한 컴퓨터 판독 가능한 기억 매체
US7840583B2 (en) Search device and recording medium
JPWO2009050797A1 (ja) 検索装置および検索方法
JPH07200622A (ja) 情報管理システム
JP2001075982A (ja) 文書検索方法、文書検索用インデックスの作成方法、文書検索装置、及び記録媒体
KR102326105B1 (ko) 워드 추출 방법 및 장치
JPS59100939A (ja) 日本語入力装置

Legal Events

Date Code Title Description
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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20100218

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

Free format text: PAYMENT UNTIL: 20130226

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4464459

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

Free format text: PAYMENT UNTIL: 20130226

Year of fee payment: 3

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313111

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

Free format text: PAYMENT UNTIL: 20130226

Year of fee payment: 3

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

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

Free format text: PAYMENT UNTIL: 20130226

Year of fee payment: 3

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

Free format text: PAYMENT UNTIL: 20160226

Year of fee payment: 6

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250