亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

python - tensorflow中TFRecord是怎么用的?

瀏覽:82日期:2022-07-23 15:52:38

問題描述

怎么把下面的代碼中的mnist數據集換成TFRecord

假設TFRecord數據集已經準備好,train.tfrecords 和 test.tfrecords 都在當前py的目錄下

已經有TFRecord的讀取代碼。

def read_and_decode(filename): filename_queue = tf.train.string_input_producer([filename]) reader = tf.TFRecordReader() _, serialized_example = reader.read(filename_queue) features = tf.parse_single_example(serialized_example, features={ ’label’: tf.FixedLenFeature([], tf.int64), ’img_raw’: tf.FixedLenFeature([], tf.string), }) img = tf.decode_raw(features[’img_raw’], tf.uint8) img = tf.reshape(img, [512, 288, 3]) img = tf.cast(img, tf.float32) * (1. / 255) - 0.5 label = tf.cast(features[’label’], tf.int32) return img, label

from tensorflow.examples.tutorials.mnist import input_dataimport tensorflow as tfmnist = input_data.read_data_sets('/tmp/tensorflow/mnist/input_data', one_hot=True)# Parameterslearning_rate = 0.001training_iters = 200000batch_size = 64display_step = 20# Network Parametersn_input = 784 # MNIST data input (img shape: 28*28)n_classes = 10 # MNIST total classes (0-9 digits)dropout = 0.75 # Dropout, probability to keep units# tf Graph inputx = tf.placeholder(tf.float32, [None, n_input])y = tf.placeholder(tf.float32, [None, n_classes])keep_prob = tf.placeholder(tf.float32) # dropout (keep probability)def init_weights(shape): return tf.Variable(tf.random_normal(shape, stddev=0.01))# Create custom modeldef conv2d(name, l_input, w, b): return tf.nn.relu(tf.nn.bias_add(tf.nn.conv2d(l_input, w, strides=[1, 1, 1, 1], padding=’SAME’), b), name=name)def max_pool(name, l_input, k): return tf.nn.max_pool(l_input, ksize=[1, k, k, 1], strides=[1, k, k, 1], padding=’SAME’, name=name)def norm(name, l_input, lsize=4): return tf.nn.lrn(l_input, lsize, bias=1.0, alpha=0.001 / 9.0, beta=0.75, name=name)def dnn(_x, _weights, _biases, _dropout): _x = tf.nn.dropout(_x, _dropout) d1 = tf.nn.relu(tf.nn.bias_add(tf.matmul(_x, _weights[’wd1’]), _biases[’bd1’]), name='d1') d2x = tf.nn.dropout(d1, _dropout) d2 = tf.nn.relu(tf.nn.bias_add(tf.matmul(d2x, _weights[’wd2’]), _biases[’bd2’]), name='d2') dout = tf.nn.dropout(d2, _dropout) out = tf.matmul(dout, _weights[’out’]) + _biases[’out’] return out# Store layers weight & biasweights = { ’wd1’: tf.Variable(tf.random_normal([784, 600], stddev=0.01)), ’wd2’: tf.Variable(tf.random_normal([600, 480], stddev=0.01)), ’out’: tf.Variable(tf.random_normal([480, 10]))}biases = { ’bd1’: tf.Variable(tf.random_normal([600])), ’bd2’: tf.Variable(tf.random_normal([480])), ’out’: tf.Variable(tf.random_normal([10]))}# Construct modelpred = dnn(x, weights, biases, keep_prob)# Define loss and optimizercost = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(pred, y))optimizer = tf.train.AdamOptimizer(learning_rate=learning_rate).minimize(cost)# Evaluate modelcorrect_pred = tf.equal(tf.argmax(pred, 1), tf.argmax(y, 1))accuracy = tf.reduce_mean(tf.cast(correct_pred, tf.float32))# Initializing the variablesinit = tf.global_variables_initializer()#tf.summary.scalar('loss', cost)tf.summary.scalar('accuracy', accuracy)# Merge all summaries to a single operatormerged_summary_op = tf.summary.merge_all()# Launch the graphwith tf.Session() as sess: sess.run(init) summary_writer = tf.summary.FileWriter(’/tmp/logs/ex12_dnn’, graph=sess.graph) step = 1 # Keep training until reach max iterations while step * batch_size < training_iters:batch_xs, batch_ys = mnist.train.next_batch(batch_size)# Fit training using batch datasess.run(optimizer, feed_dict={x: batch_xs, y: batch_ys, keep_prob: dropout})if step % display_step == 0: # Calculate batch accuracy acc = sess.run(accuracy, feed_dict={x: batch_xs, y: batch_ys, keep_prob: 1.}) # Calculate batch loss loss = sess.run(cost, feed_dict={x: batch_xs, y: batch_ys, keep_prob: 1.}) print('Iter ' + str(step * batch_size) + ', Minibatch Loss= ' + '{:.6f}'.format(loss) + ', Training Accuracy= ' + '{:.5f}'.format(acc)) summary_str = sess.run(merged_summary_op, feed_dict={x: batch_xs, y: batch_ys, keep_prob: 1.}) summary_writer.add_summary(summary_str, step)step += 1 print('Optimization Finished!') # Calculate accuracy for 256 mnist test images print('Testing Accuracy:', sess.run(accuracy, feed_dict={x: mnist.test.images[:256], y: mnist.test.labels[:256], keep_prob: 1.})) # 98%

不知道具體怎么使用, 改了幾次執行都報錯

錯誤類似

ValueError: Only call `softmax_cross_entropy_with_logits` with named arguments (labels=..., logits=..., ...)

問題解答

回答1:

不知道是否理解你的意思,這段代碼mnist = input_data.read_data_sets('/tmp/tensorflow/mnist/input_data', one_hot=True)讀取的就是mnist數據,你把它換掉,然后在使用TFRecord的讀取代碼讀取TFRecord數據,將下面訓練網絡的代碼中的mnist也換掉,同時確保你使用的卷積操作參數要和TFRecord數據對應。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 成人国内精品久久久久影院 | 黄色国产一级片 | 日本一级大黄毛片一级 | 国产级a爱做片免费观看 | 小明看看台湾 | 亚洲永久精品免费www52zcm男男 | 黑粗硬大欧美 | 欧美一级毛片不卡免费观看 | 国产精品亚洲欧美云霸高清 | 久久99精品久久久久久综合 | 日本黄色片免费观看 | 国产私拍精品88福利视频 | 96免费精品视频在线观看 | 黄色片网站在线 | 日韩一区三区 | riav久久中文一区二区 | a毛片视频 | 午夜精品同性女女 | 免费看一级淫片成人 | 国产在线精彩视频二区 | 亚洲高清视频免费 | 特黄特色的大片观看免费视频 | 国产色婷婷免费视频 | 国语一区 | 欧美成人午夜精品一区二区 | 麻豆国产精品入口免费观看 | 国产区二区 | 一级女性全黄生活片免费看 | 欧美一级在线视频 | 日本黄色高清 | 色综合色综合色综合色综合 | 香港经典a毛片免费观看爽爽影院 | se视频在线观看 | 91麻豆国产在线观看 | 91国内精品| 免费一级淫片aa | 三及黄色片 | 国产片久久 | 国内自拍网红在综合图区 | 二级黄色大片 | 影音先锋5566中文源资源 |