/usr/include/shogun/io/streaming/StreamingFileFromSparseFeatures.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 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | /*
* 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) 2011 Shashwat Lal Das
* Copyright (C) 2011 Berlin Institute of Technology and Max-Planck-Society
*/
#ifndef __STREAMING_FILEFROMSPARSE_H__
#define __STREAMING_FILEFROMSPARSE_H__
#include <shogun/io/streaming/StreamingFileFromFeatures.h>
#include <shogun/features/SparseFeatures.h>
namespace shogun
{
/** @brief Class CStreamingFileFromSparseFeatures is derived from CStreamingFile
* and provides an input source for the online framework. It uses an existing
* CSparseFeatures object to generate online examples.
*/
template <class T> class CStreamingFileFromSparseFeatures: public CStreamingFileFromFeatures
{
public:
/**
* Default constructor
*/
CStreamingFileFromSparseFeatures();
/**
* Constructor taking a SparseFeatures object as arg
*
* @param feat SparseFeatures object
*/
CStreamingFileFromSparseFeatures(CSparseFeatures<T>* feat);
/**
* Constructor taking a SparseFeatures object as arg
*
* @param feat SparseFeatures object
* @param lab Labels as float64_t*
*/
CStreamingFileFromSparseFeatures(CSparseFeatures<T>* feat, float64_t* lab);
/**
* Destructor
*/
virtual ~CStreamingFileFromSparseFeatures();
/**
* This function will be called for reading vectors from the
* corresponding SparseFeatures object.
* It is specialized depending on class type T.
*
* @param vec vector
* @param len length of vector
*/
virtual void get_sparse_vector(SGSparseVectorEntry<T>* &vec, int32_t &len);
/**
* This function will be called for reading vectors and labels
* from the corresponding SparseFeatures object. It is
* specialized depending on class type T.
*
* @param vec vector
* @param len length of vector
* @param label label
*/
virtual void get_sparse_vector_and_label(SGSparseVectorEntry<T>* &vec, int32_t &len, float64_t &label);
/**
* Reset the stream so the next example returned is the first
* example in the SparseFeatures object.
*
*/
void reset_stream()
{
vector_num = 0;
}
/** @return object name */
virtual const char* get_name() const
{
return "StreamingFileFromSparseFeatures";
}
private:
/**
* Initialize members to defaults
*/
void init(CSparseFeatures<T>* feat);
protected:
/// SparseFeatures object
CSparseFeatures<T>* features;
/// Index of vector to be returned from the feature matrix
int32_t vector_num;
};
template <class T>
CStreamingFileFromSparseFeatures<T>::CStreamingFileFromSparseFeatures()
: CStreamingFileFromFeatures()
{
init(NULL);
}
template <class T>
CStreamingFileFromSparseFeatures<T>::CStreamingFileFromSparseFeatures(CSparseFeatures<T>* feat)
: CStreamingFileFromFeatures(feat)
{
init(feat);
}
template <class T>
CStreamingFileFromSparseFeatures<T>::CStreamingFileFromSparseFeatures(CSparseFeatures<T>* feat, float64_t* lab)
: CStreamingFileFromFeatures(feat,lab)
{
init(feat);
}
template <class T>
CStreamingFileFromSparseFeatures<T>::~CStreamingFileFromSparseFeatures()
{
SG_UNREF(features);
}
template <class T>
void CStreamingFileFromSparseFeatures<T>::init(CSparseFeatures<T>* feat)
{
features = feat;
SG_REF(features);
vector_num=0;
set_generic<T>();
}
/* Functions to return the vector from the SparseFeatures object */
template <class T>
void CStreamingFileFromSparseFeatures<T>::get_sparse_vector
(SGSparseVectorEntry<T>*& vector, int32_t& len)
{
if (vector_num >= features->get_num_vectors())
{
vector=NULL;
len=-1;
return;
}
SGSparseVector<T> vec=
features->get_sparse_feature_vector(vector_num);
vector=vec.features;
len=vec.num_feat_entries;
/* TODO. check if vector needs to be freed? */
vector_num++;
}
/* Functions to return the vector from the SparseFeatures object */
template <class T>
void CStreamingFileFromSparseFeatures<T>::get_sparse_vector_and_label
(SGSparseVectorEntry<T>*& vector, int32_t& len, float64_t& label)
{
get_sparse_vector(vector, len);
label=labels[vector_num];
}
}
#endif //__STREAMING_FILEFROMSPARSE_H__
|