Turing.jl中SimplexBijector与filldist结合使用的修复方案
问题背景
在Turing.jl概率编程框架中,当用户尝试使用filldist函数创建多维Dirichlet分布的数组时,会遇到栈溢出错误。具体表现为:
@model demo() = x ~ filldist(Dirichlet(ones(2)), 3)
sample(demo(), NUTS(), 1000)
执行上述代码会导致无限递归,最终抛出StackOverflowError。这个问题源于两个技术层面的缺陷:
SimplexBijector的logabsdetjac方法存在歧义- 逆向变换的形状处理不正确
技术分析
SimplexBijector的作用
在概率编程中,SimplexBijector是一个关键的变换器,用于处理单纯形空间(simplex)上的分布。Dirichlet分布定义在单纯形上,这意味着它的样本点必须满足所有分量之和为1。为了在无约束空间中进行采样和优化,我们需要将单纯形上的点映射到无约束空间,反之亦然。
问题根源
第一个问题出现在logabsdetjac方法的实现上。当处理矩阵输入时,现有的实现会导致无限递归,因为它没有正确处理矩阵的列迭代。
第二个问题涉及形状处理。当进行逆向变换时,系统没有正确重塑输入数据的维度,导致后续计算无法正确处理多维Dirichlet分布的情况。
解决方案
方法歧义修复
我们通过明确定义矩阵输入的logabsdetjac方法来避免递归问题:
function Bijectors.logabsdetjac(b::Bijectors.SimplexBijector, x::AbstractMatrix{<:Real})
return sum(Base.Fix1(logabsdetjac, b), eachcol(x))
end
这个实现明确了对矩阵的每一列分别计算对数绝对雅可比行列式,然后求和,避免了方法调用的歧义。
形状处理修复
对于逆向变换的形状问题,我们添加了专门的形状处理逻辑:
function DynamicPPL.with_logabsdet_jacobian_and_reconstruct(
f::Bijectors.Inverse{<:Bijectors.SimplexBijector},
dist,
y
)
(d, ns...) = size(dist)
yreshaped = reshape(y, d - 1, ns...)
x, logjac = with_logabsdet_jacobian(f, yreshaped)
return x, logjac
end
这段代码首先提取分布的维度信息,然后重塑输入数据,确保变换在正确的形状上进行。
技术意义
这个修复使得Turing.jl能够正确处理多维Dirichlet分布的数组,这在许多统计模型中是非常有用的功能。例如,在主题建模或多分类问题中,我们经常需要处理多个Dirichlet分布的情况。
修复后的实现不仅解决了栈溢出问题,还保持了数值计算的稳定性和效率。通过正确处理矩阵输入和形状变换,用户可以更自由地构建复杂的概率模型,而不必担心底层实现的限制。
结论
这个问题的解决展示了Turing.jl生态系统中各个组件之间的紧密协作。通过深入理解Bijector的工作原理和形状处理的需求,我们能够提供更健壮的概率编程体验。对于用户来说,这意味着可以更自然地表达统计模型,而框架会正确处理底层的技术细节。
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
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00