ホームページ >バックエンド開発 >Python チュートリアル >OpenRAG: 大規模な言語モデルを使用してデータ クエリを強化するオープンソース GenAI アプリケーション
人工知能の時代において、企業や開発者はデータ分析と顧客との対話を合理化するために大規模言語モデル (LLM) をますます活用しています。オープンソースの Generative AI (GenAI) アプリケーションである OpenRAG は、LLM の柔軟性とさまざまなベクトル データベースにわたる効率的なデータ クエリ機能を組み合わせることで、ユーザーを支援します。 PDF を操作している場合でも、大規模なデータセットのクエリを実行している場合でも、保存されたデータから洞察を求めている場合でも、OpenRAG を使用すると、自然言語クエリを使用してデータをシームレスに操作できます。
すべてのオープンソース LLM モデルのサポート OpenRAG は、さまざまなオープンソース LLM と統合するように設計されており、ユーザーは独自のユースケースに最適なモデルを自由に選択できます。このプラットフォームの拡張性により将来の拡張が可能になり、ユーザーは AI 分野の最新の進歩を制限なく利用できるようになります。
複数のオープンソース ベクトル データベース 統合 OpenRAG は、Chroma、FAISS、Qdrant などの一般的なオープンソース ベクトル データベースをサポートするように事前構成されています。これらのデータベースは、高性能のベクトル検索と取得を容易にし、ユーザーがデータをクエリするときに正確な結果を確実に得ることができます。
PDF アップロードとデータ クエリ OpenRAG の優れた機能の 1 つは、PDF ファイルをアップロードし、構造化されたデータ コレクションに変換する機能です。このため、このアプリケーションは、大量の PDF ベースの情報を扱う専門家にとって非常に役立ちます。 PDF がアップロードされると、ユーザーは選択した LLM を使用してコンテンツをクエリし、迅速かつ効率的に洞察を抽出できます。
永続的なコレクション名 OpenRAG は、アップロードされた PDF に一意のコレクション名を割り当て、ユーザーが同じファイルを再アップロードすることなくデータを返したりクエリしたりできるようにします。この機能により時間を節約し、データ管理をよりシームレスにします。
ベクター データベースの一貫性 使用法 OpenRAG は、データ コレクションを特定のベクター データベースに結び付けることで一貫性を維持します。データベースがコレクションとして選択されると、ユーザーはデータベースを切り替えることができないため、毎回安定して正確なデータを取得できます。
AI 主導のデータ クエリの世界に飛び込む前に、スムーズなインストールのために次の前提条件を満たしていることを確認してください。
Python バージョン: Python 3.9 以降がインストールされていることを確認してください。
Qdrant Docker イメージ: OpenRAG は Qdrant と統合されており、イメージが実行されているはずです。ローカルホストのポート 6333 にアクセスできることを確認してください。
インストール
git clone https://github.com/yourrepo/openrag.git
python3 -m venv openrag-env source openrag-env/bin/activate
pip install -r required.txt
python3 -m spacy ダウンロード en_core_web_sm
uvicorn main:app --reload
デプロイメントに Docker を使用したい開発者は、OpenRAG をコンテナ化できます。
docker build -t openrag-app .
docker run -d -p 8000:8000 openrag-app
アプリが実行されたら、ブラウザーで http://localhost:8000 経由でアクセスします。
OpenRAG の API ファースト アーキテクチャにより、さまざまなフロントエンド アプリケーションに統合できます。 PDF をアップロードし、API を通じてその内容をクエリする方法の例を次に示します。
PDF をアップロードする
curl -X POST "http://localhost:8000/upload" \ -H "accept: application/json" \ -H "Content-Type: multipart/form-data" \ -F "file=@yourfile.pdf" \ -F "model_name=GPT-3.5" \ -F "vector_db_name=qdrant"
チャットセッションを開始する
PDF をアップロードした後、チャットベースのクエリを開始できます:
curl -X POST "http://localhost:8000/chat" \ -H "Content-Type: application/json" \ -d '{ "collection_name": "your_collection_name", "query": "your_query", "model_name": "GPT-3.5", "vector_db_name": "qdrant", "device": "cpu" }'
OpenRAG によるスケーラビリティ
OpenRAG の最大の強みの 1 つは、そのスケーラビリティです。 uvicorn などのツールを使用してローカル マシン上で実行できますが、本番環境に対応しており、クラウド プロバイダー、Docker、または Kubernetes を使用してデプロイできます。運用環境では、OpenRAG は Gunicorn などのツールによるスケーリングをサポートし、高トラフィックのユースケースに堅牢なパフォーマンスを提供します。
一般的なエラーと解決策
開発中に、ユーザーは次の一般的なエラーに遭遇する可能性があります:
TypeError: 記述子を直接作成できません。
これを解決するには、protobuf パッケージをバージョン 3.20.x 以下にダウングレードするか、環境変数
を設定することを検討してください。PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=python
結論
OpenRAG は、データのクエリと洞察のために LLM とベクトル データベースの機能を活用したいと考えているユーザーにとって、柔軟なオープンソース ソリューションとして際立っています。開発者、研究者、企業ユーザーのいずれであっても、OpenRAG は、非常に効率的かつ直感的な方法でデータを操作するためのツールを提供します。
詳細な API ドキュメントとその他の例については、OpenRAG の API ドキュメントを参照してください。
OpenRAG への貢献
コミュニティからの貢献を歓迎します!貢献、問題の送信、または機能のリクエストの方法の詳細については、CONTRIBUTING.md を確認してください。
Github リポジトリ リンク
ラグリポジトリを開く
以上がOpenRAG: 大規模な言語モデルを使用してデータ クエリを強化するオープンソース GenAI アプリケーションの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。