gpt4 book ai didi

data-structures - 有没有在 Erlang 中实现高效数组类型的模块?

转载 作者:行者123 更新时间:2023-12-04 14:31:41 26 4
gpt4 key购买 nike

我一直在寻找 Erlang 中具有以下特征的数组类型。

append(vector(), term())        O(1) 
nth(Idx, vector()) O(1)
set(Idx, vector(), term()) O(1)
insert(Idx, vector(), term()) O(N)
remove(Idx, vector()) O(N)

我通常为此目的使用元组,但性能特征不是我想要的大 N。我的测试显示以下性能特征......
erlang:append_element/2          O(N).
erlang:setelement/3 O(N).

我已经开始基于 clojure.lang.PersistentVector 实现的模块,但如果它已经完成,我不会重新发明轮子。

编辑:

对于那些感兴趣的人,我已经完成了 vector.erl ... 使用与 clojure.lang.PersistentVector 相同的算法.它具有与数组模块相似的性能特征,但在追加时具有稍好的常数因子。

以下测试在每个间隔附加 10000 个项目,然后在随机索引处进行 10000 次查找和 10000 次更新。所有操作都接近 O(1)。内部元组中的时间以微秒为单位。
3> seq_perf:test(vector, 100000, 10).
{2685854,
{ok,[{100000,{66966,88437,124376}},
{200000,{66928,76882,125677}},
{300000,{68030,76506,116753}},
{400000,{72429,76852,118263}},
{500000,{66296,84967,119828}},
{600000,{66953,78155,116984}},
{700000,{65996,77815,138046}},
{800000,{67801,78455,118191}},
{900000,{69489,77882,114886}},
{1000000,{67444,80079,118428}}]}}
4> seq_perf:test(array, 100000, 10).
{2948361,
{ok,[{100000,{105482,72841,108828}},
{200000,{123655,78898,124092}},
{300000,{110023,76130,106806}},
{400000,{104126,73830,119640}},
{500000,{104771,72593,110157}},
{600000,{107306,72543,109713}},
{700000,{122066,73340,110662}},
{800000,{105853,72841,110618}},
{900000,{105267,73090,106529}},
{1000000,{103445,73206,109939}}]}}

最佳答案

这些属性在纯功能实现中是不可能的。数组模块 (http://www.erlang.org/doc/man/array.html) 是一个很好的折衷方案,但如果您需要 O(1) 查找和更新,则必须改用 ETS 表.

关于data-structures - 有没有在 Erlang 中实现高效数组类型的模块?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12395074/

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