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


C++ Kmer::idToWord方法代码示例

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


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

示例1: push_back

void GraphPath::push_back(const Kmer*a){

#ifdef ASSERT
	assert(m_kmerLength!=0);
#endif

	if(!canBeAdded(a)){
		if(!m_errorRaised){
			cout<<"Error: can not add "<<a->idToWord(m_kmerLength,false)<<endl;
			cout<<"last objects:"<<endl;
			int count=16;
			int iterator=size()-count;
			while(iterator<size()){
				Kmer theObject;
				at(iterator,&theObject);

				cout<<" ["<<iterator<<"] ------> "<<theObject.idToWord(m_kmerLength,false)<<endl;

				iterator++;
			}

			m_errorRaised=true;
		}

		return;
	}

#ifdef CONFIG_PATH_STORAGE_DEFAULT
	m_vertices.push_back(*a);
#elif defined(CONFIG_PATH_STORAGE_BLOCK)

	writeObjectInBlock(a);
#endif
}
开发者ID:Huanle,项目名称:ray,代码行数:34,代码来源:GraphPath.cpp

示例2: printStuff

void BubbleTool::printStuff(Kmer root,vector<vector<Kmer> >*trees,
map<Kmer,int>*coverages){
	int m_wordSize=m_parameters->getWordSize();
	cout<<"Trees="<<trees->size()<<endl;
	cout<<"root="<<root.idToWord(m_wordSize,m_parameters->getColorSpaceMode())<<endl;
	cout<<"digraph{"<<endl;
	map<Kmer,set<Kmer> > printedEdges;
	
	for(map<Kmer ,int>::iterator i=coverages->begin();i!=coverages->end();i++){
		Kmer kmer=i->first;
		cout<<kmer.idToWord(m_wordSize,m_parameters->getColorSpaceMode())<<" [label=\""<<kmer.idToWord(m_wordSize,m_parameters->getColorSpaceMode())<<" "<<i->second<<"\"]"<<endl;
	}
	for(int j=0;j<(int)trees->size();j++){
		for(int i=0;i<(int)trees->at(j).size();i+=2){
			Kmer a=trees->at(j).at(i+0);
			#ifdef ASSERT
			assert(i+1<(int)trees->at(j).size());
			#endif
			Kmer b=trees->at(j).at(i+1);
			if(printedEdges.count(a)>0 && printedEdges[a].count(b)>0){
				continue;
			}
			cout<<a.idToWord(m_wordSize,m_parameters->getColorSpaceMode())<<" -> "<<b.idToWord(m_wordSize,m_parameters->getColorSpaceMode())<<endl;
			printedEdges[a].insert(b);
		}
	}
	cout<<"}"<<endl;
}
开发者ID:CharlesJB,项目名称:ray,代码行数:28,代码来源:BubbleTool.cpp

示例3: writeObjectInBlock

void GraphPath::writeObjectInBlock(const Kmer*a){

	#ifdef ASSERT
	assert(m_kmerLength!=0);
	#endif

#ifdef CHECK_BUG_142
	string copyA="AGGAAGAACCTGCTGAGGAACAAGAAGGTCAACTGCCTGGACTGTAATACC";
	string copyB=a->idToWord(m_kmerLength,false);
	if(copyA==copyB)
		cout<<"[GraphPath::writeObjectInBlock] returns "<<copyB<<endl;
#endif

	if(m_size==0){
		#ifdef ASSERT
		assert(m_blocks.size()==0);
		#endif

		addBlock();
		string sequence=a->idToWord(m_kmerLength,false);

		for(int blockPosition=0;blockPosition<m_kmerLength;blockPosition++){
			writeSymbolInBlock(blockPosition,sequence[blockPosition]);
		}
	}else{
		#ifdef ASSERT
		assert(m_size>=1);
		assert(a!=NULL);
		assert(m_kmerLength!=0);
		#endif

		char lastSymbol=a->getLastSymbol(m_kmerLength,false);
		int usedSymbols=size()+m_kmerLength-1;

		#ifdef ASSERT
		assert(usedSymbols>=m_kmerLength);
		assert(m_blocks.size()>=1);
		#endif

		int allocatedSymbols=m_blocks.size()*getBlockSize();

		#ifdef ASSERT
		assert(allocatedSymbols>=getBlockSize());
		#endif

		if(usedSymbols+1>allocatedSymbols){
			addBlock();
			allocatedSymbols=m_blocks.size()*getBlockSize();
		}

		#ifdef ASSERT
		assert(usedSymbols+1<=allocatedSymbols);
		assert(allocatedSymbols>=getBlockSize());
		#endif

		int position=usedSymbols;

		#ifdef ASSERT
		assert(position<allocatedSymbols);
		#endif

		writeSymbolInBlock(position,lastSymbol);
	}

	m_size++;

#ifdef ASSERT
	Kmer addedObject;
	at(size()-1,&addedObject);

	if((*a)!=addedObject){
		cout<<"Error: expected: "<<a->idToWord(m_kmerLength,false)<<endl;
		cout<<"actual: "<<addedObject.idToWord(m_kmerLength,false)<<" at position "<<size()-1<<endl;
		cout<<"kmerLength: "<<m_kmerLength<<" blockSize: "<<getBlockSize()<<endl;
		int i=size()-1;
		int j=0;
		cout<<"dump:"<<endl;
		while(i-j>=0 && j<10){
			Kmer theObject;
			at(i-j,&theObject);

			cout<<" ["<<i-j<<"] ------> "<<theObject.idToWord(m_kmerLength,false)<<endl;

			j++;
		}
	}

	assert((*a)==addedObject);
#endif
}
开发者ID:Huanle,项目名称:ray,代码行数:90,代码来源:GraphPath.cpp

示例4: depthFirstSearch

/*
 * do a depth first search with max depth of maxDepth;
 */
void DepthFirstSearchData::depthFirstSearch(Kmer root,Kmer a,int maxDepth,
        bool*edgesRequested,bool*vertexCoverageRequested,bool*vertexCoverageReceived,
        RingAllocator*outboxAllocator,int size,int theRank,StaticVector*outbox,
        int*receivedVertexCoverage,vector<Kmer>*receivedOutgoingEdges,
        int minimumCoverage,bool*edgesReceived,int wordSize,Parameters*parameters) {
    if(!m_doChoice_tips_dfs_initiated) {
        m_depthFirstSearchVisitedVertices.clear();
        m_depthFirstSearchVisitedVertices_vector.clear();

        // add an arc
        m_depthFirstSearchVisitedVertices_vector.push_back(root);
        m_depthFirstSearchVisitedVertices_vector.push_back(a);

        m_depthFirstSearchVisitedVertices_depths.clear();
        while(m_depthFirstSearchVerticesToVisit.size()>0) {
            m_depthFirstSearchVerticesToVisit.pop();
        }
        while(m_depthFirstSearchDepths.size()>0) {
            m_depthFirstSearchDepths.pop();
        }
        m_maxDepthReached=false;
        m_depthFirstSearchVerticesToVisit.push(a);
        m_depthFirstSearchVisitedVertices.insert(a);
        m_depthFirstSearchDepths.push(0);
        m_depthFirstSearch_maxDepth=0;
        m_doChoice_tips_dfs_initiated=true;
        m_doChoice_tips_dfs_done=false;
        m_coverages.clear();
        (*edgesRequested)=false;
        (*vertexCoverageRequested)=false;
#ifdef SHOW_MINI_GRAPH
        cout<<"<MiniGraph>"<<endl;
        cout<<root->idToWord(wordSize,parameters->getColorSpaceMode())<<" -> "<<a->idToWord(wordSize,parameters->getColorSpaceMode())<<endl;
#endif
    }
    if(m_depthFirstSearchVerticesToVisit.size()>0) {
        Kmer vertexToVisit=m_depthFirstSearchVerticesToVisit.top();
        if(!(*vertexCoverageRequested)) {
            (*vertexCoverageRequested)=true;
            (*vertexCoverageReceived)=false;

            MessageUnit*message=(MessageUnit*)(*outboxAllocator).allocate(KMER_U64_ARRAY_SIZE*sizeof(MessageUnit));
            int j=0;
            vertexToVisit.pack(message,&j);
            int dest=parameters->vertexRank(&vertexToVisit);

            Message aMessage(message,j,dest,RAY_MPI_TAG_REQUEST_VERTEX_COVERAGE,theRank);
            (*outbox).push_back(&aMessage);
        } else if((*vertexCoverageReceived)) {
            if(!(*edgesRequested)) {
                m_coverages[vertexToVisit]=(*receivedVertexCoverage);
                m_depthFirstSearchVisitedVertices.insert(vertexToVisit);
                int theDepth=m_depthFirstSearchDepths.top();

                if(theDepth> m_depthFirstSearch_maxDepth) {
                    m_depthFirstSearch_maxDepth=theDepth;
                }

                // visit the vertex, and ask next edges.
                MessageUnit*message=(MessageUnit*)(*outboxAllocator).allocate(1*sizeof(MessageUnit));
                int bufferPosition=0;
                vertexToVisit.pack(message,&bufferPosition);
                int destination=parameters->vertexRank(&vertexToVisit);
                Message aMessage(message,bufferPosition,destination,RAY_MPI_TAG_REQUEST_VERTEX_OUTGOING_EDGES,theRank);
                (*outbox).push_back(&aMessage);
                (*edgesRequested)=true;
                (*edgesReceived)=false;
            } else if((*edgesReceived)) {
                Kmer vertexToVisit=m_depthFirstSearchVerticesToVisit.top();
                int theDepth=m_depthFirstSearchDepths.top();
#ifdef ASSERT
                assert(theDepth>=0);
                assert(theDepth<=maxDepth);
#endif
                int newDepth=theDepth+1;

                m_depthFirstSearchVerticesToVisit.pop();
                m_depthFirstSearchDepths.pop();

                for(int i=0; i<(int)(*receivedOutgoingEdges).size(); i++) {
                    Kmer nextVertex=(*receivedOutgoingEdges)[i];
                    if(m_depthFirstSearchVisitedVertices.count(nextVertex)>0) {
                        continue;
                    }
                    if(newDepth>maxDepth) {
                        m_maxDepthReached=true;
                        continue;
                    }

                    if(m_depthFirstSearchVisitedVertices.size()<MAX_VERTICES_TO_VISIT) {
                        // add an arc
                        m_depthFirstSearchVisitedVertices_vector.push_back(vertexToVisit);
                        m_depthFirstSearchVisitedVertices_vector.push_back(nextVertex);

                        // add the depth for the vertex
                        m_depthFirstSearchVisitedVertices_depths.push_back(newDepth);

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

示例5: depthFirstSearchBidirectional

void DepthFirstSearchData::depthFirstSearchBidirectional(Kmer a,int maxDepth,
        bool*edgesRequested,bool*vertexCoverageRequested,bool*vertexCoverageReceived,
        RingAllocator*outboxAllocator,int size,int theRank,StaticVector*outbox,
        int*receivedVertexCoverage,SeedingData*seedingData,
        int minimumCoverage,bool*edgesReceived,Parameters*parameters) {

#ifdef ASSERT
    int wordSize=parameters->getWordSize();
#endif

    if(!m_doChoice_tips_dfs_initiated) {
        m_outgoingEdges.clear();
        m_ingoingEdges.clear();

        m_depthFirstSearchVisitedVertices.clear();
        m_depthFirstSearchVisitedVertices_vector.clear();
        m_depthFirstSearchVisitedVertices_depths.clear();
        while(m_depthFirstSearchVerticesToVisit.size()>0) {
            m_depthFirstSearchVerticesToVisit.pop();
        }
        while(m_depthFirstSearchDepths.size()>0) {
            m_depthFirstSearchDepths.pop();
        }
        m_maxDepthReached=false;
        m_depthFirstSearchVerticesToVisit.push(a);
        m_depthFirstSearchDepths.push(0);
        m_depthFirstSearch_maxDepth=0;
        m_doChoice_tips_dfs_initiated=true;
        m_doChoice_tips_dfs_done=false;
        m_coverages.clear();
        (*edgesRequested)=false;
        (*vertexCoverageRequested)=false;
    }
    if(m_depthFirstSearchVerticesToVisit.size()>0) {
        Kmer vertexToVisit=m_depthFirstSearchVerticesToVisit.top();

        if(!(*vertexCoverageRequested)) {

            if(m_depthFirstSearchVisitedVertices.count(vertexToVisit)>0) {
                m_depthFirstSearchVerticesToVisit.pop();
                m_depthFirstSearchDepths.pop();
                return;
            }

            (*vertexCoverageRequested)=true;
            (*vertexCoverageReceived)=false;

            MessageUnit*message=(MessageUnit*)(*outboxAllocator).allocate(KMER_U64_ARRAY_SIZE*sizeof(MessageUnit));
            int bufferPosition=0;
            vertexToVisit.pack(message,&bufferPosition);
            int dest=parameters->vertexRank(&vertexToVisit);
            Message aMessage(message,bufferPosition,dest,RAY_MPI_TAG_REQUEST_VERTEX_COVERAGE,theRank);
            (*outbox).push_back(&aMessage);
        } else if((*vertexCoverageReceived)) {
            if(!(*edgesRequested)) {
                m_coverages[vertexToVisit]=(*receivedVertexCoverage);

#ifdef ASSERT
                if(m_depthFirstSearchVisitedVertices.count(vertexToVisit)>0) {
                    cout<<"Already visited: "<<vertexToVisit.idToWord(wordSize,parameters->getColorSpaceMode())<<" root is "<<a.idToWord(wordSize,parameters->getColorSpaceMode())<<endl;
                }
                assert(m_depthFirstSearchVisitedVertices.count(vertexToVisit)==0);
                assert(*receivedVertexCoverage>0);
#endif

                if((*receivedVertexCoverage)>0) {
                    m_depthFirstSearchVisitedVertices.insert(vertexToVisit);
                } else {
#ifdef ASSERT
                    assert(false);
#endif
                    // don't visit it.
                    m_depthFirstSearchVerticesToVisit.pop();
                    m_depthFirstSearchDepths.pop();
                    (*edgesRequested)=false;
                    (*vertexCoverageRequested)=false;
                    return;
                }
                int theDepth=m_depthFirstSearchDepths.top();

                if(theDepth> m_depthFirstSearch_maxDepth) {
                    m_depthFirstSearch_maxDepth=theDepth;
                }

                // visit the vertex, and ask next edges.
                MessageUnit*message=(MessageUnit*)(*outboxAllocator).allocate(1*sizeof(MessageUnit));
                int bufferPosition=0;
                vertexToVisit.pack(message,&bufferPosition);
                int destination=parameters->vertexRank(&vertexToVisit);
                Message aMessage(message,bufferPosition,destination,RAY_MPI_TAG_REQUEST_VERTEX_EDGES,theRank);

                (*outbox).push_back(&aMessage);
                (*edgesRequested)=true;
                (*edgesReceived)=false;
            } else if((*edgesReceived)) {
                Kmer vertexToVisit=m_depthFirstSearchVerticesToVisit.top();
                int theDepth=m_depthFirstSearchDepths.top();

#ifdef ASSERT

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

示例6: isGenuineBubble

bool BubbleTool::isGenuineBubble(Kmer root,vector<vector<Kmer > >*trees,
map<Kmer ,int>*coverages,int repeatCoverage){
	#ifdef NO_BUBBLES
	return false;
	#endif

	if((*coverages)[root]>= repeatCoverage){
		return false;
	}

	int m_wordSize=m_parameters->getWordSize();
	#ifdef ASSERT
	for(int i=0;i<(int)trees->size();i++){
		for(int j=0;j<(int)trees->at(i).size();j+=2){
			Kmer a=trees->at(i).at(j+0);
			Kmer b=trees->at(i).at(j+1);
			string as=a.idToWord(m_wordSize,m_parameters->getColorSpaceMode());
			string bs=b.idToWord(m_wordSize,m_parameters->getColorSpaceMode());
			assert(as.substr(1,m_wordSize-1)==bs.substr(0,m_wordSize-1));
		}
	}
	#endif

	if(m_parameters->debugBubbles()){
		printStuff(root,trees,coverages);
	}

	if(trees->size()!=2){
		return false;// we don'T support that right now ! triploid stuff are awesome.
	}

	// given the word size
	// check that they join.
	//
	// substitution SNP is d=0
	// del is 1, 2, or 3

	map<Kmer ,int> coveringNumber;

	Kmer target;
	bool foundTarget=false;
	for(int j=0;j<(int)trees->size();j++){
		for(int i=0;i<(int)trees->at(j).size();i+=2){
			Kmer a=trees->at(j).at(i+1);
			#ifdef ASSERT
			if(coverages->count(a)==0){
				cout<<a.idToWord(m_parameters->getWordSize(),m_parameters->getColorSpaceMode())<<" has no coverage."<<endl;
			}
			assert(coverages->count(a)>0);
			#endif

			coveringNumber[a]++;
			if(!foundTarget && coveringNumber[a]==2){
				foundTarget=true;
				target=a;
				break;
			}
		}
	}

	if(!foundTarget){
		if(m_parameters->debugBubbles()){
			cout<<"Target not found."<<endl;
		}
		return false;
	}

	if((*coverages)[target]>= repeatCoverage){
		return false;
	}

	#ifdef ASSERT
	assert(coverages->count(root)>0);
	assert(coverages->count(target)>0);
	#endif
	#ifdef ASSERT
	int rootCoverage=(*coverages)[root];
	int targetCoverage=(*coverages)[target];
	assert(rootCoverage>0);
	assert(targetCoverage>0);
	#endif

	vector<map<Kmer ,Kmer > > parents;

	for(int j=0;j<(int)trees->size();j++){
		map<Kmer ,Kmer > aVector;
		parents.push_back(aVector);
		for(int i=0;i<(int)trees->at(j).size();i+=2){
			Kmer a=trees->at(j).at(i+0);
			Kmer b=trees->at(j).at(i+1);
			parents[j][b]=a;
		}
	}

	vector<vector<int> > observedValues;
	/*
 *
 *  BUBBLE is below
 *
 *    *  ----  * -------*  --------*
//.........这里部分代码省略.........
开发者ID:CharlesJB,项目名称:ray,代码行数:101,代码来源:BubbleTool.cpp


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