图像处理时数据集中存储数据的形式为[channel,image_height,image_width],在tensorflow中使用CNN时咱们须要将其转化为[image_height,image_width,channel]的形式,只须要使用tf.transpose(input_data,[1,2,0])python
输出数据tensor的第i维将根据perm[i]指定。好比,若是perm没有给定,那么默认是perm = [n-1, n-2, ..., 0],其中rank(a) = n。git
默认状况下,对于二维输入数据,其实就是常规的矩阵转置操做。github
input_data.dims = (1, 4, 3) perm = [1, 2, 0]函数
由于 output_data.dims[0] = input_data.dims[ perm[0] ] 由于 output_data.dims[1] = input_data.dims[ perm[1] ] 由于 output_data.dims[2] = input_data.dims[ perm[2] ] 因此获得 output_data.dims = (4, 3, 1) output_data.dims = (4, 3, 1)学习
import tensorflow as tf sess = tf.Session() input_data = tf.constant([[1, 2, 3], [4, 5, 6]]) print(sess.run(tf.transpose(input_data))) # [[1 4] # [2 5] # [3 6]] print(sess.run(input_data)) # [[1 2 3] # [4 5 6]] print(sess.run(tf.transpose(input_data, perm=[1, 0]))) # [[1 4] # [2 5] # [3 6]] input_data = tf.constant([[[1, 2, 3], [4, 5, 6], [7, 8, 9], [10, 11, 12]]]) print('input_data shape: ', sess.run(tf.shape(input_data))) # [1, 4, 3] output_data = tf.transpose(input_data, perm=[1, 2, 0]) print('output_data shape: ', sess.run(tf.shape(output_data))) # [4, 3, 1] print(sess.run(output_data)) # [[[ 1] # [ 2] # [ 3]] # [[ 4] # [ 5] # [ 6]] # # [[ 7] # [ 8] # [ 9]] # # [[10] # [11] # [12]]] """形式为:[[[],[],[]],[[],[],[]],[[],[],[]],[[],[],[]]]""" """输入参数: ● a: 一个Tensor。 ● perm: 一个对于a的维度的重排列组合。 ● name:(可选)为这个操做取一个名字。 输出参数: ● 一个通过翻转的Tensor。"""
input_data = tf.constant([[[1, 2, 3], [4, 5, 6], [7, 8, 9], [10, 11, 12]]]) print('input_data shape: ', sess.run(tf.shape(input_data))) # [1, 4, 3] output_data = tf.transpose(input_data) print('output_data shape: ', sess.run(tf.shape(output_data))) # output_data shape: [3 4 1] sess.close()