次の方法で共有


クイックスタート: REST を使用したベクトル検索

Search REST API を使用して、Azure AI 検索でクエリ ベクトルの作成、読み込み、クエリを行う方法について説明します。

Azure AI 検索のベクトル ストアにあるインデックス スキーマでは、ベクトル フィールドと非ベクトル フィールド、埋め込み空間を作成するアルゴリズムのためのベクトル検索構成、クエリ時に評価されるベクトル フィールド定義の設定が定義されています。 インデックス作成 REST API によってベクトル ストアが作成されます。

Azure サブスクリプションをお持ちでない場合は、開始する前に 無料アカウント を作成してください。

Note

このクイックスタートでは、ベクトル化の手順は省略し、サンプル ドキュメント内の埋め込みを提供します。 独自のコンテンツに対して組み込みのデータ チャンキングとベクトル化を追加したい場合は、[データのインポートとベクトル化] ウィザードのエンドツーエンドのチュートリアルを試してください。

前提条件

ファイルのダウンロード

GitHub から REST サンプルをダウンロードして、このクイックスタートの要求を送信します。 詳細については、「GitHub からファイルをダウンロードする」を参照してください。

ローカル システムで新しいファイルを開始し、この記事の手順を使用して手動で要求を作成することもできます。

検索エンドポイントと API キーを取得する

検索サービス エンドポイントと API キーは、Azure portal で確認できます。 次のステップで、これらの値を .rest または .http ファイルに貼り付けます。

検索エンドポイントへの要求は、認証および承認する必要があります。 このタスクには API キーまたはロールを使用できます。 キーの方が簡単に使い始めることができますが、安全性が高いのはロールの方です。 このクイックスタートでは API キーを使いますが、キーレス接続に切り替えることをお勧めします。

  1. Azure portal にサインインし、ご利用の検索サービスを探します

  2. [概要] ホーム ページで、URL を見つけます。 たとえば、エンドポイントは https://mydemo.search.windows.net のようになります。

    [概要] ページ上の URL プロパティのスクリーンショット。

  3. [設定]>[キー] の順に選択します。 [API キー] または [両方] を有効にする必要があります。 管理者 API キーは、オブジェクトの追加、変更、削除に使われます。 2 つの交換可能な管理者キーがあります。 どちらかをコピーします。

    Azure portal に表示された API キーを示すスクリーンショット。

ベクトル インデックスを作成する

[インデックスの作成 (REST)] ではベクトル インデックスを作成し、検索サービスに物理データ構造を設定します。

インデックス スキーマは、ホテルのコンテンツを中心に整理されています。 サンプル データは、7 つの架空のホテルのベクトルおよび非ベクトルの名前および説明で構成されています。 このスキーマには、ベクトル インデックス作成およびクエリとセマンティック ランク付けのための構成が含まれています。

  1. Visual Studio Code で新しいテキスト ファイルを作成します。

  2. ファイルの先頭に、前に収集した値の変数を追加します。

    @baseUrl = PUT-YOUR-SEARCH-SERVICE-URL-HERE
    @apiKey = PUT-YOUR-ADMIN-KEY-HERE
    
  3. .rest または .http ファイル拡張子でファイルを保存します。

  4. 次の例に貼り付けて、検索サービスに hotels-vector-quickstart インデックスを作成します。

    ### Create a new index
    POST {{baseUrl}}/indexes?api-version=2023-11-01  HTTP/1.1
        Content-Type: application/json
        api-key: {{apiKey}}
    
    {
        "name": "hotels-vector-quickstart",
        "fields": [
            {
                "name": "HotelId", 
                "type": "Edm.String",
                "searchable": false, 
                "filterable": true, 
                "retrievable": true, 
                "sortable": false, 
                "facetable": false,
                "key": true
            },
            {
                "name": "HotelName", 
                "type": "Edm.String",
                "searchable": true, 
                "filterable": false, 
                "retrievable": true, 
                "sortable": true, 
                "facetable": false
            },
            {
                "name": "HotelNameVector",
                "type": "Collection(Edm.Single)",
                "searchable": true,
                "retrievable": true,
                "dimensions": 1536,
                "vectorSearchProfile": "my-vector-profile"
            },
            {
                "name": "Description", 
                "type": "Edm.String",
                "searchable": true, 
                "filterable": false, 
                "retrievable": true, 
                "sortable": false, 
                "facetable": false
            },
            {
                "name": "DescriptionVector",
                "type": "Collection(Edm.Single)",
                "searchable": true,
                "retrievable": true,
                "dimensions": 1536,
                "vectorSearchProfile": "my-vector-profile"
            },
            {
                "name": "Category", 
                "type": "Edm.String",
                "searchable": true, 
                "filterable": true, 
                "retrievable": true, 
                "sortable": true, 
                "facetable": true
            },
            {
                "name": "Tags",
                "type": "Collection(Edm.String)",
                "searchable": true,
                "filterable": true,
                "retrievable": true,
                "sortable": false,
                "facetable": true
            },
            {
                "name": "Address", 
                "type": "Edm.ComplexType",
                "fields": [
                    {
                        "name": "City", "type": "Edm.String",
                        "searchable": true, "filterable": true, "retrievable": true, "sortable": true, "facetable": true
                    },
                    {
                        "name": "StateProvince", "type": "Edm.String",
                        "searchable": true, "filterable": true, "retrievable": true, "sortable": true, "facetable": true
                    }
                ]
            },
            {
                "name": "Location",
                "type": "Edm.GeographyPoint",
                "searchable": false, 
                "filterable": true, 
                "retrievable": true, 
                "sortable": true, 
                "facetable": false
            }
        ],
        "vectorSearch": {
            "algorithms": [
                {
                    "name": "my-hnsw-vector-config-1",
                    "kind": "hnsw",
                    "hnswParameters": 
                    {
                        "m": 4,
                        "efConstruction": 400,
                        "efSearch": 500,
                        "metric": "cosine"
                    }
                }
            ],
            "profiles": [      
                {
                    "name": "my-vector-profile",
                    "algorithm": "my-hnsw-vector-config-1"
                }
          ]
        },
        "semantic": {
            "configurations": [
                {
                    "name": "my-semantic-config",
                    "prioritizedFields": {
                        "titleField": {
                            "fieldName": "HotelName"
                        },
                        "prioritizedContentFields": [
                            { "fieldName": "Description" }
                        ],
                        "prioritizedKeywordsFields": [
                            { "fieldName": "Tags" }
                        ]
                    }
                }
            ]
        }
    }
    
  5. ファイルをもう一度保存してから、[要求の送信] を選びます。 HTTP/1.1 201 Created 応答が返されます。 その応答本文にはインデックス スキーマの JSON 表現が含まれています。

    この REST API に関する重要なポイント:

    • fields コレクションには、テキストおよびベクトル検索のための必須のキー フィールドと、テキストおよびベクトル フィールド (DescriptionDescriptionVector など) が含まれています。 ベクトル フィールドと非ベクトル フィールドを同じインデックスに配置すると、ハイブリッド クエリが有効になります。 たとえば、フィルター、セマンティック ランク付けを使用したテキスト検索、およびベクトルを 1 つのクエリ操作に結合できます。

    • ベクトル フィールドは、dimensions および vectorSearchProfile プロパティを含む type: Collection(Edm.Single) である必要があります。

    • vectorSearch セクションは、近似最近傍アルゴリズムの構成とプロファイルの配列です。 サポートされているアルゴリズムは、階層ナビゲーション可能な小さい世界 (hierarchical navigable small world) と網羅的 k ニアレスト ネイバーです。 詳細については、ベクトル検索の関連性スコアリングに関するページを参照してください。

    • [省略可能]: semantic 構成を使用すると、検索結果を再ランク付けできます。 結果の再ランク付けは、構成で指定された文字列フィールドに対する semantic 型のクエリで行うことができます。 詳細については、セマンティック ランク付けの概要に関するページを参照してください。

ドキュメントのアップロード

インデックスの作成と読み込みは別の手順です。 Azure AI 検索では、インデックスには検索可能なすべてのデータと、検索サービスで実行されるクエリが含まれます。 REST 呼び出しでは、データは JSON ドキュメントとして提供されます。 このタスクでは Documents- Index REST API を使用します。

URI を拡張して、docs コレクションと index 操作を含めます。

重要

次の例は実行可能なコードではありません。 読みやすくするために、ベクトル値は除外しています。各ベクトル値には 1,536 個の埋め込みがあり、この記事には長すぎるためです。 この手順を試す場合は、GitHub のサンプルから実行可能なコードをコピーします。

  1. 次の例のような、ドキュメントをアップロードする有効な要求を貼り付けます。

  2. ファイルを保存してから、[要求の送信] を選びます。 HTTP/1.1 201 Created 応答が返されます。 応答の本文に、検索ドキュメントの JSON 表現が含まれています。

### Upload documents
POST {{baseUrl}}/indexes/hotels-quickstart-vectors/docs/index?api-version=2023-11-01  HTTP/1.1
Content-Type: application/json
api-key: {{apiKey}}

{
    "value": [
        {
            "@search.action": "mergeOrUpload",
            "HotelId": "1",
            "HotelName": "Stay-Kay City Hotel",
            "HotelNameVector": [VECTOR ARRAY OMITTED],
            "Description": 
                "The hotel is ideally located on the main commercial artery of the city 
                in the heart of New York.",
            "DescriptionVector": [VECTOR ARRAY OMITTED],
            "Category": "Boutique",
            "Tags": [
                "pool",
                "air conditioning",
                "concierge"
            ],
        },
        {
            "@search.action": "mergeOrUpload",
            "HotelId": "2",
            "HotelName": "Old Century Hotel",
            "HotelNameVector": [VECTOR ARRAY OMITTED],
            "Description": 
                "The hotel is situated in a  nineteenth century plaza, which has been 
                expanded and renovated to the highest architectural standards to create a modern, 
                functional and first-class hotel in which art and unique historical elements 
                coexist with the most modern comforts.",
            "DescriptionVector": [VECTOR ARRAY OMITTED],
            "Category": "Boutique",
            "Tags": [
                "pool",
                "air conditioning",
                "free wifi",
                "concierge"
            ]
        },
        {
            "@search.action": "mergeOrUpload",
            "HotelId": "3",
            "HotelName": "Gastronomic Landscape Hotel",
            "HotelNameVector": [VECTOR ARRAY OMITTED],
            "Description": 
                "The Hotel stands out for its gastronomic excellence under the management of 
                William Dough, who advises on and oversees all of the Hotel’s restaurant services.",
            "DescriptionVector": [VECTOR ARRAY OMITTED],
            "Category": "Resort and Spa",
            "Tags": [
                "air conditioning",
                "bar",
                "continental breakfast"
            ]
        }
        {
            "@search.action": "mergeOrUpload",
            "HotelId": "4",
            "HotelName": "Sublime Palace Hotel",
            "HotelNameVector": [VECTOR ARRAY OMITTED],
            "Description": 
                "Sublime Palace Hotel is located in the heart of the historic center of 
                Sublime in an extremely vibrant and lively area within short walking distance to 
                the sites and landmarks of the city and is surrounded by the extraordinary beauty 
                of churches, buildings, shops and monuments. 
                Sublime Palace is part of a lovingly restored 1800 palace.",
            "DescriptionVector": [VECTOR ARRAY OMITTED],
            "Category": "Boutique",
            "Tags": [
                "concierge",
                "view",
                "24-hour front desk service"
            ]
        },
        {
            "@search.action": "mergeOrUpload",
            "HotelId": "13",
            "HotelName": "Luxury Lion Resort",
            "HotelNameVector": [VECTOR ARRAY OMITTED],
            "Description": 
                "Unmatched Luxury.  Visit our downtown hotel to indulge in luxury 
                accommodations. Moments from the stadium, we feature the best in comfort",
            "DescriptionVector": [VECTOR ARRAY OMITTED],
            "Category": "Resort and Spa",
            "Tags": [
                "view",
                "free wifi",
                "pool"
            ]
        },
        {
            "@search.action": "mergeOrUpload",
            "HotelId": "48",
            "HotelName": "Nordick's Valley Motel",
            "HotelNameVector": [VECTOR ARRAY OMITTED],
            "Description": 
                "Only 90 miles (about 2 hours) from the nation's capital and nearby 
                most everything the historic valley has to offer.  Hiking? Wine Tasting? Exploring 
                the caverns?  It's all nearby and we have specially priced packages to help make 
                our B&B your home base for fun while visiting the valley.",
            "DescriptionVector": [VECTOR ARRAY OMITTED],
            "Category": "Boutique",
            "Tags": [
                "continental breakfast",
                "air conditioning",
                "free wifi"
            ],
        },
        {
            "@search.action": "mergeOrUpload",
            "HotelId": "49",
            "HotelName": "Swirling Currents Hotel",
            "HotelNameVector": [VECTOR ARRAY OMITTED],
            "Description": 
                "Spacious rooms, glamorous suites and residences, rooftop pool, walking 
                access to shopping, dining, entertainment and the city center.",
            "DescriptionVector": [VECTOR ARRAY OMITTED],
            "Category": "Luxury",
            "Tags": [
                "air conditioning",
                "laundry service",
                "24-hour front desk service"
            ]
        }
    ]
}

この REST API に関する重要なポイント:

  • ペイロード内のドキュメントは、インデックス スキーマで定義されているフィールドで構成されます。

  • ベクトル フィールドには浮動小数点値が含まれます。 ディメンション属性には、それぞれ最小 2 個、最大 3,072 個の浮動小数点値があります。 このクイックスタートでは、ディメンション属性を 1,536 に設定します。これは、Azure OpenAI の text-embedding-ada-002 モデルによって生成される埋め込みのサイズであるためです。

クエリを実行する

これでドキュメントが読み込まれたので、Documents - Search Post (REST) を使用して、それらに対してベクトル クエリを発行できます。

さまざまなパターンを示すクエリがいくつかあります:

このセクションのベクトル クエリは、次の 2 つの文字列に基づいています。

  • 検索文字列: historic hotel walk to restaurants and shopping
  • ベクトル クエリ文字列 (数学的表現にベクトル化): classic lodging near running trails, eateries, retail

このベクトル クエリ文字列は、意味的には検索文字列に似ていますが、検索インデックスに存在しない用語を含んでいます。 classic lodging near running trails, eateries, retail のキーワード検索を実行すると、結果は 0 になります。 この例を使用して、一致する言葉がない場合でも関連する結果を取得する方法を示します。

重要

次の例は実行可能なコードではありません。 読みやすくするために、ベクトル値は除外しています。各配列には 1,536 個の埋め込みがあり、この記事には長すぎるためです。 これらのクエリを試す場合は、GitHub のサンプルから実行可能なコードをコピーします。

  1. POST 要求に貼り付けて検索インデックスに対するクエリを実行します。 ファイルを保存します。 次に、[要求の送信] を選択します。 URI を拡張して、/docs/search 演算子を含めます。

    ### Run a query
    POST {{baseUrl}}/indexes/hotels-vector-quickstart/docs/search?api-version=2023-11-01  HTTP/1.1
        Content-Type: application/json
        api-key: {{apiKey}}
    
        {
            "count": true,
            "select": "HotelId, HotelName, Description, Category",
            "vectorQueries": [
                {
                    "vector"": [0.01944167, 0.0040178085
                        . . .  TRIMMED FOR BREVITY
                        010858015, -0.017496133],
                    "k": 7,
                    "fields": "DescriptionVector",
                    "kind": "vector",
                    "exhaustive": true
                }
            ]
        }
    

    このベクトル クエリは、簡潔にするために短縮されています。 vectorQueries.vector はクエリ入力のベクトル化されたテキストを含み、fields は検索するベクトル フィールドを決定し、k は返される最近傍の数を指定します。

    ベクトル クエリ文字列は classic lodging near running trails, eateries, retail であり、このクエリでは 1,536 個の埋め込みにベクトル化されます。

  2. 応答を確認します。 classic lodging near running trails, eateries, retail に相当するベクトルの応答には、7 つの結果が含まれます。 各結果には、検索スコアと、select に一覧されているフィールドが表示されます。 類似性検索では、応答に常に値の類似性スコアで並べ替えられた k 個の結果が含まれます。

    {
        "@odata.context": "https://my-demo-search.search.windows.net/indexes('hotels-vector-quickstart')/$metadata#docs(*)",
        "@odata.count": 7,
        "value": [
            {
                "@search.score": 0.857736,
                "HotelName": "Nordick's Valley Motel",
                "Description": "Only 90 miles (about 2 hours) from the nation's capital and nearby most everything the historic valley has to offer.  Hiking? Wine Tasting? Exploring the caverns?  It's all nearby and we have specially priced packages to help make our B&B your home base for fun while visiting the valley."
            },
            {
                "@search.score": 0.8399129,
                "HotelName": "Swirling Currents Hotel",
                "Description": "Spacious rooms, glamorous suites and residences, rooftop pool, walking access to shopping, dining, entertainment and the city center."
            },
            {
                "@search.score": 0.8383954,
                "HotelName": "Luxury Lion Resort",
                "Description": "Unmatched Luxury.  Visit our downtown hotel to indulge in luxury accommodations. Moments from the stadium, we feature the best in comfort"
            },
            {
                "@search.score": 0.8254346,
                "HotelName": "Sublime Palace Hotel",
                "Description": "Sublime Palace Hotel is located in the heart of the historic center of Sublime in an extremely vibrant and lively area within short walking distance to the sites and landmarks of the city and is surrounded by the extraordinary beauty of churches, buildings, shops and monuments. Sublime Palace is part of a lovingly restored 1800 palace."
            },
            {
                "@search.score": 0.82380056,
                "HotelName": "Stay-Kay City Hotel",
                "Description": "The hotel is ideally located on the main commercial artery of the city in the heart of New York."
            },
            {
                "@search.score": 0.81514084,
                "HotelName": "Old Century Hotel",
                "Description": "The hotel is situated in a  nineteenth century plaza, which has been expanded and renovated to the highest architectural standards to create a modern, functional and first-class hotel in which art and unique historical elements coexist with the most modern comforts."
            },
            {
                "@search.score": 0.8133763,
                "HotelName": "Gastronomic Landscape Hotel",
                "Description": "The Hotel stands out for its gastronomic excellence under the management of William Dough, who advises on and oversees all of the Hotel’s restaurant services."
            }
        ]
    }
    

フィルターを使用した単一ベクトル検索

フィルターを追加できます。ただし、フィルターはインデックス内の非ベクトル コンテンツに適用されます。 この例では、Tags フィールドにフィルターが適用され、無料 Wi-Fi を備えていないホテルをすべて除外します。

  1. POST 要求に貼り付けて検索インデックスに対するクエリを実行します。

    ### Run a vector query with a filter
    POST {{baseUrl}}/indexes/hotels-vector-quickstart/docs/search?api-version=2023-11-01  HTTP/1.1
        Content-Type: application/json
        api-key: {{apiKey}}
    
        {
            "count": true,
            "select": "HotelId, HotelName, Category, Tags, Description",
            "filter": "Tags/any(tag: tag eq 'free wifi')",
            "vectorFilterMode": "postFilter",
            "vectorQueries": [
            {
                "vector": [ VECTOR OMITTED ],
                "k": 7,
                "fields": "DescriptionVector",
                "kind": "vector",
                "exhaustive": true
            },
        ]
    }
    
  2. 応答を確認します。 このクエリは前の例と同じですが、後処理除外フィルターを含み、無料 Wi-Fi を備えた 3 つのホテルのみが返されます。

    {
    
        "@odata.count": 3,
        "value": [
            {
                "@search.score": 0.857736,
                "HotelName": "Nordick's Valley Motel",
                "Description": "Only 90 miles (about 2 hours) from the nation's capital and nearby most everything the historic valley has to offer.  Hiking? Wine Tasting? Exploring the caverns?  It's all nearby and we have specially priced packages to help make our B&B your home base for fun while visiting the valley.",
                "Tags": [
                    "continental breakfast",
                    "air conditioning",
                    "free wifi"
                ]
            },
            {
                "@search.score": 0.8383954,
                "HotelName": "Luxury Lion Resort",
                "Description": "Unmatched Luxury.  Visit our downtown hotel to indulge in luxury accommodations. Moments from the stadium, we feature the best in comfort",
                "Tags": [
                    "view",
                    "free wifi",
                    "pool"
                ]
            },
            {
                "@search.score": 0.81514084,
                "HotelName": "Old Century Hotel",
                "Description": "The hotel is situated in a  nineteenth century plaza, which has been expanded and renovated to the highest architectural standards to create a modern, functional and first-class hotel in which art and unique historical elements coexist with the most modern comforts.",
                "Tags": [
                    "pool",
                    "free wifi",
                    "concierge"
                ]
            }
        ]
    }
    

ハイブリッド検索は、単一の検索要求内のキーワード クエリとベクトル クエリで構成されます。 次の例では、ベクトル クエリとフル テキスト検索を同時に実行します。

  • 検索文字列: historic hotel walk to restaurants and shopping
  • ベクトル クエリ文字列 (数学的表現にベクトル化): classic lodging near running trails, eateries, retail
  1. POST 要求に貼り付けて検索インデックスに対するクエリを実行します。 次に、[要求の送信] を選択します。

    ### Run a hybrid query
    POST {{baseUrl}}/indexes/hotels-vector-quickstart/docs/search?api-version=2023-11-01  HTTP/1.1
        Content-Type: application/json
        api-key: {{apiKey}}
    
    {
        "count": true,
        "search": "historic hotel walk to restaurants and shopping",
        "select": "HotelName, Description",
        "top": 7,
        "vectorQueries": [
            {
                "vector": [ VECTOR OMITTED],
                "k": 7,
                "fields": "DescriptionVector",
                "kind": "vector",
                "exhaustive": true
            }
        ]
    }
    

    これはハイブリッド クエリであるため、結果は Reciprocal Rank Fusion (RRF) によってランク付けされます。 RRF では、複数の検索結果の検索スコアを評価し、逆数を取り、結合した結果をマージして並べ替えます。 結果の top 数が返されます。

  2. 応答を確認します。

    {
        "@odata.count": 7,
        "value": [
            {
                "@search.score": 0.03279569745063782,
                "HotelName": "Luxury Lion Resort",
                "Description": "Unmatched Luxury.  Visit our downtown hotel to indulge in luxury accommodations. Moments from the stadium, we feature the best in comfort"
            },
            {
                "@search.score": 0.03226646035909653,
                "HotelName": "Sublime Palace Hotel",
                "Description": "Sublime Palace Hotel is located in the heart of the historic center of Sublime in an extremely vibrant and lively area within short walking distance to the sites and landmarks of the city and is surrounded by the extraordinary beauty of churches, buildings, shops and monuments. Sublime Palace is part of a lovingly restored 1800 palace."
            },
            {
                "@search.score": 0.03226646035909653,
                "HotelName": "Swirling Currents Hotel",
                "Description": "Spacious rooms, glamorous suites and residences, rooftop pool, walking access to shopping, dining, entertainment and the city center."
            },
            {
                "@search.score": 0.03205128386616707,
                "HotelName": "Nordick's Valley Motel",
                "Description": "Only 90 miles (about 2 hours) from the nation's capital and nearby most everything the historic valley has to offer.  Hiking? Wine Tasting? Exploring the caverns?  It's all nearby and we have specially priced packages to help make our B&B your home base for fun while visiting the valley."
            },
            {
                "@search.score": 0.03128054738044739,
                "HotelName": "Gastronomic Landscape Hotel",
                "Description": "The Hotel stands out for its gastronomic excellence under the management of William Dough, who advises on and oversees all of the Hotel’s restaurant services."
            },
            {
                "@search.score": 0.03100961446762085,
                "HotelName": "Old Century Hotel",
                "Description": "The hotel is situated in a  nineteenth century plaza, which has been expanded and renovated to the highest architectural standards to create a modern, functional and first-class hotel in which art and unique historical elements coexist with the most modern comforts."
            },
            {
                "@search.score": 0.03077651560306549,
                "HotelName": "Stay-Kay City Hotel",
                "Description": "The hotel is ideally located on the main commercial artery of the city in the heart of New York."
            }
        ]
    }
    

    RRF では結果をマージするので、入力の確認に役立ちます。 次の結果は、フル テキスト クエリのみからのものです。 上位 2 つの結果は、Sublime Palace Hotel と History Lion Resort です。 Sublime Palace Hotel は、より強い BM25 関連性スコアを持っています。

            {
                "@search.score": 2.2626662,
                "HotelName": "Sublime Palace Hotel",
                "Description": "Sublime Palace Hotel is located in the heart of the historic center of Sublime in an extremely vibrant and lively area within short walking distance to the sites and landmarks of the city and is surrounded by the extraordinary beauty of churches, buildings, shops and monuments. Sublime Palace is part of a lovingly restored 1800 palace."
            },
            {
                "@search.score": 0.86421645,
                "HotelName": "Luxury Lion Resort",
                "Description": "Unmatched Luxury.  Visit our downtown hotel to indulge in luxury accommodations. Moments from the stadium, we feature the best in comfort"
                },
    

    マッチ検索に HNSW を使用するベクトルのみのクエリでは、Sublime Palace Hotel の順位は 4 位まで落ちます。 Historic Lion の場合、フル テキスト検索では 2 位、ベクトル検索では 3 位でしたが、変動範囲が同じでないため、均質化された結果セットでは最上位の一致として表示されます。

        "value": [
            {
                "@search.score": 0.857736,
                "HotelId": "48",
                "HotelName": "Nordick's Valley Motel",
                "Description": "Only 90 miles (about 2 hours) from the nation's capital and nearby most everything the historic valley has to offer.  Hiking? Wine Tasting? Exploring the caverns?  It's all nearby and we have specially priced packages to help make our B&B your home base for fun while visiting the valley.",
                "Category": "Boutique"
            },
            {
                "@search.score": 0.8399129,
                "HotelId": "49",
                "HotelName": "Swirling Currents Hotel",
                "Description": "Spacious rooms, glamorous suites and residences, rooftop pool, walking access to shopping, dining, entertainment and the city center.",
                "Category": "Luxury"
            },
            {
                "@search.score": 0.8383954,
                "HotelId": "13",
                "HotelName": "Luxury Lion Resort",
                "Description": "Unmatched Luxury.  Visit our downtown hotel to indulge in luxury accommodations. Moments from the stadium, we feature the best in comfort",
                "Category": "Resort and Spa"
            },
            {
                "@search.score": 0.8254346,
                "HotelId": "4",
                "HotelName": "Sublime Palace Hotel",
                "Description": "Sublime Palace Hotel is located in the heart of the historic center of Sublime in an extremely vibrant and lively area within short walking distance to the sites and landmarks of the city and is surrounded by the extraordinary beauty of churches, buildings, shops and monuments. Sublime Palace is part of a lovingly restored 1800 palace.",
                "Category": "Boutique"
            },
            {
                "@search.score": 0.82380056,
                "HotelId": "1",
                "HotelName": "Stay-Kay City Hotel",
                "Description": "The hotel is ideally located on the main commercial artery of the city in the heart of New York.",
                "Category": "Boutique"
            },
            {
                "@search.score": 0.81514084,
                "HotelId": "2",
                "HotelName": "Old Century Hotel",
                "Description": "The hotel is situated in a  nineteenth century plaza, which has been expanded and renovated to the highest architectural standards to create a modern, functional and first-class hotel in which art and unique historical elements coexist with the most modern comforts.",
                "Category": "Boutique"
            },
            {
                "@search.score": 0.8133763,
                "HotelId": "3",
                "HotelName": "Gastronomic Landscape Hotel",
                "Description": "The Hotel stands out for its gastronomic excellence under the management of William Dough, who advises on and oversees all of the Hotel’s restaurant services.",
                "Category": "Resort and Spa"
            }
        ]
    

フィルターを使用したセマンティック ハイブリッド検索

ここでは、コレクションでの最後のクエリを示します。 セマンティック ランク付けを行うこのハイブリッド クエリは、ワシントン D.C. の半径 500 キロメートル以内のホテルのみを表示するようにフィルター処理されます。vectorFilterMode は、既定値 (新しいインデックスでは preFilter、古いものでは postFilter) に相当する null に設定できます。

  1. POST 要求に貼り付けて検索インデックスに対するクエリを実行します。 次に、[要求の送信] を選択します。

    ### Run a hybrid query
    POST {{baseUrl}}/indexes/hotels-vector-quickstart/docs/search?api-version=2023-11-01  HTTP/1.1
        Content-Type: application/json
        api-key: {{apiKey}}
    
    {
        "count": true,
        "search": "historic hotel walk to restaurants and shopping",
        "select": "HotelId, HotelName, Category, Description,Address/City, Address/StateProvince",
        "filter": "geo.distance(Location, geography'POINT(-77.03241 38.90166)') le 500",
        "vectorFilterMode": null,
        "facets": [ "Address/StateProvince"],
        "top": 7,
        "queryType": "semantic",
        "answers": "extractive|count-3",
        "captions": "extractive|highlight-true",
        "semanticConfiguration": "my-semantic-config",
        "vectorQueries": [
            {
                "vector": [ VECTOR OMITTED ],
                "k": 7,
                "fields": "DescriptionVector",
                "kind": "vector",
                "exhaustive": true
            }
        ]
    }
    
  2. 応答を確認します。 応答は 3 つのホテルとなり、場所でフィルター処理され、StateProvince によってファセットが適用され、意味的に再ランク付けされて、結果が昇格し、検索文字列クエリ (historic hotel walk to restaurants and shopping) に最も近くなります。

    今度は Swirling Currents Hotel が首位になります。 セマンティック ランク付けを行わない場合、Nordick's Valley Motel が 1 位となります。 セマンティック ランク付けを行う場合、機械読解モデルでは、historic が、"食事 (レストラン) やショッピングに徒歩圏内のホテル" に適用されると認識します。

    {
        "@odata.count": 3,
        "@search.facets": {
            "Address/StateProvince": [
                {
                    "count": 1,
                    "value": "NY"
                },
                {
                    "count": 1,
                    "value": "VA"
                }
            ]
        },
        "@search.answers": [],
        "value": [
            {
                "@search.score": 0.03306011110544205,
                "@search.rerankerScore": 2.5094974040985107,
                "HotelId": "49",
                "HotelName": "Swirling Currents Hotel",
                "Description": "Spacious rooms, glamorous suites and residences, rooftop pool, walking access to shopping, dining, entertainment and the city center.",
                "Category": "Luxury",
                "Address": {
                    "City": "Arlington",
                    "StateProvince": "VA"
                }
            },
            {
                "@search.score": 0.03306011110544205,
                "@search.rerankerScore": 2.0370211601257324,
                "HotelId": "48",
                "HotelName": "Nordick's Valley Motel",
                "Description": "Only 90 miles (about 2 hours) from the nation's capital and nearby most everything the historic valley has to offer.  Hiking? Wine Tasting? Exploring the caverns?  It's all nearby and we have specially priced packages to help make our B&B your home base for fun while visiting the valley.",
                "Category": "Boutique",
                "Address": {
                    "City": "Washington D.C.",
                    "StateProvince": null
                }
            },
            {
                "@search.score": 0.032258063554763794,
                "@search.rerankerScore": 1.6706111431121826,
                "HotelId": "1",
                "HotelName": "Stay-Kay City Hotel",
                "Description": "The hotel is ideally located on the main commercial artery of the city in the heart of New York.",
                "Category": "Boutique",
                "Address": {
                    "City": "New York",
                    "StateProvince": "NY"
                }
            }
        ]
    }
    

    この REST API に関する重要なポイント:

    • ベクトル検索は、vectors.value プロパティを使用して指定されます。 キーワード検索は、search プロパティを使用して指定されます。

    • ハイブリッド検索では、キーワードに対するフルテキスト検索とベクトル検索を統合できます。 フィルター、スペル チェック、セマンティック ランク付けは、ベクトルではなくテキスト コンテンツにのみ適用されます。 この最後のクエリでは、セマンティックな answer はありません。これは、システムが生成したものが十分に強力ではなかったためです。

    • 実際の結果には、セマンティック キャプションや強調表示など、より詳細な情報が含まれます。 結果は読みやすくするために変更されています。 応答の構造全体を取得するには、REST クライアントで要求を実行します。

クリーンアップ

独自のサブスクリプションを使用している場合は、プロジェクトの最後に、作成したリソースがまだ必要かどうかを確認してください。 リソースを実行したままにすると、お金がかかる場合があります。 リソースを個別に削除するか、リソース グループを削除してリソースのセット全体を削除することができます。

左端のペイン内にある [すべてのリソース] または [リソース グループ] リンクを使用して、Azure portal 内でリソースを検索および管理できます。

次の DELETE コマンドを試すこともできます。

### Delete an index
DELETE  {{baseUrl}}/indexes/hotels-vector-quickstart?api-version=2023-11-01 HTTP/1.1
    Content-Type: application/json
    api-key: {{apiKey}}

次のステップ

次のステップとして、API キーを使わずに REST API 呼び出しを行う方法を覚えることをお勧めします。

また、PythonC#、またはJavaScript のデモ コードを確認することもお勧めします。