#include "command.hpp"
#include "inputdata.h"
#include "groupmap.h"
-#include "readotu.h"
#include "validcalculator.h"
// aka. dist.shared()
The user can select the labels they wish to use as well as the groups they would like included.
They can also use as many or as few calculators as they wish. */
-class GlobalData;
class MatrixOutputCommand : public Command {
MatrixOutputCommand(string);
MatrixOutputCommand();
~MatrixOutputCommand();
- vector<string> getRequiredParameters();
- vector<string> getValidParameters();
- vector<string> getRequiredFiles();
- map<string, vector<string> > getOutputFiles() { return outputTypes; }
- int execute();
- void help();
+
+ vector<string> setParameters();
+ string getCommandName() { return "dist.shared"; }
+ string getCommandCategory() { return "OTU-Based Approaches"; }
+ string getHelpString();
+ string getCitation() { return "http://www.mothur.org/wiki/Dist.shared"; }
+ string getDescription() { return "generate a distance matrix that describes the dissimilarity among multiple groups"; }
+
+
+ int execute();
+ void help() { m->mothurOut(getHelpString()); }
private:
- void printSims(ostream&);
+ struct linePair {
+ int start;
+ int end;
+ };
+ vector<linePair> lines;
+
+ void printSims(ostream&, vector< vector<float> >&);
int process(vector<SharedRAbundVector*>);
- GlobalData* globaldata;
- ReadOTUFile* read;
vector<Calculator*> matrixCalculators;
- vector< vector<float> > simMatrix;
+ //vector< vector<float> > simMatrix;
InputData* input;
- ValidCalculators* validCalculator;
vector<SharedRAbundVector*> lookup;
- string exportFileName, output;
- int numGroups;
+ string exportFileName, output, sharedfile;
+ int numGroups, processors;
ofstream out;
bool abort, allLines;
set<string> labels; //holds labels to be used
string outputFile, calc, groups, label, outputDir;
vector<string> Estimators, Groups, outputNames; //holds estimators to be used
- map<string, vector<string> > outputTypes;
-
+ int process(vector<SharedRAbundVector*>, string, string);
+ int driver(vector<SharedRAbundVector*>, int, int, vector< vector<seqDist> >&);
};