注: 以下の翻訳の正確性は検証されていません。AIPを利用して英語版の原文から機械的に翻訳されたものです。
Palantir提供の言語モデルを使用するには、エンロールメントでまずAIPを有効にする必要があります。また、AIP開発者機能を使用する権限も必要です。カスタムモデルを使用しますか?代わりにカスタムモデルを使用してセマンティック検索ワークフローを作成するを確認してください。
このページでは、Palantir提供の埋め込みモデルを使用して概念的なエンドツーエンドのセマンティック検索ワークフローを構築するプロセスを説明します。
まず、埋め込みを生成し、それらをベクター
タイプのオブジェクトタイプに保存する必要があります。その後、Workshopでセマンティック検索ワークフローを設定するか、AIP Interactive Workshopウィジェットソリューションを構築するか、WorkshopおよびAIP Logicで使用するためのカスタムセマンティック検索関数を作成できます。
前提条件:
オプション:
Pipeline Builderを使用して、Text to Embeddings式でデータセット内のテキストをベクターとして埋め込みます。この式は文字列を取り、Palantir提供のモデルの1つを使用してベクターに変換します。ここではtext-embedding-ada-002
埋め込みモデルを使用します。
これらの埋め込みは、ベクターのプロパティとしてオントロジーに追加できます。
Palantir提供のモデルを使用して埋め込みを生成する際にさらに制御を行いたい場合は、Pythonトランスフォーム内の言語モデルを参照してください。
Workshop内でKNNオブジェクトセットを設定することは、コード不要でセマンティック検索ワークフローを構築する簡単な方法です。
+ プロパティで
オプションを選択し、メニューのプロパティのリストから埋め込みプロパティを選択します。このパネル内で次の設定を行うことができます:
さらにカスタマイズされたセマンティック検索ロジックについては、関数のセクションを参照してください。
AIP Agent Studioで作成されたAIPエージェントは、コード不要でオブジェクトをセマンティック検索を開始するのに適しています。機能性に対する制御をさらに強化したセマンティック検索の統合について学びましょう。
AIPエージェントの作成ガイドに従い、AIPエージェントを作成し、オントロジーコンテキストまたはオントロジーセマンティック検索ツールを追加します。この初期設定により、AIPエージェントにオブジェクトをセマンティック検索するように依頼することができます。
typescriptリポジトリを作成し、オブジェクトタイプをクエリする関数を作成できます。全体の目標は、ユーザーの入力を取得し、前述のPalantir提供のモデルを使用してベクターを生成し、オブジェクトタイプに対してKNN検索を行うことです。Palantir提供のモデルのインポート方法については、Functions内の言語モデルを参照してください。
以下のコードスニペットでは、ObjectApiName
のすべてのインスタンスをユーザーのユニークなObjectTypeに置き換えてください。識別子は時々小文字のobjectApiName
として表示される場合があります。
続行する前に、Functionsコードリポジトリのfunctions.json
ファイルに"enableVectorProperties": true
エントリが存在することを確認してください。このエントリが存在しない場合は、functions.json
に追加し、変更をコミットして続行します。さらなる支援が必要な場合は、Palantirの担当者に連絡してください。
Copied!1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
import { Function, Integer } from "@foundry/functions-api"; import { Objects, ObjectApiName } from "@foundry/ontology-api"; import { TextEmbeddingAda_002 } from "@foundry/models-api/language-models" // MyFunctionsクラスを定義 export class MyFunctions { // findRelevantObjectsメソッドに@Functionデコレータを付与 @Function() public async findRelevantObjects( query: string, // クエリ文字列 kValue: Integer, // 取得するオブジェクトの数 ): Promise<ObjectApiName[]> { // ObjectApiNameの配列をPromiseで返す // クエリが空の場合は空の配列を返す if (query.length < 1) { return [] } // テキスト埋め込みを生成 const embedding = await TextEmbeddingAda_002.createEmbeddings({inputs: [query]}).then(r => r.embeddings[0]); // オブジェクトを検索し、埋め込みベクトルが近いものを取得 return Objects.search() .objectApiName() // オブジェクトのAPI名で検索 .nearestNeighbors(obj => obj.embeddings.near(embedding, {kValue: kValue})) // kValue個の近傍オブジェクトを取得 .orderByRelevance() // 関連度で並び替え .take(kValue); // kValue個のオブジェクトを取得 } }
この時点で、自然言語でオブジェクトをクエリするためのセマンティック検索を実行できる関数が完成しています。関数をFoundry内のどこでも使用できるようにするために、関数を公開することを忘れないでください。
公開された関数をAIP Logic内のツールとして追加します。言語モデルに以下のようなプロンプトでツールを使用するよう指示します。
fetchRelevantObjectsツールをkValueを5に設定して使用し、最も関連性の高いオブジェクトを見つけます。ツールを使用する際にはクエリを引用符で囲むことを忘れないでください。