5 * Created by Thomas Ryabin on 2/23/09.
6 * Copyright 2009 __MyCompanyName__. All rights reserved.
11 #include "calculator.h"
13 /***********************************************************************/
15 double Geom::kEq(double k, double spec){
16 return k/(1-k)*pow(1-k, spec)/(1-pow(1-k, spec));
19 RAbundVector Geom::getRAbundVector(SAbundVector* rank){
25 for(int i = rank->size()-1; i > 0; i--)
27 int cur = rank->get(i);
28 if(mr == 1 && cur > 0)
32 for(int j = 0; j < cur; j++)
36 RAbundVector rav = RAbundVector(rData, mr, nb, ns);
37 rav.setLabel(rank->getLabel());
41 /***********************************************************************************/
43 /***********************************************************************************/
44 EstOutput Geom::getValues(SAbundVector* rank){
48 rdata = getRAbundVector(rank);
49 int numInd = rdata.getNumSeqs();
50 int numSpec = rdata.getNumBins();
51 int min = rdata.get(rdata.size()-1);
55 while(fabs(min - numInd*kEq(k, (double)numSpec)) > .0001) //This uses a binary search to find the value of k.
57 if(numInd*kEq(k, numSpec) > min)
64 double cK = 1/(1-pow(1-k, numSpec));
69 for(int i = 0; i < rdata.size(); i++)
71 sumObs += rdata.get(i);
72 sumExp += numInd*cK*k*pow(1-k, i);
73 double diff = fabs(sumObs-sumExp);
78 double DStatistic = maxDiff/numInd;
81 cout << "D-Statistic = " << DStatistic << "\n";
82 cout << "Critical value for 95% confidence interval = ";*/
85 critVal = .886/sqrt(rdata.size());
90 critVal = table.getConfLimit(numSpec);
92 /*cout << critVal << "\n";
93 cout << "If D-Statistic is less than the critical value then the data fits the Geometric Series model w/ 95% confidence.\n\n";*/
98 if (isnan(data[0]) || isinf(data[0])) { data[0] = 0; }
99 if (isnan(data[1]) || isinf(data[1])) { data[1] = 0; }
103 catch(exception& e) {
104 cout << "Standard Error: " << e.what() << " has occurred in the NPShannon class Function getValues. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
108 cout << "An unknown error has occurred in the NPShannon class function getValues. Please contact Pat Schloss at pschloss@microbio.umass.edu." << "\n";
113 /***********************************************************************/