/usr/include/shogun/statistics/KernelIndependenceTestStatistic.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 | /*
* 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) 2012-2013 Heiko Strathmann
*/
#ifndef __KERNELINDEPENDENCESTSTATISTIC_H_
#define __KERNELINDEPENDENCESTSTATISTIC_H_
#include <shogun/statistics/TwoDistributionsTestStatistic.h>
namespace shogun
{
class CFeatures;
class CKernel;
/** @brief Independence test base class. Provides an interface for performing an
* independence test. Given samples \f$Z=\{(x_i,y_i)\}_{i=1}^m\f$ from the joint
* distribution \f$\textbf{P}_x\textbf{P}_y\f$, does the joint distribution
* factorize as \f$\textbf{P}_{xy}=\textbf{P}_x\textbf{P}_y\f$? The null-
* hypothesis says yes, i.e. no independence, the alternative hypothesis says
* yes.
*
* In this class, this is done using a single kernel for each of the two sets
* of samples
*
* The class also re-implements the bootstrap_null() method. If the underlying
* kernel is a custom one (precomputed), the
*
* Abstract base class.
*/
class CKernelIndependenceTestStatistic: public CTwoDistributionsTestStatistic
{
public:
CKernelIndependenceTestStatistic();
/** Constructor
*
* @param p_and_q feature data. Is assumed to contain samples from both
* p and q. First all samples from p, then from index q_start all
* samples from q
*
* @param kernel_p kernel to use on samples from p
* @param kernel_q kernel to use on samples from q
* @param p_and_q samples from p and q, appended
* @param q_start index of first sample of q
*/
CKernelIndependenceTestStatistic(CKernel* kernel_p, CKernel* kernel_q,
CFeatures* p_and_q, index_t q_start);
/** Constructor.
* This is a convienience constructor which copies both features to one
* element and then calls the other constructor. Needs twice the memory
* for a short time
*
* @param kernel_p kernel to use on samples from p
* @param kernel_q kernel to use on samples from q
* @param p samples from distribution p, will be copied and NOT
* SG_REF'ed
* @param q samples from distribution q, will be copied and NOT
* SG_REF'ed
*/
CKernelIndependenceTestStatistic(CKernel* kernel_p, CKernel* kernel_q,
CFeatures* p, CFeatures* q);
virtual ~CKernelIndependenceTestStatistic();
/** merges both sets of samples and computes the test statistic
* m_bootstrap_iteration times. This version checks if a precomputed
* custom kernel is used, and, if so, just permutes it instead of re-
* computing it in every iteration.
*
* @return vector of all statistics
*/
virtual SGVector<float64_t> bootstrap_null();
virtual const char* get_name() const=0;
private:
void init();
protected:
/** underlying kernel for p */
CKernel* m_kernel_p;
/** underlying kernel for q */
CKernel* m_kernel_q;
};
}
#endif /* __KERNELINDEPENDENCESTSTATISTIC_H_ */
|