[レポート]PostgreSQL上の生成AIアプリでベクトル検索するためのベストプラクティス #DAT423 #AWSreInvent

[レポート]PostgreSQL上の生成AIアプリでベクトル検索するためのベストプラクティス #DAT423 #AWSreInvent

Clock Icon2024.12.04

AWSのPostgreSQLの Principal Product Manager - Technicalを務めるJonathan Katzさんによるセッション"DAT423 | Best practices for querying vector data for gen AI apps in PostgreSQL"をレポートします。

本セッションは、PostgreSQLをベクトルデータベース化する pgvector エクステンションを題材に、検索品質の評価では、再現率(recall)が何よりも大事といったベクトルデータベースのベストプラクティスが、具体的な実験結果とともに展開されました。

以下のスクリーンショットはYouTube動画からのものです。

セッション情報

セッションのハイライト

生成AIアプリでは、RAGを始めとしてモデルを利用したベクトル化(埋め込み)とベクトルを対象とした検索が求められます。

ベクトル検索では、ベクトルを元にベクトルの集合に対して検索します。
大量のベクトル同士を比較すると、計算量が膨れ上がるため、Approximate Nearest Neighbor(ANN) という近似アルゴリズムが用いられます。

このアルゴリズムはあくまでも近似のため、取りこぼしがあります。

正解10個のうち8個を当てられたら、再現率(recall)は80%です。

pgvector-recall

ベクトル検索を評価するときに

  • 再現率
  • インデックスの構築時間
  • クエリーパフォーマンス(スループット、レイテンシー)

などが気になります。

vector-search-metrics

Katzが言うには、 再現率が何よりも大事 、ということです(動画 9:09)。
いくらスループットが良くても、再現率が0%(空振っている)だと意味がありません。

pgvector のベクトル検索用インデックス

pgvector が実装している ANN はクラスターベースの IVFFlatと グラフベースの HNSW の2種類がトレードオフの関係にあります。現在は、後から実装された HNSW のほうがうまくいくことが多く、主流になりつつあります。

pgvector-index-types

selectivity とインデックスの選択

ベクトル検索ならベクトル検索用インデックスを使うべしと思考停止してしまいがちですが、一部のデータを対象にベクトル検索する場合、つまり、selectivity が高い場合、B-Tree のような古典的なインデックスでフィルタリングしたあとで、ベクトル同士を比較したほうが早いです。

pgvector HNSWは m が大事

以降では、pgvectorのHNSWインデックスを題材に様々な実験結果やトレードオフ関係が解説されます。

HNSWインデックスでは重要なパラメータが2つあります

  • m
    • the max number of connections per layer
    • デフォルトは16
  • ef_construction
    • the size of the dynamic candidate list for constructing the graph
    • デフォルトは64

例えば、動画28:55 では、Katzが最もお気に入りのスライドが紹介されています。

pgvector-m-is-all-you-need

5つの埋込モデルで検索時間を評価すると、データ数がそれぞれ異なるにも関わらず、評価候補のベクトルの数が同程度に抑えられています。

m=16としているおかげです。

まとめ

セッションタイトルからはRAG のベストプラクティスのような内容を期待しますが、PostgreSQLベクトルデータベース 化する pgvector エクステンションの HNSW インデックス を題材にした、データベース、特に、インデックス周りを深掘った、密度の濃いセッションとなっています。

データベースに興味があるなら、視聴をおすすめします。

参考

Share this article

facebook logohatena logotwitter logo

© Classmethod, Inc. All rights reserved.