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


C++ TH2D::FindFixBin方法代码示例

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


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

示例1: main


//.........这里部分代码省略.........
                m1max = 1300;
                m2step = 2;
                m2min = 2;
                m2max = 26;
	} else if (string(argv[1]) == "bprime") {
		limitFile = "/cms/thomassen/2012/EWKino/Statistics/bprime/limits.txt";
		outFile = "exclusions_bprime.root";
		m1step = 50;
		m1min = 500;
		m1max = 700;
		m2step = 0.1;
		m2min = 0;
		m2max = 1;
	} else if (string(argv[1]) == "StopHiggs") {
                limitFile = "limits/slide_combined_full_noreweight_chargino250.out";
                outFile = "exclusions/exclusions_slide_combined_full_noreweight_chargino250.root";
                m1step = 50;
                m1min = 200;
                m1max = 800;
                m2step = 0.1;
                m2min = 0;
                m2max = 1;
	} else {
		cout << "Unknown keyword " << argv[1] << endl; 
		return -1;
	}

	if(m1max < m1min || m2max < m2min) return -1;
	int m1bins = (int)((m1max - m1min) / m1step + 1);
	int m2bins = (int)((m2max - m2min) / m2step + 1);
	m1max = m1min + (m1bins - 1) * m1step;
	m2max = m2min + (m2bins - 1) * m2step;
	
	TH2D* hObs = new TH2D ("hObs", limitFile.c_str()
		, m1bins, m1min - m1step/2., m1max + m1step/2.
		, m2bins, m2min - m2step/2., m2max + m2step/2.);
	hObs->GetXaxis()->SetTitle("m_{1}");
	hObs->GetYaxis()->SetTitle("m_{2}");
	
	TH2D* hExp = new TH2D(*hObs);
	hExp->SetName("hExp");
	
	TH2D* hExp1p = new TH2D(*hObs);
	hExp1p->SetName("hExp1p");
	
	TH2D* hExp1m = new TH2D(*hObs);
	hExp1m->SetName("hExp1m");
	
	TH2D* hExp2p = new TH2D(*hObs);
	hExp2p->SetName("hExp2p");
	
	TH2D* hExp2m = new TH2D(*hObs);
	hExp2m->SetName("hExp2m");
	
	cout << "[PT] Reading limits from " << limitFile << " ..." << endl;
	ifstream in (limitFile.c_str());
	while(in) {
		string line;
		getline(in, line);
		if(!in) break;
		double m1;
		double m2;
		float limit[6];
		if(line[0] == '#') continue;
		sscanf (line.c_str(),"%lf:%lf cls: %f %f ( %f : %f ) ( %f : %f )", &m1, &m2, limit, limit+1, limit+2, limit+3, limit+4, limit+5);
		//cout << m1 << " " << m2  << " " << limit[0] << " " << limit[1] << " " << limit[2] << " " << limit[3] << " " << limit[4] << " " << limit[5] << endl;
		if(m1 < m1min || m2 < m2min || m1 > m1max || m2 > m2max) continue;

		if(!(m1 >= m1min && m1 <= m1max && (fmod(m1 - m1min, m1step) == 0 || fmod(m1 - m1min, m1step) - m1step < 1E-12)) || !(m2 >= m2min && m2 <= m2max && (fmod(m2 - m2min, m2step) == 0 || fmod(m2 - m2min, m2step) - m2step < 1E-12))) {
			cout << "[PT] Skipping point (" << m1 << "," << m2 << ") because it is not on the grid" << endl;
			continue;
		}
		if(hObs->GetBinContent(hObs->FindFixBin(m1, m2)) != 0 || hExp->GetBinContent(hExp->FindFixBin(m1, m2)) != 0) {
			cout << "[PT] ERROR: The point (" << m1 << "," << m2 << ") was already filled." << endl;
			return -1;
		}
		
		hObs->Fill(m1, m2, limit[0]);
		hExp->Fill(m1, m2, limit[1]);
		hExp1p->Fill(m1, m2, limit[2]);
		hExp1m->Fill(m1, m2, limit[3]);
		hExp2p->Fill(m1, m2, limit[4]);
		hExp2m->Fill(m1, m2, limit[5]);
	}

	TFile f(outFile.c_str(), "RECREATE");
	
	hObs->Write();
	hExp->Write();
	hExp1p->Write();
	hExp1m->Write();
	hExp2p->Write();
	hExp2m->Write();
	
	f.Close();

	cout << "Output file produced: " << outFile << endl;

	return 0;
}
开发者ID:fiveisgreen,项目名称:FNAL_Crane,代码行数:101,代码来源:makeExclusions.C


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