二维直方图在实际科研作图中使用较为广泛,它能直观的显示二维数据的分布。
下面介绍具体步骤:
- 设置二维直方图坐标值:
const Int_t nx = 12;
const Int_t ny = 20;
const char *month[nx] = {"January","February","March","April","May","June","July","August","September","October","November","December"};
const char *people[ny] = {"Jean","Pierre","Marie","Odile","Sebastien","Fons","Rene","Nicolas","Xavier","Greg","Bjarne","Anton","Otto","Eddy","Peter","Pasha","Philippe","Suzanne","Jeff","Valery"};
- 创建画布:
TCanvas *c1 = new TCanvas("c1","demo bin labels",10,10,600,600);
c1->SetGrid(); //设置网格
c1->SetLeftMargin(0.15); //左侧留边距
c1->SetBottomMargin(0.15); //底部留边距
- 创建二维直方图:
TH2F *h = new TH2F("h","test",3,0,3,2,0,2);
h->SetCanExtend(TH1::kAllAxes);
h->SetStats(0);
- 填充随机数:
gRandom->SetSeed();
for (Int_t i=0;i<15000;i++) {
Int_t rx = gRandom->Rndm()*nx;
Int_t ry = gRandom->Rndm()*ny;
h->Fill(people[ry],month[rx],1);
}
- 将选项中传递的轴的bin数减少到带有标签的bin数,对带有标签的bin进行排序或设置选项以绘制带有标签的轴,绘制直方图:
h->LabelsDeflate("X");
h->LabelsDeflate("Y");
h->LabelsOption("v");
h->Draw("text");
- 定义标签,设置标签内容并绘制:
TPaveText *pt = new TPaveText(0.6,0.85,0.98,0.98,"brNDC");
pt->SetFillColor(18);
pt->SetTextAlign(12);
pt->AddText("Use the axis Context Menu LabelsOption");
pt->AddText(" \"a\" to sort by alphabetic order");
pt->AddText(" \">\" to sort by decreasing values");
pt->AddText(" \"<\" to sort by increasing values");
pt->Draw();
代码地址:https://github.com/root-project/root/blob/master/tutorials/hist/hlabels2.C