// Copyright (C) 1998-1999 Jean-Marc Valin
#ifndef GMM_SET_H
#define GMM_SET_H
#include "gmm.h"
#include "gaussian_set.h"
#include "Object.h"
namespace FD {
class GMMSet : public Object {
protected:
int nb_gmms;
Vector<RCPtr<GMM> > gmms;
public:
/**Default Constructor*/
GMMSet()
: nb_gmms(0)
{};
/**Returns the id corresponding to the pointer (or add if absent)*/
int getIDFor(RCPtr<GMM>);
/**Returns the pointer corresponding to the id*/
RCPtr<GMM> getPtrFor(int id);
/**convert all elements to using IDs (before saving)*/
void toIDs(GaussianSet & gauss);
/**convert all elements to using Ptrs (after loading)*/
void toPtrs(const GaussianSet & gauss) const;
/** print function used for operator << */
virtual void printOn(std::ostream &out=std::cout) const;
/**Read function used for operator >> */
void readFrom (std::istream &in=std::cin);
/**extractor operator*/
friend std::istream &operator >> (std::istream &in, GMMSet &cov);
};
}//namespace FD
#endif
syntax highlighted by Code2HTML, v. 0.9.1