MLX-LM v0.26.0 版本发布:模型支持与性能优化全面升级
MLX-LM 是一个基于 MLX 框架的大型语言模型工具库,它为研究人员和开发者提供了便捷的模型加载、推理和微调功能。该项目支持多种主流开源大语言模型,并针对 Apple Silicon 芯片进行了优化,能够高效利用 Mac 设备的计算能力。
核心功能增强
本次 v0.26.0 版本带来了多项重要更新,主要集中在模型支持扩展和性能优化两个方面。
新增模型支持
-
MiniCPM4 模型:新增了对 MiniCPM4 模型结构的完整支持,这是一个轻量级但性能优异的中文语言模型,特别适合在资源受限的环境中部署。
-
BitNet1.58 模型:引入了 BitNet1.58 的自定义 Metal 内核实现,该模型采用 1.58 位量化技术,在保持模型性能的同时显著减少了内存占用和计算需求。
-
ERNIE4.5 系列:新增了百度 ERNIE4.5 标准版和 MoE(混合专家)版本的支持,ERNIE 是百度研发的大规模预训练模型,在中文任务上表现优异。
-
Hunyuan-A13B-Instruct MoE:支持了腾讯混元大模型的 MoE 版本,这是一个专为指令跟随优化的混合专家模型。
-
SmolLM3 模型:添加了对 SmolLM3 的支持,这是一个特别注重推理效率的小型语言模型。
性能优化与功能改进
-
CUDA 后端支持:现在 MLX-LM 不仅支持 Apple 的 Metal 后端,还新增了对 CUDA 的支持,使得该库可以在 NVIDIA GPU 上运行,大大扩展了适用场景。
-
动态量化改进:修复了动态量化中偏置项的处理问题,并引入了 KL 散度损失优化,提高了量化后模型的精度保持能力。
-
内存优化:针对深度量化(DWQ)和动态量化场景进行了内存使用优化,使得大模型能够在有限的内存资源下运行。
-
工具调用支持:增强了服务器端对工具调用的支持,并提供了使用 OpenAI 客户端的示例,方便开发者集成外部工具功能。
-
模型序列化:现在模型支持 pickle 序列化,便于模型的保存和加载,简化了模型部署流程。
开发者体验提升
-
本地模型转换:新增了直接转换本地模型的功能,开发者可以更灵活地处理自定义模型。
-
输入嵌入处理:改进了对输入嵌入(input_embeddings)的处理流程,特别是在 Mistral3 模型类型中,使得模型能够更灵活地接受不同类型的输入。
-
JSON 参数解析:在 OpenAI 工具调用场景中,现在能够自动解析 JSON 格式的参数,简化了工具集成过程。
-
流式解码修复:修复了 NaiveStreamingDetokenizer 中的索引错误问题,提高了流式输出的稳定性。
-
依赖简化:移除了对 sentencepiece 的依赖,使库更加轻量化,减少了安装和部署的复杂度。
技术实现亮点
本次更新中有几个值得注意的技术实现:
-
AFM(Attention Free Memory)实现:这是一种新型的注意力机制替代方案,能够在不使用传统注意力机制的情况下实现类似的效果,计算效率更高。
-
Metal 内核优化:特别是针对 BitNet1.58 的定制 Metal 内核,充分利用了 Apple Silicon 的硬件特性,实现了高效的 1.58 位量化计算。
-
混合专家模型支持:对多个 MoE 模型的支持表明 MLX-LM 在处理复杂模型架构方面的能力不断提升。
-
跨后端兼容性:同时支持 Metal 和 CUDA 后端,体现了框架设计的灵活性和可扩展性。
应用场景展望
随着这些新特性的加入,MLX-LM 在以下场景中将更具优势:
-
移动端部署:轻量级模型和量化支持使得在 iPhone 和 iPad 等移动设备上部署大模型成为可能。
-
研究实验:新增的模型支持和改进的工具调用功能为研究人员提供了更多实验可能性。
-
生产环境:序列化支持和内存优化使得模型更易于在生产环境中部署和维护。
-
多平台开发:CUDA 后端的加入使得开发者可以在 Mac 和 Linux/Windows 平台上使用相同的代码库。
本次更新标志着 MLX-LM 在模型支持广度和技术深度上都有了显著提升,为开发者提供了更强大、更灵活的工具来探索和应用大型语言模型。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
new-apiAI模型聚合管理中转分发系统,一个应用管理您的所有AI模型,支持将多种大模型转为统一格式调用,支持OpenAI、Claude、Gemini等格式,可供个人或者企业内部管理与分发渠道使用。🍥 A Unified AI Model Management & Distribution System. Aggregate all your LLMs into one app and access them via an OpenAI-compatible API, with native support for Claude (Messages) and Gemini formats.JavaScript01
idea-claude-code-gui一个功能强大的 IntelliJ IDEA 插件,为开发者提供 Claude Code 和 OpenAI Codex 双 AI 工具的可视化操作界面,让 AI 辅助编程变得更加高效和直观。Java01
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility.Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00