-
Notifications
You must be signed in to change notification settings - Fork 566
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #788 from SheffieldML/devel
Release 1.9.9
- Loading branch information
Showing
60 changed files
with
846 additions
and
145 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
__version__ = "1.9.8" | ||
__version__ = "1.9.9" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
# Copyright (c) 2018, GPy authors (see AUTHORS.txt). | ||
# Licensed under the BSD 3-clause license (see LICENSE.txt) | ||
from .kern import Kern | ||
import numpy as np | ||
from paramz.caching import Cache_this | ||
|
||
class DiffKern(Kern): | ||
""" | ||
Diff kernel is a thin wrapper for using partial derivatives of kernels as kernels. Eg. in combination with | ||
Multioutput kernel this allows the user to train GPs with observations of latent function and latent | ||
function derivatives. NOTE: DiffKern only works when used with Multioutput kernel. Do not use the kernel as standalone | ||
The parameters the kernel needs are: | ||
-'base_kern': a member of Kernel class that is used for observations | ||
-'dimension': integer that indigates in which dimensions the partial derivative observations are | ||
""" | ||
def __init__(self, base_kern, dimension): | ||
super(DiffKern, self).__init__(base_kern.active_dims.size, base_kern.active_dims, name='DiffKern') | ||
self.base_kern = base_kern | ||
self.dimension = dimension | ||
|
||
def parameters_changed(self): | ||
self.base_kern.parameters_changed() | ||
|
||
@Cache_this(limit=3, ignore_args=()) | ||
def K(self, X, X2=None, dimX2 = None): #X in dimension self.dimension | ||
if X2 is None: | ||
X2 = X | ||
if dimX2 is None: | ||
dimX2 = self.dimension | ||
return self.base_kern.dK2_dXdX2(X,X2, self.dimension, dimX2) | ||
|
||
@Cache_this(limit=3, ignore_args=()) | ||
def Kdiag(self, X): | ||
return np.diag(self.base_kern.dK2_dXdX2(X,X, self.dimension, self.dimension)) | ||
|
||
@Cache_this(limit=3, ignore_args=()) | ||
def dK_dX_wrap(self, X, X2): #X in dimension self.dimension | ||
return self.base_kern.dK_dX(X,X2, self.dimension) | ||
|
||
@Cache_this(limit=3, ignore_args=()) | ||
def dK_dX2_wrap(self, X, X2): #X in dimension self.dimension | ||
return self.base_kern.dK_dX2(X,X2, self.dimension) | ||
|
||
def reset_gradients(self): | ||
self.base_kern.reset_gradients() | ||
|
||
@property | ||
def gradient(self): | ||
return self.base_kern.gradient | ||
|
||
@gradient.setter | ||
def gradient(self, gradient): | ||
self.base_kern.gradient = gradient | ||
|
||
def update_gradients_full(self, dL_dK, X, X2=None, dimX2=None): | ||
if dimX2 is None: | ||
dimX2 = self.dimension | ||
gradients = self.base_kern.dgradients2_dXdX2(X,X2,self.dimension,dimX2) | ||
self.base_kern.update_gradients_direct(*[self._convert_gradients(dL_dK, gradient) for gradient in gradients]) | ||
|
||
def update_gradients_diag(self, dL_dK_diag, X): | ||
gradients = self.base_kern.dgradients2_dXdX2(X,X, self.dimension, self.dimension) | ||
self.base_kern.update_gradients_direct(*[self._convert_gradients(dL_dK_diag, gradient, f=np.diag) for gradient in gradients]) | ||
|
||
def update_gradients_dK_dX(self, dL_dK, X, X2=None): | ||
if X2 is None: | ||
X2 = X | ||
gradients = self.base_kern.dgradients_dX(X,X2, self.dimension) | ||
self.base_kern.update_gradients_direct(*[self._convert_gradients(dL_dK, gradient) for gradient in gradients]) | ||
|
||
def update_gradients_dK_dX2(self, dL_dK, X, X2=None): | ||
gradients = self.base_kern.dgradients_dX2(X,X2, self.dimension) | ||
self.base_kern.update_gradients_direct(*[self._convert_gradients(dL_dK, gradient) for gradient in gradients]) | ||
|
||
def gradients_X(self, dL_dK, X, X2): | ||
tmp = self.base_kern.gradients_XX(dL_dK, X, X2)[:,:,:, self.dimension] | ||
return np.sum(tmp, axis=1) | ||
|
||
def gradients_X2(self, dL_dK, X, X2): | ||
tmp = self.base_kern.gradients_XX(dL_dK, X, X2)[:, :, self.dimension, :] | ||
return np.sum(tmp, axis=1) | ||
|
||
def _convert_gradients(self, l,g, f = lambda x:x): | ||
if type(g) is np.ndarray: | ||
return np.sum(f(l)*f(g)) | ||
else: | ||
return np.array([np.sum(f(l)*f(gi)) for gi in g]) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.