- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我尝试在线程应用程序中使用 keras 和可用模型 VGG16 执行预测。但是,如果我在主线程中调用预测,一切正常。但是,如果我在线程函数内部进行预测(无论我使用 threading
、multiprocessing
、...
),它只会在预测期间停止:
这是最小的例子:
########################################
# Alter this variable
USE_THREADING = True
########################################
import numpy as np
import cv2
import copy
import threading
import keras
import platform
import tensorflow as tf
from keras.models import model_from_json
from multiprocessing import Process
def inference_handler(model_hash, frame_resized):
print("multiprocessing: before prediction call")
model_hash.predict(np.expand_dims(frame_resized, axis=0), batch_size = 1)
print("multiprocessing: after prediction call")
if __name__ == "__main__":
print("keras version:", keras.__version__)
print("tf vresion: ", tf.__version__)
print("python version:", platform.python_version())
model_hash = keras.applications.VGG16(weights='imagenet', include_top=False, input_shape=(224, 224, 3))
# Perform the demo
cap = cv2.VideoCapture(0)
while(True):
# Capture frame-by-frame
ret, frame = cap.read()
# Process the keys
key = cv2.waitKey(1) & 0xFF
if key == ord('q'):
print("quit")
break
# Get the proper image for the network
frame_resized = cv2.resize(frame, (224, 224))
# show the images
cv2.imshow('frame',frame)
cv2.imshow('frame_resized',frame_resized)
# Predict
if USE_THREADING:
p = Process(target=inference_handler, args=(model_hash, frame_resized,))
p.start()
p.join()
else:
print("main thread: before prediction call")
model_hash.predict(np.expand_dims(frame_resized, axis=0), batch_size = 1)
print("main thread: after prediction call")
# When everything done, release the capture
cap.release()
cv2.destroyAllWindows()
USE_THREADING = False 给我:
Using TensorFlow backend.
keras version: 2.2.0
tf vresion: 1.8.0
python version: 3.5.2
2019-02-25 20:47:32.926696: I tensorflow/core/platform/cpu_feature_guard.cc:140] Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 FMA
main thread: before prediction call
main thread: after prediction call
main thread: before prediction call
main thread: after prediction call
main thread: before prediction call
...
USE_THREADING = True(失败)给我:
Using TensorFlow backend.
keras version: 2.2.0
tf vresion: 1.8.0
python version: 3.5.2
2019-02-25 20:50:34.922696: I tensorflow/core/platform/cpu_feature_guard.cc:140] Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 FMA
multiprocessing: before prediction call
最佳答案
因此,如果将模型作为子流程的参数给出,那么具有 tensorflow 后端的 Keras 不幸地存在预测期间停止的问题。但是,如果直接在子流程中创建模型,则一切正常。因此,解决方案是将帧通过队列发送到子进程。这是一个可行的解决方案:
import numpy as np
import cv2
import copy
import keras
import platform
import tensorflow as tf
from keras.models import model_from_json
from multiprocessing import Process, Queue
def inference_handler(frame_queue):
model_hash = keras.applications.VGG16(weights='imagenet', include_top=False, input_shape=(224, 224, 3))
model_hash._make_predict_function()
while True:
print("multiprocessing: before queue")
frame_resized = frame_queue.get(block=True, timeout=None)
print("multiprocessing: before prediction call")
model_hash.predict(np.expand_dims(frame_resized, axis=0), batch_size = 1)
print("multiprocessing: after prediction call")
if __name__ == "__main__":
print("keras version:", keras.__version__)
print("tf version: ", tf.__version__)
print("python version:", platform.python_version())
frame_queue = Queue(maxsize=1)
p = Process(target=inference_handler, args=(frame_queue,))
p.start()
# p.join()
cap = cv2.VideoCapture(0)
while(True):
# Capture frame-by-frame
ret, frame = cap.read()
# Process the keys
key = cv2.waitKey(1) & 0xFF
if key == ord('q'):
print("quit")
break
# Get the proper image for the network
frame_resized = cv2.resize(frame, (224, 224))
# show the images
cv2.imshow('frame',frame)
cv2.imshow('frame_resized',frame_resized)
# Advertise the frame
if frame_queue.empty():
print("Put frame into the queue")
frame_queue.put_nowait(frame_resized)
# When everything done, release the capture
p.terminate()
cap.release()
cv2.destroyAllWindows()
这给了我
keras version: 2.2.0
tf version: 1.8.0
python version: 3.5.2
Put frame into the queue
multiprocessing: before queue
multiprocessing: before prediction call
Put frame into the queue
multiprocessing: after prediction call
multiprocessing: before queue
multiprocessing: before prediction call
Put frame into the queue
...
关于python - Keras 模型无法预测是否在线程中调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54873681/
我有一个 PowerBI Online 数据集,它是在 PowerBI 桌面中创建然后在线发布的。到目前为止,一切都很好。 我通过 PowerBI pusblish 从 Excel 连接到数据集,按预
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 2 年前。
我必须对一些太大而无法放入内存的数据训练分类模型,我正在使用 scikit learn 和 pandas 来进行分析。所以这是我的问题,如何在在线学习管道中使用验证来调整超参数? 我使用带有chuck
我正在开发一个应用程序,该应用程序将从 webservice 获取数据和图像并将其存储在设备中以供离线使用。同时,应用程序会将一些数据存储在 sqlite db 中,并将一些图像作为默认数据。 这是应
是否可以使用 FileReader API 和 onprogress 事件访问随 HTML5 传入的数据? 如果是这样,是否有 MD5 或其他快速散列算法的“在线”版本,以便我可以在文件完全读取之前开
希望任何人都可以帮助我更改下面的代码,我的临时文件包含以下代码: Temp=8.4* Humidity=70.4% 代替代码 Temp = 24 *C, Hum = 40 % 适用于以下脚本。 我需
我必须创建一个功能类似于联系人应用程序的应用程序。您可以在客户的 iPhone 上添加一个联系人,它应该会上传到客户的 iPad 上。如果客户在他们的 iPad 上更新联系人,它应该会在他们的 iPh
在 gitlab.com 上审查 merge 请求时,有时我必须在完成 merge 之前进行 rebase。 在 gitlab 上按“Rebase”后,我有一个特定的管道步骤失败,因为它无法验证用户的
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
我正在尝试在 azure 上托管 SQL 服务器以与节点应用程序进行通信。我已经成功地完成了创建数据库服务器和数据库本身的过程。现在,我想编辑我的数据库结构。据我发现online ,应该有一种方法可以
我在 Quickbooks Intuit 开发人员 API 中使用 Oauth 2 获得了访问 token 。 范围是 com.intuit.quickbooks.accounting 我能够使用 Q
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
是否可以使Angular Material progress spinner与文本并大致与字符的大小一致地显示? 我想要类似的东西: please wait 微调器仅与“请稍候”文本成行出现。 这可
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我有一个每天运行的Powershell脚本。今天它失败了,因为我正在使用的域 Controller 不可用。在继续执行脚本的其余部分之前,我想确保可以连接到可用的DC。 $LdapServer = "
我想制作一款在线 Flash 游戏,它将具有社交功能,但游戏玩法将主要是单人游戏。例如,屏幕上不会同时出现两个玩家,社交互动将通过异步消息进行,不会有实时聊天或其他任何内容。大部分逻辑将发生在客户端中
这几天我开始在线玩OpenShift。我部署了一个非常简单的“Hello World”Java 示例(1 行代码!),没有任何依赖项(没有 Spring!)命令行是这样的: oc.exe new-a
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
所以我一直在网上学习Java(初学者),并且我一直在尝试制作一个用于制作矩形的类文件。但是,我的在线 java 评估器指出它找不到实例变量。 This is the comment on it.我的代
我是一名优秀的程序员,十分优秀!