aboutsummaryrefslogtreecommitdiff
path: root/include/gensvm_kernel.h
blob: 45b7e62d7aa7a16cdcb10bae588336e789ab50ed (plain)
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
/**
 * @file gensvm_kernel.h
 * @author Gertjan van den Burg
 * @date January, 2014
 * @brief Header file for kernel functionality
 *
 * @details
 * Contains function declarations for computing the kernel matrix
 * in nonlinear MSVMGen. Additional kernel functions should be
 * included here and in gensvm_kernel.c
 *
 */

#ifndef GENSVM_KERNEL_H
#define GENSVM_KERNEL_H

// forward declarations
struct GenData;
struct GenModel;

// function declarations

void gensvm_kernel_preprocess(struct GenModel *model, struct GenData *data);
void gensvm_kernel_postprocess(struct GenModel *model,
	       	struct GenData *traindata, struct GenData *testdata);
void gensvm_make_kernel(struct GenModel *model, struct GenData *data,
		double *K);
long gensvm_make_eigen(double *K, long n, double **P, double **Sigma);
void gensvm_make_crosskernel(struct GenModel *model,
		struct GenData *data_train, struct GenData *data_test,
		double **K2);
void gensvm_make_trainfactor(struct GenData *data, double *P, double *Sigma,
		long r);
void gensvm_make_testfactor(struct GenData *testdata,
	       	struct GenData *traindata, double *K2);
double gensvm_dot_rbf(double *x1, double *x2, double *kernelparam, long n);
double gensvm_dot_poly(double *x1, double *x2, double *kernelparam, long n);
double gensvm_dot_sigmoid(double *x1, double *x2, double *kernelparam, long n);

#endif