/*********************************************************************** * * This is PlotResultInRoot.C for ExtractXSec *.root output * * The Xsec are stored in (TObjArray *) gList * * This program is simple get plot all the member in the gList * * ----------------------------------------------------- * This program will call the root library and compile in g++ * compilation: * g++ PlotResultInROOT.C -o PlotResultInROOT `root-config --cflags --glibs` * * ------------------------------------------------------ * created by Ryan (Tsz Leung) Tang, Nov-18, 2018 * email: goluckyryan@gmail.com * ********************************************************************/ #include #include #include #include #include #include #include #include #include #include void PlotTGraphTObjArray(TString rootFileName, bool isSavePNG = false){ TFile * file = new TFile(rootFileName, "READ"); TObjArray * gList = (TObjArray *) file->FindObjectAny("qList"); if( gList == NULL ) { printf("No Result was found.\n"); return; } TCanvas * cPlots = new TCanvas("cPlots", "Ptolemy Results", 0, 0, 800, 600); cPlots->SetLogy(); TLegend * legend = new TLegend( 0.6, 0.6, 0.9, 0.9); //x1, y1, x2, y2 const int n = gList->GetLast() + 1 ; TGraph * gr[n]; const std::vector color = {kBlack, kRed, kOrange+7, kYellow+1, kGreen+2, kGreen+3, kBlue, kBlue+3, kMagenta, kMagenta+2, kGray+2, kRed+2, kYellow+3 }; short nColor = color.size(); //Get minimum, maximum Y double maxY = 0; double minY = 10000000; for ( int i = 0; i < n ; i++){ gr[i] = (TGraph *) gList->At(i); gr[i]->SetLineColor(color[ i % nColor]); gr[i]->GetXaxis()->SetTitle("#theta_{CM} [deg]"); gr[i]->GetYaxis()->SetTitle("d#sigma/d#Omega [mb/sr]"); TString name = gr[i]->GetName(); int pos = name.First("|"); name.Remove(0, pos+1); legend->AddEntry(gr[i], name); double miny = gr[i]->GetHistogram()->GetMinimum(); double maxy = gr[i]->GetHistogram()->GetMaximum(); if( miny < minY ) minY = miny; if( maxy > maxY ) maxY = maxy; } for ( int i = 0; i < n ; i++){ gr[i]->Draw("same"); if( i == 0 ){ gr[i]->Draw(); gr[i]->GetYaxis()->SetRangeUser(minY * 0.8, maxY * 1.2); }else{ gr[i]->Draw("same"); } } legend->Draw(); cPlots->SetGrid(1,1); cPlots->Update(); cPlots->Draw(); if( isSavePNG ){ TDatime dateTime; TString outPNGName = Form("Xsec_%d%02d%02d_%06d.png", dateTime.GetYear(), dateTime.GetMonth(), dateTime.GetDay(), dateTime.GetTime()); cPlots->SaveAs(outPNGName); printf("%s\n", outPNGName.Data()); gROOT->ProcessLine(".q"); } }