Metarank: サービスとしてのリアルタイムのパーソナライゼーション
Metarank はオープンソースのランキング サービスです。これは、パーソナライズされたセマンティック/ニューラル検索と推奨事項を構築するのに役立ちます。
ただ始めたい場合は、次のことを試してください。
Metarank を使用すると、既存の検索と推奨事項をよりスマートにできます。
メタランクは速いです:
開発時間を節約します:
Metarank は、検索と推奨のための高度なランキング システムの構築に役立ちます。
ブログ投稿:
ミートアップとカンファレンストーク:
メタランクのデモは、demo.metarank.ai でプレイできます。
デモ自体と使用されるデータはオープンソースであり、トレーニング イベントと構成ファイルのコピーを github リポジトリで取得できます。
LambdaMART ベースの再ランキングを使用してコンテンツのパーソナライズを 1 分以内に開始できる方法を示します。
デモで使用する Ranklens データセットを使用するので、データ ファイルをダウンロードするだけです。
curl -O -L https://github.com/metarank/metarank/raw/master/src/test/resources/ranklens/events/events.jsonl.gz
デモの構成ファイルを再度使用します。インメモリ ストアを利用するため、他の依存関係は必要ありません。
curl -O -L https://raw.githubusercontent.com/metarank/metarank/master/src/test/resources/ranklens/config.yml
最後のステップでは、API のトレーニングと実行を 1 つのコマンドに組み合わせる Metarank のstandalone
モードを使用します。
docker run -i -t -p 8080:8080 -v $( pwd ) :/opt/metarank metarank/metarank:latest standalone --config /opt/metarank/config.yml --data /opt/metarank/events.jsonl.gz
Metarank が開始され、データが処理されている間、いくつかの有用な出力が表示されます。これが完了したら、リクエストをlocalhost:8080
に送信して、パーソナライズされた結果を取得できます。
ここでは、いくつかのムービーの 1 つをクリックして結果を観察することで、それらを操作します。
まず、Metarank を操作する前に、Metarank によって提供される初期出力を見てみましょう。
# get initial ranking for some items
curl http://localhost:8080/rank/xgboost
-d ' {
"event": "ranking",
"id": "id1",
"items": [
{"id":"72998"}, {"id":"67197"}, {"id":"77561"},
{"id":"68358"}, {"id":"79132"}, {"id":"103228"},
{"id":"72378"}, {"id":"85131"}, {"id":"94864"},
{"id":"68791"}, {"id":"93363"}, {"id":"112623"}
],
"user": "alice",
"session": "alice1",
"timestamp": 1661431886711
} '
# {"item":"72998","score":0.9602446652021992},{"item":"79132","score":0.7819134441404151},{"item":"68358","score":0.33377910321385645},{"item":"112623","score":0.32591281190727805},{"item":"103228","score":0.31640256043322723},{"item":"77561","score":0.3040782705414116},{"item":"94864","score":0.17659007036183608},{"item":"72378","score":0.06164568676567339},{"item":"93363","score":0.058120639770243385},{"item":"68791","score":0.026919880032451306},{"item":"85131","score":-0.35794106000271037},{"item":"67197","score":-0.48735167237049154}
# tell Metarank which items were presented to the user and in which order from the previous request
# optionally, we can include the score calculated by Metarank or your internal retrieval system
curl http://localhost:8080/feedback
-d ' {
"event": "ranking",
"fields": [],
"id": "test-ranking",
"items": [
{"id":"72998","score":0.9602446652021992},{"id":"79132","score":0.7819134441404151},{"id":"68358","score":0.33377910321385645},
{"id":"112623","score":0.32591281190727805},{"id":"103228","score":0.31640256043322723},{"id":"77561","score":0.3040782705414116},
{"id":"94864","score":0.17659007036183608},{"id":"72378","score":0.06164568676567339},{"id":"93363","score":0.058120639770243385},
{"id":"68791","score":0.026919880032451306},{"id":"85131","score":-0.35794106000271037},{"id":"67197","score":-0.48735167237049154}
],
"user": "test2",
"session": "test2",
"timestamp": 1661431888711
} '
それでは、アイテム
93363
を操作してみましょう
# click on the item with id 93363
curl http://localhost:8080/feedback
-d ' {
"event": "interaction",
"type": "click",
"fields": [],
"id": "test-interaction",
"ranking": "test-ranking",
"item": "93363",
"user": "test",
"session": "test",
"timestamp": 1661431890711
} '
Metarank は項目をパーソナライズします。応答内の項目の順序は異なります。
# personalize the same list of items
# they will be returned in a different order by Metarank
curl http://localhost:8080/rank/xgboost
-d ' {
"event": "ranking",
"fields": [],
"id": "test-personalized",
"items": [
{"id":"72998"}, {"id":"67197"}, {"id":"77561"},
{"id":"68358"}, {"id":"79132"}, {"id":"103228"},
{"id":"72378"}, {"id":"85131"}, {"id":"94864"},
{"id":"68791"}, {"id":"93363"}, {"id":"112623"}
],
"user": "test",
"session": "test",
"timestamp": 1661431892711
} '
# {"items":[{"item":"93363","score":2.2013986484185124},{"item":"72998","score":1.1542776301073876},{"item":"68358","score":0.9828904282341605},{"item":"112623","score":0.9521647429731446},{"item":"79132","score":0.9258841742518286},{"item":"77561","score":0.8990921381835769},{"item":"103228","score":0.8990921381835769},{"item":"94864","score":0.7131600718467729},{"item":"68791","score":0.624462038351694},{"item":"72378","score":0.5269765094008626},{"item":"85131","score":0.29198666089255343},{"item":"67197","score":0.16412780810560743}]}
より詳細なクイックスタートの完全なリファレンスを確認してください。
ご質問がございましたら、お気軽に Slack にご参加ください。
このプロジェクトは、ライセンス ファイルで指定されているように、Apache 2.0 ライセンスに基づいてリリースされます。