Tensorflow-datasets-数据集

tf.data包含了对数据进行读取、操作、输入模型的各种方法。


理解流程

鸢尾花案例中的train_input_fn喂食函数中,使用了tf.data对数据进行处理:

#针对训练的喂食函数
def train_input_fn(features, labels, batch_size):
    dataset = tf.data.Dataset.from_tensor_slices((dict(features), labels))
    dataset = dataset.shuffle(1000).repeat().batch(batch_size) #每次随机调整数据顺序
    return dataset

这个train_input_fn输入函数后面被train使用:

#开始训练模型!
batch_size=100
classifier.train(input_fn=lambda:train_input_fn(train_x, train_y,batch_size),
                 steps=1000)

由此可见,train_input_fn可以把特征数据features(train_x)和标签数据labels(train_y)联合成一个dataset,以供分类器的训练函数train使用。

我们print(train_x):

     SepalLength  SepalWidth  PetalLength  PetalWidth
0            6.4         2.8          5.6         2.2
1            5.0         2.3          3.3         1.0
2            4.9         2.5          4.5         1.7
...

print(train_y),左侧是序号,右侧是花的类型0、1、2

0      2
1      1
2      2
...

下面分别介绍train_input_fn的三个参数


特征数据Features

  • features:包含单个列表字段的字典dict,格式如{'feature_name':[]};或者pandas.DataFrame对象。

pandas.DataFrame(data,index,columns,dtype,copy)语法
data:dict,numpy ndarray或DataFrame
index,columns:Index或类似数组
dtype:数值类型,默认None会进行自动推断
copy:布尔值,是否从输入拷贝

#测试DataFrame
import pandas as pd
import numpy as np
d = {'col1': [1, 2], 'col2': [3, 4]}
df = pd.DataFrame(data=d, dtype=np.int8)
d2=np.random.randint(low=0, high=10, size=(5, 5))
df2 = pd.DataFrame(d2,columns=['a', 'b', 'c', 'd', 'e'])

print(df,'\n',d2,'\n',df2)

输出可以看到DataFrame的基本样式:

#df
     col1  col2
0     1     3
1     2     4 

#d2
 [[2 4 6 4 2]
 [9 4 5 0 3]
 [1 5 1 4 5]
 [9 3 8 0 1]
 [1 3 0 5 0]] 

#df2
   a  b  c  d  e
0  2  4  6  4  2
1  9  4  5  0  3
2  1  5  1  4  5
3  9  3  8  0  1
4  1  3  0  5  0

实际上鸢尾花案例中的train_x就是pandas.read_csv生成的DataFrame对象

#载入训练数据
train = pd.read_csv(train_path, names=FUTURES, header=0)
train_x, train_y = train, train.pop('Species')

标签数据Labels

标签数据应该是一个数组,依照特征数据的顺序为每个样本example做了标记。在鸢尾花案例中就是用0、1、2标记了每朵鸢尾花的类型。


批次尺寸Batch_size

批次尺寸必须是一个整数,对模型训练中的梯度下降运算效率有影响。建议不要超过样本数量,32,64,128...


切片Slices

在鸢尾花案例中使用了tf.data.Dataset.from_tensor_slices方法,它得到一个tf.data.Dataset对象:

def train_input_fn(features, labels, batch_size):
    dataset = tf.data.Dataset.from_tensor_slices((dict(features), labels))
    print(dataset)
    ...

打印出来得到一个TensorSliceDataset对象,里面包含了特征列名称和数值类型:

<TensorSliceDataset
    shapes: (
        {
          SepalLength: (), PetalWidth: (),
          PetalLength: (), SepalWidth: ()},
        ()),
    types: (
        {
          SepalLength: tf.float64, PetalWidth: tf.float64,
          PetalLength: tf.float64, SepalWidth: tf.float64},
        tf.int64)>

如果我们有个数据的形状shape是(100,28,28),那么就可以把它切成100百个切片,每个切片是28x28的矩阵。


操作数据

Dataset将按照固定顺序进行迭代,每次生成一个元素。
然后我们用下面的方法对数据进行了处理:

    dataset = dataset.shuffle(1000).repeat().batch(batch_size) 

shuffle,随机扰乱数据,1000表示使用的缓存数量,必须比样本数量大才有意义。
repeat,重复,达到数据尾端然后再返回,如果要限定周期数量,可以添加count参数。
batch,批次,将样本进行堆叠,比如把100个(28,28)的二维数据可以堆叠成(100,28,28)的三维数据。
如下,batch之后print(dataset),输出中出现了问号,这是由于反复分批次堆叠处理之后,最后一批的数量并不确定和之前每批次一样多。

<TensorSliceDataset
    shapes: (
        {
          SepalLength: (?,), PetalWidth: (?,),
          PetalLength: (?,), SepalWidth: (?,)},
        (?,)),

    types: (
        {
          SepalLength: tf.float64, PetalWidth: tf.float64,
          PetalLength: tf.float64, SepalWidth: tf.float64},
        tf.int64)>

张量Tensor

张量是TensorFlow 程序中的主要数据结构。张量是 N 维(其中 N 可能非常大)数据结构,最常见的是标量、向量或矩阵。张量的元素可以包含整数值、浮点值或字符串值。

Tensor包含两个属性:

  • 数据类型(例如float32, int32, or string等)
  • 数据形状(定义数据的维数,特征数据中得到或运算时得到)

Tensor内的每个数据元素都具有相同的确定类型。
Tensor的维度又叫做等级rank:

Rank Math entity
0 标量Scalar (只有大小之分)
1 向量Vector (有大小和方向的区别)
2 矩阵Matrix (数字组成的表)
3 3-Tensor (数字立方体)
n n-Tensor (...)

#rank0
mammal = tf.Variable("Elephant", tf.string)
ignition = tf.Variable(451, tf.int16)
floating = tf.Variable(3.14159265359, tf.float64)
its_complicated = tf.Variable(12.3 - 4.85j, tf.complex64)

#rank 1
mystr = tf.Variable(["Hello"], tf.string)
cool_numbers  = tf.Variable([3.14159, 2.71828], tf.float32)
first_primes = tf.Variable([2, 3, 5, 7, 11], tf.int32)
its_very_complicated = tf.Variable([12.3 - 4.85j, 7.5 - 6.23j], tf.complex64)

#更高rank
mymat = tf.Variable([[7],[11]], tf.int16)
myxor = tf.Variable([[False, True],[True, False]], tf.bool)
linear_squares = tf.Variable([[4], [9], [16], [25]], tf.int32)
squarish_squares = tf.Variable([ [4, 9], [16, 25] ], tf.int32)
mymatC = tf.Variable([[7],[11]], tf.int32)

表示多张图片数据的rank4张量(数量X宽X高X颜色)

my_image = tf.zeros([10, 299, 299, 3])  # batch x height x width x color

可以用[n,m]方法获得张量的特定切片

my_scalar = my_vector[2]
my_scalar = my_matrix[1, 2] #得到的是rank0标量
my_row_vector = my_matrix[2] #得到的是rank1向量
my_column_vector = my_matrix[:, 3] #得到一整列向量

张量的形状shape是指张量每个元素的维数。


张量的形状、层级、维度

探索人工智能的新边界

如果您发现文章错误,请不吝留言指正;
如果您觉得有用,请点喜欢;
如果您觉得很有用,感谢转发~


END

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容