Merlin

Merlin

GPU加速推荐系统解决方案 助力大规模数据处理与模型训练

Merlin是NVIDIA开发的开源库,为推荐系统提供GPU加速解决方案。它包含多个组件如NVTabular和HugeCTR,支持大规模数据处理、特征工程、模型训练和部署。Merlin能处理数百TB数据,通过GPU加速提升系统性能。它兼容TensorFlow、PyTorch等框架,便于构建和优化推荐模型。

NVIDIA Merlin推荐系统GPU加速深度学习特征工程Github开源项目

NVIDIA Merlin

GitHub 标签(最新语义化版本) GitHub 许可证 文档

NVIDIA Merlin 是一个开源库,可在 NVIDIA GPU 上加速推荐系统。该库使数据科学家、机器学习工程师和研究人员能够大规模构建高性能推荐系统。Merlin 包含用于解决常见特征工程、训练和推理挑战的工具。Merlin 管道的每个阶段都经过优化,可支持数百 TB 的数据,所有这些都可通过易于使用的 API 访问。有关更多信息,请参阅 NVIDIA 开发者网站上的 NVIDIA Merlin

优势

NVIDIA Merlin 是一个可扩展且 GPU 加速的解决方案,可轻松地从头到尾构建推荐系统。使用 NVIDIA Merlin,您可以:

  • 转换数据(ETL)以进行预处理和特征工程。
  • 通过利用优化的、定制的数据加载器加速您在 TensorFlow、PyTorch 或 FastAI 中的现有训练流程。
  • 通过分配超出可用 GPU 和 CPU 内存的大型嵌入表来扩展大型深度学习推荐模型。
  • 仅需几行代码即可将数据转换和训练模型部署到生产环境中。

NVIDIA Merlin 的组件

NVIDIA Merlin 由以下开源库组成:

NVTabular PyPI 版本 shields.io 文档 <br> NVTabular 是用于表格数据的特征工程和预处理库。该库可以快速轻松地处理用于训练基于深度学习的推荐系统的 TB 级数据集。该库提供了一个高级 API,可定义复杂的数据转换工作流程。使用 NVTabular,您可以:

  • 快速轻松地准备数据集以进行实验,从而可以训练更多模型。
  • 处理超出 GPU 和 CPU 内存的数据集,而无需担心规模问题。
  • 通过在操作级别使用抽象,专注于如何处理数据,而不是如何实现。

HugeCTR 文档<br> HugeCTR 是一个 GPU 加速的训练框架,可以通过在多个 GPU 和节点之间分配训练来扩展大型深度学习推荐模型。HugeCTR 包含具有 GPU 加速的优化数据加载器,并提供策略来扩展超出可用内存的大型嵌入表。使用 HugeCTR,您可以:

  • 将嵌入表扩展到多个 GPU 或节点。
  • 在训练阶段以粗粒度、按需方式将嵌入表的子集加载到 GPU 中。

Merlin Models PyPI 版本 shields.io 文档<br> Merlin Models 库为推荐系统提供标准模型,旨在实现从经典机器学习模型到高度先进的深度学习模型的高质量实现。使用 Merlin Models,您可以:

  • 通过使用TensorFlow、PyTorch和HugeCTR的高性能数据加载器,将排序模型训练速度提高至10倍。
  • 通过自动将NVTabular创建的数据集映射到模型输入层,快速迭代特征工程和模型探索。模型输入层使您能够更改其中一个而不影响另一个。
  • 为常见的推荐系统架构组装可连接的构建模块,以便您能够快速轻松地创建新模型。

Transformers4Rec PyPI版本shields.io 文档<br> Transformers4Rec库提供序列和会话推荐。该库提供与标准PyTorch模块兼容的模块化构建块。您可以使用这些构建块设计自定义架构,如多塔、多头和任务以及损失函数。使用Transformers4Rec,您可以:

  • 从任何序列表格数据构建序列和会话推荐器。
  • 利用与NVTabular的集成,实现无缝数据预处理和特征工程。
  • 执行下一项预测以及经典的二元分类或回归任务。

Merlin Systems PyPI版本shields.io 文档<br> Merlin Systems提供工具,用于将推荐模型与生产推荐系统的其他元素(如特征存储、最近邻搜索和探索策略)结合,形成端到端的推荐管道,可通过Triton推理服务器提供服务。使用Merlin Systems,您可以:

  • 从基于Triton推理服务器构建的集成平台开始,为推荐提供服务。
  • 创建定义生成推荐的端到端过程的图。
  • 受益于与推荐系统管道中常见的流行工具的现有集成。

Merlin Core PyPI版本shields.io 文档<br> Merlin Core提供在整个Merlin生态系统中使用的功能。使用Merlin Core,您可以:

  • 使用标准数据集抽象来处理跨多个GPU和节点的大型数据集。
  • 受益于识别关键数据集特征的通用模式,使Merlin能够自动执行常规建模和服务任务。
  • 通过使用构建数据转换操作符图的共享API来简化代码。

安装

使用Merlin最简单的方法是运行Docker容器。NVIDIA GPU Cloud (NGC)提供包含所有Merlin组件库、依赖项的容器,并进行单元和集成测试。有关更多信息,请参阅容器页面。

要开发和贡献Merlin,请查看每个组件库的安装文档。每个Merlin组件的开发环境都可以通过condapip轻松设置:

组件安装步骤
HugeCTRhttps://nvidia-merlin.github.io/HugeCTR/master/hugectr_contributor_guide.html
Merlin Corehttps://github.com/NVIDIA-Merlin/core/blob/stable/README.md#installation
Merlin Modelshttps://github.com/NVIDIA-Merlin/models/blob/stable/README.md#installation
Merlin Systemshttps://github.com/NVIDIA-Merlin/systems/blob/stable/README.md#installation
NVTabularhttps://github.com/NVIDIA-Merlin/NVTabular/blob/stable/README.md#installation
Transformers4Rechttps://github.com/NVIDIA-Merlin/Transformers4Rec/blob/stable/README.md#installation

示例笔记本和教程

一系列端到端示例以Jupyter笔记本的形式提供。这些示例笔记本演示了如何:

  • 下载和准备数据集。
  • 使用预处理和特征工程。
  • 使用TensorFlow、PyTorch、FastAI、HugeCTR或Merlin Models训练深度学习推荐模型。
  • 使用Triton推理服务器将模型部署到生产环境。

这些示例基于不同的数据集,提供了广泛的真实世界用例。

Merlin的技术基础

RAPIDS cuDF<br> Merlin依赖cuDF进行GPU加速的DataFrame操作,用于特征工程。

Dask<br> Merlin依赖Dask在NVTabular中分布式和扩展特征工程和预处理,并加速Merlin Models和HugeCTR中的数据加载。

Triton推理服务器<br> Merlin利用Triton推理服务器为推荐系统管道提供GPU加速服务。

反馈和支持

要报告错误或获取帮助,请提交问题

编辑推荐精选

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

TRELLIS

TRELLIS

用于可扩展和多功能 3D 生成的结构化 3D 潜在表示

TRELLIS 是一个专注于 3D 生成的项目,它利用结构化 3D 潜在表示技术,实现了可扩展且多功能的 3D 生成。项目提供了多种 3D 生成的方法和工具,包括文本到 3D、图像到 3D 等,并且支持多种输出格式,如 3D 高斯、辐射场和网格等。通过 TRELLIS,用户可以根据文本描述或图像输入快速生成高质量的 3D 资产,适用于游戏开发、动画制作、虚拟现实等多个领域。

ai-agents-for-beginners

ai-agents-for-beginners

10 节课教你开启构建 AI 代理所需的一切知识

AI Agents for Beginners 是一个专为初学者打造的课程项目,提供 10 节课程,涵盖构建 AI 代理的必备知识,支持多种语言,包含规划设计、工具使用、多代理等丰富内容,助您快速入门 AI 代理领域。

AEE

AEE

AI Excel全自动制表工具

AEE 在线 AI 全自动 Excel 编辑器,提供智能录入、自动公式、数据整理、图表生成等功能,高效处理 Excel 任务,提升办公效率。支持自动高亮数据、批量计算、不规则数据录入,适用于企业、教育、金融等多场景。

UI-TARS-desktop

UI-TARS-desktop

基于 UI-TARS 视觉语言模型的桌面应用,可通过自然语言控制计算机进行多模态操作。

UI-TARS-desktop 是一款功能强大的桌面应用,基于 UI-TARS(视觉语言模型)构建。它具备自然语言控制、截图与视觉识别、精确的鼠标键盘控制等功能,支持跨平台使用(Windows/MacOS),能提供实时反馈和状态显示,且数据完全本地处理,保障隐私安全。该应用集成了多种大语言模型和搜索方式,还可进行文件系统操作。适用于需要智能交互和自动化任务的场景,如信息检索、文件管理等。其提供了详细的文档,包括快速启动、部署、贡献指南和 SDK 使用说明等,方便开发者使用和扩展。

Wan2.1

Wan2.1

开源且先进的大规模视频生成模型项目

Wan2.1 是一个开源且先进的大规模视频生成模型项目,支持文本到图像、文本到视频、图像到视频等多种生成任务。它具备丰富的配置选项,可调整分辨率、扩散步数等参数,还能对提示词进行增强。使用了多种先进技术和工具,在视频和图像生成领域具有广泛应用前景,适合研究人员和开发者使用。

爱图表

爱图表

全流程 AI 驱动的数据可视化工具,助力用户轻松创作高颜值图表

爱图表(aitubiao.com)就是AI图表,是由镝数科技推出的一款创新型智能数据可视化平台,专注于为用户提供便捷的图表生成、数据分析和报告撰写服务。爱图表是中国首个在图表场景接入DeepSeek的产品。通过接入前沿的DeepSeek系列AI模型,爱图表结合强大的数据处理能力与智能化功能,致力于帮助职场人士高效处理和表达数据,提升工作效率和报告质量。

Qwen2.5-VL

Qwen2.5-VL

一款强大的视觉语言模型,支持图像和视频输入

Qwen2.5-VL 是一款强大的视觉语言模型,支持图像和视频输入,可用于多种场景,如商品特点总结、图像文字识别等。项目提供了 OpenAI API 服务、Web UI 示例等部署方式,还包含了视觉处理工具,有助于开发者快速集成和使用,提升工作效率。

下拉加载更多