/usr/include/shogun/lib/IndexBlockTree.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 | /*
* 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.
*
* Copyright (C) 2012 Sergey Lisitsyn
*/
#ifndef INDEXBLOCKTREE_H_
#define INDEXBLOCKTREE_H_
#include <shogun/lib/IndexBlock.h>
#include <shogun/lib/IndexBlockRelation.h>
namespace shogun
{
/** @brief class IndexBlockTree used to represent
* tree guided feature relation.
*
* Can be constructed via CIndexBlock instance having
* sub blocks, adjacency matrix or precomputed indices.
*/
class CIndexBlockTree : public CIndexBlockRelation
{
public:
/** default constructor */
CIndexBlockTree();
/** constructor from index block
* @param root_block root block of the tree
*/
CIndexBlockTree(CIndexBlock* root_block);
/** constructor from adjacency matrix
* @param adjacency_matrix adjacency matrix
* @param include_supernode whether to include supernode
*/
CIndexBlockTree(SGMatrix<float64_t> adjacency_matrix, bool include_supernode);
/** constructor from general precomputed indices
* each node is represented with indices G[ind_t.min:ind_t.max]
* and weight ind_t.weight
* @param G custom G containing mapping indices
* @param ind_t custom ind_t containing flatten parameters of each node [min,max,weight]
*/
CIndexBlockTree(SGVector<float64_t> G, SGVector<float64_t> ind_t);
/** constructor from basic precomputed indices
* each node is represented with indices ind_t.min:ind_t.max
* and weight ind_t.weight
* @param ind_t custom ind_t containing flatten parameters of each node [min,max,weight]
*/
CIndexBlockTree(SGVector<float64_t> ind_t);
/** destructor */
virtual ~CIndexBlockTree();
/** get root IndexBlock */
CIndexBlock* get_root_block() const;
/** set root block */
void set_root_block(CIndexBlock* root_block);
/** returns information about blocks in
* SLEP "ind" format
*/
virtual SGVector<index_t> get_SLEP_ind();
/** returns information about blocks in
* SLEP "G" format
*/
virtual SGVector<float64_t> get_SLEP_G();
/** returns information about blocks relations
* in SLEP "ind_t" format
*/
virtual SGVector<float64_t> get_SLEP_ind_t() const;
/** returns relation type */
virtual EIndexBlockRelationType get_relation_type() const { return TREE; }
/** whether relation is general, i.e. not well ordered */
bool is_general() const;
/** get name */
const char* get_name() const { return "IndexBlockTree"; };
protected:
/** root block */
CIndexBlock* m_root_block;
/** general */
bool m_general;
/** precomputed ind_t */
SGVector<float64_t> m_precomputed_ind_t;
/** precomputed G */
SGVector<float64_t> m_precomputed_G;
};
}
#endif
|