#include "needlemanoverlap.hpp"
#include "blastalign.hpp"
#include "noalign.hpp"
-#include "nast.hpp"
#include "ignoregaps.h"
#include "eachgapdist.h"
//**********************************************************************************************************************
PairwiseSeqsCommand::PairwiseSeqsCommand(){
try {
- abort = true;
- //initialize outputTypes
+ abort = true; calledHelp = true;
vector<string> tempOutNames;
outputTypes["phylip"] = tempOutNames;
outputTypes["column"] = tempOutNames;
//**********************************************************************************************************************
PairwiseSeqsCommand::PairwiseSeqsCommand(string option) {
try {
- abort = false;
+ abort = false; calledHelp = false;
//allow user to run help
- if(option == "help") { help(); abort = true; }
+ if(option == "help") { help(); abort = true; calledHelp = true; }
else {
int PairwiseSeqsCommand::execute(){
try {
- if (abort == true) { return 0; }
+ if (abort == true) { if (calledHelp) { return 0; } return 2; }
int longestBase = 2000; //will need to update this in driver if we find sequences with more bases. hardcoded so we don't have the pre-read user fasta file.
delete distCalculator;
+ //set phylip file as new current phylipfile
+ string current = "";
+ itTypes = outputTypes.find("phylip");
+ if (itTypes != outputTypes.end()) {
+ if ((itTypes->second).size() != 0) { current = (itTypes->second)[0]; m->setPhylipFile(current); }
+ }
+
+ //set column file as new current columnfile
+ itTypes = outputTypes.find("column");
+ if (itTypes != outputTypes.end()) {
+ if ((itTypes->second).size() != 0) { current = (itTypes->second)[0]; m->setColumnFile(current); }
+ }
+
m->mothurOutEndLine();
m->mothurOut("Output File Name: "); m->mothurOutEndLine();
for (int i = 0; i < outputNames.size(); i++) { m->mothurOut(outputNames[i]); m->mothurOutEndLine(); }
alignment->resize(alignDB.get(j).getUnaligned().length()+1);
}
- Sequence* seqI = new Sequence(alignDB.get(i).getName(), alignDB.get(i).getAligned());
- Sequence* seqJ = new Sequence(alignDB.get(j).getName(), alignDB.get(j).getAligned());
+ Sequence seqI(alignDB.get(i).getName(), alignDB.get(i).getAligned());
+ Sequence seqJ(alignDB.get(j).getName(), alignDB.get(j).getAligned());
- Nast(alignment, seqI, seqJ);
+ alignment->align(seqI.getUnaligned(), seqJ.getUnaligned());
+ seqI.setAligned(alignment->getSeqAAln());
+ seqJ.setAligned(alignment->getSeqBAln());
- distCalculator->calcDist(*seqI, *seqJ);
+ distCalculator->calcDist(seqI, seqJ);
double dist = distCalculator->getDist();
- delete seqI; delete seqJ;
-
if(dist <= cutoff){
if (output == "column") { outFile << alignDB.get(i).getName() << ' ' << alignDB.get(j).getName() << ' ' << dist << endl; }
}
alignment->resize(alignDB.get(j).getUnaligned().length()+1);
}
- Sequence* seqI = new Sequence(alignDB.get(i).getName(), alignDB.get(i).getAligned());
- Sequence* seqJ = new Sequence(alignDB.get(j).getName(), alignDB.get(j).getAligned());
+ Sequence seqI(alignDB.get(i).getName(), alignDB.get(i).getAligned());
+ Sequence seqJ(alignDB.get(j).getName(), alignDB.get(j).getAligned());
- Nast(alignment, seqI, seqJ);
+ alignment->align(seqI.getUnaligned(), seqJ.getUnaligned());
+ seqI.setAligned(alignment->getSeqAAln());
+ seqJ.setAligned(alignment->getSeqBAln());
- distCalculator->calcDist(*seqI, *seqJ);
+ distCalculator->calcDist(seqI, seqJ);
double dist = distCalculator->getDist();
-
- delete seqI; delete seqJ;
outFile << dist << '\t';
}
alignment->resize(alignDB.get(j).getUnaligned().length()+1);
}
- Sequence* seqI = new Sequence(alignDB.get(i).getName(), alignDB.get(i).getAligned());
- Sequence* seqJ = new Sequence(alignDB.get(j).getName(), alignDB.get(j).getAligned());
+ Sequence seqI(alignDB.get(i).getName(), alignDB.get(i).getAligned());
+ Sequence seqJ(alignDB.get(j).getName(), alignDB.get(j).getAligned());
- Nast(alignment, seqI, seqJ);
+ alignment->align(seqI.getUnaligned(), seqJ.getUnaligned());
+ seqI.setAligned(alignment->getSeqAAln());
+ seqJ.setAligned(alignment->getSeqBAln());
- distCalculator->calcDist(*seqI, *seqJ);
+ distCalculator->calcDist(seqI, seqJ);
double dist = distCalculator->getDist();
- delete seqI; delete seqJ;
-
if(dist <= cutoff){
outputString += (alignDB.get(i).getName() + ' ' + alignDB.get(j).getName() + ' ' + toString(dist) + '\n');
}
MPI_File_open(MPI_COMM_SELF, filename, amode, MPI_INFO_NULL, &outMPI);
- int startTime = time(NULL);
+
string outputString = "";
size = 0;
alignment->resize(alignDB.get(j).getUnaligned().length()+1);
}
- Sequence* seqI = new Sequence(alignDB.get(i).getName(), alignDB.get(i).getAligned());
- Sequence* seqJ = new Sequence(alignDB.get(j).getName(), alignDB.get(j).getAligned());
+ Sequence seqI(alignDB.get(i).getName(), alignDB.get(i).getAligned());
+ Sequence seqJ(alignDB.get(j).getName(), alignDB.get(j).getAligned());
- Nast(alignment, seqI, seqJ);
+ alignment->align(seqI.getUnaligned(), seqJ.getUnaligned());
+ seqI.setAligned(alignment->getSeqAAln());
+ seqJ.setAligned(alignment->getSeqBAln());
- distCalculator->calcDist(*seqI, *seqJ);
+ distCalculator->calcDist(seqI, seqJ);
double dist = distCalculator->getDist();
- delete seqI; delete seqJ;
-
outputString += toString(dist) + "\t";
}
MPI_File_open(MPI_COMM_SELF, filename, amode, MPI_INFO_NULL, &outMPI);
- int startTime = time(NULL);
+
string outputString = "";
size = 0;
alignment->resize(alignDB.get(j).getUnaligned().length()+1);
}
- Sequence* seqI = new Sequence(alignDB.get(i).getName(), alignDB.get(i).getAligned());
- Sequence* seqJ = new Sequence(alignDB.get(j).getName(), alignDB.get(j).getAligned());
+ Sequence seqI(alignDB.get(i).getName(), alignDB.get(i).getAligned());
+ Sequence seqJ(alignDB.get(j).getName(), alignDB.get(j).getAligned());
- Nast(alignment, seqI, seqJ);
+ alignment->align(seqI.getUnaligned(), seqJ.getUnaligned());
+ seqI.setAligned(alignment->getSeqAAln());
+ seqJ.setAligned(alignment->getSeqBAln());
- distCalculator->calcDist(*seqI, *seqJ);
+ distCalculator->calcDist(seqI, seqJ);
double dist = distCalculator->getDist();
- delete seqI; delete seqJ;
-
outputString += toString(dist) + "\t";
}