本文整理汇总了C++中DeBruijnNode::add3pLink方法的典型用法代码示例。如果您正苦于以下问题:C++ DeBruijnNode::add3pLink方法的具体用法?C++ DeBruijnNode::add3pLink怎么用?C++ DeBruijnNode::add3pLink使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类DeBruijnNode
的用法示例。
在下文中一共展示了DeBruijnNode::add3pLink方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: NucNode
pair<AssemblyJobSsDeBruijn::NucNode*,long> AssemblyJobSsDeBruijn::makeGraphTree(set<ScoredSeq*>* seqs, int kmerSize){
NucNode* topNode = new NucNode(0, '\0');
long numBaseNodes = 0;
if (kmerSize > 0){
for (set<ScoredSeq*>::iterator seqIt = seqs->begin(); seqIt != seqs->end(); ++seqIt){
ScoredSeq* seq = *seqIt;
// these are the nodes for which the current nuc is at the Nth position in the kmer;
// the elements earlier in the array represent kmers that come later in the sequence
SeqNode* currentNodes[kmerSize-1];
float worstScores[kmerSize-1];
// for making the de Bruijn graph at the tips
DeBruijnNode* finishedNode = 0;
DeBruijnNode* priorNode = 0;
// used to determine how far along the kmer construction has made it
long maxCurrentNodeIndex = 0;
bool createFinishedNode = false;
char* nucs = seq->getSeq('+');
float* scores = seq->getScores('+');
float* links = seq->getLinks('+');
long seqSize = seq->size();
long seqSizeM1 = seqSize - 1;
for (long pos = 0; pos < seqSize; ++pos){
char nuc = nucs[pos];
float nucScore = scores[pos];
// will only be used up to the second-to-last position
float linkScore;
if (pos < seqSizeM1){ linkScore = links[pos]; }
else { linkScore = 0; }
// re-set the derivation of kmers if the nucleotide is an N
if (nuc == 'N'){
maxCurrentNodeIndex = 0;
createFinishedNode = false;
finishedNode = 0;
priorNode = 0;
} else {
priorNode = finishedNode;
if (createFinishedNode){
SeqNode* oldNode = currentNodes[maxCurrentNodeIndex];
float worstScore = worstScores[maxCurrentNodeIndex];
finishedNode = dynamic_cast<DeBruijnNode*>( oldNode->getBranch(nuc) );
if (finishedNode == 0){
finishedNode = new DeBruijnNode(oldNode, nuc);
oldNode->addBranch(finishedNode);
numBaseNodes++;
}
// add the kmer score to the node; the worst score possible!
if ( nucScore < worstScore ){ worstScore = nucScore; }
finishedNode->addKmerScore(worstScore);
// add the 3p-directed link score
if (priorNode != 0){
float link3pScore = links[pos-1];
float link5pScore = links[pos-kmerSize];
float worseLinkScore = link3pScore;
if (link5pScore < worseLinkScore){ worseLinkScore = link5pScore; }
priorNode->add3pLink(finishedNode,worseLinkScore);
finishedNode->add5pLink(priorNode,worseLinkScore);
}
}
for (int n = maxCurrentNodeIndex; n >= 0; --n){
SeqNode* oldNode;
float worstScore;
if (n==0){
oldNode = topNode;
worstScore = nucScore;
}
else {
oldNode = currentNodes[n-1];
worstScore = worstScores[n-1];
if ( nucScore < worstScore ){ worstScore = nucScore; }
}
if ( linkScore < worstScore ){ worstScore = linkScore; }
SeqNode* newNode = oldNode->getBranch(nuc);
if (newNode == 0){
newNode = new NucNode(oldNode,nuc);
oldNode->addBranch( newNode );
}
currentNodes[n] = newNode;
worstScores[n] = worstScore;
}
if (! createFinishedNode){
if (maxCurrentNodeIndex < kmerSize-2){ maxCurrentNodeIndex++; }
else { createFinishedNode = true; }
}
}
}
delete [] nucs;
delete [] scores;
delete [] links;
}
}
return pair<NucNode*,long>(topNode,numBaseNodes);
}