Turing.jl v0.39.0版本发布:变分推断接口升级与核心模块重构
Turing.jl是一个基于Julia语言的概率编程框架,它允许用户使用简洁的语法构建复杂的概率模型,并支持多种推断算法。作为Julia生态系统中最重要的概率编程工具之一,Turing.jl持续推动着贝叶斯统计和机器学习的发展。
变分推断接口的重大升级
本次v0.39.0版本最显著的变化是对变分推断(Variational Inference, VI)接口的全面升级,使其与AdvancedVI.jl的0.4版本保持兼容。这一升级为Turing.jl用户带来了多项强大的新功能:
1. 位置-尺度分布族的扩展支持 新版本引入了对密集尺度矩阵的支持,这意味着用户现在可以构建更复杂的变分分布族,特别是那些需要完整协方差矩阵表示的模型。这一改进显著提升了变分后验近似的能力,特别适用于变量间存在复杂相关性的场景。
2. 参数自由的随机优化算法 新增了DoG(Distance over Gradients)和DoWG(Distance over Weighted Gradients)等先进优化算法。这些算法不需要手动调整学习率等超参数,大大简化了变分推断的调参过程,同时保持了良好的收敛性能。
3. 稳定优化的近端算子 引入近端算子技术为优化过程提供了额外的稳定性保障,特别是在处理非光滑目标函数或病态问题时,能够有效防止数值不稳定现象的发生。
4. 更快的收敛控制变量 实现了"sticking-the-landing"控制变量技术,这一方法通过减少梯度估计的方差来加速收敛过程,使得变分推断能够在更少的迭代次数下达到满意的近似精度。
5. 非可微目标的评分梯度估计器 对于包含非可微分组件的概率模型,新版本提供了专门的评分梯度估计器,扩展了变分推断的应用范围,使其能够处理更广泛的统计模型。
核心模块重构与API调整
Turing.Essential模块的移除 为了简化代码结构和提高可维护性,v0.39.0版本移除了Turing.Essential模块。该模块中的功能现在可以直接从Turing或DynamicPPL中导入。这一变化虽然对现有代码可能造成一些影响,但从长远看将提高API的一致性和易用性。
@addlogprob!宏的正式公开
@addlogprob!宏现在被正式纳入Turing.jl的公共接口并导出。这个宏允许用户在模型定义中直接操作对数概率,为构建自定义概率模型提供了更大的灵活性。它的正式公开意味着这一功能将得到长期维护,用户可以放心地在生产代码中使用。
升级建议与兼容性考虑
对于现有用户,升级到v0.39.0版本需要注意以下几点:
-
如果使用了变分推断功能,需要检查现有代码是否与新接口兼容,特别是优化器配置部分可能需要调整。
-
从Turing.Essential导入的功能需要改为从Turing或DynamicPPL导入。
-
可以开始利用
@addlogprob!宏的公共接口特性重构模型代码,以获得更好的可维护性。 -
新版本的变分推断功能提供了更多优化选项,建议用户尝试新的优化算法和梯度估计器,可能会获得更好的性能。
Turing.jl v0.39.0的这些改进进一步巩固了它作为Julia生态中最强大概率编程框架的地位,特别是在变分推断方面提供了更丰富、更稳定的功能集。对于需要进行大规模贝叶斯分析的用户,这些升级将显著提升建模的灵活性和计算效率。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C080
baihu-dataset异构数据集“白虎”正式开源——首批开放10w+条真实机器人动作数据,构建具身智能标准化训练基座。00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python056
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7GLM-4.7上线并开源。新版本面向Coding场景强化了编码能力、长程任务规划与工具协同,并在多项主流公开基准测试中取得开源模型中的领先表现。 目前,GLM-4.7已通过BigModel.cn提供API,并在z.ai全栈开发模式中上线Skills模块,支持多模态任务的统一规划与协作。Jinja00
agent-studioopenJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力TSX0133
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00