00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024 #ifndef __FST_H__
00025 #define __FST_H__
00026 #include <utility>
00027 #include <set>
00028 #include <memory>
00029 #include <Sequence/stateCounter.hpp>
00030 #include <Sequence/SeqExceptions.hpp>
00031 #include <boost/utility.hpp>
00035 namespace Sequence
00036 {
00037 class PolyTable;
00038 class FSTimpl;
00039 class FST : boost::noncopyable
00040 {
00041 private:
00042 void doCalcs(void) const;
00043 mutable std::auto_ptr<FSTimpl> impl;
00044 public:
00045 explicit FST(const PolyTable *data, unsigned npop, const unsigned *config=NULL,
00046 const double *weights=NULL, bool haveOutgroup = false,
00047 unsigned outgroup = 0) throw (SeqException);
00048 ~FST(void);
00049 double HSM(void) const;
00050 double Slatkin(void) const;
00051 double HBK(void) const;
00052 double piB(void) const;
00053 double piT(void) const;
00054 double piS(void) const;
00055 double piD(void) const;
00056 std::set<double> shared(unsigned pop1, unsigned pop2) const;
00057 std::set<double> fixed(unsigned pop1, unsigned pop2) const;
00058 std::pair< std::set<double>,std::set<double> > Private(unsigned pop1, unsigned pop2) const;
00059 };
00060 }
00061 #endif