public:
CollectDisplay(Calculator* calc, FileOutput* file) : estimate(calc), output(file) {timesCalled = 0;};
~CollectDisplay() { delete estimate; delete output; }
+
+
void update(SAbundVector* rank){
nSeqs=rank->getNumSeqs();
data = estimate->getValues(rank);
n++;
}
- if (estimate->getMultiple() == true) {
+ if ((estimate->getMultiple() == true) && all) {
numGroupComb++;
groupData.resize((numGroupComb*data.size()), 0);
//is this the time its called with all values
output->output(numSeqs, groupData);
}
};
-
+
void init(string s) { output->initFile(s); };
void reset() { output->resetFile(); };
void close() { output->resetFile(); };
- bool isCalcMultiple() { return estimate->getMultiple(); }
+ void setAll(bool a) { all = a; }
+ bool getAll() { return all; }
+
+
+ bool isCalcMultiple() { return estimate->getMultiple(); }
+ bool hasLciHci() {
+ if (estimate->getCols() == 3) { return true; }
+ else{ return false; }
+ }
+
+ string getName() { return estimate->getName(); }
+
private:
+
Calculator* estimate;
FileOutput* output;
int nSeqs, timesCalled, numGroupComb;
vector<double> data;
vector<double> groupData;
+ bool all;
+
};
/***********************************************************************/