gpt4 book ai didi

parallel-processing - Common Lisp (SBCL) 是否具有高级并行功能?

转载 作者:行者123 更新时间:2023-12-04 08:08:19 24 4
gpt4 key购买 nike

在 Haskell 中,我可以使用以下方法启用列表的并行评估:

map expensiveFunction list `using` parList rdeepseq

仅添加 `using` parList rdeepseq 可以实现纯并行计算,并且在我的四核处理器上运行速度提高 4 倍。

是否有使用 SBCL 的类似功能?

最佳答案

Common Lisp 没有执行此操作的标准工具,但有一个库专门用于执行此操作,大多数 CL 实现都很好地支持它:Lparallel

使用 lparallel,您可以执行以下操作:

(let ((number-sets '((1 2 3) (4 5 6) (10 11 12 13 14) (100 200 300))))
(lparallel:pmap 'list (lambda (v) (apply #'+ v)) number-sets))

这将并行执行单独的求和,但否则返回与使用普通 map 相同的结果。

关于parallel-processing - Common Lisp (SBCL) 是否具有高级并行功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33009082/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com