ImplicitKernelMatrix.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /**
  2. * @file ImplicitKernelMatrix.h
  3. * @author Erik Rodner, Alexander Freytag
  4. * @brief An implicit kernel matrix, allowing for fast multiplication with arbitrary vectors (Interface)
  5. * @date 02/14/2012
  6. */
  7. #ifndef _NICE_IMPLICITKERNELMATRIXINCLUDE
  8. #define _NICE_IMPLICITKERNELMATRIXINCLUDE
  9. #include <iostream>
  10. #include <core/algebra/GenericMatrix.h>
  11. #include "core/basics/Persistent.h"
  12. namespace NICE {
  13. /** @class ImplicitKernelMatrix
  14. * @brief An implicit kernel matrix, allowing for fast multiplication with arbitrary vectors
  15. * @author Erik Rodner, Alexander Freytag
  16. * @date 02/14/2012
  17. */
  18. class ImplicitKernelMatrix : public GenericMatrix, NICE::Persistent
  19. {
  20. protected:
  21. public:
  22. /** simple constructor */
  23. ImplicitKernelMatrix();
  24. /** simple destructor */
  25. virtual ~ImplicitKernelMatrix();
  26. //get set methods
  27. virtual void getDiagonalElements ( Vector & diagonalElements ) const = 0;
  28. virtual void getFirstDiagonalElement ( double & diagonalElement ) const = 0;
  29. virtual uint getNumParameters() const = 0;
  30. virtual void getParameters(Vector & parameters) const = 0;
  31. virtual void setParameters(const Vector & parameters) = 0;
  32. virtual bool outOfBounds(const Vector & parameters) const = 0;
  33. virtual Vector getParameterLowerBounds() const = 0;
  34. virtual Vector getParameterUpperBounds() const = 0;
  35. virtual double approxFrobNorm() const = 0;
  36. virtual void setApproximationScheme(const int & _approxScheme) = 0;
  37. /** Persistent interface */
  38. virtual void restore ( std::istream & is, int format = 0 ) = 0;
  39. virtual void store ( std::ostream & os, int format = 0 ) const = 0;
  40. virtual void clear () = 0;
  41. //high order methods
  42. virtual void multiply (NICE::Vector &y, const NICE::Vector &x) const = 0;
  43. };
  44. }
  45. #endif