mirror of
https://github.com/SheffieldML/GPy.git
synced 2026-05-18 13:55:14 +02:00
Merge branch 'devel' of github.com:SheffieldML/GPy into devel
This commit is contained in:
commit
68bf4dc436
11 changed files with 58 additions and 27 deletions
|
|
@ -6,3 +6,4 @@ from parameterised import *
|
||||||
import priors
|
import priors
|
||||||
from GPy.core.gp import GP
|
from GPy.core.gp import GP
|
||||||
from GPy.core.sparse_gp import SparseGP
|
from GPy.core.sparse_gp import SparseGP
|
||||||
|
from fitc import FITC
|
||||||
|
|
|
||||||
|
|
@ -4,5 +4,5 @@
|
||||||
import classification
|
import classification
|
||||||
import regression
|
import regression
|
||||||
import dimensionality_reduction
|
import dimensionality_reduction
|
||||||
import non_gaussian
|
import non_Gaussian
|
||||||
import tutorials
|
import tutorials
|
||||||
|
|
|
||||||
|
|
@ -24,7 +24,7 @@ def crescent_data(seed=default_seed): # FIXME
|
||||||
Y = data['Y']
|
Y = data['Y']
|
||||||
Y[Y.flatten()==-1] = 0
|
Y[Y.flatten()==-1] = 0
|
||||||
|
|
||||||
m = GPy.models.GP_classification(data['X'], Y)
|
m = GPy.models.GPClassification(data['X'], Y)
|
||||||
m.ensure_default_constraints()
|
m.ensure_default_constraints()
|
||||||
m.update_likelihood_approximation()
|
m.update_likelihood_approximation()
|
||||||
m.optimize()
|
m.optimize()
|
||||||
|
|
@ -41,7 +41,7 @@ def oil():
|
||||||
Y[Y.flatten()==-1] = 0
|
Y[Y.flatten()==-1] = 0
|
||||||
|
|
||||||
# Create GP model
|
# Create GP model
|
||||||
m = GPy.models.GP_classification(data['X'], Y)
|
m = GPy.models.GPClassification(data['X'], Y)
|
||||||
|
|
||||||
# Contrain all parameters to be positive
|
# Contrain all parameters to be positive
|
||||||
m.constrain_positive('')
|
m.constrain_positive('')
|
||||||
|
|
@ -66,7 +66,7 @@ def toy_linear_1d_classification(seed=default_seed):
|
||||||
Y[Y.flatten() == -1] = 0
|
Y[Y.flatten() == -1] = 0
|
||||||
|
|
||||||
# Model definition
|
# Model definition
|
||||||
m = GPy.models.GP_classification(data['X'], Y)
|
m = GPy.models.GPClassification(data['X'], Y)
|
||||||
m.ensure_default_constraints()
|
m.ensure_default_constraints()
|
||||||
|
|
||||||
# Optimize
|
# Optimize
|
||||||
|
|
@ -95,7 +95,7 @@ def sparse_toy_linear_1d_classification(seed=default_seed):
|
||||||
Y[Y.flatten() == -1] = 0
|
Y[Y.flatten() == -1] = 0
|
||||||
|
|
||||||
# Model definition
|
# Model definition
|
||||||
m = GPy.models.sparse_GP_classification(data['X'], Y)
|
m = GPy.models.SparseGPClassification(data['X'], Y)
|
||||||
m['.*len']= 2.
|
m['.*len']= 2.
|
||||||
|
|
||||||
m.ensure_default_constraints()
|
m.ensure_default_constraints()
|
||||||
|
|
@ -127,7 +127,7 @@ def sparse_crescent_data(inducing=10, seed=default_seed):
|
||||||
Y = data['Y']
|
Y = data['Y']
|
||||||
Y[Y.flatten()==-1]=0
|
Y[Y.flatten()==-1]=0
|
||||||
|
|
||||||
m = GPy.models.sparse_GP_classification(data['X'], Y)
|
m = GPy.models.SparseGPClassification(data['X'], Y)
|
||||||
m.ensure_default_constraints()
|
m.ensure_default_constraints()
|
||||||
m['.*len'] = 10.
|
m['.*len'] = 10.
|
||||||
m.update_likelihood_approximation()
|
m.update_likelihood_approximation()
|
||||||
|
|
@ -135,3 +135,27 @@ def sparse_crescent_data(inducing=10, seed=default_seed):
|
||||||
print(m)
|
print(m)
|
||||||
m.plot()
|
m.plot()
|
||||||
return m
|
return m
|
||||||
|
|
||||||
|
def FITC_crescent_data(inducing=10, seed=default_seed):
|
||||||
|
"""Run a Gaussian process classification on the crescent data. The demonstration calls the basic GP classification model and uses EP to approximate the likelihood.
|
||||||
|
|
||||||
|
:param model_type: type of model to fit ['Full', 'FITC', 'DTC'].
|
||||||
|
:param seed : seed value for data generation.
|
||||||
|
:type seed: int
|
||||||
|
:param inducing : number of inducing variables (only used for 'FITC' or 'DTC').
|
||||||
|
:type inducing: int
|
||||||
|
"""
|
||||||
|
|
||||||
|
data = GPy.util.datasets.crescent_data(seed=seed)
|
||||||
|
Y = data['Y']
|
||||||
|
Y[Y.flatten()==-1]=0
|
||||||
|
|
||||||
|
m = GPy.models.FITCClassification(data['X'], Y)
|
||||||
|
m.ensure_default_constraints()
|
||||||
|
m['.*len'] = 10.
|
||||||
|
m.update_likelihood_approximation()
|
||||||
|
m.optimize()
|
||||||
|
print(m)
|
||||||
|
m.plot()
|
||||||
|
return m
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,13 +1,12 @@
|
||||||
# Copyright (c) 2012, GPy authors (see AUTHORS.txt).
|
# Copyright (c) 2012, GPy authors (see AUTHORS.txt).
|
||||||
# Licensed under the BSD 3-clause license (see LICENSE.txt)
|
# Licensed under the BSD 3-clause license (see LICENSE.txt)
|
||||||
|
|
||||||
|
|
||||||
from gp_regression import GPRegression
|
from gp_regression import GPRegression
|
||||||
|
from gp_classification import GPClassification
|
||||||
from sparse_gp_regression import SparseGPRegression
|
from sparse_gp_regression import SparseGPRegression
|
||||||
|
from sparse_gp_classification import SparseGPClassification
|
||||||
|
from fitc_classification import FITCClassification
|
||||||
from gplvm import GPLVM
|
from gplvm import GPLVM
|
||||||
from warped_gp import WarpedGP
|
from warped_gp import WarpedGP
|
||||||
from bayesian_gplvm import BayesianGPLVM
|
from bayesian_gplvm import BayesianGPLVM
|
||||||
from mrd import MRD
|
from mrd import MRD
|
||||||
from generalized_fitc import GeneralizedFITC
|
|
||||||
from fitc import FITC
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -7,7 +7,11 @@ from ..util.linalg import mdot, jitchol, chol_inv, pdinv, trace_dot
|
||||||
from ..util.plot import gpplot
|
from ..util.plot import gpplot
|
||||||
from .. import kern
|
from .. import kern
|
||||||
from scipy import stats, linalg
|
from scipy import stats, linalg
|
||||||
|
<<<<<<< HEAD:GPy/models/generalized_FITC.py
|
||||||
|
from sparse_GP import sparse_GP
|
||||||
|
=======
|
||||||
from ..core import SparseGP
|
from ..core import SparseGP
|
||||||
|
>>>>>>> 7040b26f41f382edfdca3d3f7b689b9bbfc1a54f:GPy/models/generalized_fitc.py
|
||||||
|
|
||||||
def backsub_both_sides(L,X):
|
def backsub_both_sides(L,X):
|
||||||
""" Return L^-T * X * L^-1, assumuing X is symmetrical and L is lower cholesky"""
|
""" Return L^-T * X * L^-1, assumuing X is symmetrical and L is lower cholesky"""
|
||||||
|
|
@ -36,12 +40,17 @@ class GeneralizedFITC(SparseGP):
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, X, likelihood, kernel, Z, X_variance=None, normalize_X=False):
|
def __init__(self, X, likelihood, kernel, Z, X_variance=None, normalize_X=False):
|
||||||
|
|
||||||
self.Z = Z
|
self.Z = Z
|
||||||
self.num_inducing = self.Z.shape[0]
|
self.num_inducing = self.Z.shape[0]
|
||||||
self.true_precision = likelihood.precision
|
self.true_precision = likelihood.precision
|
||||||
|
|
||||||
|
<<<<<<< HEAD:GPy/models/generalized_FITC.py
|
||||||
|
sparse_GP.__init__(self, X, likelihood, kernel=kernel, Z=self.Z, X_variance=None, normalize_X=False)
|
||||||
|
=======
|
||||||
super(GeneralizedFITC, self).__init__(X, likelihood, kernel=kernel, Z=self.Z, X_variance=X_variance, normalize_X=normalize_X)
|
super(GeneralizedFITC, self).__init__(X, likelihood, kernel=kernel, Z=self.Z, X_variance=X_variance, normalize_X=normalize_X)
|
||||||
self._set_params(self._get_params())
|
self._set_params(self._get_params())
|
||||||
|
>>>>>>> 7040b26f41f382edfdca3d3f7b689b9bbfc1a54f:GPy/models/generalized_fitc.py
|
||||||
|
|
||||||
def _set_params(self, p):
|
def _set_params(self, p):
|
||||||
self.Z = p[:self.num_inducing*self.input_dim].reshape(self.num_inducing, self.input_dim)
|
self.Z = p[:self.num_inducing*self.input_dim].reshape(self.num_inducing, self.input_dim)
|
||||||
|
|
|
||||||
|
|
@ -7,11 +7,11 @@ from ..core import GP
|
||||||
from .. import likelihoods
|
from .. import likelihoods
|
||||||
from .. import kern
|
from .. import kern
|
||||||
|
|
||||||
class GP_classification(GP):
|
class GPClassification(GP):
|
||||||
"""
|
"""
|
||||||
Gaussian Process classification
|
Gaussian Process classification
|
||||||
|
|
||||||
This is a thin wrapper around the models.GP class, with a set of sensible defalts
|
This is a thin wrapper around the models.GP class, with a set of sensible defaults
|
||||||
|
|
||||||
:param X: input observations
|
:param X: input observations
|
||||||
:param Y: observed values
|
:param Y: observed values
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,7 @@ class GPRegression(GP):
|
||||||
"""
|
"""
|
||||||
Gaussian Process model for regression
|
Gaussian Process model for regression
|
||||||
|
|
||||||
This is a thin wrapper around the models.GP class, with a set of sensible defalts
|
This is a thin wrapper around the models.GP class, with a set of sensible defaults
|
||||||
|
|
||||||
:param X: input observations
|
:param X: input observations
|
||||||
:param Y: observed values
|
:param Y: observed values
|
||||||
|
|
|
||||||
|
|
@ -3,17 +3,16 @@
|
||||||
|
|
||||||
|
|
||||||
import numpy as np
|
import numpy as np
|
||||||
from ..core import sparse_GP
|
from ..core import SparseGP
|
||||||
from .. import likelihoods
|
from .. import likelihoods
|
||||||
from .. import kern
|
from .. import kern
|
||||||
from ..likelihoods import likelihood
|
from ..likelihoods import likelihood
|
||||||
from GPRegression import GPRegression
|
|
||||||
|
|
||||||
class sparse_GP_classification(sparse_GP):
|
class SparseGPClassification(SparseGP):
|
||||||
"""
|
"""
|
||||||
sparse Gaussian Process model for classification
|
sparse Gaussian Process model for classification
|
||||||
|
|
||||||
This is a thin wrapper around the sparse_GP class, with a set of sensible defalts
|
This is a thin wrapper around the sparse_GP class, with a set of sensible defaults
|
||||||
|
|
||||||
:param X: input observations
|
:param X: input observations
|
||||||
:param Y: observed values
|
:param Y: observed values
|
||||||
|
|
@ -25,8 +24,6 @@ class sparse_GP_classification(sparse_GP):
|
||||||
:type normalize_Y: False|True
|
:type normalize_Y: False|True
|
||||||
:rtype: model object
|
:rtype: model object
|
||||||
|
|
||||||
.. Note:: Multiple independent outputs are allowed using columns of Y
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, X, Y=None, likelihood=None, kernel=None, normalize_X=False, normalize_Y=False, Z=None, M=10):
|
def __init__(self, X, Y=None, likelihood=None, kernel=None, normalize_X=False, normalize_Y=False, Z=None, M=10):
|
||||||
|
|
@ -46,5 +43,5 @@ class sparse_GP_classification(sparse_GP):
|
||||||
else:
|
else:
|
||||||
assert Z.shape[1]==X.shape[1]
|
assert Z.shape[1]==X.shape[1]
|
||||||
|
|
||||||
sparse_GP.__init__(self, X, likelihood, kernel, Z=Z, normalize_X=normalize_X)
|
SparseGP.__init__(self, X, likelihood, kernel, Z=Z, normalize_X=normalize_X)
|
||||||
self._set_params(self._get_params())
|
self._set_params(self._get_params())
|
||||||
|
|
|
||||||
|
|
@ -194,9 +194,12 @@ class GradientTests(unittest.TestCase):
|
||||||
N = 20
|
N = 20
|
||||||
X = np.hstack([np.random.rand(N / 2) + 1, np.random.rand(N / 2) - 1])[:, None]
|
X = np.hstack([np.random.rand(N / 2) + 1, np.random.rand(N / 2) - 1])[:, None]
|
||||||
k = GPy.kern.rbf(1) + GPy.kern.white(1)
|
k = GPy.kern.rbf(1) + GPy.kern.white(1)
|
||||||
Y = np.hstack([np.ones(N / 2), -np.ones(N / 2)])[:, None]
|
Y = np.hstack([np.ones(N/2),-np.ones(N/2)])[:,None]
|
||||||
likelihood = Binomial(Y)
|
|
||||||
m = GPy.models.GeneralizedFITC(X, likelihood, k, inducing=4)
|
distribution = GPy.likelihoods.likelihood_functions.binomial()
|
||||||
|
likelihood = GPy.likelihoods.EP(Y, distribution)
|
||||||
|
#likelihood = GPy.inference.likelihoods.binomial(Y)
|
||||||
|
m = GPy.models.generalized_FITC(X,likelihood,k,inducing=4)
|
||||||
m.constrain_positive('(var|len)')
|
m.constrain_positive('(var|len)')
|
||||||
m.approximate_likelihood()
|
m.approximate_likelihood()
|
||||||
self.assertTrue(m.checkgrad())
|
self.assertTrue(m.checkgrad())
|
||||||
|
|
|
||||||
|
|
@ -13,7 +13,7 @@ default_seed = 10000
|
||||||
# Some general utilities.
|
# Some general utilities.
|
||||||
def sample_class(f):
|
def sample_class(f):
|
||||||
p = 1. / (1. + np.exp(-f))
|
p = 1. / (1. + np.exp(-f))
|
||||||
c = np.random.Binomial(1, p)
|
c = np.random.binomial(1, p)
|
||||||
c = np.where(c, 1, -1)
|
c = np.where(c, 1, -1)
|
||||||
return c
|
return c
|
||||||
|
|
||||||
|
|
@ -34,8 +34,6 @@ def fetch_dataset(resource, save_name = None, save_file = True, messages = True)
|
||||||
print "Done!"
|
print "Done!"
|
||||||
return html
|
return html
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def della_gatta_TRP63_gene_expression(gene_number=None):
|
def della_gatta_TRP63_gene_expression(gene_number=None):
|
||||||
mat_data = scipy.io.loadmat(os.path.join(data_path, 'DellaGattadata.mat'))
|
mat_data = scipy.io.loadmat(os.path.join(data_path, 'DellaGattadata.mat'))
|
||||||
X = np.double(mat_data['timepoints'])
|
X = np.double(mat_data['timepoints'])
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue