堆积条形图有问题。请在下面查看我当前的代码。我有两个问题:
1)我想按以下方式对正负数据进行排序:正数据最常具有接近x轴的正值,负数据最常具有负值也最接近x轴。轴(当然,如目前所做的那样,在x轴上方和下方)。当前的均值排序无法达到目的,我相信这也会弄乱图例分配。
2)我想为不同的数据使用非常不同的颜色,以便图例很有用。我还想自动分配颜色,以便可以将相同的代码结构用于不同的图。请尝试查看下面的代码,但是颜色较暗且相似,因此无法轻松区分。 “其他”代表每个不同的数据,我只是厌倦了命名。
非常感谢。
clc
clear
%% Datevector
datevector = {'08-Jul-2040',...
'08-Aug-2040',...
'08-Sep-2040',...
'08-Oct-2040',...
'08-Nov-2040',...
'08-Dec-2040',...
'08-Jan-2041',...
'08-Feb-2041',...
'08-Mar-2041',...
'08-Apr-2041',...
'08-May-2041',...
'08-Jun-2041',...
'08-Jul-2041',...
'08-Aug-2041',...
'08-Sep-2041',...
'08-Oct-2041',...
'08-Nov-2041',...
'08-Dec-2041',...
'08-Jan-2042',...
'08-Feb-2042',...
'08-Mar-2042',...
'08-Apr-2042',...
'08-May-2042',...
'08-Jun-2042',...
'08-Jul-2042',...
'08-Aug-2042',...
'08-Sep-2042'};
%% Cash flows
data{1} = -5*rand(27,1);
data{2} = -3*rand(27,1);
data{3} = -5*rand(27,1);
data{4} = 4*rand(27,1);
data{5} = 2*rand(27,1);
data{6} = 3*rand(27,1);
data{7} = 2*rand(27,1);
data{8} = 1*rand(27,1);
data{9} = 5*rand(27,1);
data{10} = 3*rand(27,1);
data{11} = 4*rand(27,1);
data{12} = 1*rand(27,1);
data{13} = 5*rand(27,1);
data{14} = 3*rand(27,1);
data{15} = 4*rand(27,1);
data{16} = 1*rand(27,1);
data{17} = 5*rand(27,1);
data{18} = 3*rand(27,1);
data{19} = 4*rand(27,1);
data{20} = 1*rand(27,1);
data{21} = 5*rand(27,1);
data{22} = 3*rand(27,1);
data{23} = 4*rand(27,1);
labels = {'revenueFixed';...
'revenueMarket';...
'fullService';...
'partService';...
'lease';...
'techMgmt';...
'comMgmt';...
'guarantee';...
'decommission';...
'repowering';...
'taxAudit';...
'other';...
'other';...
'other';...
'other';...
'other';...
'other';...
'other';...
'other';...
'other';...
'other';...
'other';...
'other'};
colors = zeros(size(labels,1),3);
colors(1:7,:) = [1 1 0;...
1 0 1;...
0 1 1;...
1 0 0;...
0 1 0;...
0 0 1;...
1 1 1];
noAdditionalColors = size(labels,1)-7;
rounds = ceil(noAdditionalColors/7);
multiplier = 0.5.^(1:rounds);
for noRounds = 1:rounds-1
for noColor = noRounds*7+1 : (noRounds+1)*7
colors(noColor,:) = multiplier(noRounds) .* colors(noColor-noRounds*7,:);
end
end
for noRounds = rounds
for noColor = rounds*7+1 : rounds*7 + rem(noAdditionalColors,7)
colors(noColor,:) = multiplier(noRounds) .* colors(noColor-noRounds*7,:);
end
end
xData = datenum(datevector,'dd-mmm-yyyy');
for i = 1:numel(data)
dataNeg{i} = data{i};
dataNeg{i}(data{i}>0) = 0;
dataPos{i} = data{i};
dataPos{i}(data{i}<0) = 0;
mdata(i) = mean(data{i});
end
[~,posOrder] = sort(mdata,'ascend');
[~,negOrder] = sort(mdata,'descend');
yDataPos = [dataPos{posOrder}];
yDataNeg = [dataNeg{negOrder}];
hold on;
bNeg = bar(xData,yDataNeg,'stack');
bPos = bar(xData,yDataPos,'stack');
datetick('x','yyyy','keeplimits');
for i= 1:numel(data)
set(bNeg(i),'FaceColor',colors(negOrder(i),:))
set(bPos(i),'FaceColor',colors(posOrder(i),:))
end
legend(labels{:});
hold off;