/usr/include/shogun/lib/tapkee/projection.hpp 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 | /* This software is distributed under BSD 3-clause license (see LICENSE file).
*
* Copyright (c) 2012-2013 Sergey Lisitsyn, Fernando Iglesias
*/
#ifndef TAPKEE_PROJECTION_H_
#define TAPKEE_PROJECTION_H_
namespace tapkee
{
//! A base class for implementation of projecting
struct ProjectionImplementation
{
virtual ~ProjectionImplementation()
{
}
//! Projects provided vector to new space
//! @param vec vector to be projected
//! @return projected vector
virtual DenseVector project(const DenseVector& vec) = 0;
};
//! A pimpl wrapper for projecting function
struct ProjectingFunction
{
ProjectingFunction() : implementation(NULL) {};
ProjectingFunction(ProjectionImplementation* impl) : implementation(impl) {};
//! Destroys current implementation
void clear()
{
delete implementation;
}
//! Projects provided vector to new space
//! @param vec vector to be projected
//! @return projected vector
inline DenseVector operator()(const DenseVector& vec)
{
return implementation->project(vec);
}
ProjectionImplementation* implementation;
};
//! Basic @ref ProjectionImplementation that subtracts mean from the vector
//! and multiplies projecting matrix with it.
struct MatrixProjectionImplementation : public ProjectionImplementation
{
MatrixProjectionImplementation(DenseMatrix matrix, DenseVector mean) : proj_mat(matrix), mean_vec(mean)
{
}
virtual ~MatrixProjectionImplementation()
{
}
virtual DenseVector project(const DenseVector& vec)
{
return proj_mat*(vec-mean_vec);
}
DenseMatrix proj_mat;
DenseVector mean_vec;
};
}
#endif
|