提交 5e02f08e authored 作者: Matthew Rocklin's avatar Matthew Rocklin

Add matrix_of_scalars function

上级 8632816e
......@@ -8224,3 +8224,19 @@ def diag(v, k=0):
return diagonal(v, k)
else:
raise ValueError("Input must be 1- or 2-d.")
def matrix_of_scalars(list_of_lists):
""" Returns a matrix of scalars
>>> from theano.tensor import matrix_of_scalars, scalar
>>> from theano import function
>>> a,b,c,d = map(scalar, 'abcd')
>>> X = matrix_of_scalars([[a, b],
... [c, d]])
>>> f = function([a, b, c, d], X)
>>> f(1, 2, 3, 4)
array([[ 1., 2.],
[ 3., 4.]], dtype=float32)
"""
from functools import partial
return stack(*map(partial(apply, stack), list_of_lists))
......@@ -43,7 +43,8 @@ from theano.tensor import (_shared, wvector, bvector, autocast_float_as,
ScalarFromTensor, TensorFromScalar, dtensor4, Rebroadcast, Alloc,
dtensor3, SpecifyShape, Mean, IncSubtensor, AdvancedIncSubtensor1,
itensor3, Tile, AdvancedIncSubtensor, switch, Diagonal, Diag,
nonzero, flatnonzero, nonzero_values, inplace_increment)
nonzero, flatnonzero, nonzero_values, inplace_increment,
matrix_of_scalars)
from theano.tests import unittest_tools as utt
......@@ -3767,9 +3768,9 @@ class TestAdvancedSubtensor(unittest.TestCase):
a.broadcastable, self.ix2.broadcastable)
def test_inc_adv_subtensor_w_matrix(self):
if inplace_increment is None:
if inplace_increment is None:
raise inplace_increment_missing
subt = self.v[self.ix2]
a = inc_subtensor(subt,subt)
......@@ -3780,7 +3781,7 @@ class TestAdvancedSubtensor(unittest.TestCase):
assert numpy.allclose(aval, [.4, .9 * 3, .1 * 3])
def test_inc_adv_subtensor_w_2vec(self):
if inplace_increment is None:
if inplace_increment is None:
raise inplace_increment_missing
subt = self.m[self.ix1, self.ix12]
......@@ -3801,7 +3802,7 @@ class TestAdvancedSubtensor(unittest.TestCase):
[.5, .3 * 2, .15]]), aval
def test_inc_adv_subtensor_with_broadcasting(self):
if inplace_increment is None:
if inplace_increment is None:
raise inplace_increment_missing
a = inc_subtensor(self.m[self.ix1, self.ix12], 2.1)
......@@ -3820,7 +3821,7 @@ class TestAdvancedSubtensor(unittest.TestCase):
[.5, .3 + 2.1, .15]]), aval
def test_inc_adv_subtensor_with_index_broadcasting(self):
if inplace_increment is None:
if inplace_increment is None:
raise inplace_increment_missing
a = inc_subtensor(self.m[self.ix1, self.ix2], 2.1)
......@@ -6778,6 +6779,15 @@ def test_transpose():
assert tensor.transpose(x3).name == 'x3.T'
assert tensor.transpose(tensor.dmatrix()).name is None
def test_matrix_of_scalars():
a,b,c,d = map(scalar, 'abcd')
X = matrix_of_scalars([[a, b],
[c, d]])
f = function([a, b, c, d], X)
result = f(1,2,3,4)
assert result.shape == (2, 2)
assert numpy.allclose(f(1, 2, 3, 4), numpy.asarray([[1,2],[3,4]]))
class TestSpecifyShape(unittest.TestCase):
def shortDescription(self):
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论