我正在编写一个多线程人脸识别程序,使用Keras作为高级模型,并将tensorflow作为后端。代码就是打击:
class FaceRecognizerTrainThread(QThread):
def run(self):
print("[INFO] Loading images...")
images, org_labels, face_classes = FaceRecognizer.load_train_file(self.train_file)
print("[INFO] Compiling Model...")
opt = SGD(lr=0.01)
face_recognizer = LeNet.build(width=Const.FACE_SIZE[0], height=Const.FACE_SIZE[1], depth=Const.FACE_IMAGE_DEPTH,
classes=face_classes, weightsPath=None)
face_recognizer.compile(loss="categorical_crossentropy", optimizer=opt, metrics=["accuracy"])
images = np.array(images)[:, np.newaxis, :, :] / 255.0
labels = np_utils.to_categorical(org_labels, face_classes)
print("[INFO] Training model...")
try:
face_recognizer.fit(images, labels, epochs=50, verbose=2, batch_size=10)
except Exception as e:
print(e)
print("[INFO] Training model done...")
save_name = "data/CNN_" + time.strftime("%Y%m%d%H%M%S", time.localtime()) + ".hdf5"
if save_name:
face_recognizer.save(save_name)
self.signal_train_end.emit(save_name)
在普通模式下运行时,每件事情都可以,但是当我在QThread中运行它时它会进入
face_recognizer.fit(images, labels, epochs=50, verbose=2, batch_size=10)
它给了我错误:
Cannot interpret feed_dict key as Tensor: Tensor Tensor("conv2d_1_input:0", shape=(?, 1, 30, 30), dtype=float32) is not an element of this graph.
我该如何解决?欢迎任何建议,非常感谢~~~~
答案 0 :(得分:0)
TensorFlow允许您定义tf.Graph()
,然后您可以使用图形创建tf.Session()
,然后运行图中定义的操作。当您以这种方式执行此操作时,每个QThread都会尝试创建自己的TF Graph。这就是为什么你得到not an element of this graph
的错误。我没有看到你的feed_dict
代码,所以我认为它可能是在你的其他线程看不到的主线程中运行的。在每个帖子中加入feed_dict
可能会使其有效,但如果不查看完整代码就很难得出结论。
Replicating models in Keras and Tensorflow for a multi-threaded setting可能会对您有所帮助。
要解决您的问题,您应该使用与this post类似的内容。从该帖子转载的代码:
# Thread body: loop until the coordinator indicates a stop was requested.
# If some condition becomes true, ask the coordinator to stop.
def MyLoop(coord):
while not coord.should_stop():
...do something...
if ...some condition...:
coord.request_stop()
# Main thread: create a coordinator.
coord = tf.train.Coordinator()
# Create 10 threads that run 'MyLoop()'
threads = [threading.Thread(target=MyLoop, args=(coord,)) for i in xrange(10)]
# Start the threads and wait for all of them to stop.
for t in threads:
t.start()
coord.join(threads)
关于inter_op
和intra_op
并行here也值得一读。