ranking

ranking

TensorFlow平台上的学习排名技术库

TensorFlow Ranking是一个适用于学习排名(LTR)技术的开源库,基于TensorFlow平台。该库包括点对、成对和列表损失函数,以及各类排名指标如平均倒数排名(MRR)和标准折扣累积增益(NDCG)。它提供了群组评分功能和LambdaLoss的实现,用于优化排名指标。此外,它还支持从偏见反馈数据中进行无偏学习。该库旨在为学术研究和工业应用提供一个开放、便捷的平台。用户可通过教程和演示快速入门,无需复杂安装。

TensorFlow Ranking学习排序深度学习排序模型TensorBoardGithub开源项目

TensorFlow Ranking

TensorFlow Ranking是一个用于TensorFlow平台上的排序学习(LTR)技术的库。它包含以下组件:

我们希望这个库能提供一个方便的开放平台,用于托管和推进基于深度学习技术的最先进排序模型,从而促进学术研究和工业应用。

教程幻灯片

TF-Ranking在信息检索的顶级会议SIGIR 2019ICTIR 2019上进行了展示!幻灯片可以在这里查看。

演示

我们提供了一个无需安装的演示,以帮助您开始使用TF-Ranking。此演示运行在一个互动的Python环境——colaboratory notebook上。使用TF-Ranking中的稀疏特征和嵌入: 在Google Colab中运行。 此演示展示了如何:

  • 使用稀疏/嵌入特征
  • 处理TFRecord格式的数据
  • 在colab笔记本中,使用Estimator API进行Tensorboard集成

另请参见运行脚本获取可执行脚本。

Linux安装

稳定版本

要从PyPI安装最新版本,请运行以下命令:

# 使用`--upgrade`标志确保您获取最新版本。 pip install --user --upgrade tensorflow_ranking

要强制安装Python 3特定版本,请在上述命令中将pip替换为pip3。有关额外的安装帮助、安装前提条件的指南和(可选的)设置虚拟环境,请参见TensorFlow安装指南

注意:由于TensorFlow现已包含在TensorFlow Ranking包(在setup.py中)作为依赖。如果您希望使用不同版本的TensorFlow(例如,tensorflow-gpu),可能需要卸载现有版本并安装所需版本:

$ pip uninstall tensorflow $ pip install tensorflow-gpu

从源代码安装

  1. 本地构建TensorFlow Ranking,您需要安装:

    • Bazel,一个开源构建工具。

      $ sudo apt-get update && sudo apt-get install bazel
    • Pip,一个Python包管理器。

      $ sudo apt-get install python-pip
    • VirtualEnv,一个创建独立Python环境的工具。

      $ pip install --user virtualenv
  2. 克隆TensorFlow Ranking仓库。

    $ git clone https://github.com/tensorflow/ranking.git
  3. 构建TensorFlow Ranking wheel文件并存储在/tmp/ranking_pip文件夹中。

    $ cd ranking # 克隆的文件夹在步骤2中。 $ bazel build //tensorflow_ranking/tools/pip_package:build_pip_package $ bazel-bin/tensorflow_ranking/tools/pip_package/build_pip_package /tmp/ranking_pip
  4. 使用pip安装wheel包。在virtualenv中测试,以避免与任何系统依赖冲突。

    $ ~/.local/bin/virtualenv -p python3 /tmp/tfr $ source /tmp/tfr/bin/activate (tfr) $ pip install /tmp/ranking_pip/tensorflow_ranking*.whl

    在某些情况下,您可能希望安装特定版本的tensorflow,例如,tensorflow-gputensorflow==2.0.0。为此,您可以

    (tfr) $ pip uninstall tensorflow (tfr) $ pip install tensorflow==2.0.0

    或者

    (tfr) $ pip uninstall tensorflow (tfr) $ pip install tensorflow-gpu
  5. 运行所有TensorFlow Ranking测试。

    (tfr) $ bazel test //tensorflow_ranking/...
  6. 在python中调用TensorFlow Ranking包(在virtualenv中)。

    (tfr) $ python -c "import tensorflow_ranking"

运行脚本

为了方便实验,我们还提供了a TFRecord示例a LIBSVM示例作为可执行脚本,这对于高超参数调整特别有用,其中超参数作为脚本的标志提供。

TFRecord示例

  1. 设置数据和目录。

    MODEL_DIR=/tmp/tf_record_model && \ TRAIN=tensorflow_ranking/examples/data/train_elwc.tfrecord && \ EVAL=tensorflow_ranking/examples/data/eval_elwc.tfrecord && \ VOCAB=tensorflow_ranking/examples/data/vocab.txt
  2. 构建并运行。

    rm -rf $MODEL_DIR && \ bazel build -c opt \ tensorflow_ranking/examples/tf_ranking_tfrecord_py_binary && \ ./bazel-bin/tensorflow_ranking/examples/tf_ranking_tfrecord_py_binary \ --train_path=$TRAIN \ --eval_path=$EVAL \ --vocab_path=$VOCAB \ --model_dir=$MODEL_DIR \ --data_format=example_list_with_context

LIBSVM示例

  1. 设置数据和目录。

    OUTPUT_DIR=/tmp/libsvm && \ TRAIN=tensorflow_ranking/examples/data/train.txt && \ VALI=tensorflow_ranking/examples/data/vali.txt && \ TEST=tensorflow_ranking/examples/data/test.txt
  2. 构建并运行。

    rm -rf $OUTPUT_DIR && \ bazel build -c opt \ tensorflow_ranking/examples/tf_ranking_libsvm_py_binary && \ ./bazel-bin/tensorflow_ranking/examples/tf_ranking_libsvm_py_binary \ --train_path=$TRAIN \ --vali_path=$VALI \ --test_path=$TEST \ --output_dir=$OUTPUT_DIR \ --num_features=136 \ --num_train_steps=100

TensorBoard

训练结果如损失和指标可以使用Tensorboard可视化。

  1. (可选)如果您在远程服务器上工作,请使用此命令设置端口转发。

    $ ssh <remote-server> -L 8888:127.0.0.1:8888
  2. 安装Tensorboard并使用以下命令调用。

    (tfr) $ pip install tensorboard (tfr) $ tensorboard --logdir $OUTPUT_DIR

Jupyter Notebook

tensorflow_ranking/examples/handling_sparse_features.ipynb中提供了一个示例jupyter notebook。

  1. 要运行此notebook,首先按照安装步骤设置virtualenv环境并安装tensorflow_ranking包。

  2. 在virtualenv中安装jupyter。

    (tfr) $ pip install jupyter
  3. 在远程服务器上启动jupyter notebook实例。

    (tfr) $ jupyter notebook tensorflow_ranking/examples/handling_sparse_features.ipynb \ --NotebookApp.allow_origin='https://colab.research.google.com' \ --port=8888
  4. (可选)如果您在远程服务器上工作,请使用此命令设置端口转发。

    $ ssh <remote-server> -L 8888:127.0.0.1:8888
  5. 运行notebook。

    • 在您的本地机器上启动jupyter notebook,地址为http://localhost:8888/并浏览到ipython notebook。

    • 另一种选择是通过colab.research.google.com使用colaboratory notebook,并在浏览器中打开notebook。选择本地运行时并链接到端口8888。

参考

  • Rama Kumar Pasumarthi, Sebastian Bruch, Xuanhui Wang, Cheng Li, Michael Bendersky, Marc Najork, Jan Pfeifer, Nadav Golbandi, Rohan Anil, Stephan Wolf. TF-Ranking: Scalable TensorFlow Library for Learning-to-Rank. KDD 2019.

  • Qingyao Ai, Xuanhui Wang, Sebastian Bruch, Nadav Golbandi, Michael Bendersky, Marc Najork. Learning Groupwise Scoring Functions Using Deep Neural Networks. ICTIR 2019

  • Xuanhui Wang, Michael Bendersky, Donald Metzler, and Marc Najork. Learning to Rank with Selection Bias in Personal Search. SIGIR 2016.

  • Xuanhui Wang, Cheng Li, Nadav Golbandi, Mike Bendersky, Marc Najork. The LambdaLoss Framework for Ranking Metric Optimization. CIKM 2018.

引用

如果您在研究中使用TensorFlow Ranking并希望引用它,我们建议您使用以下引用:

@inproceedings{TensorflowRankingKDD2019,
   author = {Rama Kumar Pasumarthi and Sebastian Bruch and Xuanhui Wang and Cheng Li and Michael Bendersky and Marc Najork and Jan Pfeifer and Nadav Golbandi and Rohan Anil and Stephan Wolf},
   title = {TF-Ranking: Scalable TensorFlow Library for Learning-to-Rank},
   booktitle = {Proceedings of the 25th ACM SIGKDD International Conference on Knowledge Discovery and Data Mining},
   year = {2019},
   pages = {2970--2978},
   location = {Anchorage, AK}
}

编辑推荐精选

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

下拉加载更多