####
'''
tf.train.slice_input_producer :定义样本放入文件名队列的方式[迭代次数,是否乱序],但此时文件名队列还没有真正写入数据
slice_input_producer(tensor_list, num_epochs=None, shuffle=True, seed=None,capacity=32, shared_name=None, name=None)
tensor_list:如[images,labels] = [['img1','image2','imag3','img4','img5','img6'],[1,2,3,4,5,6]]
num_epochs:可选参数,迭代次数 num_epochs=None 无限次遍历tensor列表 num_epochs=N 生成器只能遍历列表N次
shuffle:shuffle=True 乱序样本 shuffle=False需要在批处理时使用tf.train.shuffle_batch函数打乱样本
seed:随机数种子 在shuffle=True 时使用
capacity:设置tensor列表的容量
shared_name:可选参数,如果设置一个‘shared_name’,则在不同的上下文环境(Session)中可以通过这个名字共享生成的tensor
name:设置操作名称 '''
import tensorflow as tf ###思路:准备入文件名队列 创建线程 入队线程
images = ['img1','image2','imag3','img4','img5','img6']
labels = [1,2,3,4,5,6] epoch_num = 8
queue = tf.train.slice_input_producer([images,labels],num_epochs=None,shuffle=False) #从文件里抽取tensor,准备放入文件名队列
with tf.Session() as sess:
sess.run(tf.global_variables_initializer())
coord = tf.train.Coordinator() ###创建一个线程协调器,用来管理之后再Session中启动的所有线程
###启动入队线程,由多个或单个线程,按照设定规则把文件读入到文件名队列中,返回线程ID的列表。一般情况下,系统有多少核,就会启动多少个入队线程
###入队具体使用多少个线程在tf.train.batch中设定
threads = tf.train.start_queue_runners(sess,coord=coord)
for i in range(epoch_num):
k = sess.run(queue)
print("*************")
print(i,k,k[0],k[1]) '''
*************
0 [b'img1', 1] b'img1' 1
*************
1 [b'image2', 2] b'image2' 2
*************
2 [b'imag3', 3] b'imag3' 3
*************
3 [b'img4', 4] b'img4' 4
*************
4 [b'img5', 5] b'img5' 5
*************
5 [b'img6', 6] b'img6' 6
*************
6 [b'img1', 1] b'img1' 1
*************
7 [b'image2', 2] b'image2' 2
'''

准备 -- 创建线程 -- 入队线程

import tensorflow as tf

###思路:准备入文件名队列    创建线程    入队线程  异常处理
images = ['img1','image2','imag3','img4','img5','img6']
labels = [1,2,3,4,5,6] epoch_num = 8
queue = tf.train.slice_input_producer([images,labels],num_epochs=None,shuffle=False) #从文件里抽取tensor,准备放入文件名队列
with tf.Session() as sess:
sess.run(tf.global_variables_initializer())
coord = tf.train.Coordinator() ###创建一个线程协调器,用来管理之后再Session中启动的所有线程
###启动入队线程,由多个或单个线程,按照设定规则把文件读入到文件名队列中,返回线程ID的列表。一般情况下,系统有多少核,就会启动多少个入队线程
###入队具体使用多少个线程在tf.train.batch中设定
threads = tf.train.start_queue_runners(sess,coord=coord)
try:
for i in range(epoch_num):
if coord.should_stop(): ###查询是否应该终止所有线程,当文件队列(queue)中的所有文件都已经读取出列的时候,
# 会抛出一个 OutofRangeError 的异常,这时候就应该停止Sesson中的所有线程了;
break
k = sess.run(queue)
print("*************")
print(i,k,k[0],k[1])
except tf.errors.OutOfRangeError: ###如果读取文件到文件队列末尾会抛出此异常
print('完成!!现在终止所有线程')
finally:
##协调器coord发出所有线程终止信号,使用coord.join(threads)把线程加入主线程,等待threads结束
coord.request_stop()
print('所有线程请求终止')
coord.join(threads) ###把开启的线程加入主线程,等待threads结束
print('所有线程终止')

最新文章

  1. ASP.NET MVC和EF集成AngularJS开发
  2. Python学习笔记09
  3. POJ 2774 Long Long Message (后缀数组模板)
  4. MVC-04 视图(2)
  5. 快学Scala-第三章 数组相关操作
  6. Git 上传 GitHub
  7. SOFA 源码分析 — 自定义线程池原理
  8. 记录Nginx代理的配置
  9. vue内置的标签(组件)
  10. 《我们不一样》Alpha冲刺_1-5
  11. LeetCode Weekly Contest 117
  12. 为虚机Linux系统设置静态IP,ping通外网并解决相关问题
  13. APP界面设计 大概总结
  14. learning gcc args
  15. 微信小程序的页面渲染(if/for)
  16. POI搜索简介
  17. 如何给Windows Server 2012 R2 添加“磁盘清理”选项
  18. EasyUI 中GridView 满足某条件 改变行的背景色
  19. CentOS 7关闭图形桌面开启文本界面
  20. 网络基础知识 tcp

热门文章

  1. #python# 代理过程中遇到的error
  2. cocos2d-x 3.0正式版创建project笔记
  3. 图解git中的最常用命令
  4. 20191114PHP验证码
  5. linux篇—Nginx反向代理负载均衡
  6. Error- Overloaded method value createDirectStream in error Spark Streaming打包报错
  7. 牛客小白月赛16 D 小阳买水果 (思维题)
  8. 第四章 走进jVM
  9. Zen Coding – 超快地写网页代码(注:已更名为Emmet)
  10. Linux的运行级别和设置开机启动服务的方式