Matlab有很强的绘图功能,其基本的用法参阅帮助文档已经足矣。但是对于一些定制性的功能,在帮助文档中未必能很容易查到,或者说是隐(暗)藏(黑)技巧。我们首先来看看在绘制barplot(柱状图)时,可能会不知所措的一些麻烦,我们主要通过一段示例代码来实现下面四个功能(其中加标签的方法是比较tricky的),最终绘制出来的效果图如下图所示。
1)为柱状图中的每个条柱设置不同的颜色(用于表示不同的类别),并附上图例;
2)将每个条柱所表示数值以标签的形式添加到柱上,并将文字方向设置为垂直;
3)其他设置横坐标和纵坐标的的技巧;
4)设置图表背景为白色;
5)注意字符串连接的方法。
单独实现上述功能的方法其实有很多,但是将所有功能同时实现的方法却相当困难,主要是很多任务比较难全自动实现(人工编码介入的成分较大)。我们给出一个参考程序如下:
figure1 = figure('Color',[1 1 1]); p1X = [1]; p1Y = [0.067]; p2X = [2]; p2Y = [0.177]; p3X = [3]; p3Y = [0.067]; p4X = [4]; p4Y = [0.096]; p1 = bar(p1X,p1Y); hold on; p2 = bar(p2X,p2Y); hold on; p3 = bar(p3X,p3Y); hold on; p4 = bar(p4X,p4Y); % 设置各个柱状图的颜色 set(p1,'FaceColor','red'); set(p2,'FaceColor','blue'); set(p3,'FaceColor','m'); set(p4,'FaceColor','g'); % 在柱状图上显示数值(文字方向为垂直) txt1 = text(p1X, p1Y+0.01, strcat(num2str(p1Y*100),'%'), 'rotation', 90); txt2 = text(p2X, p2Y+0.01, strcat(num2str(p2Y*100),'%'), 'rotation', 90); txt3 = text(p3X, p3Y+0.01, strcat(num2str(p3Y*100),'%'), 'rotation', 90); txt4 = text(p4X, p4Y+0.01, strcat(num2str(p4Y*100),'%'), 'rotation', 90); set(txt1, 'fontsize', 20); set(txt2, 'fontsize', 20); set(txt3, 'fontsize', 20); set(txt4, 'fontsize', 20); ylim([0, 0.24]); ylabel( 'RR' ); set(gca,'XTickLabel',{}) set(gca,'fontsize',24); set(gca, 'YTick',[0, 0.04, 0.08, 0.12, 0.16, 0.20, 0.24]) set(gca, 'YTicklabel',{'0%','4%','8%','12%', '16%','20%','24%'}); % 画图例 legend1=legend('RF-MinVar','MaxDom','MinVar','Area-Greedy', 'location','northeast'); set(legend1,'FontSize',20); set(legend1,'box','off');
下面我们来讨论利用Matlab绘制折线图的一些技巧,主要包括:
1)设置折线中Marker的形式和大小,折线的线形和粗细;
2)设置横纵坐标的标签(注意为了写出幂次,我们使用了TeX语法);
3)设置横纵坐标的取值范围;
4)设置图例的形式及位置等;
5)注意Matlab中的续行符号是 “...”。
k_st = 10:3:34; max_ces_st = [0.251014, 0.251014, 0.089194, 0.089194, ... 0.089194, 0.089194, 0.089194, 0.000014, 0.000014]; min_ces_st = [0.002519, 0.002519, 0.002519, 0.002519, ... 0.001307, 0.001307, 0.001307, 0.001307, 0.001307]; rf_ces_st = [0.002519, 0.001307, 0.001307, 0.001307, ... 0.001062, 0.001062, 0.001062, 0.000001, 0.000001]; area_ces_st = [0.010109, 0.010109, 0.010109, 0.010109, 0.010109, ... 0.008745, 0.008745, 0.006179, 0.001982]; figure1=figure('Color',[1 1 1]); semilogy(k_st, rf_ces_st, 'r-o', ... k_st, min_ces_st, 'b-v', ... k_st, max_ces_st,'g-*', ... k_st, area_ces_st,'m-+','Markersize', 24,'linewidth',2); xlabel('k','FontSize',36); ylabel('RR','FontSize',36); xlim([10, 34]); ylim([1e-6, 1]); set(gca,'fontsize',30); set(gca, 'XTick',[10,13,16,19,22,25,28,31,34]); set(gca, 'YTick',[1e-6,1e-4,1e-2,1]); set(gca, 'XTicklabel',{'10','13','16','19','22','25','28', '31','34'}); set(gca, 'YTicklabel',{'0^{ }','10^{-4}','10^{-2}', '10^{0}'}); legend1=legend('RF-MinVar','MinVar','MaxDom','Area-Greedy', 'location','southwest'); set(legend1,'FontSize',24); set(legend1,'box','off');
(本文完)