我有以下代码,用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)阻止?
答案 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)))
如果有人感兴趣,可以提供更多通用的输入数量。