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


C++ Hit::set_row方法代码示例

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


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

示例1: m_importData

//Since all of the getter and setter methods are taken care of in the base class the derived class really only needs to worry about the virtual function. 
void RCEDataReader::m_importData(EventMap* events ){

	if(PRINTOUTS)
		std::cout << "Opening file: " << filename <<std::endl;

	//Read file in binary mode, note bitwise OR 
	std::fstream infile(filename.c_str(), std::fstream::in | std::fstream::binary);

	if(PRINTOUTS)
		std::cout<< "... reading file ..." <<std::endl;

	//Timestamp: 4 bytes
	timestamp = 0;
	infile.read((char*)&timestamp, 4);
	if(PRINTOUTS)
		std::cout<<"Data with timestamp: "<< timestamp << std::endl;

	//Number of rce's: 4 bytes
	num_rces = 0;
	infile.read((char*)&num_rces, 4);
	if(PRINTOUTS)
		std::cout<<"RCE's used: " << num_rces << std::endl;

	//********** E V E N T S **********
	while(infile){

		//Event size: 4 bytes
		event_size = 0;
		infile.read((char*)&event_size, 4);

		//Break here if reached end of file
		if(!infile)
			break;

		//Event number: 4 bytes
		event_number = 0;
		infile.read((char*)&event_number, 4);

		//RCE number: 4 bytes
		rce_number = 0;
		infile.read((char*)&rce_number, 4);

		//Trigger information: 9*4 bytes
		infile.read(trig_info, 9*4);
		//TODO

		event_size -= 12*4; //Subtract the parts of header already read

		//Read FE data
		char *fe_data = new char[event_size];
		infile.read(fe_data, event_size);
		unsigned bcid, link;

		for(unsigned i=0; i<event_size; i+=4){
			//Cast first char to ui, so can tell what type of record it is
			FormattedRecord record(*(unsigned*)&fe_data[i]);
			bcid = 0;
			if(record.isHeader()){
				link = record.get_link();
				//For each new link, we add an EventContainer to the EventMap
				if(events->find(link)==events->end() )
					events->insert(std::pair<unsigned,EventContainer*>(link, new EventContainer));
	
				else if(events->at(link)->back().get_nHits() == 0)
					events->at(link)->pop_back();

				//For a new event (i.e. a new trigger), add an event to the EventContainer
				events->at(link)->push_back(Event(record.get_lv1id()));
			
				//This is used in the Hit info
				bcid = record.get_bcid();
				
				if(PRINTOUTS){
					std::cout<< "DH: "<< record.get_lv1id() <<" "
						<< record.get_bcid() << " "
						<< record.get_link() << std::endl;
				}
			} else if(record.isData()) {
				//Temp var just to keep the code more readable
				Hit tempHit;
				tempHit.set_bcid(bcid);
				tempHit.set_col(record.get_col());
				tempHit.set_row(record.get_row());
				tempHit.set_tot(record.get_tot());
				//Add the hit to the last event at that link
				events->at(link)->back().addHit(tempHit);
				
				if(PRINTOUTS)
					std::cout<< "DR: "<< record.get_col() <<" "
						<< record.get_row() << " "
						<< record.get_tot() << std::endl;

			}
		}
/*		
		EventMap::iterator i;
		EventContainer::iterator j;
		for(i = events->begin(); i != events->end(); ++i){
			for(j = i->second->begin(); j!= i->second->end(); ++j){
//.........这里部分代码省略.........
开发者ID:rmdcarney,项目名称:testBeamAna,代码行数:101,代码来源:RCEDataReader.cpp


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