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}
}

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具使用教程AI营销产品酷表ChatExcelAI智能客服
TRAE编程

TRAE编程

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

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

热门AI工具生产力协作转型TraeAI IDE
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

数据安全AI助手热门AI工具AI辅助写作AI论文工具论文写作智能生成大纲
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

热门AI工具AI办公办公工具智能排版AI生成PPT博思AIPPT海量精品模板AI创作
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

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

SimilarWeb流量提升

SimilarWeb流量提升

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

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

Sora2视频免费生成

Sora2视频免费生成

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

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

下拉加载更多