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


C++ OutputBuffer::get方法代码示例

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


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

示例1: addMsScans

// Add scans from the raw data file
// addMs2 enables/disables extraction of data from MS2 scans
int addMsScans(sqlite3 *db, const char *inputRawFileName, const char * outputFileName, Engine::Readers::RawData * pRawData, bool addMs2Peaks) {
	createPeaksTable(db, inputRawFileName, addMs2Peaks);

	// Prepare statement
	const char *insertStatement = "INSERT INTO peaks (scan, peak_count, peaks) VALUES (?1, ?2, ?3);";

	sqlite3_stmt *pStatement=NULL;
	int rc = sqlite3_prepare_v2(db, insertStatement, strlen(insertStatement), &pStatement, NULL);
	if( rc!=SQLITE_OK ){
		fprintf(stderr, "SQL error when preparing insert statement.\n");
		exit(1);
	}	

	OutputBuffer buf;

	try {
		int percentDone = 0;
		int numScans = pRawData->GetNumScans();

		std::vector<double> mzs;
		std::vector<double> intensities;

		for(int i=pRawData->GetFirstScanNum(); i<=pRawData->GetLastScanNum(); i=pRawData->GetNextScanNum(i)) {
			int msLevel = pRawData->GetMSLevel(i);
			// MS level 1 indicates a survey (FTMS) scan
			bool addThisScan = (msLevel==1) || (msLevel==2 && addMs2Peaks);
			if(addThisScan) {			
				pRawData->GetRawData(&mzs, &intensities, i);

				int scanNumber = i;
				int numPeaks = mzs.size();
				int numPeaksStored = 0;

				// About 20% speedup - allocating what we need in advance
				buf.ensureBufferHasSpace(numPeaks*2*sizeof(TJavaFloat));

				// OUTPUT: m/z, intensity float pairs
				std::vector<double>::iterator mzIt = mzs.begin();
				std::vector<double>::iterator intIt = intensities.begin();			
				bool wasZero = false;
				bool zeroStored = false;
				TJavaFloat previousMass = 0.0;
				while(mzIt!=mzs.end()) {
					TJavaFloat newIntensity = (TJavaFloat)*intIt;
					TJavaFloat newMass = (TJavaFloat)*mzIt;
					bool isZero = newIntensity==(TJavaFloat)0.0;

					// Skip long sequences of zeros. Retain only beginning and trailing zero for graph plotting
					if(!wasZero) {
						// Store current value
						buf.addJavaFloat(newMass);
						buf.addJavaFloat(newIntensity);
						numPeaksStored++;
						if(isZero) { // !wasZero, isZero
							wasZero=true;
							zeroStored=true;
						}
					} else { // wasZero 
						if(!isZero) {
							wasZero=false;
							if(!zeroStored) {
								// Store the previous zero
								buf.addJavaFloat(previousMass);
								buf.addJavaFloat((TJavaFloat)0.0);
								numPeaksStored++;
							}
							// Store current value
							buf.addJavaFloat(newMass);
							buf.addJavaFloat(newIntensity);
							numPeaksStored++;
						} else { // wasZero && isZero							
							// The current zero is not getting stored
							zeroStored=false;
							previousMass = newMass;	
							// Keep going, do not store anything
						}
					}
					mzIt++;
					intIt++;
				}

				// Store the last zero (if it did not get stored) to terminate our graph neatly
				if(!zeroStored) {
					buf.addJavaFloat(previousMass);
					buf.addJavaFloat((TJavaFloat)0.0);
					numPeaksStored++;
				}

				cse(sqlite3_bind_int(pStatement, 1, i));
				cse(sqlite3_bind_int(pStatement, 2, numPeaksStored));
				cse(sqlite3_bind_blob(pStatement, 3, buf.get(), buf.usedSize(), SQLITE_TRANSIENT));

				rc = sqlite3_step(pStatement);
				if(rc!=SQLITE_DONE) {
					throw 1;
				}
				cse(sqlite3_reset(pStatement));

//.........这里部分代码省略.........
开发者ID:MayoClinic,项目名称:MprcExtractRaw,代码行数:101,代码来源:MprcExtractRaw.cpp


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