百度沈抖:智能,生成无限可能

4月16日,Create 2024百度AI开发者大会在深圳举行。会上,百度集团执行副总裁、百度智能云事业群总裁沈抖正式发布新一代智能计算操作系统——百度智能云万源。它能管理万卡规模的集群,极致地发挥GPU、CPU的性能;它有强大的大模型作为核心引擎,构建起全面的大模型服务能力。它让应用开发像搭积木一样简单,提升AI原生应用的开发效率与体验,加速AI原生应用的爆发。

沈抖表示,传统的云计算系统依然重要,但不再是主角,我们需要一个全新的操作系统,对新的计算平台,也就是智能计算做好抽象和封装,重新定义人机交互,为开发者提供更简单、更流畅的开发体验。百度智能云万源,就是这样的新一代智能计算操作系统。

image.png

百度集团执行副总裁、百度智能云事业群总裁 沈抖

以下为演讲实录:

image.png

大家上午好!今天,我想用一句我非常喜欢的话来开场:“简单是终极的复杂”。

这句话来自苹果公司的第一本宣传册,也有人说它来自达芬奇。不论来自哪里,它代表着我们对极简之美的共同追求。

在百度,我们的使命就是“用科技让复杂的世界更简单”。回到今天的主题“人人都是开发者”,那我们追求的一种简单,就是让每个人都可以用极简的方式开发出极强的软件。

640.gif

80年前,第一代“程序员”手动插拔电缆、转动旋钮,用布线板来操作计算机,难度大、效率低还容易出错。

640 (1).gif

后来,汇编语言和汇编器出现了。我们可以用一种相对自然的方式告诉机器如何工作,大大提高了开发效率。这种让程序代替人工、让软件管理硬件的方式,就是操作系统的雏形。

但这还远远不够。

640 (2).gif

再后来,高级编程语言和编译器诞生了,计算平台进一步进化,开发者可以用更接近人类的方式表达需求,无需关心底层软硬件的复杂性。大多数的应用可以在不修改任何代码的情况下,都可以迁移到其它硬件上去运行。

640 (3).gif

9,000+行代码的UNIX6

640 (4).gif

4,300,000+行代码的WinNT

640 (5).gif

45,000,000+行代码的WinXP

软件越来越复杂,硬件越来越先进。随之升级的是快速迭代的操作系统。

本质上,操作系统就是管理硬件和软件,往下一层层屏蔽底层的复杂性、往上抽象成简单的交互界面。对开发者来说,只需要关注业务本身的逻辑,使用简单的编程工具和语言,开发相应的软件功能。

640 (6).gif

随着软件规模和复杂度的提高,单台机器已经不能满足需求,集群出现了。

集群出现以后,操作系统管理的对象,不再是单台机器和运行在上面的“进程”,而是整个集群和上面运行的各种“微服务”,管理的对象和复杂性有了质的变化。

640 (7).gif

云计算应运而生,集群管理的复杂性从此被隐去,开发者可以按需扩缩容,灵活响应市场的变化。

640 (8).gif

到了今天又不一样了,大模型出现了。机器和系统第一次不再是人类的提线木偶,而是具备了“理解、生成、逻辑和记忆”的能力。这将彻底改变人和机器的关系,这其中最重要的一点就是软件开发的范式。编程不再是少数经过专业训练的程序员的特权。相反,人人都是开发者。编程不再需要从C/C++学起,而是从自然语言开始;编程不再是面向过程、面向对象,而是面向需求,以后编程的过程,就是一个人表达愿望的过程。

这是革命性的变化。它会彻底颠覆原有的操作系统。

在操作系统的内核中,底层的硬件从以CPU算力为主变成以GPU算力为主,而且第一次增加了硬件和软件以外的资源,也就是被大模型压缩的世界知识。操作系统管理的对象,从管理进程到管理微服务,进而进化到了管理智能。

image.png

传统的云计算系统依然重要,但不再是主角,我们需要一个全新的操作系统,对新的计算平台,也就是智能计算做好抽象和封装,重新定义人机交互,为开发者提供更简单、更流畅的开发体验。那这种操作系统到底应该长什么样子呢?

640 (9).gif

它需要能管理万卡规模的集群,需要极致发挥GPU、CPU的性能,需要高速互联。

640 (10).gif

它需要有强大的大模型作为核心引擎,不仅是语言大模型,还有视觉大模型。

而这些就构成了操作系统的内核。

640 (11).gif

在内核层之上,还需要构建起强大的大模型服务能力,我们刚才提到内核层的各种模型,它们的精调、评估、部署、调用等工具链,我们都要建立起来。

640 (12).gif

而在这之上,我们还有好的应用开发工具去做工作流编排、插件管理,让应用开发像搭积木一样简单!

640 (13).gif

当然了,一个操作系统,作为企业服务,安全和运维也必不可少。

640 (14).gif

此外,它还要隐藏掉上一代云原生系统的复杂性。

而且最后,它要能够推动加速AI原生应用的爆发。

image.png

这就是新一代智能计算操作系统……万源!

鼓个掌!这个鼓掌很值得,为什么呢?

有一种说法叫软件定义世界,而今天我们呈现的万源就是用来帮助人类去定义软件。

image.png

接下来,我们打开万源,看看里面的每一个部分。

image.png

首先是内核层。大模型不是免费的午餐,强大的模型能力需要巨大的算力、甚至电力,算力的有效管理至关重要。实际上现在因为不合理的算力管理和使用方法,当下社会上很多算力被浪费掉了。我们需要一个强大的操作系统将现有的算力资源发挥到极致,支撑大模型和应用创新的迭代。

我们知道,要训练一个好的大模型,需要上万张卡的集群。但是,如果要让上万张卡像一张卡一样工作、实现性能的线性扩展、保障任务不间断,这对集群的设计、调度、容错都是巨大的挑战。

目前,在百舸,我们的万卡集群上的有效训练时长占比达到了98.8%;线性加速比和带宽有效性都超过了95%。这绝对是业界最高级别的算力效能。

image.png

在算力方面,国内还有一个特殊情况,就是芯片供应的不确定性,这必然会导致将来多款芯片并存的格局。短期看,这是大家被动接受的局面;但是长期看,这一定是大家主动选择的结果。因为只有这样,才能摆脱对单一芯片的依赖,实现更优的成本,保证更有弹性的供应链。

但是,不同厂商的芯片差异很大;即使同一厂商,不同代际的芯片差距也很大。用来推理还可以,但如果想训练大模型、尤其是在单一训练任务上,把不同芯片用好非常难。

今天,我很高兴地告诉大家,百舸平台上已经实现了百卡规模、单一训练任务下,不同厂商芯片的混合训练,而且把训练的性能损失控制在3%,即使在千卡规模下,性能损失也不超过5%。可见百舸已经给大家屏蔽掉了芯片之间的差异,给了大家选择不同芯片组合的权利!

这里真的应该有掌声,我们苦芯片久矣。芯片会变得越来越多元,我们需要这样的能力去帮助我们管理不同的芯片,把它们绑在一起像一款芯片一样工作。

image.png

当然了,内核中的另一个重要组成部分是大模型。它压缩了庞大的世界知识,将理解、生成、逻辑、记忆能力封装起来、向上提供简单的接口,让AI原生应用可以高效运行。

万源的内核,既包含了业界领先的ERNIE 4.0、3.5这些海峰刚刚讲过的模型、也包括ERNIE Speed/Lite/Tiny系列轻量模型,此外还包括文心视觉大模型和一些各有特色的第三方大模型,充分满足用户在不同业务场景下的多样化需求。

image.png

内核之上是千帆ModelBuilder。内核中的这些模型的管理、调度、二次开发,都可以通过ModelBuilder解决。很多场景化的需求,不需要从头去训练大模型,只要在合适的基础大模型上,做些模型精调、甚至就是改一下提示词,就可以很好地解决问题。

ModelBuilder的目的就是要把这些工具产品化,屏蔽掉模型开发的复杂性,让更多人只需要投入少量的数据、资源和精力,就能快速精调出适合自己业务的模型。

在实际应用中,就像Robin刚才提到的,我们需要合理地组合不同的模型。ModelBuilder提供的模型路由服务,会自动给不同难度的任务选择最合适的模型,实现效果和成本的最优组合,在效果基本持平的情况下,它可以使得推理成本降低30%以上。

image.png

再往上看,是工具层。千帆AppBuilder和AgentBuilder是强大的应用开发平台,正如Robin刚才已经演示了好几个这样的案例,它们可以支持各种agent和应用的快速开发和发布。通过AppBuilder开发的应用,可以一键发布到百度搜索、微信公众号等平台,也可以通过API或SDK的方式直接集成到您自己的系统中。真正做到极速开发,轻松上市。

image.png

当然了,现阶段,大模型还不够完美,有些场景下,人的经验可以帮agent做更好的任务规划,因此AppBuilder发布了工作流编排功能。基于AppBuilder的工作流编排,开发者可以使用预置的模板和组件,轻松定制自己的业务流程,还可以在上面集成、扩建自己特色的组件,在不同节点上选用不同的模型。如果您在ModelBuilder上精调了模型,那现在在AppBuilder上也可以很方便地直接调用,整个过程非常便捷。

image.png

所以现在大家可以看到,万源从内核到Shell、再到应用开发工具,已经实现了层与层的有机结合、端到端的效能优化。过去一年多,在内外部客户的各种实际应用中,不断打磨、持续完善,万源,已经成为AI原生时代的智能计算操作系统,为用户提供极简的开发体验、智能的系统内核,和高效的异构算力。

image.png

今天的发布是一个起点。未来,我们会进一步开放操作系统各个层面的生态合作。

image.png

向上,我们要开放更多的能力和接口,开发者可以非常简单地开发应用。

image.png

向左,我们可以用万源作为基础、帮助大家打造出适合自己垂直行业的操作系统。

image.png

向右,我们可以把万源直接部署在智算中心,享受稳定、安全、高效的智能计算平台。

image.png

向下,我们会适配更多的芯片,为开发者进一步隐去异构集群的复杂性,让不同的芯片都能发挥最大的效能。

image.png

除了底层硬件,我们也欢迎更多的合作伙伴一起,在模型、工具、应用等各个层面上持续丰富万源的生态。

image.png

这就是我今天要给大家分享的,全新一代智能计算操作系统——万源,强大、敏捷、开放,为在座诸位和每一个有想法的人提供极致简单的开发体验,让您的每一个创意都能在分钟之间上线、应用!

image.png

今天,人人都是开发者,人人都是创造者。

无需等待,即刻启程。

让智能,生成无限可能!谢谢大家!

——————END——————

推荐阅读

基于afx透明视频的视觉增强前端方案

百度一站式数据自助分析平台(TDA)建设

浅析如何加速商业业务实时化

登录系统演进、便捷登录设计与实现

一文带你完整了解Go语言IO基础库

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

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

相关文章

本地环境运行Llama 3大型模型:可行性与实践指南

简介: Llama 是由 Meta(前身为 Facebook)的人工智能研究团队开发并开源的大型语言模型(LLM),它对商业用途开放,对整个人工智能领域产生了深远的影响。继之前发布的、支持4096个上下文的Llama 2…

19. TypeScript 类型运算符

TypeScript作为JavaScript的超集,不仅提供了静态类型检查,还引入了多种类型运算符,使得类型定义更加灵活和强大。这些运算符可以帮助我们构建更加精确和灵活的类型定义。本文将详细介绍这些类型运算符的用法和应用场景。 keyof 运算符 keyo…

Python 数据可视化 boxplot

Python 数据可视化 boxplot import pandas as pd import matplotlib.pyplot as plt import numpy as np import seaborn as sns# 读取 TSV 文件 df pd.read_csv(result.tsv, sep\t)normal_df df[df["sample_name"].str.contains("normal")] tumor_df df…

重磅!!!监控分布式NVIDIA-GPU状态

简介:Uptime Kuma是一个易于使用的自托管监控工具,它的界面干净简洁,部署和使用都非常方便,用来监控GPU是否在占用,非常美观。 历史攻略: docker应用:搭建uptime-kuma监控站点 win下持续观察…

新能源汽车电池盒尺寸检测

SNK施努卡电池盒错漏装和尺寸检测 随着环境污染和能源短缺问题日益突出,新能源汽车作为一种环保、可持续的交通工具得到了广泛关注和推广。其中,电池是新能源汽车的核心部件之一,其性能和质量直接影响到整车的续航能力和安全性。而电池盒作为…

Unity Meta Quest MR 开发(七):使用 Stencil Test 模板测试制作可以在虚拟与现实之间穿梭的 MR 传送门

文章目录 📕教程说明📕Stencil Test 模板测试📕Stencil Shader📕使用 Unity URP 渲染管线设置模板测试⭐Render Pipeline Asset 与 Universal Renderer Data⭐删除场景中的天空盒⭐设置虚拟世界的层级 Layer⭐设置模板测试 &#…

《Vid2Seq》论文笔记

原文链接 [2302.14115] Vid2Seq: Large-Scale Pretraining of a Visual Language Model for Dense Video Captioning (arxiv.org) 原文笔记 What: 《Vid2Seq: Large-Scale Pretraining of a Visual Language Model for Dense Video Captioning》 作者提出一种多…

uniapp实现相册、拍照及视频录制功能

一、调用相册、拍照及视频录制功能要先获取相册权限,摄像头权限,要不然,调用不了下面的方法 1.1、到插件市场先下载js_sdk 1.2、引入js_sdk import permision from "/js_sdk/wa-permission/permission.js" 1.3 、安卓手机获取权…

Python内置函数input()详解

Python内置函数input()详解 在Python编程中,input()函数是一个基本的内置函数,它允许程序从用户那里获取输入。这个函数对于创建交互式程序来说非常重要,因为它让程序能够接收用户的文本输入。 函数功能 input()函数的主要功能是从标准输入…

深度学习检测算法YOLOv5的实战应用

在当前的检测项目中,需要一个高效且准确的算法来处理大量的图像数据。经过一番研究和比较,初步选择了YOLOv5作为算法工具。YOLOv5是一个基于深度学习的检测算法,以其快速和准确而闻名。它不仅能够快速处理图像数据,还能提供较高的…

两数、三数以及四数之和

两数之和 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值 target 的那两个整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。 你可以按…

Java基础教程(7)-Java中的面向对象和类

面向对象编程 Java是一种面向对象的编程语言。面向对象编程,英文是Object-Oriented Programming,简称OOP 面向对象和面向过程的区别 面向过程编程是自顶而下的编程模式;把问题分解成一个一个步骤,每个步骤用函数实现,依次调用即可 面向对象编程是将事务高度抽象化的编程…

acwing算法提高之图论--拓扑排序

目录 1 介绍2 训练3 参考 1 介绍 本专题用来记录拓扑排序相关的题目。 求拓扑序列算法的关键步骤: 把入度为0的结点插入队列q。弹出队头t(将t记录下来),遍历队头t的下一个结点,将其入度减1。操作之后,如…

【OceanBase诊断调优】——hpet(高精度时钟源)引起的CPU高问题排查

最近总结一些诊断OCeanBase的一些经验,出一个【OceanBase诊断调优】专题出来,也欢迎大家贡献自己的诊断OceanBase的方法。 1. 前言 昨天在问答区帮忙排查一个用户CPU高的问题,帖子链接:《刚刚新安装的OceanBase集群,…

Rime 如何通过 iCloud 实现词库多端同步,Windows、iOS、macOS

Rime 如何通过 iCloud 实现词库多端同步,Windows、iOS、macOS 一、设备环境 最理想的输入环境就是在多端都使用同一个词库,这样能保持多端的输入习惯是一致的。 以我为例,手头每天都要用到的操作平台和对应的输入法: 操作系统设…

39 vue.js

1.1 vue是什么? vue是当下主流的前端框架,用于构建用户界面的 渐进式 自底向上增量开发的MVVM框架。 渐进式:其实每个框架都有自己的特点,在开发的过程中,可以在原有的系统上,把其中一两个功能用VUE…

【热门前端【vue框架】】——vue框架和node.js的下载和安装保姆式教程

👨‍💻个人主页:程序员-曼亿点 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 曼亿点 原创 👨‍💻 收录于专栏&#xff1a…

如何修复Django中的“ImproperlyConfigured”错误?

在Django中,通常会遇到“ImproperlyConfigured”错误,这表示配置不正确或缺少必要设置。下面是一些常见的修复方法: 检查settings.py文件:确保设置了正确的数据库配置、应用程序、模板路径、静态文件路径等。确保所有必要的设置都…

使用Nginx和内网穿透实现多个本地Web站点的公网访问

在需要将多个本地Web站点暴露到公网的情况下,可以通过Nginx配置文件的修改结合内网穿透技术来实现。下面是具体的步骤和示例: 1. 安装和配置Nginx 首先,确保已经在服务器上安装了Nginx,并且配置了基本的Nginx服务器块&#xff0…

【ARM 裸机】模仿 STM32 驱动开发

1、修改驱动 对于 STM32 来说,使用了一个结构体将一个外设的所有寄存器都放在一起,在上一节的基础上进行修改; 1.1、添加清除 bss 段代码, 1.2、添加寄存器结构体 新建一个文件,命名imx6u.h,注意地址的连…