- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我已将数据保存到 tfrecord 文件中。它有 1000 个样本和 2 个特征(一个是输入,另一个是输出)。输入是形状 [1,20] 和输出 [1,10]。它们都是由扁平化的 numpy 数组创建的。我正在尝试从中创建批处理,以便我可以使用它们来训练我的网络,但我无法弄清楚如何进行。
这是我用于训练网络的代码
learning_rate = 0.01
epochs = 2
batch_size = 200 #total 5 batches
dataSize = 1000
dataset = rd.getData()
x = tf.placeholder(shape=(None,20), dtype=tf.float32)
y = tf.placeholder(shape=(None,10), dtype=tf.float32)
w1 = tf.Variable(tf.random_normal([20, 20], stddev=0.03))
w2 = tf.Variable(tf.random_normal([20, 20], stddev=0.03))
w3 = tf.Variable(tf.random_normal([20, 20], stddev=0.03))
w4 = tf.Variable(tf.random_normal([20, 20], stddev=0.03))
w5 = tf.Variable(tf.random_normal([20, 10], stddev=0.03))
b1 = tf.Variable(tf.random_normal([20]))
b2 = tf.Variable(tf.random_normal([20]))
b3 = tf.Variable(tf.random_normal([20]))
b4 = tf.Variable(tf.random_normal([20]))
b5 = tf.Variable(tf.random_normal([10]))
out1 = tf.add(tf.matmul(x, w1), b1)
out1 = tf.tanh(out1)
out2 = tf.add(tf.matmul(out1, w2), b2)
out2 = tf.tanh(out2)
out3 = tf.add(tf.matmul(out2, w3), b3)
out3 = tf.tanh(out3)
out4 = tf.add(tf.matmul(out3, w4), b4)
out4 = tf.tanh(out4)
out5 = tf.add(tf.matmul(out4, w5), b5)
finalOut = tf.tanh(out5)
cost = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(labels=y, logits=finalOut))
optimiser = tf.train.RMSPropOptimizer(learning_rate=learning_rate).minimize(cost)
# finally setup the initialisation operator
init_op = tf.global_variables_initializer()
with tf.Session() as sess:
# initialise the variables
sess.run(init_op)
total_batch = int(dataSize / batch_size)
for epoch in range(epochs):
iterator = dataset.make_one_shot_iterator()
avg_cost = 0
for i in range(total_batch):
#create batch
batch_y = []
batch_x = []
for counter in range(0,batch_size):
uv, z = iterator.get_next()
batch_x.append(uv)
batch_y.append(z)
_, c = sess.run([optimiser, cost],
feed_dict={x: batch_x, y: batch_y})
avg_cost += c / total_batch
print("Epoch:", (epoch + 1), "cost =", "{:.3f}".format(avg_cost))
这是我从中获取数据的文件。
def decode(serialized_example):
features = tf.parse_single_example(
serialized_example,
features={'uv': tf.FixedLenFeature([1,20], tf.float32),
'z': tf.FixedLenFeature([1,10], tf.float32)})
return features['uv'], features['z']
def getData():
filename = ["train.tfrecords"]
dataset = tf.data.TFRecordDataset(filename).map(decode)
return dataset
错误:
Traceback (most recent call last):
File "network.py", line 102, in <module>
feed_dict={x: batch_x, y: batch_y})
File "C:\Users\User\AppData\Local\Programs\Python\Python36\lib\site-packages\tensorflow\python\client\session.py", line 889, in run
run_metadata_ptr)
File "C:\Users\User\AppData\Local\Programs\Python\Python36\lib\site-packages\tensorflow\python\client\session.py", line 1089, in _run
np_val = np.asarray(subfeed_val, dtype=subfeed_dtype)
File "C:\Users\User\AppData\Roaming\Python\Python36\site-packages\numpy\core\numeric.py", line 531, in asarray
return array(a, dtype, copy=False, order=order)
ValueError: setting an array element with a sequence.
在查看其他问题后,我在想也许我的批处理应该是 ndarray 或其他什么?但我无法弄清楚如何将我的数据集转换成这种形式。我什至无法弄清楚如何在没有迭代器的情况下使用我的数据。任何指导都会很棒!谢谢
最佳答案
请尝试关注,看看是否有帮助。
tf.parse_single_example
不接收批量维度。因此,
features = tf.parse_single_example(
serialized_example,
features={'uv': tf.FixedLenFeature([20], tf.float32),
'z': tf.FixedLenFeature([10], tf.float32)})
来自 Simple Batching section of TensorFlow Guide on Dataset API ,您会发现 print(sess.run(next_element))
运行了 3 次,但 next_element
仅声明了一次。同样,在您的代码中,无需在 for 循环下运行 dataset.make_one_shot_iterator()
和 iterator.get_next()
。数据集声明可以放在最开头或 getData()
内部,以便于理解。
可以使用以下方式形成数据批处理:
# read file
dataset = tf.data.TFRecordDataset(filename)
# parse each instance
dataset = dataset.map(your_parser_fun, num_parallel_calls=num_threads)
# preprocessing, e.g. scale to range [0, 1]
dataset = dataset.map(some_preprocessing_fun)
# shuffle
dataset = dataset.shuffle(buffer_size)
# form batch and epoch
dataset = dataset.batch(batch_size)
dataset = dataset.repeat(num_epoch)
iterator = dataset.make_one_shot_iterator()
# get a batch
x_batch, y_batch = self.iterator.get_next()
# do calculations
...
检查Processing multiple epochs section查看使用 for 循环设置纪元的示例。
关于python - 如何从 TFrecord 创建批处理用于 tensorflow 中的训练网络?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47949159/
有什么方法可以直接将 .tfrecords 文件拆分为多个 .tfrecords 文件,而无需写回每个数据集示例? 最佳答案 在 tensorflow 2.0.0 中,这将起作用: import te
我想从 AutoGraph 生成的图形内部将 tensorflow 示例记录写入 TFRecordWriter。 tensorflow 2.0 的文档说明如下: The simplest way to
我正在使用 tensorflow 对象检测 api 创建用于微调任务的数据集。 我的目录结构是: 火车/ -- 图片/ ---- img1.jpg -- 安/ ---- img1.csv 其中每个图像
保存到 TFRecord 时,我使用: def _int64_feature(value): return tf.train.Feature(int64_list=tf.train.Int64
我的理解是,最好对每个时期的训练样本进行洗牌,以便每个小批量包含整个数据集的一个很好的随机样本。如果我将整个数据集转换为包含 TFRecords 的单个文件,那么在加载整个数据集的情况下如何实现这种改
为什么在 TensorFlow 的初始模型示例中对 TFRecords 文件进行分片? 为了随机性,不能在创建一个 TFRecord 文件之前打乱文件列表吗? 最佳答案 为什么 TFRecords 文
根据您的经验,在各种设备(硬盘、SSD、NVME)和存储位置(本地计算机、具有网络安装的 HPC 集群)上运行效果最好的 .tfrecord 文件的理想大小是多少? 如果我在云中技术更强大的计算机上获
为什么在 TensorFlow 的初始模型示例中对 TFRecords 文件进行分片? 为了随机性,不能在创建一个 TFRecord 文件之前打乱文件列表吗? 最佳答案 为什么 TFRecords 文
我有一个包含大约 4000 万行的 CSV。每行都是一个训练实例。根据 the documentation on consuming TFRecords我正在尝试对数据进行编码并将其保存在 TFRec
我在另一个论坛上被问到这个问题,但我想我会把它发布在这里,以供遇到 TFRecords 问题的任何人使用。 如果 TFRecord 文件中的标签与 labels.pbtxt 文件中的标签不对齐,Ten
我正在处理相当大的时间序列数据集,然后将准备为 SequenceExample 的数据写入 TFRecord 。这会产生一个相当大的文件(超过 100GB),但我想将它存储在块中。我试过了: file
关于 Carvana Image Masking Challenge 给出的数据格式,我们如何将其转换为tfrecord可以输入到 Deeplab V3 中的格式型号,可支持VOC和 Cityscap
我得到了一个 TFRecord 数据文件 filename = train-00000-of-00001,其中包含未知大小的图像,可能还包含其他信息。我知道我可以使用 dataset = tf.dat
TensorFlow 对象检测 API 更喜欢 TFRecord 文件格式。 MXNet 和 Amazon Sagemaker 似乎使用 RecordIO 格式。这两种二进制文件格式有何不同,或者它们
我有 5 个 tfrecords 文件,每个对象一个。在训练时,我想从所有 5 个 tfrecord 中平均读取数据,即如果我的批量大小为 50,我应该从第一个 tfrecord 文件中获取 10 个
我想用 TensorFlow 执行多标签分类。 我有大约 95000 张图像,每张图像都有一个相应的标签向量。每个图像有 7 个标签。这 7 个标签表示为一个大小为 7 的张量。每个图像的形状为 (2
在 TensorFlow 教程示例中,TFRecords 的用法与 MNIST 数据集一起提供。 MNIST 数据集被转换为 TFRecords 文件,如下所示: def convert_to(dat
我想将整数列表(或任何多维 numpy 矩阵)写入一个 TFRecords 示例。对于单个值或多个值的列表,我可以创建 TFRecord 文件而不会出错。我还知道如何从 TFRecord 文件中读取单
尝试编写 w/和 w/o 多线程的 tfrecord,发现速度差异不大(w/4 线程:434 秒;w/o 多线程 590 秒)。不确定我是否正确使用它。有没有更好的方法来更快地编写 tfrecord?
我的目标是在本地运行Tensorflow Training App时使用存储在Google Cloud存储中的培训数据(格式:tfrecords)。 (为什么要在本地?:在将其转换为Cloud ML培
我是一名优秀的程序员,十分优秀!