当前位置: 首页>>代码示例>>C++>>正文


C++ TFile::GetObject方法代码示例

本文整理汇总了C++中TFile::GetObject方法的典型用法代码示例。如果您正苦于以下问题:C++ TFile::GetObject方法的具体用法?C++ TFile::GetObject怎么用?C++ TFile::GetObject使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在TFile的用法示例。


在下文中一共展示了TFile::GetObject方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: count_entries

void count_entries(const char* listname="list.txt", const char* treename="analyze/Analysis") {
    TFile *f;
    TTree *tree;
    Int_t count=0;
    Int_t filecount=0;

    ifstream list;
    list.open(listname);
    char filename[300];

    while (true) {
        list >> filename;
        if (!list.good()) break;
        cout << filename << endl;
        TString base("dcap://t3se01.psi.ch:22125/");
        base.Append(filename);
        f=TFile::Open(base.Data(),"read");
        filecount++;
        f->GetObject(treename,tree);
        count+=tree->GetEntries();
        f->Close();
    }

    list.close();

    cout << "Total entries: " << count << " from " << filecount << " files" <<  endl;

}
开发者ID:peruzzim,项目名称:UserCode,代码行数:28,代码来源:count_entries.C

示例2: GetGraph

TGraph2DErrors* GetGraph(std::string fname)
{
    TGraph2DErrors* gr = 0;

    std::string fGrName = "mygraph";

    TFile *f = new TFile(fname.data());
    if (!f->IsOpen())
    {
        std::cerr << "Failed to open " << fname << std::endl;
        return gr;
    }

    f->ls();

    std::cout << "Enter name of graph : ";
    if (std::cin.peek()=='\n') std::cin.get();
    std::getline(std::cin, fGrName);

    f->GetObject(fGrName.data(), gr);
    if (gr!=NULL)
    {

        TGraph2DErrors* tgr = (TGraph2DErrors*) gr->Clone("mygraph_0");
        gr=tgr;
        gr->SetDirectory(0);
    }

    return gr;
}
开发者ID:jrtomps,项目名称:phdwork,代码行数:30,代码来源:VisualizeRegionIntegratedSurface.cpp

示例3: testSimpleFile

int testSimpleFile(const char *filename, Long64_t entries, Int_t compSetting, Long64_t fileSize, UInt_t tolerance = 0)
{
   fprintf(stdout,"Checking %s\n",filename);
   TFile *file = TFile::Open(filename);
   if (file == nullptr || file->IsZombie()) {
      Error("testSimpleFile", "Could not open %s.",filename);
      return 1;
   }
   //file->ls();
   if (file->GetCompressionSettings() != compSetting) {
      Error("testSimpleFile","Compression level of %s should have been %d but is %d\n",file->GetName(), 206, file->GetCompressionSettings() );
      return 3;
   }
   if (abs(file->GetSize()-fileSize) > tolerance) {
      Error("testSimpleFile","Disk size of %s should have been %lld but is %lld (tolerance %u bytes)\n",file->GetName(), fileSize, file->GetSize(), tolerance);
      return 4;
   }

   TTree *ntuple;
   file->GetObject("ntuple",ntuple);
   if (ntuple == 0) {
      Error("testSimpleFile", "Could not retrieve ntuple from %s.",file->GetName());
      return 2;
   }
   if (ntuple->GetEntries() != entries) {
      Error("testSimpleFile","Number of entries in ntuple in %s should have been %lld but is %lld\n",file->GetName(), entries, ntuple->GetEntries());
      return 4;
   }
   delete file;

   return 0;
}
开发者ID:bbockelm,项目名称:roottest,代码行数:32,代码来源:execTestMultiMerge.C

示例4: ViewData

void ViewData() {
  TFile *file = new TFile("result.root", "READ");
  TTree *tree;
  file->GetObject("run", tree);

  Double_t qtotal;
  tree->SetBranchAddress("Q_total", &qtotal);

  for (Int_t i = 0; i < tree->GetEntries(); i++) {
    tree->GetEntry(i);
    cout << "Q_total = " << qtotal << endl;
  }

  /*
  vector<double> arrivalTimes;
  tree->SetBranchAddress("ArrivalTime", &arrivalTimes);
  cout << "Arrival Times from Measurement.root" << endl;
  for (unsigned int i = 0; i < 10; i++) {
    cout << "arrival time number " << i << ": " << arrivalTimes.at(i) << endl;
  }
  */

  //TCanvas *c1 = new TCanvas("c1", "Test", 800, 600);
  //c1->cd();
}
开发者ID:WortPixel,项目名称:bachelor_thesis,代码行数:25,代码来源:TModulTest.cpp

示例5: Yield

float Yield(Int_t ip_chan, Int_t ip_level){ 
  TH1F* hist; 
  TFile* inputfile = TFile::Open(path + sampleName);
  inputfile->GetObject("H_Yields_" + chan[ip_chan],hist);
  float yield = hist->GetBinContent(ip_level+1);
  delete inputfile;
  return yield*lumi;
}
开发者ID:GonzalezFJR,项目名称:TOP13TeV,代码行数:8,代码来源:pdfWeights.C

示例6: addDQMFiles_MC

int addDQMFiles_MC(){

  TH2F* Charge_Vs_Index=0;
  TH2F* together=0;
  int i=0;
  int run;
  TFile *f;
  TString strFile;
  ifstream inputFile("runlistMC.txt");

  while(inputFile>>run){
    cout<<"run = "<<run<<endl;
    strFile.Form("MC2012/%i/DQM_V0001_R000000001__Express__PCLTest__ALCAPROMPT.root",run);
    cout<<"Open "<<strFile<<endl;
    f = TFile::Open(strFile);
    if(!f){
      cout<<"continue"<<endl;
      continue;
    }
    TString strHisto;
    strHisto = "DQMData/Run 1/AlCaReco/Run summary/SiStripGains/Charge_Vs_Index;1";
    cout<<"Get "<<strHisto<<endl;
    if(i==0){
      f->GetObject(strHisto,together);
      together->SetDirectory(0);
      if(!together){
	cout<<"No histogram available"<<endl;
	continue;
      }
    }
    else{
      f->GetObject(strHisto,Charge_Vs_Index);
      together->Add(Charge_Vs_Index,1);
    }
    delete f;
    i++;
  }

  TFile fSave("DQM_MC.root","recreate");
  together->Write();
  fSave.Close();

  return 0;
}
开发者ID:telenz,项目名称:PixelCalibration,代码行数:44,代码来源:addDQMFiles_MC.C

示例7: printSizes

int printSizes()
{
   TFile *f = TFile::Open("hsimple.root");
   if (!f) return 1;
   TTree *t; f->GetObject("ntuple",t);
   if (!t) return 1;

   printTreeSummary(t);
   return 0;
}
开发者ID:chunjie-sam-liu,项目名称:genome_resequencing_pipeline,代码行数:10,代码来源:printSizes.C

示例8: GetWeight

float GetWeight(TString chan, TString lev, Int_t index){ 
  // index from 1 to 249
  TH1F* hist; 
  TFile* inputfile = TFile::Open(path + sampleName);
  inputfile->GetObject("H_LHEweights"+ chan + "_" + lev,hist);
  float weight = hist->GetBinContent(index)*lumi;
	inputfile -> Close();
	delete inputfile;
	return weight/GetWeightSum(index)*fac;
}
开发者ID:GonzalezFJR,项目名称:TOP13TeV,代码行数:10,代码来源:pdfWeights.C

示例9: MECompare

void MECompare( TString currentfile = "new.root",
                TString referencefile = "ref.root",
                TString theDir = "DQMData/Run 1/Generator/Run summary/MBUEandQCD" )
{
  
  std::vector<TString> theList =  histoList(currentfile, theDir);
  
  gROOT ->Reset();
  const char*  rfilename = referencefile.Data();
  const char*  sfilename = currentfile.Data();
  
  delete gROOT->GetListOfFiles()->FindObject(rfilename);
  delete gROOT->GetListOfFiles()->FindObject(sfilename);
  
  TFile * rfile = new TFile(rfilename);
  TFile * sfile = new TFile(sfilename);
  
  const char* baseDir=theDir.Data();
  
  rfile->cd(baseDir);
  gDirectory->ls();
  
  sfile->cd(baseDir);
  gDirectory->ls();

  for ( unsigned int index = 0; index < theList.size() ; index++ ) {

    std::cout << index << std::endl;

    TString theName = theDir+"/"+theList[index];
    std::cout << theName << std::endl;

    TH1* href_;
    rfile->GetObject(theName,href_);
    
    TH1* hnew_;
    sfile->GetObject(theName,hnew_);
    
    MEComparePlot(href_, hnew_, currentfile, referencefile, theDir, theList[index]); 

  }
 
}
开发者ID:DesyTau,项目名称:cmssw,代码行数:43,代码来源:MECompare.C

示例10: nu_spect

void nu_spect(const std::string& filename) {

  TFile* file = new TFile(filename.c_str(), "read");
  TTree* tree = NULL;
  file->GetObject("MARLEY_event_tree", tree);
  if (!tree) {
    std::cout << "MARLEY event tree not found" << '\n';
    return;
  }

  marley::Event* ev = new marley::Event;
  tree->SetBranchAddress("event", &ev);

  size_t num_events = tree->GetEntries();

  std::vector<double> E_vec;

  for (size_t i = 0; i < num_events; ++i) {

    tree->GetEntry(i);

    E_vec.push_back(ev->projectile().total_energy());

    if (i % 1000 == 0) std::cout << "Event " << i << '\n';
  }

  double E_max = -1e30;
  double E_min = 1e30;
  for (size_t k = 0; k < E_vec.size(); ++k) {
    double e = E_vec.at(k);
    if (e > E_max) E_max = e;
    else if (e < E_min) E_min = e;
  }

  TString title_str;

  TH1D* Es = new TH1D("nu_Es", "reacting neutrino spectrum", 100,
    E_max, E_min);

  for (size_t j = 0; j < E_vec.size(); ++j) {
    Es->Fill(E_vec.at(j));
  }

  TCanvas* c = new TCanvas;
  c->cd();

  gStyle->SetOptStat();

  Es->SetStats(true);
  Es->SetLineColor(kBlue);
  Es->SetLineWidth(2);
  Es->Draw();

  //c->SaveAs("nu_Es.pdf");
}
开发者ID:sjgardiner,项目名称:marley,代码行数:55,代码来源:nu_spect.C

示例11: rootFileName

DrawPlot::DrawPlot(const unsigned int iterationNumber, const bool summaryFile):
outpath_(nullptr), file_(nullptr), fileZeroApe_(nullptr), designFile_(nullptr), baselineTreeX_(nullptr), baselineTreeY_(nullptr), delta0_(nullptr),
legendEntry_("data (final APE)"), legendEntryZeroApe_("data (APE=0)"), designLegendEntry_("MCideal"),
legendXmin_(0.41), legendYmin_(0.27), legendXmax_(0.71), legendYmax_(0.42),
thesisMode_(false)
{
  std::stringstream ss_inpath, ss_inpathZeroApe;
  ss_inpath<<"$CMSSW_BASE/src/Alignment/APEEstimation/hists/workingArea/iter";
  ss_inpathZeroApe<<ss_inpath.str()<<"0/";
  ss_inpath<<iterationNumber<<"/";
  
  const TString* inpath = new TString(ss_inpath.str().c_str());
  const TString* inpathZeroApe = new TString(ss_inpathZeroApe.str().c_str());
  outpath_ = new TString(inpath->Copy().Append("plots/"));
  const TString rootFileName(summaryFile ? "allData_resultsFile.root" : "allData.root");
  const TString* fileName = new TString(inpath->Copy().Append(rootFileName));
  const TString* fileNameZeroApe = new TString(inpathZeroApe->Copy().Append(rootFileName));
  const TString* designFileName = new TString("$CMSSW_BASE/src/Alignment/APEEstimation/hists/Design/baseline/" + rootFileName);
  const TString* baselineFileName = new TString("$CMSSW_BASE/src/Alignment/APEEstimation/hists/Design/baseline/allData_baselineApe.root");
  
  std::cout<<"\n";
  std::cout<<"Outpath: "<<*outpath_<<"\n";
  std::cout<<"File name (final APE): "<<*fileName<<"\n";
  std::cout<<"File name (zero APE): "<<*fileNameZeroApe<<"\n";
  std::cout<<"Design file name: "<<*designFileName<<"\n";
  std::cout<<"Baseline file name: "<<*baselineFileName<<"\n";
  std::cout<<"\n";
  
  if(iterationNumber!=0)file_ = new TFile(*fileName, "READ");
  fileZeroApe_ = new TFile(*fileNameZeroApe, "READ");
  designFile_ = new TFile(*designFileName, "READ");
  TFile* baselineFile = new TFile(*baselineFileName, "READ");
  
  //if(!file_ || !fileZeroApe_ || !designFile_ || !baselineFile){
    // Not needed: root gives error by default when file is not found
    //std::cout<<"\n\tInput file not found, please check file name: "<<*fileName<<"\n";
  //}
  
  if(baselineFile){
    baselineFile->GetObject("iterTreeX", baselineTreeX_);
    baselineFile->GetObject("iterTreeY", baselineTreeY_);
  }
  
  if(!baselineTreeX_)std::cout<<"Baseline tree for x coordinate not found, cannot draw baselines!\n";
  if(!baselineTreeY_)std::cout<<"Baseline tree for y coordinate not found, cannot draw baselines!\n";
  
  baseLineTreeX_->SetDirectory(nullptr);
  baselineTreeY_->SetDirectory(nullptr);
  
  delete inpath;
  delete fileName;
  delete fileNameZeroApe;
  delete designFileName;
  delete baselineFileName;
}
开发者ID:ANSH0712,项目名称:cmssw,代码行数:55,代码来源:DrawPlot.C

示例12: stat

float stat(TString mass){
  TString samplename = "TTbar_Powheg";
  if (mass == "1725") samplename += ".root";
  else samplename += "_mtop" + mass + ".root"; 
  TFile *f = TFile::Open(path + samplename);
  TH1F* h;
  f->GetObject("H_Yields_ElMu", h);
  float y = h->GetBinError(5); 
  delete f;
  return y*Lumi;
}
开发者ID:GonzalezFJR,项目名称:TOP13TeV,代码行数:11,代码来源:getMassPlot.C

示例13: runreadvararypolyp

void runreadvararypolyp()
{
   C* c = 0;
   TFile* f = new TFile(testfilename);
   f->GetObject("C", c);
   c->print();
   c->clear();
   TTree* t = 0;
   f->GetObject("t", t);
   t->SetBranchAddress("br1.", &c);
   t->GetEntry(1);
   cout << endl;
   c->print();
   delete t;
   t = 0;
   f->Close();
   delete f;
   f = 0;
   delete c;
   c = 0;
}
开发者ID:asmagina1995,项目名称:roottest,代码行数:21,代码来源:runreadvararypolyp.C

示例14: makeGraphData

int makeGraphData(){

 
  
  TGraphErrors* histoJet, *histoPhoton;
  
  
  TCanvas* canvas[13];
  TFile *file;
  TString fileName;

  for(int i=4; i<13; i++){

    fileName.Form("c%i",i);
    canvas[i] = new TCanvas(fileName,fileName,0,0,500,500);

    canvas[i] ->cd();
    fileName.Form("root_files_JetHemisphere/jet_energy_resolution_for_1_eta_bin_%i_pTGamma_bin_PFCHS_mc.root",i);
    file = TFile::Open(fileName);
    file->GetObject("Graph",histoJet);
    histoJet -> SetMarkerColor(2);
    histoJet -> SetLineColor(2);
    histoJet -> GetFunction("fResolutionAlpha")->SetLineColor(2);
    histoJet ->Draw("AP"); 
    delete file;
    
    fileName.Form("root_files/jet_energy_resolution_for_1_eta_bin_%i_pTGamma_bin_PFCHS_mc.root",i);
    file = TFile::Open(fileName);
    file->GetObject("Graph",histoPhoton);
    histoPhoton -> SetMarkerColor(3);
    histoPhoton -> SetLineColor(3);
    histoPhoton -> GetFunction("fResolutionAlpha")->SetLineColor(3);
    histoPhoton ->Draw("Psame");
    delete file;
  }


  return 0;

}
开发者ID:telenz,项目名称:jetphoton_PUstudies,代码行数:40,代码来源:MCClosure.C

示例15: GetTree

void eurica_treeinfo::GetTree(TString infile, TTree *tree)
{
    // if parameter tree is not specified (or zero), connect the file
    // used to generate this class and read the Tree.
       if (tree == 0) {
          TFile *f = (TFile*)gROOT->GetListOfFiles()->FindObject(infile);
          if (!f || !f->IsOpen()) {
             f = new TFile(infile);
          }
          f->GetObject("tree",tree);
       }
       Init(tree);
}
开发者ID:vihophong,项目名称:aidaanalysis-devel,代码行数:13,代码来源:eurica_treeinfo.cpp


注:本文中的TFile::GetObject方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。