百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

PDF文件长出“AI大脑”?网友惊呼:这操作太“黑科技”了

liuian 2025-05-28 18:48 19 浏览

你以为PDF只是用来阅读文档的?这次它彻底颠覆了你的想象!极客Aiden Bai最新整活——直接把大语言模型(LLM)塞进PDF里,打开文件就能让AI讲故事、陪你聊天!更夸张的是,连Linux系统都能在PDF里运行。

技术宅太疯狂!

在PDF中,也能运行LLM。

从PDF里跑出AI大脑?网友惊呼:这操作太「黑科技」了!

最近,Aiden Bai的推文掀起了热议,已有数万浏览!

他展示了一个名为「llm.pdf」的项目,标题赫然写着:「在PDF文件中,运行大语言模型!」

疯狂程度堪比人类穿越进入电子游戏!

更夸张的是,评论区里还有人爆料,连Linux系统都能塞进PDF里运行。

日常办公、「高端爆料」中常见的文件格式——

Portable Document Format(.PDF),还能跑大模型,这到底怎么回事儿?

PDF里藏AI:还能讲故事、聊聊天

「llm.pdf」的项目在PDF里面,嵌入了几个小型语言模型(SLM),比如TinyStories(3M参数)、Pythia(31M参数)和TinyLLM(10M参数)。

这些模型虽然「小巧」,但功能可不简单!

TinyStories:3M参数,运行速度快。号称是最小的能生成连贯文本的语言模型,专门为讲故事设计。想象一下,打开PDF,它给你讲个儿童故事,比如「小红帽大战大灰狼2.0」!

Pythia:31M参数,速度稍慢,支持对话。一个小型对话模型,能与人聊天,比如问它「今天天气怎么样」,它可能会一本正经地回答:「我不知道,但我可以给你讲个下雨天的故事!」

TinyLLM:10M参数,速度快。一个概念验证模型,专注于文本生成,适合做些简单的创作实验。

用户可以直接下载这些已构建好的PDF文件,打开后就能体验AI的「魔法」——直接在PDF里生成文本、讲故事,甚至聊天!

想象一下,你打开一个PDF文件,里面不是枯燥的文档,而是一个能跟你互动的AI小助手,给你讲个睡前故事,或者陪你聊聊今天的趣事。

这种体验是不是有点像科幻电影里的场景?

网友们炸开了锅,有人调侃:「我现在是更怕醒来发现自己被困在PDF里,还是怕变成Fortnite里的联动角色?」

TinyStories:讲睡前故事的最小LLM

「llm.pdf」项目里提到的TinyStories模型,其实背后还有一段有趣的故事。

这个模型基于TinyStories数据集,最早是为了研究小型语言模型的能力。

研究者用GPT-3.5和GPT-4生成了数百万个儿童小故事,内容简单但包含了语法、词汇和推理等语言要素。

词汇简单,3到4岁儿童就能看得懂。

论文链接:
https://arxiv.org/abs/2305.07759

Pythia:从实验室到百姓

Pythia旨在研究语言模型的「可解释性」和「学习动态」。

简单来说,他们想搞清楚:AI模型在训练过程中,到底是怎么「学会」语言的?知识又是如何一步步积累的?

论文链接:
https://arxiv.org/abs/2304.01373

Pythia项目聚焦于自回归Transformer模型,结合可解释性分析和规模法则(scaling laws),研究模型在训练中的知识演变。

Pythia模型家族包含多个版本,从70M到12B参数不等,而「llm.pdf」里用到的Pythia-31M是其中最小的一个版本。

虽然小,但它继承了Pythia项目的核心优势:高效、透明、适合研究。

多项目研究利用Pythia模型的透明性和可控性,深入探索了语言模型的「黑箱」问题。

而「llm.pdf」项目把Pythia-31M塞进PDF里,也算是让学术成果「飞入寻常百姓家」,从实验室走向了普通用户。

TinyLLM:为边缘设备量身打造

TinyLLM的目标是为边缘设备(比如物联网设备、嵌入式传感器)设计轻量级语言模型,因为这些设备通常计算资源有限,跑不动动辄几十亿参数的大模型。

TinyLLM框架有几个亮点:

轻量高效:TinyLLM模型只有10M参数,却能完成基本的文本生成任务,非常适合资源受限的场景。这种小模型在边缘设备上推理时,内存占用和计算需求都极低。

训练框架:TinyLLM提供了一个完整的训练和部署pipeline,支持用户用自己的数据训练模型。框架支持多种优化技术,比如量化(quantization)和剪枝(pruning),进一步降低模型的资源需求。

嵌入式应用:TinyLLM最初是为嵌入式传感设备设计的。

「llm.pdf」项目里的TinyLLM-10M,正是这个框架的一个实例。

虽然PDF并不是TinyLLM的典型应用场景,但这种跨界玩法也体现了小型语言模型的灵活性。

不只是AI,连Linux都能跑?

更让人瞠目结舌的是,Zaid在评论区丢出一记「重磅炸弹」:早在2月份,他就发帖提到过,PDF文件还能运行Linux系统!

他提到的项目利用RISC-V模拟器(基于TinyEMU),通过JavaScript在PDF里模拟出一个完整的Linux环境。

换句话说,你打开一个PDF,里面可能藏着一个能跑命令行的小型操作系统!

这波操作简直让网友们脑洞大开。

网友Gadgets Fan甚至开玩笑说:「这不算啥,毕竟我们整个宇宙可能都在一个PDF里模拟运行呢!」

虽然是玩笑,但也反映了大家对这种技术的惊叹——PDF这个我们常用的文件格式,竟然能变成一个「万能容器」,装下AI、操作系统,甚至更多可能性。

这背后是怎么做到的?

技术原理

你可能好奇,PDF不是用来存文档的吗?怎么还能跑AI和Linux?

其实,这一切都要归功于PDF格式的一个隐藏技能——它支持JavaScript!

是的,你没听错,PDF文件可以通过嵌入JavaScript代码来执行动态操作。

早在Adobe Acrobat等PDF编辑软件中,就已经支持在PDF里运行JavaScript了,比如用来做动态表单或者交互效果。

「llm.pdf」项目正是利用了这一点。

开发团队将小型语言模型编译成JavaScript代码(通过工具像Emscripten将C代码转为asm.js),然后嵌入到PDF中。

打开PDF时,JavaScript引擎就会运行这些代码,让AI模型「活」过来。

在对应的Github项目中,开发者解释了具体的细节:

模型编译:用Emscripten工具把高效的语言模型推理框架llama.cpp编译成了asm.js,这样模型就可以在JavaScript环境中运行。

嵌入PDF:利用老版本的PDF JavaScript注入技术(PDF JS injection),他们把编译好的模型代码嵌入到PDF文件中。

不仅如此,模型的权重文件(比如TinyStories的3M参数权重)也被转成base64格式,直接塞进了PDF里。

这意味着,整个AI模型和它的运行环境都打包在一个PDF文件里,打开就能用!

运行推理:当你打开PDF时,阅读器会执行嵌入的JavaScript代码,加载模型并运行推理(inference),直接在PDF界面上生成文本或对话。

不过,这种操作也有局限性。

现代浏览器(比如Chrome)的PDF引擎禁用了JIT(即时编译)功能,导致JavaScript运行速度较慢。

相比之下,Adobe Acrobat的表现更好,因为它的JavaScript引擎更宽松,支持更高效的执行。

至于Linux项目,原理类似,也是利用PDF的JavaScript支持,通过RISC-V模拟器(TinyEMU)在PDF里模拟一个小型操作系统。虽然性能有限,但这种创意已经足够震撼了!

结语:PDF,你还有多少惊喜?

谁能想到,平日里我们用来存简历、合同的PDF,竟然能变成AI和操作系统的「游乐场」?

从Linux模拟,再到如今的「llm.pdf」,PDF的潜力似乎被彻底挖掘出来了。

或许在未来,PDF不再只是静态文档,而是可以互动、计算甚至「思考」的智能容器。

PDF的下一个「魔法」会是什么?

参考资料:

https://www.youtube.com/watch?v=4cBom2lAx-g

https://x.com/aidenybai/status/1916171665421053963

本文来自微信公众号“新智元”,作者:新智元,36氪经授权发布。

相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...