一种简化以下代码的方法

时间:2014-04-27 05:30:36

标签: algorithm matlab

我有以下代码,用Matlab编写,找到三个单位的组合MW:单元1,2和3.逻辑如下:

合并单位1的总和,存储它。

合并第2单元的总数,存储它。

合并第3单元的总数,存储它。

合并单元1和单元2的总和,存储它。

将单元1和单元2以及单元3的总和相结合,存储它。

合并单元1和单元3的总和,存储它。

将第2单元和第3单元的总和相结合,存储它。

Programcaticaly,我正在做以下事情:

%Max MW for each unit
maxMW = [200 60 50];

%Min MW for each unit
minMW = [50 15 15]


%Load Pattern in MW
              %1-2      3-4     5-6     7-8
loadPattern = [250      320     110     75]

%Full load production cost for each unit
productionCost = [15.4  16.0062 16.800  18.060  18.900]  

combination(1) = maxMW(1)
combination(2) = maxMW(2)
combination(3) = maxMW(3)
combination(4) = maxMW(1)+maxMW(2)
combination(5) = maxMW(1)+maxMW(2)+maxMW(3)
combination(6) = maxMW(2)+maxMW(3)
combination(7) = maxMW(1) + maxMW(3)

有没有办法简化组合(i)阻止?

2 个答案:

答案 0 :(得分:2)

如果订单不重要,那么这段代码:

M=[1 2 3];
S=0;
for i=1:length(M)
S=S+nchoosek(3,i);
end
combinations=sum((arrayfun(@str2num,num2str(dec2bin(1:S))).*repmat(M,S,1))');

给出了这个:

combinations(1)=M(3)
combinations(2)=M(2)
combinations(3)=M(2)+M(3)
combinations(4)=M(1)
combinations(5)=M(1)+M(3)
combinations(6)=M(1)+M(2)
combinations(7)=M(1)+M(2)+M(3)

答案 1 :(得分:2)

你也可以试试这个 -

combination(1:3) = maxMW(nchoosek(1:3,3));
combination([4 7 6]) = sum(maxMW(nchoosek(1:3,2)),2)'; %%//'
combination(5) = sum(maxMW(nchoosek(1:3,1)))

如果有人感兴趣,可以提供更多通用的输入数量。