mirror of
https://github.com/SheffieldML/GPy.git
synced 2026-05-12 05:22:38 +02:00
bugfix: cross term psi1 bias + linear
This commit is contained in:
parent
743112c448
commit
389a04d2b5
4 changed files with 28 additions and 11 deletions
|
|
@ -60,7 +60,7 @@ class BGPLVMTests(unittest.TestCase):
|
|||
|
||||
#@unittest.skip('psi2 cross terms are NotImplemented for this combination')
|
||||
def test_linear_bias_kern(self):
|
||||
N, M, Q, D = 10, 3, 2, 4
|
||||
N, M, Q, D = 30, 5, 4, 30
|
||||
X = np.random.rand(N, Q)
|
||||
k = GPy.kern.linear(Q) + GPy.kern.bias(Q) + GPy.kern.white(Q, 0.00001)
|
||||
K = k.K(X)
|
||||
|
|
|
|||
|
|
@ -105,6 +105,18 @@ if __name__ == "__main__":
|
|||
import sys
|
||||
interactive = 'i' in sys.argv
|
||||
if interactive:
|
||||
N, M, Q, D = 30, 5, 4, 30
|
||||
X = numpy.random.rand(N, Q)
|
||||
k = GPy.kern.linear(Q) + GPy.kern.bias(Q) + GPy.kern.white(Q, 0.00001)
|
||||
K = k.K(X)
|
||||
Y = numpy.random.multivariate_normal(numpy.zeros(N), K, D).T
|
||||
Y -= Y.mean(axis=0)
|
||||
k = GPy.kern.linear(Q) + GPy.kern.bias(Q) + GPy.kern.white(Q, 0.00001)
|
||||
m = GPy.models.Bayesian_GPLVM(Y, Q, kernel=k, M=M)
|
||||
m.ensure_default_constraints()
|
||||
m.randomize()
|
||||
# self.assertTrue(m.checkgrad())
|
||||
|
||||
Q = 5
|
||||
N = 50
|
||||
M = 10
|
||||
|
|
@ -119,17 +131,17 @@ if __name__ == "__main__":
|
|||
GPy.kern.linear(Q) + GPy.kern.bias(Q),
|
||||
GPy.kern.rbf(Q) + GPy.kern.bias(Q)]
|
||||
|
||||
for k in kernels:
|
||||
m = PsiStatModel('psi1', X=X, X_variance=X_var, Z=Z,
|
||||
M=M, kernel=k)
|
||||
assert m.checkgrad(), "{} x psi1".format("+".join(map(lambda x: x.name, k.parts)))
|
||||
# for k in kernels:
|
||||
# m = PsiStatModel('psi1', X=X, X_variance=X_var, Z=Z,
|
||||
# M=M, kernel=k)
|
||||
# assert m.checkgrad(), "{} x psi1".format("+".join(map(lambda x: x.name, k.parts)))
|
||||
#
|
||||
# m0 = PsiStatModel('psi0', X=X, X_variance=X_var, Z=Z,
|
||||
# M=M, kernel=GPy.kern.linear(Q))
|
||||
# m1 = PsiStatModel('psi1', X=X, X_variance=X_var, Z=Z,
|
||||
# M=M, kernel=kernel)
|
||||
m1 = PsiStatModel('psi1', X=X, X_variance=X_var, Z=Z,
|
||||
M=M, kernel=kernel)
|
||||
# m1 = PsiStatModel('psi1', X=X, X_variance=X_var, Z=Z,
|
||||
# M=M, kernel=kernel)
|
||||
m2 = PsiStatModel('psi2', X=X, X_variance=X_var, Z=Z,
|
||||
M=M, kernel=GPy.kern.rbf(Q))
|
||||
m3 = PsiStatModel('psi2', X=X, X_variance=X_var, Z=Z,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue