/usr/include/shogun/features/TOPFeatures.h is in libshogun-dev 3.1.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 | /*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* Written (W) 1999-2009 Soeren Sonnenburg
* Written (W) 1999-2008 Gunnar Raetsch
* Copyright (C) 1999-2009 Fraunhofer Institute FIRST and Max-Planck-Society
*/
#ifndef _CTOPFEATURES__H__
#define _CTOPFEATURES__H__
#include <shogun/features/DenseFeatures.h>
#include <shogun/distributions/HMM.h>
namespace shogun
{
template <class T> class CDenseFeatures;
class CHMM;
#ifndef DOXYGEN_SHOULD_SKIP_THIS
/** HMM indices */
struct T_HMM_INDIZES
{
/** index p */
int32_t* idx_p;
/** index q */
int32_t* idx_q;
/** index a rows */
int32_t* idx_a_rows;
/** index a cols */
int32_t* idx_a_cols;
/** index b rows */
int32_t* idx_b_rows;
/** index b cols */
int32_t* idx_b_cols;
/** number p */
int32_t num_p;
/** number q */
int32_t num_q;
/** number a */
int32_t num_a;
/** number b */
int32_t num_b;
};
#endif // DOXYGEN_SHOULD_SKIP_THIS
/** @brief The class TOPFeatures implements TOP kernel features obtained from
* two Hidden Markov models.
*
* It was used in
*
* K. Tsuda, M. Kawanabe, G. Raetsch, S. Sonnenburg, and K.R. Mueller. A new
* discriminative kernel from probabilistic models. Neural Computation,
* 14:2397-2414, 2002.
*
* which also has the details.
*
* Note that TOP-features are computed on the fly, so to be effective feature
* caching should be enabled.
*
* It inherits its functionality from CDenseFeatures, which should be
* consulted for further reference.
*/
class CTOPFeatures : public CDenseFeatures<float64_t>
{
public:
/** default constructor */
CTOPFeatures();
/** constructor
*
* @param size cache size
* @param p positive HMM
* @param n negative HMM
* @param neglin if negative HMM is of linear shape
* @param poslin if positive HMM is of linear shape
*/
CTOPFeatures(int32_t size, CHMM* p, CHMM* n, bool neglin, bool poslin);
/** copy constructor */
CTOPFeatures(const CTOPFeatures &orig);
virtual ~CTOPFeatures();
/** set HMMs
*
* @param p positive HMM
* @param n negative HMM
*/
void set_models(CHMM* p, CHMM* n);
/** set feature matrix
*
* @return something floaty
*/
virtual float64_t* set_feature_matrix();
/** compute number of features
*
* @return number of features
*/
int32_t compute_num_features();
/** compute relevant indices
*
* @param hmm HMM to compute for
* @param hmm_idx HMM index
* @return if computing was successful
*/
bool compute_relevant_indizes(CHMM* hmm, T_HMM_INDIZES* hmm_idx);
/** @return object name */
virtual const char* get_name() const { return "TOPFeatures"; }
protected:
/** compute feature vector
*
* @param num num
* @param len len
* @param target
* @return something floaty
*/
virtual float64_t* compute_feature_vector(
int32_t num, int32_t& len, float64_t* target=NULL);
/** computes the feature vector to the address addr
*
* @param addr address
* @param num num
* @param len len
*/
void compute_feature_vector(float64_t* addr, int32_t num, int32_t& len);
private:
void init();
protected:
/** positive HMM */
CHMM* pos;
/** negative HMM */
CHMM* neg;
/** if negative HMM is a LinearHMM */
bool neglinear;
/** if positive HMM is a LinearHMM */
bool poslinear;
/** positive relevant indices */
T_HMM_INDIZES pos_relevant_indizes;
/** negative relevant indices */
T_HMM_INDIZES neg_relevant_indizes;
};
}
#endif
|