JP7206687B2 - Apiパラメータのマッピング - Google Patents

Apiパラメータのマッピング Download PDF

Info

Publication number
JP7206687B2
JP7206687B2 JP2018152605A JP2018152605A JP7206687B2 JP 7206687 B2 JP7206687 B2 JP 7206687B2 JP 2018152605 A JP2018152605 A JP 2018152605A JP 2018152605 A JP2018152605 A JP 2018152605A JP 7206687 B2 JP7206687 B2 JP 7206687B2
Authority
JP
Japan
Prior art keywords
key
api
column
value
extracted
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2018152605A
Other languages
English (en)
Other versions
JP2019133622A (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.)
Fujitsu Ltd
Original Assignee
Fujitsu 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 Fujitsu Ltd filed Critical Fujitsu Ltd
Publication of JP2019133622A publication Critical patent/JP2019133622A/ja
Application granted granted Critical
Publication of JP7206687B2 publication Critical patent/JP7206687B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/73Program documentation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/541Interprogram communication via adapters, e.g. between incompatible applications

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Library & Information Science (AREA)
  • Stored Programmes (AREA)

Description

本稿で論じられる実施形態はAPIパラメータ・マッピングに関する。
アプリケーション・プログラミング・インターフェース(API)は、ソフトウェア・アプリケーションを構築するためのルーチン、プロトコルおよびツールの集合である。APIはソフトウェア・コンポーネントがどのように相互作用すべきかを指定し、グラフィカル・ユーザー・インターフェース(GUI)コンポーネントをプログラムするときにAPIが使われる。APIは典型的にはソフトウェア・アプリケーションの関数またはデータを公開するものであり、それが他のアプリケーションが、該関数またはデータの実装を心配することなく、該APIの資源を使うことを可能にする。
本願で請求される主題は、何らかの欠点を解決する、あるいは記載されたような環境でのみ動作する実施形態に限定されるものではない。むしろ、この背景は、本稿に記載されるいくつかの実施形態が実施されうる一つの例示的な技術を例解するために与えられているだけである。
ある実施形態のある側面によれば、システムは、通信インターフェースと、該通信インターフェースに動作上結合されたプロセッサとを含んでいてもよい。プロセッサは、通信インターフェースを介して、定義されたAPI仕様を受け取るよう構成されてもよい。定義されたAPI仕様は、第一のフォーマットでのAPIテーブルを含んでいてもよく、該APIテーブルの各列はAPIパラメータに関連付けられていてもよい。プロセッサは、キー・モデルを生成するよう構成されていてもよい。キー・モデルは、定義されたAPI仕様に基づいていてもよい。キー・モデルは、APIテーブルに含まれるAPIドキュメンテーションの一つまたは複数のAPIパラメータが、定義されたフォーマットでのAPIパラメータの対応するクラスにマッピングされたものを含んでいてもよい。いくつかの実施形態では、APIテーブルは、ハイパーテキスト・マークアップ言語(HTML)テーブルを含んでいてもよい。さらに、プロセッサは、通信インターフェースを介して、抽出されたテーブルを受領するよう構成されてもよい。抽出されたテーブルの各列は、第一のフォーマットにおけるAPIパラメータに関連付けられてもよい。プロセッサは、抽出されたテーブルの各列を、キー・モデルに基づいて、定義されたフォーマットにおけるAPIパラメータのクラスに関連付けるよう構成されていてもよい。プロセッサはまた、定義されたフォーマットにおいて、抽出されたテーブルのAPIパラメータを含む、API仕様を生成するよう構成されていてもよい。
実施形態の目的および利点は、少なくとも、請求項において具体的に指摘される要素、特徴および組み合わせによって、実現され、達成される。
上記の一般的な記述および以下の詳細な説明はいずれも例示および説明するものであり、特許請求される本発明を制約するものでないことは理解されるものとする。
例示的実施形態は、付属の図面を使ってさらに具体的かつ詳細に記述され、説明される。
APIパラメータのマッピングに関する例示的環境を示す図である。 キー・モデルの生成に関する例示的方法の流れ図である。 キー・モデルの生成に関するもう一つの例示的方法の流れ図である。 例示的なAPIドキュメンテーションのスクリーンショットである。 定義されたフォーマットにおいてAPI仕様を生成することに関する例示的方法の流れ図である。 抽出されたテーブルのキー項目をAPIテーブルのキー項目に関連付けることに関する例示的方法の流れ図である。 本稿で論じられる方法の任意の一つまたは複数を機械に実行させるための一組の命令が実行されうる、コンピューティング装置という例示的な形の機械の図的な表現である。 みな、本稿に記載される少なくとも一つの実施形態に基づいて構成される。
アプリケーション・プログラミング・インターフェース(API)のいくつかの型がある。たとえばウェブAPIはその関数およびデータを、インターネットまたはイントラネットにおけるウェブ・サービスを通じて公開してもよい。装置APIは、装置ハードウェア・モジュール機能を他の装置および/またはソフトウェアに公開してもよい。アプリケーションAPIは、オペレーティング・システムなどを通じて、ソフトウェア・アプリケーションの関数またはデータベースへのアクセスを提供してもよい。典型的には、APIは、APIからまたはAPIを通じて提供されるサービス、関数またはデータに基づいて新たなシステムを実装するときに、開発者にとって有用でありうる。通常のAPIはしばしば、サービスを提供する「ブラックボックス」として機能する一方、開発者は典型的には、ブラックボックスの内部を見て実装の詳細を識別することはできない。いくつかのAPIはシステムの複雑さを抽象化することがあり、いくつかのAPIはいくつかの詳細を開発者から隠すことがあり、それは実装における柔軟性を低下させることがある。
各APIは典型的には、自分のサービスおよび/またはデータを、異なるデータ属性をもつ異なる型のデータをもつ異なるプロトコルを通じて公開する。この通常のアプローチは、開発者が多様なAPIを用いて作業しているときに、異種性問題を引き起こすことがある。さらに、たいていのAPIは形式的な定義をもたず、大半はHTMLファイルとして記述された、人間が読んでわかる記述である。結果として、ソフトウェア開発者は典型的には、API関数にアクセスしてこれと対話するために、APIドキュメンテーションを読んで学習する。ソフトウェア開発をさらに複雑にすることに、各APIは異なるプログラミング言語を通じてアクセス可能であることがある。
いくつかのAPI公開者は、API仕様に含まれるAPIパラメータを記述するために、標準的なAPIフォーマット(たとえば定義されたAPIフォーマット)を使う。一方、他の公開者は、API仕様に含まれるAPIパラメータを記述するために、標準的なAPIフォーマットを使わない。API仕様のアクセスおよび可読性を簡単にするために、抽出されたテーブルが、APIドキュメンテーションから抽出された情報を含んでいてもよい。抽出されたテーブルは、APIドキュメンテーションの種々の特性、属性またはフィールドを含んでいてもよい。該種々の特性、属性またはフィールドを定義されたフォーマットにマッピングすることは、困難を呈する。API公開者は、前記種々の特性、属性またはフィールドを前記定義されたフォーマットにマッピングするために考慮される種々の項目(たとえばキー項目、値項目またはルート・ペアレント)を理解しないことがあるからである。たとえば、あるフォーマットにおいてAPIパラメータの特定のクラスに関連付けられているキー項目は「parameter name」〔パラメータ名〕を含んでいることがあり、別のフォーマットにおいてはAPIパラメータの前記特定のクラスに関連付けられているキー項目は「field name」〔フィールド名〕を含んでいることがある。キー項目におけるこの相違は、さまざまなAPIドキュメンテーションにおける種々の特性、属性またはフィールドの定義されたフォーマットへのマッピングの際に、誤りまたは他の問題を引き起こすことがありうる。
一つまたは複数の機械可読フォーマット(たとえばオープンAPI仕様、JavaScript(登録商標)記法(JSON)など)で書かれた一つまたは複数の機械可読API仕様が、異なる用語法を理解し、種々の特性、属性またはフィールドを定義されたフォーマットにマッピングすることを可能にするキー・モデルをトレーニングするために使用されてもよい。キー・モデルは、ある特性、属性またはフィールドのすべての等価なキー項目;所与の特性、属性またはフィールドのすべての値項目;および所与の特性、属性またはフィールドの構造(たとえばルート・ペアレント)を考えてもよい。これは、多様なフォーマットにおける多様なAPIパラメータについて、さまざまな用語法、さまざまな用語法の構造および他の可能なフィールド名を理解するキー・モデルを許容しうる。
これは、種々のAPIパラメータに関連付けられた対応する値項目に基づいて種々のAPIパラメータのマッピングを許容しうる。たとえば、あるフォーマットにおけるAPIパラメータは、「name of parameter」〔パラメータの名称〕を含むキー項目と、「ID」を含む値項目とを含んでいてもよく、別のフォーマットにおけるAPIパラメータは、「parameter」〔パラメータ〕を含むキー項目と、「ID」を含む値項目とを含んでいてもよい。単にキー項目に基づいてマッピングが実行されたとしたら、これらのAPIパラメータはAPIパラメータの同様のクラスにマッピングされないことがありうる。その代わり、マッピングは、値項目が同じまたは実質的に同様であること(たとえば、値項目「ID」が同じまたは実質的に同様であること)に基づいていてもよい。このシナリオでは、キー項目「parameter」および「parameter name」は、パラメータ名に関連付けられたAPIパラメータのクラスにマッピングされうる。
さらに、これは、種々のAPIパラメータのマッピングを、該種々のAPIパラメータに関連付けられた対応するルート・ペアレントに基づいて許容してもよい。たとえば、キー項目「name」〔名前〕および値項目「ID」を含むAPIパラメータが、キー項目「default」〔デフォルト〕および値項目「Null」〔ヌル〕を含むその後のAPIパラメータに基づくパラメータ名に関連付けられたAPIパラメータのクラスにマッピングされてもよい。APIパラメータおよびその後のAPIパラメータのルート・ペアレント(たとえばファイル・パス)が、定義されたフォーマットのルート・ペアレントと同じまたは実質的に同様だからである。
図1は、本開示に記載される少なくとも一つの実施形態に基づいて構成された、APIパラメータのマッピングに関する例示的環境100を示している。たとえば、環境100は、抽出されたテーブル102に含まれるAPIパラメータを、該抽出されたテーブルのAPIパラメータに関連付けられたキー項目、値項目および/またはルート・ペアレントに基づいて、定義されたフォーマットにおけるAPIパラメータのクラスにマッピングすることに関係していてもよい。環境100は、抽出されたテーブル102に含まれるAPIパラメータを、定義されたフォーマットにおけるAPIパラメータのクラスに、定義されたAPI仕様108に基づいていてもよいキー・モデルを使ってマッピングするよう構成されたAPI仕様モジュール104を含んでいてもよい。定義されたフォーマットは、機械可読フォーマットを含んでいてもよい。API仕様モジュール104は、API仕様112を出力するよう構成されていてもよい。API仕様112は、抽出されたテーブル102のAPIパラメータが、定義されたフォーマットにおけるAPIパラメータのクラスにマッピングされたものを含んでいてもよい。
API仕様モジュール104は、プロセッサ、メモリおよび/または通信機能を含むコンピュータ・ベースのハードウェア装置を含んでいてもよい。API仕様モジュール104は、プロセッサ・ベースのコンピューティング装置を含んでいてもよい。たとえば、API仕様モジュール104は、ハードウェア・サーバーまたはサーバーとして機能するよう構成された他のプロセッサ・ベースのコンピューティング装置を含んでいてもよい。API仕様モジュール104はメモリおよびネットワーク通信機能を含んでいてもよい。API仕様モジュール104は、本開示で記載されるように、第一のフォーマットにおけるAPIパラメータを定義されたフォーマットにおけるAPIパラメータのクラスにマッピングすることに関係したさまざまな動作を実行してもよい。
定義されたAPI仕様108は、APIテーブル110を含んでいてもよい。APIテーブル110は、第一のフォーマットでの一つまたは複数のAPIパラメータを含んでいてもよい。たとえば、前記一つまたは複数のAPIパラメータはJSONフォーマット、オープンAPIフォーマットまたはAPIパラメータのための他の任意の受け入れ可能なフォーマットで記憶されてもよい。さらに、定義されたAPI仕様108は、機械可読フォーマットを含んでいてもよい。APIテーブル110は、第一のフォーマットにおける一つまたは複数のAPIパラメータを含んでいてもよく、該フォーマットでは、各列がAPIパラメータまたは他の任意のテーブル型(たとえば、応答型、データ型、セキュリティ情報、認証などを記述するテーブル)に関連付けられてもよい。いくつかの実施形態では、APIテーブル110は一つまたは複数の列を含んでいてもよく、各列は異なるAPIパラメータに対応していてもよい。各APIパラメータ(たとえば各列)は、一つまたは複数のキー項目、値項目および/またはルート・ペアレントを含んでいてもよい。
キー項目は、関連付けられたAPIパラメータを定義してもよい。たとえば、キー項目は「required」〔必須〕を含んでいてもよく、これは、該関連付けられたAPIパラメータを必須APIパラメータとして定義してもよい。キー項目のさらなる例は、「necessary」〔必要〕、「is required」〔要求される〕および「required」〔必須〕を含んでいてもよいが、それに限られない。値項目は、対応するキー項目にどんな情報が関連付けられうるかを示してもよい。たとえば、必須キー項目についての値項目は、「true」、「yes」および「no」を含んでいてもよい。さらに、ルート・ペアレントは、対応するキー項目およびまたは値項目についてのファイル・パスを示してもよい。たとえば、ルート・ペアレントは「parameter」→「required:true」を含んでいてもよい。
API仕様モジュール104は、定義されたAPI仕様108および/またはAPIテーブル110に基づいてキー・モデル106を生成するよう構成されてもよい。API仕様モジュール104は、APIテーブル110の各列からキー項目を抽出してもよい。さらに、API仕様モジュール104はAPIテーブル110の各列から値項目を抽出してもよい。さらに、API仕様モジュール104は、APIテーブル110の各列から各キー項目および/または値項目についてのルート・ペアレントを抽出してもよい。APIテーブルを含む例示的なAPI仕様は、図4との関係でのちにより詳細に論じる。
キー・モデル106は、定義されたフォーマットでのキー項目の種々のクラスおよび関連付けられたAPIパラメータを含んでいてもよい。キー・モデル106におけるキー項目の各クラスは、APIテーブル110からの同様/類似のキー項目の集合を含んでいてもよい。たとえば、キー項目の「required」クラスは、「required value」〔必須の値〕および「necessary」〔必要〕というキー項目を含んでいてもよい。さらに、キー・モデル106は、定義されたAPI仕様108に基づく定義されたフォーマットにおけるターゲット・テーブル(たとえばAPIパラメータ)を含んでいてもよい。
キー・モデル106は、定義されたフォーマットにおいてAPIテーブル110に含まれるキー項目、値項目およびルート・ペアレントを関連付けるために生成されてもよい、明瞭キー・テーブル107を含んでいてもよい。定義されたフォーマットは、JSONフォーマット、標準的な機械可読API(SMRAPI: standard machine readable API)フォーマット、Swaggerフォーマット、Open API仕様フォーマット、イェット・アナザー・マークアップ・ランゲージ(yet another markup language)/YAMLエイント・マークアップ・ランゲージ(YAML aint markup language)(YAML)フォーマット、拡張可能マークアップ言語(XML)フォーマット、テキスト・フォーマットまたはAPIパラメータのための他の任意の受け入れ可能なフォーマットを含みうる。前記明瞭キー・テーブル107の第一列は、APIテーブル110における各キー項目を異なる行に含んでいてもよい。前記明瞭キー・テーブル107の第二列は、APIテーブル110における各値項目を、対応するキー項目と同じ行に含んでいてもよい。たとえば、キー項目が「required」を含んでいてもよく、対応する例示的な値項目が「True」を含んでいてもよい。値項目「true」はキー項目「required」と同じ行にマッピングされてもよい。さらに、前記明瞭キー・テーブル107の第三列は、APIテーブル110における各ルート・ペアレントを、対応するキー項目および値項目と同じ行に含んでいてもよい。
API仕様モジュール104は、前記明瞭キー・テーブル107における一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定してもよい。一つまたは複数のキー項目が同じまたは実質的に同様であることに応答して、対応するキー項目、値項目および/またはルート・ペアレントは、前記明瞭キー・テーブル107において互いに関連付けられてもよい。
APIテーブル110におけるキー項目、値項目および/またはルート・ペアレントであって、定義されたフォーマットにおけるAPIパラメータのクラスの対応するキー項目、値項目および/またはルート・ペアレントをもたないものは、前記明瞭キー・テーブル107にマッピングされなくてもよい。前記明瞭キー・テーブル107には定義されたフォーマットにマッピングされることのできるAPIパラメータのみを含めるようにするためである。
キー・モデル106は、前記明瞭キー・テーブル107におけるキー項目、値項目およびルート・ペアレントを、定義されたフォーマットにおけるAPIパラメータの対応するクラスにマッピングするために生成されてもよい。たとえば、前記明瞭キー・テーブル107のある行は、その行におけるキー項目、値項目および/またはルート・ペアレントが、定義されたフォーマットにおけるAPIパラメータの第一のクラスのキー項目、値項目および/またはルート・ペアレントに対応する場合、APIパラメータの該第一のクラスにマッピングされてもよい。行内のキー項目、値項目およびルート・ペアレントは、定義されたフォーマットにおけるAPIパラメータの第一のクラスにマッピングされてもよく、それにより、前記明瞭キー・テーブル107の異なるキー項目、値項目およびルート・ペアレントと、前記定義されたフォーマットにおけるAPIパラメータの前記第一のクラスとが単一のフォーマット(たとえば前記定義されたフォーマット)において関係付けられる。
いくつかの実施形態では、キー・モデル106は、前記明瞭キー・テーブル107のキー項目、値項目および/またはルート・ペアレントが前記第一のフォーマットにおけるAPIパラメータのあるクラスの対応するキー項目、値項目および/またはルート・ペアレントにマッピングされたものを含んでいてもよい。
APIテーブル110のキー項目、値項目およびルート・ペアレントをキー・モデル106におけるAPIパラメータの対応するクラスに関連付けることは、API仕様モジュール104が、第一のフォーマットおよび/または定義されたフォーマットにおける抽出されたテーブル102におけるAPIパラメータを、定義されたフォーマットにおけるAPIパラメータの対応するクラスに、キー・モデル106を使ってマッピングすることを許容する。たとえば、APIテーブル110はJSONフォーマットにおけるAPIパラメータを含んでいてもよく、JSONフォーマットのAPIテーブル110の一つまたは複数のAPIパラメータをオープンAPIフォーマットのAPIパラメータの対応するクラスにマッピングするようキー・モデル106が生成されてもよい。抽出されたテーブル102がJSONフォーマットおよび/またはオープンAPIフォーマットにおけるAPIパラメータを含んでいる場合には、API仕様モジュール104は、いずれかのフォーマットのAPIパラメータを、オープンAPIフォーマットのAPIパラメータにマッピングすることができる。
API仕様モジュール104は、抽出されたテーブル102を受け取るよう構成されていてもよい。いくつかの実施形態では、抽出されたテーブル102の各列は、第一のフォーマットでAPIパラメータを含んでいてもよい。あるいはまた、抽出されたテーブル102の各列は、定義されたフォーマットでAPIパラメータを含んでいてもよい。いくつかの実施形態では、抽出されたテーブル102の各列は、第一のフォーマットまたは定義されたフォーマットのいずれかでAPIパラメータを含んでいてもよい。抽出されたテーブル102は、各APIパラメータに関連付けられたキー項目、値項目および/またはルート・ペアレントをも含んでいてもよい。
API仕様モジュール104は、抽出されたテーブル102の各列および前記明瞭キー・テーブル107の各列におけるキー項目のキー類似性スコアを決定してもよい。同様に、API仕様モジュール104は、抽出されたテーブル102の各列および前記明瞭キー・テーブル107の各列における値項目の値類似性スコアを決定してもよい。さらに、API仕様モジュール104は、抽出されたテーブル102の各列および前記明瞭キー・テーブル107の各列におけるルート・ペアレントの構造類似性スコアを決定してもよい。たとえば、抽出されたテーブル102は二つの列を含んでいてもよく、前記明瞭キー・テーブル107は二つの列を含んでいてもよい。キー類似性スコア、値類似性スコアおよび構造類似性スコアが、抽出されたテーブル102の第一列および前記明瞭キー・テーブル107の第一列、抽出されたテーブル102の第一列および前記明瞭キー・テーブル107の第二列、抽出されたテーブル102の第二列および前記明瞭キー・テーブル107の第一列ならびに抽出されたテーブル102の第二列および前記明瞭キー・テーブル107の第二列について決定されてもよい。
API仕様モジュール104は、キー類似性スコア、値類似性スコアおよび構造類似性スコアに基づいて、抽出されたテーブル102における各列および前記明瞭キー・テーブル107の各列について列類似性スコアを決定してもよい。いくつかの実施形態では、列類似性スコアは、式(1)を使って決定されてもよい。
Figure 0007206687000001
式(1)において、iは1からキー項目の総数までの範囲内の値であり、jは1から値項目の総数までの範囲内の値であり、lは1からルート・ペアレントの総数までの範囲内の値であり、Siは抽出されたテーブル102の第i列および前記明瞭キー・テーブル107の各列についてのルート・ペアレントの構造類似性スコアであり、Viは抽出されたテーブル102の各列および前記明瞭キー・テーブル107の各列についてのi番目の値項目の値類似性スコアであり、Kiは抽出されたテーブルの各列および前記明瞭キー・テーブル107の各列についてのi番目のキー項目のキー類似性スコアである。列類似性スコアについての値は、0から1の範囲内であってもよく、0の列類似性スコアは低い類似性を表わしてもよく、1の列類似性スコアは高い類似性を表わしてもよい。いくつかの実施形態では、列類似性スコアについての値は、0より小さかったり、あるいは1より大きかったりしてもよい。
ある例示的実施形態では、キー項目「name」に関連付けられた前記明瞭キー・テーブル107における列と、キー項目「field」に関連付けられた抽出されたテーブル102における列についての列類似性スコアは同じまたは実質的に同様であってもよく、二つの列は、定義されたフォーマットにおけるAPIパラメータの同じクラスにマッピングされてもよい。たとえば、前記明瞭キー・テーブル107の内容(たとえば「P2」の値をもつ「Name」、「123」の値をもつ「Default Value」および「True」の値をもつ「Required Field」)が、抽出されたテーブル102の内容に対して高い類似性(たとえば90%)をもつ場合、前記明瞭キー・テーブル107の内容は抽出されたテーブル102の対応するパラメータに関連付けられてもよい。キー項目マッチ(たとえばプラス1)、値項目マッチ(たとえばプラス1)およびルート・ペアレント・マッチ(たとえばプラス1)がある場合、3という値が計算されてもよい。
API仕様モジュール104は、抽出されたテーブル102の各列および前記明瞭キー・テーブル107の各列についての列類似性スコアが類似性範囲内にあるかどうかを判定してもよい。抽出されたテーブル102のある列および前記明瞭キー・テーブル107のある列についての列類似性スコアが類似性範囲内にあれば、API仕様モジュール104は、抽出されたテーブルのその列を、定義されたフォーマットにおける、前記明瞭キー・テーブル107の対応する列に関連付けられたAPIパラメータのクラスと関連付けてもよい。
追加的または代替的に、抽出されたテーブル102のさまざまな列を、定義されたフォーマットにおけるAPIパラメータのクラスにマッピングすることは、キー類似性スコア、値類似性スコアおよび/または構造類似性スコアの重み付けされたスコアに基づいていてもよい。
API仕様モジュール104は、定義されたフォーマットでAPI仕様112を出力するよう構成されていてもよい。API仕様112は、APIテーブル110のキー項目、値項目およびルート・ペアレントが定義されたフォーマットにおけるAPIパラメータのさまざまなクラスにマッピングされたものを含んでいてもよい。
一つまたは複数のフォーマットにおけるAPIパラメータを定義されたフォーマットにおけるAPIパラメータのクラスにマッピングすることは、さまざまなAPI仕様をレビューするために必要とされる時間の長さを短縮しうる。同様に、APIパラメータを機械可読な定義されたフォーマットにマッピングすることは、機械が単一のフォーマットでのAPI仕様108を読むことを許容することによって、種々のAPIパラメータを見出すためのプロセスを単純化しうる。
図2、図3、図5および図6は、例示的方法の流れ図を示している。これらの方法は、ハードウェア(回路、専用論理など)、ソフトウェア(汎用コンピュータ・システムまたは専用機において実行されるようなもの)または両者の組み合わせを含んでいてもよい処理論理によって実行されてもよい。該処理論理は図1のAPI仕様モジュール104または別のコンピュータ・システムまたは装置に含まれてもよい。しかしながら、これらの方法を実行するために、別のシステムまたはシステムの組み合わせが使われてもよい。説明の簡単のため、本稿に記載される方法は、一連の工程として描かれ、記述される。しかしながら、本開示に基づく工程は、さまざまな順序でおよび/または同時並行して、あるいは本稿では呈示および記載されない他の工程とともに行なわれてもよい。さらに、図示したすべての工程が開示される主題に基づく方法を実装するために必要とされるとは限らない。さらに、当業者は、これらの方法は代替的に、状態図またはイベントを介して一連の相互に関係した状態として表現されうることを理解するであろう。さらに、本明細書で開示される方法は、そのような方法をコンピューティング装置に輸送し、転送することを容易にするために、非一時的なコンピュータ可読媒体のような製造物に記憶されることができる。本稿で使われるところの製造物という用語は、任意のコンピュータ可読デバイスまたは記憶媒体からアクセス可能なコンピュータ・プログラムを包含することが意図されている。離散的なブロックとして示されているが、所望される実装に依存して、さまざまなブロックは追加的なブロックに分割されたり、より少数のブロックに組み合わされたり、あるいはなくされたりしてもよい。
図2は、本稿に記載される少なくとも一つの実施形態に基づく、キー・モデルの生成に関する例示的方法200の流れ図を示している。方法200は、ブロック202で始まってもよく、ここで、処理論理は、APIテーブルを含む定義されたAPI仕様を受け取ってもよい。たとえば、処理論理は、図1のAPIテーブル110を含む定義されたAPI仕様を受け取ってもよい。定義されたAPI仕様および/またはAPIテーブルは、第一のフォーマットでの一つまたは複数のAPIパラメータを含んでいてもよい。
ブロック204では、処理論理は、APIテーブルから各列を抽出してもよい。APIテーブルの各列は、第一のフォーマットにおいてAPIパラメータに関連付けられたキー項目、値項目および/またはルート・ペアレントを含んでいてもよい。
ブロック206では、処理論理は、キー項目のリストを生成してもよい。たとえば、リストは、APIテーブルにおけるAPIパラメータについて、それぞれの関連付けられたキー項目を含んでいてもよい。ブロック208では、処理論理は、値項目のリストを生成してもよい。値項目のリストは、APIテーブルにおけるAPIパラメータについて、それぞれの関連付けられた値項目を含んでいてもよい。ブロック210では、処理論理は、ルート・ペアレントのリストを生成してもよい。ルート・ペアレントのリストは、APIテーブルにおける各キー項目および/または値項目について、ファイル・パスを含んでいてもよい。
ブロック212では、処理論理は、APIテーブルにおいて同様のキー項目を関連付けてもよい。たとえば、キー項目「required」およびキー項目「needed」は、それらが同様の機能に関係しているまたは同様の機能を含んでいることを示すよう、関連付けられてもよい。
ブロック214では、処理論理は、明瞭キー・テーブルを生成してもよい。たとえば、処理論理は、図1の明瞭キー・テーブルを生成してもよい。明瞭キー・テーブルは、APIテーブルにおける一つまたは複数のキー項目、値項目および/またはルート・ペアレントを含んでいてもよい。さらに、各キー項目および対応する値項目およびルート・ペアレントは、明瞭キー・テーブルに関連付けられてもよい。たとえば、明瞭キー・テーブルの、第一のキー項目に関連付けられている行は、すべての関連付けられたキー項目を第一列において含み、第一のキー項目に関連付けられたすべての対応する値項目を第二列において含み、第一のキー項目および該第一のキー項目に関連付けられた値項目に関連付けられたすべての対応するルート・ペアレントを第三列において含んでいてもよい。
ブロック216では、処理論理は、キー・モデルを生成してもよい。たとえば、処理論理は、図1のキー・モデル106を生成してもよい。キー・モデルは、キー項目、値項目、ルート・ペアレントおよび/またはAPIテーブルのAPIパラメータの一つまたは複数が、定義されたフォーマットにおけるAPIパラメータのクラスにマッピングされたものを含んでいてもよい。定義されたフォーマットは、APIパラメータのためのいかなる受け入れ可能な機械可読フォーマットを含んでいてもよい。
図3は、本稿に記載される少なくとも一つの実施形態に基づく、キー・モデルの生成に関するもう一つの例示的方法300の流れ図を示している。方法300は、ブロック302で始まってもよく、ここで、処理論理は、抽出されたテーブルを受け取ってもよい。たとえば、処理論理は、図1の抽出されたテーブル102を受け取ってもよい。抽出されたテーブルの各列は第一のフォーマットでAPIパラメータを含んでいてもよい。抽出されたテーブルは、第一のフォーマットでのAPIパラメータに関連付けられた一つまたは複数のキー項目、値項目および/またはルート・ペアレントをも含んでいてもよい。
ブロック304では、処理論理は、抽出されたテーブルから各列を抽出してもよい。たとえば、抽出されたテーブルからそれぞれのキー項目および対応する値項目および/またはルート・ペアレントが抽出されてもよい。
ブロック306では、処理論理は、明瞭キー・テーブルを受領してもよい。たとえば、処理論理は、図1の明瞭キー・テーブル107を受け取ってもよい。明瞭キー・テーブルは図2との関係で上記で詳細に論じている。ブロック308では、処理論理は、明瞭キー・テーブルから各列を抽出してもよい。明瞭キー・テーブルの各列は、定義されたフォーマットにおけるAPIパラメータを含んでいてもよい。同様に、明瞭キー・テーブルは、該明瞭キー・テーブルにおける各APIパラメータに関連付けられた一つまたは複数のキー項目、値項目および/またはルート・ペアレントを含んでいてもよい。
ブロック310では、処理論理は、抽出されたテーブルおよび明瞭キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定してもよい。キー類似性スコアは、抽出されたテーブルの列および明瞭キー・テーブルの列におけるキー項目が類似しているか否かを示してもよい。たとえば、キー類似性スコアは、「field」、「property」および「parameter」のようなキー項目が類似した属性のキー項目であることを示してもよい。さらに、処理論理は、抽出されたテーブルの各列を明瞭キー・テーブルの各列と比較して、抽出されたテーブルおよび明瞭キー・テーブルの列のすべての組み合わせについてキー類似性スコアが決定されるようにしてもよい。
ブロック312では、処理論理は、抽出されたテーブルおよび明瞭キー・テーブルの各列に含まれる値項目の値類似性スコアを決定してもよい。値類似性スコアは、抽出されたテーブルの列および明瞭キー・テーブルの列における値項目が類似しているか否かを示してもよい。追加的または代替的に、値類似性スコアは、値項目および対応するキー項目が同じまたは実質的に同様であるかどうかを示してもよい。
ブロック314では、処理論理は、抽出されたテーブルおよび明瞭キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定してもよい。構造類似性スコアは、抽出されたテーブルの列および明瞭キー・テーブルの列における二つ以上のキー項目および/または値項目が類似したファイル・パスを含むかどうかを示してもよい。類似したファイル・パスは、二つの異なるキー項目および/または値項目が、たとえ対応するキー類似性スコアおよび/または値類似性スコアがそう示さなくても、互いに関連付けられてもよいことを示しうる。
ブロック316では、処理論理は、明瞭キー・テーブルの各キー項目についてのキー類似性スコアを決定してもよい。明瞭キー・テーブルの各キー項目についてのキー類似性スコアは、類似性範囲を決定するために使われてもよい。たとえば、明瞭キー・テーブルがDefault Value〔デフォルト値〕というキー項目をもつ列タイトルおよびDefault Value of Parameter〔パラメータのデフォルト値〕というキー項目をもつ別の列タイトルを含む場合、キー項目における三つのキーワードのうちの一つがマッチしているので、0.33のキー類似性スコアが決定されてもよい。
ブロック318では、処理論理は、明瞭キー・テーブルの列に比べた、抽出されたテーブルの列についての列類似性スコアを決定してもよい。たとえば、列類似性スコアは、明瞭キー・テーブルの第一列に比べた、抽出されたテーブルの第一列について決定されてもよい。列類似性スコアは、上記でより詳細に論じた式(1)を使って決定されてもよい。列類似性スコアは、抽出されたテーブルの列および明瞭キー・テーブルの列についての、キー類似性スコア、値類似性スコアおよび構造類似性スコアに基づいて決定されてもよい。
ブロック320では、処理論理は、列類似性スコアが類似性範囲内であるかどうかを判定してもよい。列類似性範囲は、明瞭キー・テーブルの各キー項目についてのキー類似性スコアからある閾値を引いたものよりも大きく、明瞭キー・テーブルの各キー項目についてのキー類似性スコアに前記閾値を加えたものよりも小さい、値範囲内であってもよい。たとえば、閾値は、0.70より大きくてもよい。いくつかの実施形態では、閾値は、0.70以下であってもよい。閾値より大きな列類似性スコアは、類似したテーブル(たとえばパラメータ・テーブル)を示しうる。
列類似性スコアが類似性範囲内である場合、処理論理はブロック322において、抽出されたテーブルの列を、定義されたフォーマットにおけるAPIパラメータのクラスと関連付けてもよい。APIパラメータのクラスは、明瞭キー・テーブルの対応する列内のキー項目に関連付けられていてもよい。列類似性スコアが類似性範囲内でない場合、処理論理はブロック324において、明瞭キー・テーブルの各列に比べて、抽出されたテーブルの各列について、列類似性スコアが決定されたかどうかを判定してもよい。
明瞭キー・テーブルの各列に比べて、抽出されたテーブルの各列について、列類似性スコアがまだ決定されていない場合、処理論理は、明瞭キー・テーブルの各列に比べて、抽出されたテーブルの各列について、列類似性スコアが決定されるまで、ブロック318、320、322および/または324のプロセスを繰り返してもよい。明瞭キー・テーブルの各列に比べて、抽出されたテーブルの各列について、列類似性スコアが決定され終わった場合には、処理論理は、ブロック326において、キー・モデルを生成してもよい。たとえば、処理論理は、図1のキー・モデル106を生成してもよい。キー・モデルは、抽出されたテーブルの各キー項目、値項目、ルート・ペアレントおよび/またはAPIテーブルを、定義されたフォーマットにおけるAPIパラメータの一つまたは複数のクラスの一部として含んでいてもよい。
図4は、本稿に記載される少なくとも一つの実施形態に基づく、例示的なAPIドキュメンテーション400のスクリーンショットを示している。APIドキュメンテーション400は、APIテーブル416およびファイル・パス414(ここでは「ルート・ペアレント414」)を含んでいてもよい。
APIテーブル416は、関連付けられたAPIパラメータについてのキー項目および値項目を含む五つの列を含んでいてもよい。図4に示した例では、[0]における五つの列はrequired、type、description、nameおよびinというキー項目を含んでいる。図4では、APIテーブル416における例示的なキー項目を示すために、キー項目requiredが418と記されている。キー項目の例は、「default value ex.」「Value」「required?」「Example」「name」「examples」「field」「group」「location」「put」「post」「get」「uri」「delete」および「url」を含んでいてもよいが、これに限られるものではない。同様に、[0]における五つの列はTrue、string、The user's Spotify user ID、user_idおよびpathという値項目を含んでいる。図4では、APIテーブル416における例示的な値項目を示すために、値項目Trueが420として記されている。さらに、APIテーブル416、前記キー項目および前記値項目についてのルート・ペアレント414は、paths→users→get→parametersを含んでいてもよい。
APIテーブル416の各列は抽出されてもよく、各キー項目および値項目が収集されてもよい。さらに、APIテーブル416における各キー項目の頻度が決定されてもよい。例示的な明瞭キー・テーブルは下記を含んでいてもよい。
[(u'description', 9490), (u'type', 4409), (u'parameter', 4021), (u'name', 1997), (u'value', 1861), (u'method', 1413), (u'required', 1212), (u'resource', 1201), (u'url', 684), (u'notes', 516), (u'default', 485), (u'endpoint', 455), (u'parameter name', 408), (u'api', 387), (u'http method', 343), (u'key', 308), (u'path', 282), (u'attribute', 266), (u'', 248), (u'example', 240), (u'field', 238), (u'required?', 237), (u'uri', 217), (u'default value ex.', 207), (u'function', 205), (u'auto-generated-0', 195), (u'location', 187), (u'verb', 177), (u'operation', 173), (u'required parameter', 173), (u'code', 161), (u'api method', 156), (u'action', 143), (u'parameters', 131), (u'options', 127), (u'arguments', 122), (u'param', 121), (u'http verb', 117), (u'default value', 116), (u'returns', 110), (u'method / url', 107), (u'http', 106), (u'data type', 99), (u'result', 99), (u'get', 97), (u'property', 93), (u'use', 93), (u'methods', 84), (u'presence', 83), (u'call type', 83), (u'sdk method', 83), (u'request/params', 82), (u'optional', 80), (u'response', 79), (u'status', 78), (u'field name', 77), (u'functionality', 76), (u'cached', 76), (u'auth', 76), (u'link', 74), (u'uri schema', 73), (u'reason', 70), (u'usage', 69), (u'authentication', 68), (u'request', 66), (u'overview', 64), (u'required/optional', 63), (u'required parameters', 61), (u'documentation', 61), (u'how to use', 58), (u'model', 57), (u'string', 56), (u'authorization', 55), (u'request body (xml)', 50), (u'validation', 47), (u'value to be specified', 46)]
図5は、本稿に記載される少なくとも一つの実施形態に基づく、定義されたフォーマットでのAPI仕様の生成に関係した例示的方法500の流れ図を示している。方法500はブロック502で始まってもよく、ここで、処理論理は定義されたAPI仕様を受け取ってもよい。定義されたAPI仕様はAPIテーブルを含んでいてもよい。たとえば、処理論理は、図1のAPIテーブル110を含む定義されたAPI仕様108を受け取ってもよい。定義されたAPI仕様および/またはAPIテーブルは、第一のフォーマットで一つまたは複数のAPIパラメータを含んでいてもよい。同様に、APIテーブルの各列はAPIパラメータに関連付けられていてもよい。
ブロック504では、処理論理はキー・モデルを生成してもよい。たとえば、処理論理は図1のキー・モデル106を生成してもよい。キー・モデルは、APIテーブルおよび/または定義されたAPI仕様のキー項目、値項目、ルート・ペアレントおよび/またはAPIパラメータの一つまたは複数が、定義されたフォーマットにおけるAPIパラメータのクラスにマッピングされたものを含んでいてもよい。定義されたフォーマットは、APIパラメータのためのいかなる受け入れ可能な機械可読フォーマットを含んでいてもよい。さらに、キー・モデルは、APIテーブルの一つまたは複数のAPIパラメータが定義されたフォーマットにおけるAPIパラメータの対応するクラスにマッピングされたものを含んでいてもよい。
ブロック506では、処理論理は、抽出されたテーブルを受け取ってもよい。たとえば、処理論理は図1の抽出されたテーブル102を受け取ってもよい。抽出されたテーブルの各列は、第一のフォーマットでのAPIパラメータを含んでいてもよい。抽出されたテーブルは、第一のフォーマットでのAPIパラメータに関連付けられたキー項目、値項目および/またはルート・ペアレントをも含んでいてもよい。抽出されたテーブルの各列は、第一のフォーマットでのAPIパラメータと関連付けられてもよい。さらに、抽出されたテーブルの各列は、第一のフォーマットでのターゲットAPIテーブル(たとえばAPIパラメータ)に関連付けられてもよい。
ブロック508では、処理論理は、抽出されたテーブルの各列を、定義されたフォーマットにおけるAPIパラメータのクラスと関連付けてもよい。抽出されたテーブルの各列は、キー・モデルに基づいて、APIパラメータのクラスと関連付けてもよい。さらに、処理論理は、抽出されたテーブルの各列を、定義されたフォーマットにおけるAPIパラメータにおけるターゲットAPIテーブル(たとえばAPIパラメータ)と関連付けてもよい。ブロック510では、処理論理は、定義されたフォーマットにおける抽出されたテーブルのAPIパラメータを含むAPI仕様を生成してもよい。
図6は、本稿に記載される少なくとも一つの実施形態に基づく、抽出されたテーブルのキー項目をAPIテーブルのキー項目に関連付けることに関係する例示的方法600の流れ図を示している。方法600はブロック602で始まってもよく、ここで、処理論理はAPIテーブルの各列についてのキー項目を決定してもよい。各キー項目は、APIパラメータを定義してもよい。ブロック604では、処理論理は、APIテーブルの各列についての値項目を決定してもよい。各値項目は、APIパラメータについての対応するキー項目に関連付けられてもよい。ブロック606では、処理論理は、APIテーブルの各列についての各キー項目および値項目に関連付けられたルート・ペアレントを決定してもよい。
ブロック608では、処理論理は、明瞭キー・テーブルを生成してもよい。たとえば、処理論理は、図1の明瞭キー・テーブル107を生成してもよい。明瞭キー・テーブルは、APIテーブルにおけるキー項目、値項目および/またはルート・ペアレントの一つまたは複数を含んでいてもよい。さらに、キー項目および対応する値項目およびルート・ペアレントが明瞭キー・テーブルに関連付けられてもよい。明瞭キー・テーブルの第一列は、APIテーブルのキー項目を、異なる行に位置されて含んでいてもよい。明瞭キー・テーブルの第二列は、値項目を対応するキー項目と同じ行内に含んでいてもよい。同様に、明瞭キー・テーブルの第三列は、ルート・ペアレントを、対応するキー項目および値項目と同じ行に含んでいてもよい。
ブロック610では、処理論理は、少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定してもよい。一つまたは複数のキー項目が同じまたは実質的に同様であれば、処理論理はブロック612において、同じまたは実質的に同様であるキー項目と、対応する値項目およびルート・ペアレントとを、明瞭キー・テーブルにおける対応するAPIパラメータに関連付けられた列にマッピングしてもよい。さらに、明瞭キー・テーブルに基づいて、キー・モデルが生成されてもよい。
図7は、本稿で論じられる方法の任意の一つまたは複数を機械に実行させるための一組の命令が実行されうるコンピューティング装置700の例示的な形での機械の図的な表現を示している。コンピューティング装置700は、携帯電話、スマートフォン、ネットブック・コンピュータ、ラックマウント・サーバー、ルーター・コンピュータ、サーバー・コンピュータ、パーソナル・コンピュータ、メインフレーム・コンピュータ、ラップトップ・コンピュータ、タブレット・コンピュータ、デスクトップ・コンピュータなどを含んでいてもよく、その中で、本稿で論じられる方法の任意の一つまたは複数を機械に実行させるための一組の命令が実行されうる。代替的な実施形態では、機械はLAN、イントラネット、エクストラネットまたはインターネット内の他の機械に接続(たとえばネットワーク接続)されていてもよい。機械は、クライアント・サーバー・ネットワーク環境におけるサーバー機械の役割で動作してもよい。機械は、パーソナル・コンピュータ(PC)、セットトップボックス(STB)、サーバー、ネットワーク・ルーター、スイッチまたはブリッジまたは、その機械によって行なわれるべきアクションを指定する一組の命令(逐次的またはその他)を実行することのできるいかなる機械であってもよい。さらに、一つの機械が図示されているだけだが、用語「機械」は、本稿で論じられる方法の任意の一つまたは複数を実行するために、個々にまたは合同して一組の(または複数組の)命令を実行する機械の任意の集合をも含みうる。
例示的なコンピューティング装置700は、処理装置(たとえばプロセッサ)702、メイン・メモリ704(たとえば読み出し専用メモリ(ROM)、フラッシュメモリ、動的ランダム・アクセス・メモリ(DRAM)、たとえば同期DRAM(SDRAM))、静的メモリ706(たとえばフラッシュメモリ、静的ランダム・アクセス・メモリ(SRAM))およびデータ記憶装置716を含み、これらはバス708を介して互いと通信する。
処理装置702は、マイクロプロセッサ、中央処理ユニットなどといった一つまたは複数の汎用処理装置を表わす。より具体的には、処理装置702は、複雑命令セット・コンピューティング(CISC)マイクロプロセッサ、縮小命令セット・コンピューティング(RISC)マイクロプロセッサ、超長命令語(VLIW: very long instruction word)マイクロプロセッサまたは他の命令セットを実装するプロセッサまたは諸命令セットの組み合わせを実装する諸プロセッサを含んでいてもよい。処理装置702は、特定用途向け集積回路(ASIC)、フィールドプログラマブルゲートアレイ(FPGA)、デジタル信号プロセッサ(DSP)、ネットワーク・プロセッサなどといった一つまたは複数の特殊目的処理装置をも含んでいてもよい。処理装置702は、本稿で論じられた動作および段階を実行するための命令726を実行するよう構成されてもよい。
コンピューティング装置700はさらに、ネットワーク718と通信しうるネットワーク・インターフェース装置722を含んでいてもよい。コンピューティング装置700は、ディスプレイ装置710(たとえば液晶ディスプレイ(LCD)または陰極線管(CRT))、英数字入力装置712(たとえばキーボード)、カーソル制御装置714(たとえばマウス)および信号生成装置720(たとえばスピーカー)をも含んでいてもよい。ある実装では、ディスプレイ装置710、英数字入力装置712およびカーソル制御装置714は単一のコンポーネントまたは装置(たとえばLCDタッチスクリーン)に組み合わされてもよい。
データ記憶装置716は、本稿に記載される方法または機能の任意の一つまたは複数を具現する一組または複数組の命令726(たとえば図1のAPI仕様モジュール104)が記憶されているコンピュータ可読記憶媒体724を含んでいてもよい。命令726は、コンピューティング装置700によるその実行の間、完全にまたは少なくとも部分的に、メイン・メモリ704内および/または処理装置702内に存在し、メイン・メモリ704および処理装置702もコンピュータ可読媒体をなしてもよい。命令はさらに、ネットワーク・インターフェース装置722を介してネットワーク718を通じて送受信されてもよい。
コンピュータ可読記憶媒体724はある例示的実施形態では単一の媒体であると示されているが、「コンピュータ可読記憶媒体」という用語は、前記一組または複数組の命令を記憶する単一の媒体または複数の媒体(たとえば、中央集中式または分散式のデータベースおよび/または付随するキャッシュおよびサーバー)を含んでいてもよい。「コンピュータ可読記憶媒体」という用語はまた、本開示の方法の任意の一つまたは複数を機械に実行させる、機械による実行のための一組の命令を、記憶する、エンコードするまたは担持することができる任意の媒体をも含んでいてもよい。よって、「コンピュータ可読記憶媒体」という用語は、半導体メモリ、光メディアおよび磁気メディアを含むがそれに限られないと解釈されうる。
本稿に記載される実施形態は、コンピュータ実行可能命令を担持するまたは記憶するためのコンピュータ可読媒体を使って実装されてもよい。そのようなコンピュータ可読媒体は、汎用または特殊目的コンピュータによってアクセスされうるいかなる利用可能な媒体であってもよい。限定ではなく例として、そのようなコンピュータ可読媒体は、非一時的なコンピュータ可読記憶媒体を含んでいてもよく、それは、ランダム・アクセス・メモリ(RAM)、読み出し専用メモリ(ROM)、電気的に消去可能なプログラム可能な読み出し専用メモリ(EEPROM)、コンパクトディスク読み出し専用メモリ(CD-ROM)または他の光ディスク記憶、磁気ディスク記憶または他の磁気記憶デバイス、フラッシュメモリ・デバイス(たとえば半導体メモリ・デバイス)またはコンピュータ実行可能命令またはデータ構造の形で所望されるプログラム・コードを担持または記憶するために使用されうる、汎用または専用コンピュータによってアクセスされうる他の任意の記憶媒体を含んでいてもよい。上記の組み合わせも、コンピュータ可読媒体の範囲内に含められてもよい。
コンピュータ実行可能命令はたとえば、汎用コンピュータ、専用コンピュータまたは専用処理装置(たとえば一つまたは複数のプロセッサ)に、ある機能または機能群を実行させる命令およびデータを含んでいてもよい。主題は構造的な特徴および/または方法論的な工程に固有の言辞で記述されてきたが、付属の請求項において定義される主題は必ずしも上記の個別的な特徴または工程に限定されないことは理解される。むしろ、上記の個別的な特徴および工程は、請求項を実装する例示的な形として開示されている。
本稿での用法では、用語「モジュール」または「コンポーネント」は、コンピューティング・システムの汎用ハードウェア(たとえばコンピュータ可読媒体、処理装置など)に記憶および/または実行されうるモジュールまたはコンポーネントおよび/またはソフトウェア・オブジェクトまたはソフトウェア・ルーチンの動作を実行するよう構成された個別的なハードウェア実装を指すことがありうる。いくつかの実施形態では、本稿に記載される種々のコンポーネント、モジュール、エンジンおよびサービスは、(たとえば別個のスレッドとして)コンピューティング・システム上で実行されるオブジェクトまたはプロセスとして実装されてもよい。本稿に記載されるシステムおよび方法のいくつかは一般に(汎用ハードウェアに記憶されるおよび/または実行される)ソフトウェアで実装されるものとして記述されるが、個別的なハードウェア実装またはソフトウェアおよび個別的ハードウェア実装の組み合わせも可能であり、考えられている。本稿において、「コンピューティング・エンティティ」は、本稿で先に定義した任意のコンピューティング・システムまたはコンピューティング・システム上で走る任意のモジュールまたはモジュレットの組み合わせであってよい。
本稿に記載されるすべての例および条件付きの言辞は、本発明および発明者によって当技術分野の発展のために寄与される概念の理解において読者を助ける教育目的を意図されており、そのような特定的に挙げられる例および条件に限定することなく解釈されるものとする。本発明の実施形態について詳細に述べてきたが、本発明の精神および範囲から外れることなく、これにさまざまな変化、代替および変更をなすことができることは理解しておくべきである。
以上の実施例を含む実施形態に関し、さらに以下の付記を開示する。
(付記1)
通信インターフェースと;
前記通信インターフェースに動作上結合されたプロセッサとを有するシステムであって、前記プロセッサは:
前記通信インターフェースを介して、定義されたアプリケーション・プログラミング・インターフェース(API)仕様(specification)を受け取る段階であって、前記定義されたAPI仕様は、第一のフォーマットでのAPIテーブルを含み、前記APIテーブルの各列はAPIパラメータに関連付けられている、段階と;
前記定義されたAPI仕様に基づいてキー・モデルを生成する段階であって、前記キー・モデルは、前記APIテーブルの一つまたは複数のAPIパラメータが、定義されたフォーマットでのAPIパラメータの対応するクラスにマッピングされたものを含む、段階と;
前記通信インターフェースを介して、抽出されたテーブルを受け取る段階であって、前記抽出されたテーブルの各列は、前記第一のフォーマットでのAPIパラメータに関連付けられている、段階と;
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける段階と;
前記定義されたフォーマットで前記抽出されたテーブルの前記APIパラメータを含むAPI仕様を生成する段階とを含む動作を実行するよう構成されている、
システム。
(付記2)
前記定義されたAPI仕様に基づいてキー・モデルを生成する動作が:
前記APIテーブルの各列についてキー項目を定義する段階であって、各キー項目はAPIパラメータを定義する、段階と;
前記APIテーブルの各列について値項目を決定する段階と;
前記APIテーブルの各列についての各キー項目および値項目に関連付けられたルート・ペアレントを決定する段階と;
明瞭キー・テーブル(distinct key table)を生成する段階であって、前記明瞭キー・テーブルの第一列は、異なる行に位置する前記APIテーブルのキー項目を含み、第二列は対応するキー項目と同じ行に値項目を含み、第三列は対応するキー項目および値項目と同じ行にルート・ペアレントを含む、段階と;
少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定する段階と;
一つまたは複数のキー項目が同じまたは実質的に同様であると判定することに応答して、同じまたは実質的に同様であるキー項目と、対応する値項目およびルート・ペアレントとを、前記明瞭キー・テーブルにおいて対応するAPIパラメータに関連付けられた列にマッピングする段階であって、前記キー・モデルは前記明瞭キー・テーブルに基づいて生成される、段階とを含む、
付記1記載のシステム。
(付記3)
各ルート・ペアレントが、各キー項目および値項目にアクセスするためのファイル・パスの構造を含む、付記2記載のシステム。
(付記4)
前記プロセッサがさらに:
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定する段階と;
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれる値項目の値類似性スコアを決定する段階と;
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定する段階とを実行するようさらに構成されている、
付記2記載のシステム。
(付記5)
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける動作が、前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についての列類似性スコアを
Figure 0007206687000002
に従って決定することを含み、iは1からキー項目の総数までの範囲内の値であり、jは1から値項目の総数までの範囲内の値であり、lは1からルート・ペアレントの総数までの範囲内の値であり、Siは前記抽出されたテーブルの第i列および前記明瞭キー・テーブルの各列についてのルート・ペアレントの構造類似性スコアであり、Viは前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についてのi番目の値項目の値類似性スコアであり、Kiは前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についてのi番目のキー項目のキー類似性スコアである、
付記4記載のシステム。
(付記6)
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける動作がさらに、
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についての列類似性スコアが類似性範囲内であるかどうかを判定し;
前記抽出されたテーブルのある列および前記明瞭キー・テーブルのある列についての列類似性スコアが前記類似性範囲内であると判定することに応答して、前記抽出されたテーブルのその列を前記定義されたフォーマットでのAPIパラメータの対応するクラスに関連付けることを含む、
付記5記載のシステム。
(付記7)
前記抽出されたテーブルが、前記第一のフォーマットで前記抽出されたテーブルに含まれるAPIパラメータに関連付けられた、一つまたは複数のキー項目、一つまたは複数の値項目および一つまたは複数のルート・ペアレントのうちの少なくとも一つを含む、付記1記載のシステム。
(付記8)
通信インターフェースを介して、定義されたアプリケーション・プログラミング・インターフェース(API)仕様を受け取る段階であって、前記定義されたAPI仕様は、第一のフォーマットでのAPIテーブルを含み、前記APIテーブルの各列はAPIパラメータに関連付けられている、段階と;
前記定義されたAPI仕様に基づいてキー・モデルを生成する段階であって、前記キー・モデルは、前記APIテーブルの一つまたは複数のAPIパラメータが、定義されたフォーマットでのAPIパラメータの対応するクラスにマッピングされたものを含む、段階と;
前記通信インターフェースを介して、抽出されたテーブルを受け取る段階であって、前記抽出されたテーブルの各列は、前記第一のフォーマットでのAPIパラメータに関連付けられている、段階と;
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける段階と;
前記定義されたフォーマットで前記抽出されたテーブルの前記APIパラメータを含むAPI仕様を生成する段階とを含む
方法。
(付記9)
前記定義されたAPI仕様に基づいてキー・モデルを生成する動作が:
前記APIテーブルの各列についてキー項目を定義する段階であって、各キー項目はAPIパラメータを定義する、段階と;
前記APIテーブルの各列について値項目を決定する段階と;
前記APIテーブルの各列についての各キー項目および値項目に関連付けられたルート・ペアレントを決定する段階と;
明瞭キー・テーブルを生成する段階であって、前記明瞭キー・テーブルの第一列は、異なる行に位置する前記APIテーブルのキー項目を含み、第二列は対応するキー項目と同じ行に値項目を含み、第三列は対応するキー項目および値項目と同じ行にルート・ペアレントを含む、段階と;
少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定する段階と;
一つまたは複数のキー項目が同じまたは実質的に同様であると判定することに応答して、同じまたは実質的に同様であるキー項目と、対応する値項目およびルート・ペアレントとを、前記明瞭キー・テーブルにおいて対応するAPIパラメータに関連付けられた列にマッピングする段階であって、前記キー・モデルは前記明瞭キー・テーブルに基づいて生成される、段階とを含む、
付記8記載のシステム。
(付記10)
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定する段階と;
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれる値項目の値類似性スコアを決定する段階と;
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定する段階とをさらに含む、
付記9記載の方法。
(付記11)
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける動作が、前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についての列類似性スコアを
Figure 0007206687000003
に従って決定することを含み、iは1からキー項目の総数までの範囲内の値であり、jは1から値項目の総数までの範囲内の値であり、lは1からルート・ペアレントの総数までの範囲内の値であり、Siは前記抽出されたテーブルの第i列および前記明瞭キー・テーブルの各列についてのルート・ペアレントの構造類似性スコアであり、Viは前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についてのi番目の値項目の値類似性スコアであり、Kiは前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についてのi番目のキー項目のキー類似性スコアである、
付記10記載の方法。
(付記12)
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける動作がさらに、
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についての列類似性スコアが類似性範囲内であるかどうかを判定し;
前記抽出されたテーブルのある列および前記明瞭キー・テーブルのある列についての列類似性スコアが前記類似性範囲内であると判定することに応答して、前記抽出されたテーブルのその列を前記定義されたフォーマットでのAPIパラメータの対応するクラスに関連付けることを含む、
付記11記載の方法。
(付記13)
前記抽出されたテーブルが、前記第一のフォーマットで前記抽出されたテーブルに含まれるAPIパラメータに関連付けられた、一つまたは複数のキー項目、一つまたは複数の値項目および一つまたは複数のルート・ペアレントのうちの少なくとも一つを含む、付記8記載の方法。
(付記14)
動作を実行するためにプロセッサによって実行可能なプログラミング・コードがエンコードされている非一時的なコンピュータ可読媒体であって、前記動作は:
通信インターフェースを介して、定義されたアプリケーション・プログラミング・インターフェース(API)仕様を受け取る段階であって、前記定義されたAPI仕様は、第一のフォーマットでのAPIテーブルを含み、前記APIテーブルの各列はAPIパラメータに関連付けられている、段階と;
前記定義されたAPI仕様に基づいてキー・モデルを生成する段階であって、前記キー・モデルは、前記APIテーブルの一つまたは複数のAPIパラメータが、定義されたフォーマットでのAPIパラメータの対応するクラスにマッピングされたものを含む、段階と;
前記通信インターフェースを介して、抽出されたテーブルを受け取る段階であって、前記抽出されたテーブルの各列は、前記第一のフォーマットでのAPIパラメータに関連付けられている、段階と;
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける段階と;
前記定義されたフォーマットで前記抽出されたテーブルの前記APIパラメータを含むAPI仕様を生成する段階とを含む、
非一時的なコンピュータ可読媒体。
(付記15)
前記定義されたAPI仕様に基づいてキー・モデルを生成する動作が:
前記APIテーブルの各列についてキー項目を定義する段階であって、各キー項目はAPIパラメータを定義する、段階と;
前記APIテーブルの各列について値項目を決定する段階と;
前記APIテーブルの各列についての各キー項目および値項目に関連付けられたルート・ペアレントを決定する段階と;
明瞭キー・テーブルを生成する段階であって、前記明瞭キー・テーブルの第一列は、異なる行に位置する前記APIテーブルのキー項目を含み、第二列は対応するキー項目と同じ行に値項目を含み、第三列は対応するキー項目および値項目と同じ行にルート・ペアレントを含む、段階と;
少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定する段階と;
一つまたは複数のキー項目が同じまたは実質的に同様であると判定することに応答して、同じまたは実質的に同様であるキー項目と、対応する値項目およびルート・ペアレントとを、前記明瞭キー・テーブルにおいて対応するAPIパラメータに関連付けられた列にマッピングする段階であって、前記キー・モデルは前記明瞭キー・テーブルに基づいて生成される、段階とを含む、
付記14記載の非一時的なコンピュータ可読媒体。
(付記16)
各ルート・ペアレントが、各キー項目および値項目にアクセスするためのファイル・パスの構造を含む、付記15記載の非一時的なコンピュータ可読媒体。
(付記17)
前記動作がさらに:
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定する段階と;
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれる値項目の値類似性スコアを決定する段階と;
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定する段階とを含む、
付記15記載の非一時的なコンピュータ可読媒体。
(付記18)
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける動作が、前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についての列類似性スコアを
Figure 0007206687000004
に従って決定することを含み、iは1からキー項目の総数までの範囲内の値であり、jは1から値項目の総数までの範囲内の値であり、lは1からルート・ペアレントの総数までの範囲内の値であり、Siは前記抽出されたテーブルの第i列および前記明瞭キー・テーブルの各列についてのルート・ペアレントの構造類似性スコアであり、Viは前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についてのi番目の値項目の値類似性スコアであり、Kiは前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についてのi番目のキー項目のキー類似性スコアである、
付記17記載の非一時的なコンピュータ可読媒体。
(付記19)
前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたフォーマットでのAPIパラメータのクラスに関連付ける動作がさらに、
前記抽出されたテーブルの各列および前記明瞭キー・テーブルの各列についての列類似性スコアが類似性範囲内であるかどうかを判定し;
前記抽出されたテーブルのある列および前記明瞭キー・テーブルのある列についての列類似性スコアが前記類似性範囲内であると判定することに応答して、前記抽出されたテーブルのその列を前記定義されたフォーマットでのAPIパラメータの対応するクラスに関連付けることを含む、
付記18記載の非一時的なコンピュータ可読媒体。
(付記20)
前記抽出されたテーブルが、前記第一のフォーマットで前記抽出されたテーブルに含まれるAPIパラメータに関連付けられた、一つまたは複数のキー項目、一つまたは複数の値項目および一つまたは複数のルート・ペアレントのうちの少なくとも一つを含む、付記14記載の非一時的なコンピュータ可読媒体。
102 抽出されたテーブル
104 API仕様モジュール
106 キー・モジュール
107 明瞭キー・テーブル
108 定義されたAPI仕様
110 APIテーブル
112 API仕様

202 APIテーブルを含む定義されたAPI仕様を受領
204 APIテーブルから各列を抽出
206 キー項目のリストを生成
208 値項目のリストを生成
210 ルート・ペアレントのリストを生成
212 APIテーブルにおける同様のキー項目を関連付け
214 明瞭キー・テーブルを生成
216 キー・モデルを生成

302 抽出されたテーブルを受領
304 抽出されたテーブルから各列を抽出
306 明瞭キー・テーブルを受領
308 明瞭キー・テーブルから各列を抽出
310 抽出されたテーブルおよび明瞭キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定
312 抽出されたテーブルおよび明瞭キー・テーブルの各列に含まれる値項目の値類似性スコアを決定
314 抽出されたテーブルおよび明瞭キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定
316 明瞭キー・テーブルの各キー項目についてキー類似性スコアを決定
318 明瞭キー・テーブルの列に比べた、抽出されたテーブルの列についての列類似性スコアを決定
320 列類似性スコアが類似性範囲内?
322 抽出されたテーブルのその列を、定義されたフォーマットでのAPIパラメータのクラスに関連付け
324 明瞭キー・テーブルの各列に比べた、抽出されたテーブルの各列についての列類似性スコアが決定済みか?
326 キー・モデルを生成

502 定義されたAPI仕様を受領
504 キー・モデルを生成
506 抽出されたテーブルを受領
508 抽出されたテーブルの各列を、定義されたフォーマットでのAPIパラメータのクラスに関連付け
510 定義されたフォーマットで抽出されたテーブルのAPIパラメータを含むAPI仕様を生成

602 APIテーブルの各列についてキー項目を決定
604 APIテーブルの各列について値項目を決定
606 APIテーブルの各列について、各キー項目および値項目に関連付けられたルート・ペアレントを決定
608 明瞭キー・テーブルを生成
610 少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定
612 同じまたは実質的に同様であるキー項目および対応する値項目およびルート・ペアレントを、明瞭キー・テーブルにおいて対応するAPIパラメータに関連付けられている列にマッピング

702 プロセッサ
704 メイン・メモリ
706 静的メモリ
710 表示装置
712 英数字入力装置
714 カーソル制御装置
716 データ記憶装置
718 ネットワーク
720 信号生成装置
722 ネットワーク・インターフェース装置
724 コンピュータ可読媒体
726 命令

Claims (20)

  1. 通信インターフェースと;
    前記通信インターフェースに動作上結合されたプロセッサとを有するシステムであって、前記プロセッサは:
    前記通信インターフェースを介して、機械可読な定義されたアプリケーション・プログラミング・インターフェース(API)仕様を受け取る段階であって、前記定義されたAPI仕様は、第一のAPI記述フォーマットでのAPIテーブルを含み、前記APIテーブルの各列はAPIパラメータに関連付けられている、段階と;
    前記定義されたAPI仕様に基づいてキー・モデルを生成する段階であって、前記キー・モデルは、前記APIテーブルの一つまたは複数のAPIパラメータが、定義されたAPI記述フォーマットでのAPIパラメータの対応するクラスにマッピングされたものを含む、段階と;
    前記通信インターフェースを介して、APIドキュメンテーションから抽出されたテーブルを受け取る段階であって、前記抽出されたテーブルの各列は、前記第一のAPI記述フォーマットでのAPIパラメータに関連付けられている、段階と;
    前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける段階と;
    前記定義されたAPI記述フォーマットで前記抽出されたテーブルの前記APIパラメータを含むAPI仕様を生成する段階とを含む動作を実行するよう構成されている、
    システム。
  2. 前記定義されたAPI仕様に基づいてキー・モデルを生成する動作が:
    前記APIテーブルの各列についてキー項目を定義する段階であって、各キー項目はAPIパラメータを決定する、段階と;
    前記APIテーブルの各列について値項目を決定する段階と;
    前記APIテーブルの各列についての各キー項目および値項目に関連付けられたルート・ペアレントを決定する段階と;
    ー・テーブルを生成する段階であって、前記キー・テーブルの第一列は、前記APIテーブルのキー項目を異なる行に含み、第二列は前記APIテーブルの値項目を、その値項目に対応するキー項目と同じ行に含み、第三列は前記APIテーブルのルート・ペアレントを、そのルート・ペアレントに対応するキー項目および値項目と同じ行に含む、段階と;
    少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定する段階と;
    一つまたは複数のキー項目が同じまたは実質的に同様であると判定することに応答して、同じまたは実質的に同様であるキー項目と、対応する値項目およびルート・ペアレントとを、前記キー・テーブルにおいて対応するAPIパラメータに関連付けられた列にマッピングする段階であって、前記キー・モデルは前記キー・テーブルに基づいて生成される、段階とを含む、
    請求項1記載のシステム。
  3. 各ルート・ペアレントが、各キー項目および値項目にアクセスするためのファイル・パスの構造を含む、請求項2記載のシステム。
  4. 前記プロセッサがさらに:
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定する段階と;
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれる値項目の値類似性スコアを決定する段階と;
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定する段階とを実行するようさらに構成されている、
    請求項2記載のシステム。
  5. 前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける動作が、前記抽出されたテーブルの各列および前記キー・テーブルの各列についての列類似性スコアを
    Figure 0007206687000005

    に従って決定することを含み、iは1からキー項目の総数までの範囲内の値であり、jは1から値項目の総数までの範囲内の値であり、lは1からルート・ペアレントの総数までの範囲内の値であり、Siは前記抽出されたテーブルの第i列および前記キー・テーブルの各列についてのルート・ペアレントの構造類似性スコアであり、Viは前記抽出されたテーブルの各列および前記キー・テーブルの各列についてのi番目の値項目の値類似性スコアであり、Kiは前記抽出されたテーブルの各列および前記キー・テーブルの各列についてのi番目のキー項目のキー類似性スコアである、
    請求項4記載のシステム。
  6. 前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける動作がさらに、
    前記抽出されたテーブルの各列および前記キー・テーブルの各列についての列類似性スコアが類似性範囲内であるかどうかを判定し;
    前記抽出されたテーブルのある列および前記キー・テーブルのある列についての列類似性スコアが前記類似性範囲内であると判定することに応答して、前記抽出されたテーブルのその列を前記定義されたAPI記述フォーマットでのAPIパラメータの対応するクラスに関連付けることを含む、
    請求項5記載のシステム。
  7. 前記抽出されたテーブルが、前記第一のAPI記述フォーマットで前記抽出されたテーブルに含まれるAPIパラメータに関連付けられた、一つまたは複数のキー項目、一つまたは複数の値項目および一つまたは複数のルート・ペアレントのうちの少なくとも一つを含む、請求項1記載のシステム。
  8. 通信インターフェースを介して、機械可読な定義されたアプリケーション・プログラミング・インターフェース(API)仕様を受け取る段階であって、前記定義されたAPI仕様は、第一のAPI記述フォーマットでのAPIテーブルを含み、前記APIテーブルの各列はAPIパラメータに関連付けられている、段階と;
    前記定義されたAPI仕様に基づいてキー・モデルを生成する段階であって、前記キー・モデルは、前記APIテーブルの一つまたは複数のAPIパラメータが、定義されたAPI記述フォーマットでのAPIパラメータの対応するクラスにマッピングされたものを含む、段階と;
    前記通信インターフェースを介して、APIドキュメンテーションから抽出されたテーブルを受け取る段階であって、前記抽出されたテーブルの各列は、前記第一のAPI記述フォーマットでのAPIパラメータに関連付けられている、段階と;
    前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける段階と;
    前記定義されたAPI記述フォーマットで前記抽出されたテーブルの前記APIパラメータを含むAPI仕様を生成する段階とを含む
    方法。
  9. 前記定義されたAPI仕様に基づいてキー・モデルを生成する動作が:
    前記APIテーブルの各列についてキー項目を定義する段階であって、各キー項目はAPIパラメータを決定する、段階と;
    前記APIテーブルの各列について値項目を決定する段階と;
    前記APIテーブルの各列についての各キー項目および値項目に関連付けられたルート・ペアレントを決定する段階と;
    ー・テーブルを生成する段階であって、前記キー・テーブルの第一列は、前記APIテーブルのキー項目を異なる行に含み、第二列は前記APIテーブルの値項目を、その値項目に対応するキー項目と同じ行に含み、第三列は前記APIテーブルのルート・ペアレントを、そのルート・ペアレントに対応するキー項目および値項目と同じ行に含む、段階と;
    少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定する段階と;
    一つまたは複数のキー項目が同じまたは実質的に同様であると判定することに応答して、同じまたは実質的に同様であるキー項目と、対応する値項目およびルート・ペアレントとを、前記キー・テーブルにおいて対応するAPIパラメータに関連付けられた列にマッピングする段階であって、前記キー・モデルは前記キー・テーブルに基づいて生成される、段階とを含む、
    請求項8記載の方法。
  10. 前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定する段階と;
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれる値項目の値類似性スコアを決定する段階と;
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定する段階とをさらに含む、
    請求項9記載の方法。
  11. 前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける動作が、前記抽出されたテーブルの各列および前記キー・テーブルの各列についての列類似性スコアを
    Figure 0007206687000006

    に従って決定することを含み、iは1からキー項目の総数までの範囲内の値であり、jは1から値項目の総数までの範囲内の値であり、lは1からルート・ペアレントの総数までの範囲内の値であり、Siは前記抽出されたテーブルの第i列および前記キー・テーブルの各列についてのルート・ペアレントの構造類似性スコアであり、Viは前記抽出されたテーブルの各列および前記キー・テーブルの各列についてのi番目の値項目の値類似性スコアであり、Kiは前記抽出されたテーブルの各列および前記キー・テーブルの各列についてのi番目のキー項目のキー類似性スコアである、
    請求項10記載の方法。
  12. 前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける動作がさらに、
    前記抽出されたテーブルの各列および前記キー・テーブルの各列についての列類似性スコアが類似性範囲内であるかどうかを判定し;
    前記抽出されたテーブルのある列および前記キー・テーブルのある列についての列類似性スコアが前記類似性範囲内であると判定することに応答して、前記抽出されたテーブルのその列を前記定義されたAPI記述フォーマットでのAPIパラメータの対応するクラスに関連付けることを含む、
    請求項11記載の方法。
  13. 前記抽出されたテーブルが、前記第一のAPI記述フォーマットで前記抽出されたテーブルに含まれるAPIパラメータに関連付けられた、一つまたは複数のキー項目、一つまたは複数の値項目および一つまたは複数のルート・ペアレントのうちの少なくとも一つを含む、請求項8記載の方法。
  14. 動作を実行するためにプロセッサによって実行可能なプログラミング・コードがエンコードされている非一時的なコンピュータ可読媒体であって、前記動作は:
    通信インターフェースを介して、機械可読な定義されたアプリケーション・プログラミング・インターフェース(API)仕様を受け取る段階であって、前記定義されたAPI仕様は、第一のAPI記述フォーマットでのAPIテーブルを含み、前記APIテーブルの各列はAPIパラメータに関連付けられている、段階と;
    前記定義されたAPI仕様に基づいてキー・モデルを生成する段階であって、前記キー・モデルは、前記APIテーブルの一つまたは複数のAPIパラメータが、定義されたAPI記述フォーマットでのAPIパラメータの対応するクラスにマッピングされたものを含む、段階と;
    前記通信インターフェースを介して、APIドキュメンテーションから抽出されたテーブルを受け取る段階であって、前記抽出されたテーブルの各列は、前記第一のAPI記述フォーマットでのAPIパラメータに関連付けられている、段階と;
    前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける段階と;
    前記定義されたAPI記述フォーマットで前記抽出されたテーブルの前記APIパラメータを含むAPI仕様を生成する段階とを含む、
    非一時的なコンピュータ可読媒体。
  15. 前記定義されたAPI仕様に基づいてキー・モデルを生成する動作が:
    前記APIテーブルの各列についてキー項目を定義する段階であって、各キー項目はAPIパラメータを決定する、段階と;
    前記APIテーブルの各列について値項目を決定する段階と;
    前記APIテーブルの各列についての各キー項目および値項目に関連付けられたルート・ペアレントを決定する段階と;
    ー・テーブルを生成する段階であって、前記キー・テーブルの第一列は、前記APIテーブルのキー項目を異なる行に含み、第二列は前記APIテーブルの値項目を、その値項目に対応するキー項目と同じ行に含み、第三列は前記APIテーブルのルート・ペアレントを、そのルート・ペアレントに対応するキー項目および値項目と同じ行に含む、段階と;
    少なくとも一つまたは複数のキー項目が同じまたは実質的に同様であるかどうかを判定する段階と;
    一つまたは複数のキー項目が同じまたは実質的に同様であると判定することに応答して、同じまたは実質的に同様であるキー項目と、対応する値項目およびルート・ペアレントとを、前記キー・テーブルにおいて対応するAPIパラメータに関連付けられた列にマッピングする段階であって、前記キー・モデルは前記キー・テーブルに基づいて生成される、段階とを含む、
    請求項14記載の非一時的なコンピュータ可読媒体。
  16. 各ルート・ペアレントが、各キー項目および値項目にアクセスするためのファイル・パスの構造を含む、請求項15記載の非一時的なコンピュータ可読媒体。
  17. 前記動作がさらに:
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれるキー項目のキー類似性スコアを決定する段階と;
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれる値項目の値類似性スコアを決定する段階と;
    前記抽出されたテーブルの各列および前記キー・テーブルの各列に含まれるルート・ペアレントの構造類似性スコアを決定する段階とを含む、
    請求項15記載の非一時的なコンピュータ可読媒体。
  18. 前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける動作が、前記抽出されたテーブルの各列および前記キー・テーブルの各列についての列類似性スコアを
    Figure 0007206687000007

    に従って決定することを含み、iは1からキー項目の総数までの範囲内の値であり、jは1から値項目の総数までの範囲内の値であり、lは1からルート・ペアレントの総数までの範囲内の値であり、Siは前記抽出されたテーブルの第i列および前記キー・テーブルの各列についてのルート・ペアレントの構造類似性スコアであり、Viは前記抽出されたテーブルの各列および前記キー・テーブルの各列についてのi番目の値項目の値類似性スコアであり、Kiは前記抽出されたテーブルの各列および前記キー・テーブルの各列についてのi番目のキー項目のキー類似性スコアである、
    請求項17記載の非一時的なコンピュータ可読媒体。
  19. 前記抽出されたテーブルの各列を、前記キー・モデルに基づいて、前記定義されたAPI記述フォーマットでのAPIパラメータのクラスに関連付ける動作がさらに、
    前記抽出されたテーブルの各列および前記キー・テーブルの各列についての列類似性スコアが類似性範囲内であるかどうかを判定し;
    前記抽出されたテーブルのある列および前記キー・テーブルのある列についての列類似性スコアが前記類似性範囲内であると判定することに応答して、前記抽出されたテーブルのその列を前記定義されたAPI記述フォーマットでのAPIパラメータの対応するクラスに関連付けることを含む、
    請求項18記載の非一時的なコンピュータ可読媒体。
  20. 前記抽出されたテーブルが、前記第一のAPI記述フォーマットで前記抽出されたテーブルに含まれるAPIパラメータに関連付けられた、一つまたは複数のキー項目、一つまたは複数の値項目および一つまたは複数のルート・ペアレントのうちの少なくとも一つを含む、請求項14記載の非一時的なコンピュータ可読媒体。
JP2018152605A 2018-02-02 2018-08-14 Apiパラメータのマッピング Active JP7206687B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US15/887,906 US10387145B1 (en) 2018-02-02 2018-02-02 Mapping API parameters
US15/887906 2018-02-02

Publications (2)

Publication Number Publication Date
JP2019133622A JP2019133622A (ja) 2019-08-08
JP7206687B2 true JP7206687B2 (ja) 2023-01-18

Family

ID=67475569

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2018152605A Active JP7206687B2 (ja) 2018-02-02 2018-08-14 Apiパラメータのマッピング

Country Status (2)

Country Link
US (1) US10387145B1 (ja)
JP (1) JP7206687B2 (ja)

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10594684B2 (en) 2016-09-14 2020-03-17 Oracle International Corporation Generating derived credentials for a multi-tenant identity cloud service
US10831789B2 (en) 2017-09-27 2020-11-10 Oracle International Corporation Reference attribute query processing for a multi-tenant cloud service
US10715564B2 (en) 2018-01-29 2020-07-14 Oracle International Corporation Dynamic client registration for an identity cloud service
US11423111B2 (en) 2019-02-25 2022-08-23 Oracle International Corporation Client API for rest based endpoints for a multi-tenant identify cloud service
US11792226B2 (en) * 2019-02-25 2023-10-17 Oracle International Corporation Automatic api document generation from scim metadata
US11687378B2 (en) 2019-09-13 2023-06-27 Oracle International Corporation Multi-tenant identity cloud service with on-premise authentication integration and bridge high availability
US11870770B2 (en) 2019-09-13 2024-01-09 Oracle International Corporation Multi-tenant identity cloud service with on-premise authentication integration
US10915378B1 (en) * 2019-10-29 2021-02-09 Sap Se Open discovery service
US11763073B2 (en) * 2021-08-20 2023-09-19 Sap Se Multi-dimensional table reproduction from image

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008041082A (ja) 2006-07-12 2008-02-21 Hitachi Ltd 処理装置及びプログラム
JP2016151881A (ja) 2015-02-17 2016-08-22 日本電信電話株式会社 Api集約装置及びapi互換方法
JP2017041158A (ja) 2015-08-21 2017-02-23 日本電信電話株式会社 Api変換テーブル生成装置、api変換テーブル生成方法、および、api変換テーブル生成プログラム

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6854123B1 (en) * 2000-05-09 2005-02-08 International Business Machines Corporation Method, system, and program for mapping standard application program interfaces (APIs) to user interface APIs
US7269833B2 (en) * 2001-12-12 2007-09-11 Sun Microsystems, Inc. Scriptable plug-in application programming interface
US7340745B2 (en) * 2002-06-25 2008-03-04 Sun Microsystems, Inc. Systems and methods for mapping API calls
US9811395B1 (en) * 2016-10-11 2017-11-07 Google Inc. Multi-platform mapping API

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008041082A (ja) 2006-07-12 2008-02-21 Hitachi Ltd 処理装置及びプログラム
JP2016151881A (ja) 2015-02-17 2016-08-22 日本電信電話株式会社 Api集約装置及びapi互換方法
JP2017041158A (ja) 2015-08-21 2017-02-23 日本電信電話株式会社 Api変換テーブル生成装置、api変換テーブル生成方法、および、api変換テーブル生成プログラム

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
KEHAGIAS, D. D., et al.,"An ontology-based mechanism for automatic categorization of web services",Concurrency and Computation: Practice and Experience [online],2011年08月15日,Vol. 24, No. 3,pp. 214-236,[retrieved on 2022-06-20], Retrieved from the Internet: <URL: https://onlinelibrary.wiley.com/doi/10.1002/cpe.1818>,<DOI: 10.1002/cpe.1818>

Also Published As

Publication number Publication date
JP2019133622A (ja) 2019-08-08
US20190243643A1 (en) 2019-08-08
US10387145B1 (en) 2019-08-20

Similar Documents

Publication Publication Date Title
JP7206687B2 (ja) Apiパラメータのマッピング
US9135244B2 (en) Method and apparatus for configurable microplanning
US10776561B2 (en) Method and apparatus for generating a linguistic representation of raw input data
US9047346B2 (en) Reporting language filtering and mapping to dimensional concepts
JP2018097846A (ja) Api学習
US8701087B2 (en) System and method of annotating class models
JP7178441B2 (ja) 要約生成方法、装置、プログラム、電子デバイス及び記憶媒体
WO2014035406A1 (en) Method and apparatus for configurable microplanning
US20140282189A1 (en) Chaining applications
US20200210158A1 (en) Automated or machine-enhanced source code debugging
KR20210056961A (ko) 의미 처리 방법, 장치, 전자 기기 및 매체
US11727222B2 (en) Method and apparatus for natural language document orchestrator
US11232105B2 (en) Unified metrics computation platform
US9026989B2 (en) Object extensions using attributes to decouple base classes from derived classes
US8869105B2 (en) Extensibility integrated development environment for business object extension development
US9507693B2 (en) Method, device and computer-readable storage medium for closure testing
Saabith et al. Popular python libraries and their application domains
US8856728B2 (en) Composition studio to develop and maintain surveillance and compliance scenarios
US20100218200A1 (en) Method for programmatic editing of text files
CN112269884B (zh) 信息抽取方法、装置、设备及存储介质
US9280361B2 (en) Methods and systems for a real time transformation of declarative model and layout into interactive, digital, multi device forms
US20180341645A1 (en) Methods and systems for translating natural language requirements to a semantic modeling language statement
Luckow et al. Symbolic pathfinder v7
Dudáš et al. What can the ontology describe? Visualizing local coverage in PURO modeler
De Meester High quality schema and data transformations for linked data generation

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20210513

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20220516

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20220628

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20220824

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20221219

R150 Certificate of patent or registration of utility model

Ref document number: 7206687

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150