tf.stack()
是一个矩阵拼接函数,即将秩为 R 的张量列表堆叠成一个秩为 (R+1) 的张量
import tensorflow as tf
a = tf.constant([[1,2,3],[4,5,6]])
b = tf.constant([[7,8,9],[0,1,7]])
c = tf.stack([a,b],axis = 0)
with tf.Session() as sess:
result1 = sess.run(c)
print(result1)
>>>
[[[1 2 3]
[4 5 6]]
[[7 8 9]
[0 1 7]]]
将 values 中的张量列表打包成一个张量,该张量比 values 中的每个张量都高一个秩,通过沿 axis 维度打包。
给定一个形状为(A, B, C)的张量的长度 N 的列表;
如果 axis == 0,那么 output 张量将具有形状(N, A, B, C)。
如果 axis == 1,那么 output 张量将具有形状(A, N, B, C)。
如果 axis == 2,那么 output 张量将具有形状( A, B, N, C)。
如果 axis == 3,那么 output 张量将具有形状(A, B, C, N)。 或者 axis=-1 表示最后一个??
tf.unstack()
是一个拆分矩阵的函数,将秩为 R 的张量的给定维度出栈为秩为 (R-1) 的张量。
通过沿 axis 维度将 num 张量从 value 中分离出来。如果没有指定 num(默认值),则从 value 的形状推断。如果 value.shape[axis] 不知道,则引发 ValueError。
例如,给定一个具有形状 (A, B, C, D) 的张量。
这与堆栈(stack.)相反
tf.constant() https://blog.csdn.net/csdn_jiayu/article/details/82155224
在TensorFlow API中创建常量的函数原型如下所示:
tf.constant(
value,
dtype=None,
shape=None,
name='Const',
verify_shape=False
)
可以看到第一个值value是必须的,可以是一个数值,也可以是一个列表。
1 如果是数值:
tensor=tf.constant(1)
为查看结果必须创建一个会话,并用取值函数eval()来查看创建的tensor的值:
sess=tf.Session()
with sess.as_default():
print('结果是:', tensor.eval())
sess=tf.Session()
with sess.as_default():
print('结果是:', tensor.eval())
结果是:1
2 如果value是一个列表:
tensor=tf.constant([1, 2])
sess=tf.Session()
with sess.as_default():
print('结果是:', tensor.eval())
结果是:[1 2]
3 参数说明
tf.constant(
value,
dtype=None,
shape=None,
name='Const',
verify_shape=False
)
后面四个参数可写可不写,
1 第二个参数
表示数据类型,一般可以是tf.float32, tf.float64等:
tensor=tf.constant([1, 2], dtype=tf.float32)
sess=tf.Session()
with sess.as_default():
print('结果是:', tensor.eval())
结果是: [1. 2.]
2 第三个参数
表示张量的“形状”,即维数以及每一维的大小。
如果指定了第三个参数,当第一个参数value是数字时,张量的所有元素都会用该数字填充:
tensor=tf.constant(-1, shape=[2, 3])
sess=tf.Session()
with sess.as_default():
print('结果是:', tensor.eval())
结果是: [[-1 -1 -1]
[-1 -1 -1]]
可以看到是一个二维张量,第一维大小为2, 第二维大小为3,全用数字-1填充。
而当第一个参数value是一个列表时,注意列表的长度必须小于等于第三个参数shape的大小(即各维大小的乘积),
否则7个数,但是给了6个位置[2,3]会报错:
tensor=tf.constant([1, 2, 3, 4, 5, 6, 7], shape=[2, 3])
报错如下:Traceback (most recent call last):
File "
tensor=tf.constant([1, 2, 3, 4, 5, 6, 7], shape=[2, 3])
ValueError: Too many elements provided. Needed at most 6, but received 7
而如果列表大小小于shape大小,则会用列表的最后一项元素填充剩余的张量元素:
tensor=tf.constant([1, 2], shape=[1, 4, 3])
sess=tf.Session()
with sess.as_default():
print('结果是:', tensor.eval())
结果是: [[[1 2 2]
[2 2 2]
[2 2 2]
[2 2 2]]]
3 第四个参数
name可以是任何内容,主要是字符串就行。
不输入任何内容时:
tensor=tf.constant([1, 2])
print(tensor)
Tensor("Const_16:0", shape=(2,), dtype=int32)
作为对比:
tensor=tf.constant([1, 2], name="jiayu")
print(tensor)
Tensor("jiayu_1:0", shape=(2,), dtype=int32)
4 第五个参数
verify_shape默认为False,
如果修改为True的话表示检查value的形状与shape是否相符,如果不符会报错。
tensor=tf.constant([[1, 2, 3], [4, 5, 6]], shape=[2, 3], verify_shape=True)
以上代码value与shape都是两行三列,检查结果正确。而下面的代码会报错:
tensor=tf.constant([1, 2], shape=[3, 2], verify_shape=True)