VectorFeature.cpp 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #include "core/image/ImageT.h"
  2. #include "core/vector/VectorT.h"
  3. #include "core/vector/MatrixT.h"
  4. #include <iostream>
  5. #include "VectorFeature.h"
  6. #include "vislearning/cbaselib/FeaturePool.h"
  7. using namespace OBJREC;
  8. using namespace std;
  9. using namespace NICE;
  10. /** simple destructor */
  11. VectorFeature::~VectorFeature()
  12. {
  13. }
  14. double VectorFeature::val( const Example *example ) const
  15. {
  16. return (*(example->vec))[feature_index];
  17. }
  18. void VectorFeature::explode ( FeaturePool & featurePool, bool variableWindow ) const
  19. {
  20. for ( int i = 0 ; i < dimension ; i++ )
  21. {
  22. VectorFeature *f = new VectorFeature ( dimension );
  23. f->feature_index = i;
  24. featurePool.addFeature(f, 1.0 / dimension);
  25. }
  26. }
  27. Feature *VectorFeature::clone() const
  28. {
  29. VectorFeature *f = new VectorFeature( dimension );
  30. f->feature_index = feature_index;
  31. return f;
  32. }
  33. Feature *VectorFeature::generateFirstParameter () const
  34. {
  35. return clone();
  36. }
  37. void VectorFeature::restore (istream & is, int format)
  38. {
  39. is >> feature_index;
  40. }
  41. void VectorFeature::store (ostream & os, int format) const
  42. {
  43. os << "VECTORFEATURE "
  44. << feature_index;
  45. }
  46. void VectorFeature::clear ()
  47. {
  48. }
  49. void VectorFeature::getStump ( int & _feature_index, int & _dimension ) const
  50. {
  51. _feature_index = feature_index;
  52. _dimension = dimension;
  53. }