メインコンテンツまでスキップ
バージョン: User Guides (BYOC)

Decompounder

decompounderフィルターは、指定された辞書に基づいて複合語を個々の要素に分割し、複合語の一部を検索しやすくします。このフィルターは、ドイツ語のように複合語を頻繁に使用する言語に特に有用です。

構成

decompounderフィルターはZilliz Cloudのカスタムフィルターです。使用するには、フィルター構成で"type": "decompounder"を指定し、認識する語要素を提供するword_listパラメータを指定してください。

analyzer_params = {
"tokenizer": "standard",
"filter":[{
"type": "decompounder", # フィルターの種類をdecompounderとして指定します
"word_list": ["dampf", "schiff", "fahrt", "brot", "backen", "automat"],
}],
}

decompounderフィルターは、以下の設定可能なパラメータを受け入れます。

パラメータ

説明

word_list

複合語を分割するための語要素のリスト。この辞書は、複合語がどのように個々の語に分解されるかを決定します。

decompounderフィルターは、トークナイザーによって生成された用語に対して操作を行うため、トークナイザーと組み合わせて使用する必要があります。Zilliz Cloudで利用可能なトークナイザーのリストについては、トークナイザー参照を参照してください。

analyzer_paramsを定義した後、コレクションスキーマを定義する際にVARCHARフィールドに適用できます。これにより、Zilliz Cloudは、指定されたアナライザーを使用してそのフィールド内のテキストを効率的にトークン化およびフィルタリング処理できます。詳細については、使用例を参照してください。

コレクションスキーマにアナライザー構成を適用する前に、run_analyzerメソッドを使用してその動作を検証してください。

アナライザー構成

analyzer_params = {
"tokenizer": "standard",
"filter":[{
"type": "decompounder", # フィルターの種類をdecompounderとして指定します
"word_list": ["dampf", "schiff", "fahrt", "brot", "backen", "automat"],
}],
}

run_analyzerを使用した検証

from pymilvus import (
MilvusClient,
)

client = MilvusClient(uri="YOUR_CLUSTER_ENDPOINT")

# 解析するサンプルテキスト
sample_text = "dampfschifffahrt brotbackautomat"

# 定義された構成でstandardアナライザーを実行
result = client.run_analyzer(sample_text, analyzer_params)
print("Standard analyzer output:", result)

期待される出力

['dampf', 'schiff', 'fahrt', 'brotbackautomat']