KernelLinearCombination.cpp 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /**
  2. * @file KernelLinearCombination.cpp
  3. * @brief Interface for the popular exponential mercer kernels
  4. * @author Erik Rodner
  5. * @date 10/24/2007
  6. */
  7. #ifdef NOVISUAL
  8. #include <vislearning/nice_nonvis.h>
  9. #else
  10. #include <vislearning/nice.h>
  11. #endif
  12. #include <iostream>
  13. #include <math.h>
  14. #include "KernelLinearCombination.h"
  15. using namespace OBJREC;
  16. using namespace std;
  17. using namespace NICE;
  18. KernelLinearCombination::KernelLinearCombination( uint num, bool _exponential )
  19. : alpha ( num ), exponential(_exponential)
  20. {
  21. for ( uint i = 0 ; i < num ; i++ )
  22. alpha[i] = - log(num);
  23. }
  24. KernelLinearCombination::KernelLinearCombination ( const KernelLinearCombination & src )
  25. {
  26. alpha.resize ( src.alpha.size() );
  27. alpha = src.alpha;
  28. exponential = src.exponential;
  29. }
  30. KernelLinearCombination::~KernelLinearCombination()
  31. {
  32. }
  33. KernelLinearCombination *KernelLinearCombination::clone(void) const
  34. {
  35. return new KernelLinearCombination ( *this );
  36. }
  37. double KernelLinearCombination::K (const NICE::Vector & x, const NICE::Vector & y) const
  38. {
  39. fthrow(Exception, "Unable to calculate kernel values directly.");
  40. }
  41. void KernelLinearCombination::updateKernelData ( KernelData *kernelData ) const
  42. {
  43. NICE::Matrix & kernelMatrix = kernelData->getKernelMatrix();
  44. for ( uint k = 0 ; k < alpha.size(); k++ )
  45. {
  46. const NICE::Matrix & cachedMatrix = kernelData->getCachedMatrix ( k );
  47. if ( k == 0 ) {
  48. kernelMatrix.resize ( cachedMatrix.rows(), cachedMatrix.cols() );
  49. kernelMatrix.set(0.0);
  50. }
  51. kernelMatrix += exp(alpha[k]) * cachedMatrix;
  52. }
  53. if ( exponential ) {
  54. for ( uint i = 0 ; i < kernelMatrix.rows(); i++ )
  55. for ( uint j = 0 ; j < kernelMatrix.cols(); j++ )
  56. kernelMatrix(i,j) = exp(- kernelMatrix(i,j));
  57. }
  58. }
  59. void KernelLinearCombination::getKernelJacobi ( size_t parameter, const NICE::Vector & parameters, const KernelData *kernelData, NICE::Matrix & jacobiMatrix ) const
  60. {
  61. const NICE::Matrix & kernelMatrix = kernelData->getKernelMatrix();
  62. if ( parameter >= alpha.size() )
  63. fthrow(Exception, "Parameter index exceeds parameter vector size" );
  64. jacobiMatrix.resize ( kernelMatrix.rows(), kernelMatrix.cols() );
  65. const Matrix & kernelMatrixParameter = kernelData->getCachedMatrix( parameter );
  66. if ( exponential ) {
  67. for ( uint i = 0 ; i < jacobiMatrix.rows(); i++ )
  68. for ( uint j = 0 ; j < jacobiMatrix.cols(); j++ )
  69. jacobiMatrix(i,j) = - kernelMatrixParameter(i,j) * exp(alpha[parameter]) * kernelMatrix(i,j);
  70. } else {
  71. jacobiMatrix = exp(alpha[parameter]) * kernelMatrixParameter;
  72. }
  73. }
  74. void KernelLinearCombination::setParameters( const NICE::Vector & newParameters )
  75. {
  76. alpha = newParameters;
  77. }
  78. void KernelLinearCombination::getParameters( NICE::Vector & newParameters ) const
  79. {
  80. newParameters.resize ( alpha.size() );
  81. newParameters = alpha;
  82. }