我有一个关于Minizinc的语法的简单问题。我的.dzn文件输入包含一组2门维阵列(约高达30阵列),声明如下:Minizinc,如何创建地图或字典数据结构
rates_index_0 = array2d(1..3, 1..501, [ 15, 20, 23, ....
rates_index_12 = array2d(1..3, 1..501, [ 21, 24, 27, ....
...
注:索引号中都有间隙(例如,12 - > 20)
在我的模型中,我需要根据变量的值使用这些数组中的一个。在通用编程语言中,我会使用映射或字典数据结构来解决它。但在Minizinc我以下列方式硬编码的:
function var int: get_rate(int: index, var int: load, int: dc_size) =
if index == 0 then
rates_index_0[dc_size, load]
else if index == 12 then
rates_index_12[dc_size, load]
else if index == 16 then
rates_index_16[dc_size, load]
else if index == 20 then
rates_index_20[dc_size, load]
else
assert(false, "unknown index", 0)
endif endif endif endif;
这段代码的一个明显的问题是,我需要每个更改输入时间来改变模式。有没有更好的方式如何以通用的方式编码?
谢谢!
好的,我明白了,请您澄清一下关于编译时间和内存使用情况的声明。 array3d(0..60,1..3,1..501)比60 array2d(1..3,1..501)需要更多的计算/内存资源吗? 我明白你的解决方案,基本上我只是将我的array2ds合并到一个3d中,然后映射索引。唯一的缺点是数据对于人类来说更难以理解。但是现在我不需要改变模型。谢谢! – kirbo
我想你明白了!关于内存消耗:60二维数组在编译期间不会占用比组合的三维数组更多的内存。但是,如果您不想执行转换步骤并选择在3d数组中添加不在2d数组之间的额外(空)数组,则可能会有大的内存开销。 – Dekker
明白了,谢谢! – kirbo