DeepSeek 开源周:DeepEP 项目详解,GPU 压榨计划启动!

news2025/3/1 4:35:39

引言

就在今天,2025年2月25日,DeepSeek 再次为人工智能社区带来了一场技术盛宴——DeepEP 项目的开源。这个旨在优化 GPU 性能的工具一经发布便迅速获得了广泛的关注和赞誉,短短两小时内就斩获了超过1000个 Star。本文将详细介绍 DeepEP 的功能、应用场景以及如何使用它来提升 AI 训练和推理的效率。

DeepEP 概述

功能与作用

DeepEP 是一个专门针对 Mixture-of-Experts (MoE) 训练方法设计的通信工具,其核心目标是通过优化 GPU 之间的数据传输来加速 AI 的训练和推理过程。具体来说,DeepEP 能够:

  • 提升 GPU 间的数据传输速度,无论是 NVLink(同一机器内的 GPU)还是 RDMA(跨机器的 GPU)。
  • 减少推理解码阶段的延迟,这对于实时应用如 ChatGPT 至关重要。
  • 实现计算和数据传输的并行执行,避免因等待数据传输而导致的计算停滞。

技术细节

DeepEP 采用了特殊的 hook 机制,使得 GPU 可以在进行数据传输的同时继续执行计算任务,从而提高了整体效率。此外,DeepEP 还支持低延迟模式,特别适合需要快速响应的大规模模型推理场景。

实际性能表现

根据测试,在 NVIDIA H800 GPU 加上 400Gb/s RDMA 的服务器环境下,DeepEP 展现出了令人印象深刻的性能指标:

  • 普通模式:NVLink 速度可达 158GB/s,RDMA 速度在 43-47GB/s 之间。
  • 低延迟模式:延迟可低至 163 微秒,RDMA 速度维持在 39-46GB/s。

这些数字表明,DeepEP 能够显著提高大规模 MoE 模型的训练和推理效率。

安装与使用指南

系统要求

为了充分利用 DeepEP 的性能优势,你需要具备以下硬件和软件环境:

  • GPU:Hopper 架构的 GPU(例如 H100 或 H800)
  • Python:版本 3.8 及以上
  • CUDA:版本 12.3 及以上
  • PyTorch:版本 2.1 及以上
  • 网络设备:NVLink 和 RDMA 支持

安装步骤

首先,确保你已经安装了必要的依赖项,然后执行以下命令来安装 DeepEP:

NVSHMEM_DIR=/path/to/installed/nvshmem python setup.py install

使用示例

MoE 训练中的应用

以下是一个简单的代码示例,展示了如何在 MoE 训练过程中使用 DeepEP 来分配任务和合并结果:

import torch
import torch.distributed as dist
from deep_ep import Buffer

# 初始化通信 buffer
_buffer = None

def get_buffer(group, hidden_bytes):
    global _buffer
    if _buffer is None or _buffer.group != group:
        _buffer = Buffer(group, hidden_bytes, hidden_bytes)
    return _buffer

# MoE 分发任务
def dispatch_forward(x, topk_idx, topk_weights, num_experts):
    global _buffer
    recv_x, recv_topk_idx, recv_topk_weights, handle, event = _buffer.dispatch(x, topk_idx, topk_weights, num_experts)
    return recv_x, recv_topk_idx, recv_topk_weights, handle, event

这段代码创建了一个高效的“快速通道”,用于分发 MoE 任务并接收计算结果。

推理解码阶段的应用

在推理解码时,DeepEP 可以让数据在后台传输,不影响 GPU 的计算任务:

import torch
import torch.distributed as dist
from deep_ep import Buffer

_buffer = None

def get_buffer(group, num_max_tokens, hidden, num_experts):
    global _buffer
    if _buffer is None or _buffer.group != group:
        _buffer = Buffer(group, 0, num_max_tokens * hidden * num_experts, low_latency_mode=True)
    return _buffer

def low_latency_dispatch(hidden_states, topk_idx, num_max_tokens, num_experts):
    global _buffer
    recv_hidden_states, recv_expert_count, handle, event, hook = _buffer.low_latency_dispatch(hidden_states, topk_idx, num_max_tokens, num_experts)
    return recv_hidden_states, recv_expert_count, handle, event, hook

这段代码确保了数据能够在后台高效传输,同时不影响 GPU 的计算能力。

结论

随着 DeepEP 的开源,AI 开发者们现在拥有了一个强大的工具来优化他们的 GPU 资源,提高训练和推理的速度。DeepSeek 的这一举措不仅展示了其对技术创新的承诺,也为整个 AI 社区带来了更多的可能性。

如果你对 DeepEP 感兴趣,可以通过以下链接访问其 GitHub 仓库并开始探索:

DeepEP GitHub

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2307706.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

从零开始自主「起身站立」,上海AI Lab发布最新控制算法,机器人:起猛了

来源 | 机器之心 近日,上海 AI Lab 具身智能中心研究团队在机器人控制领域取得了最新突破,提出的 HoST(Humanoid Standing-up Control)算法,成功让人形机器人在多种复杂环境中实现了自主站起,并展现出强大…

Solr中得Core和Collection的作用和关系

Solr中得Core和Collection的作用和关系 一, 总结 在Apache Solr中,Core和Collection 是两个核心概念,他们分别用于单机模式和分布式模式(SolrCloud)中,用于管理和组织数据。 二,Core 定义&am…

AI驱动的自动化留给人类的时间不多了

时间紧迫!时间紧迫!时间紧迫! 关于AI工作流催生的行业任务自动化时间窗口,结合技术成熟度、成本效益、行业特性等维度,可划分为以下阶段: 一、技术渗透阶段(2025-2028年) 高重复性任…

使用 Containerd 通过 HTTP 协议拉取 Harbor 私有镜像仓库的镜像

在 Kubernetes 1.24及以上版本环境中,docker不再被支持,主要使用Containerd 是常用的容器运行。默认情况下,Containerd 使用 HTTPS 协议与镜像仓库通信。然而,在某些场景下(如测试环境或内部网络)&#xff…

Dify在Ubuntu20.04系统的部署

文章目录 一、dify 介绍1.核心功能优势2.应用场景 二、dify 安装(docker方式)1.代码库下载2.配置文件修改3.启动docker 容器 三、遇到问题与解决1.使用sudo docker compose up -d报错2.使用service docker start报错 一、dify 介绍 Dify 是一款开源的大语言模型(LL…

达梦:内存相关参数

目录 28个相关参数1. 内存池相关MEMORY_POOLMEMORY_N_POOLSMEMORY_BAK_POOL 2. 大缓冲区相关HUGE_BUFFERHUGE_BUFFER_POOLS 3. 共享缓冲区相关BUFFERBUFFER_POOLSBUFFER_MODEMAX_BUFFER 4. 快速池相关FAST_POOL_PAGES 5. 回收池相关RECYCLE_POOLS 6. 回滚段池相关ROLLSEG_POOLS…

计算机毕设-基于springboot的融合多源高校画像数据与协同过滤算法的高考择校推荐系统的设计与实现(附源码+lw+ppt+开题报告)

博主介绍:✌多个项目实战经验、多个大型网购商城开发经验、在某机构指导学员上千名、专注于本行业领域✌ 技术范围:Java实战项目、Python实战项目、微信小程序/安卓实战项目、爬虫大数据实战项目、Nodejs实战项目、PHP实战项目、.NET实战项目、Golang实战…

《Qt动画编程实战:轻松实现头像旋转效果》

《Qt动画编程实战:轻松实现头像旋转效果》 Qt 提供了丰富的动画框架,可以轻松实现各种平滑的动画效果。其中,旋转动画是一种常见的 UI 交互方式,广泛应用于加载指示器、按钮动画、场景变换等。本篇文章将详细介绍如何使用 Qt 实现…

SpringBoot3—快速入门

一、简介 (1)前置知识 Java17Spring、SpringMVC、MyBatisMaven、IDEA (2)环境要求 (3)SpringBoot3是什么 核心概念:Spring Boot 底层是 Spring,能简单、快速地创建一个独立的、生…

Python基于机器学习的微博舆情情感分析系统,微博评论情感分析可视化系统(全新升级)

大家好,今天为大家带来的是Python基于机器学习的微博舆情情感分析系统,微博评论情感分析可视化系统,这个系统在原本的系统上进行优化升级。 算法从开源框架的 snlow ,到支持机器学习的 lstm 算法可以手动输入语句,进行…

Matlab地图绘制教程第2期—水陆填充图

上一期分享了海岸线图的绘制方法: 本着由浅入深的理念,本期再来分享一下水陆填充图的绘制方法。 先来看一下成品效果: 特别提示:Matlab地图绘制教程系列,旨在降低大家使用Matlab进行地图类科研绘图的门槛,…

云创智城YunCharge 新能源二轮、四轮充电解决方案(云快充、万马爱充、中电联、OCPP1.6J等多个私有单车、汽车充电协议)之新能源充电行业系统说明书

云创智城YunCharge 新能源充电行业系统说明书 ⚡官方文档 ⚡官网地址 1. 引言 随着全球环境保护和能源危机的加剧,新能源汽车行业得到了快速发展,充电基础设施建设也随之蓬勃发展。新能源充电行业系统旨在提供高效、便捷的充电服务,满足电…

(八)Java-Collection

一、Collection接口 1.特点 Collection实现子类可以存放多个元素,每个元素可以是Object; 有些Collection的实现类,可以存放重复的元素,有些不可以; 有些Collection的实现类,有些是有序的(Li…

小程序高度问题背景scss

不同的机型&#xff0c;他的比例啥的都会不一样&#xff0c;同样的rpx也会有不同的效果。所以这里选择了取消高度。 <view class"box-border" :style"{padding-top: ${navHeight}px,}"><!-- 已登录 --><view v-if"userStore.userInfo&…

Cuppa CMS v1.0 任意文件读取(CVE-2022-25401)

漏洞简介&#xff1a; Cuppa CMS v1.0 administrator/templates/default/html/windows/right.php文件存在任意文件读取漏洞 漏洞环境&#xff1a; 春秋云镜中的漏洞靶标&#xff0c;CVE编号为CVE-2022-25401 漏洞复现 弱口令行不通 直接访问administrator/templates/defau…

基于Spark的电商供应链系统的设计与实现

目录 1.研究背景与意义 2、国内外研究现状 3、相关理论与技术 &#xff08;一&#xff09;分布式计算系统Spark &#xff08;二&#xff09;数据仓库Hive &#xff08;三&#xff09;读取服务器本地磁盘的日志数据Flume &#xff08;四&#xff09;分布式消息队列Kafka …

从零开始用react + tailwindcs + express + mongodb实现一个聊天程序(二)

1.安装mogondb数据库 参考MongoDB安装配置教程&#xff08;详细版&#xff09;_mongodb安装详细步骤-CSDN博客 安装mondbcompass数据库连接工具 参考https://www.mongodb.com/zh-cn/docs/compass/current/connect/ 2.后端服务 1.创建src文件夹 并在src文件夹下创建 index…

server.servlet.session.timeout: 12h(HTTP 会话的超时时间为 12 小时)

从你提供的配置文件&#xff08;应该是 Spring Boot 的 application.yml 或 application.properties 文件&#xff09;来看&#xff0c;以下部分与会话超时时间相关&#xff1a; server:servlet:session:timeout: 12h # timeout: 30cookie:name: VENDER_SID会话超时时间的…

使用vscode导出Markdown的PDF无法显示数学公式的问题

我的硬件环境是M2的MacBook air&#xff0c;在vscode中使用了Markdown PDF来导出md文件对应的PDF。但不管导出html还是PDF文件&#xff0c;数学公式都是显示的源代码。 我看了许多教程&#xff0c;给的是这个方法&#xff1a;在md文件对应的html文件中加上以下代码&#xff1a…

Idea编译项目很久之后,提示 Error:java:OutOfMemoryError:insufficient memory

项目挺老的的了&#xff0c;平常项目启动&#xff0c;也要挺久的&#xff0c;但是最起码能启动成功&#xff0c;今天下午的时候&#xff0c;项目启动了十几分&#xff0c;一直在转圈&#xff0c;后面控制台输出了这一行异常 Error:java:OutOfMemoryError:insufficient memory …