OpenCV深度学习人脸检测断言错误函数“cv::dnn::ConvolutionLayerImpl::getMemoryShapes”

2024-09-28 21:47:37 发布

您现在位置:Python中文网/ 问答频道 /正文

我跟随tutorial使用OpenCV和深度学习SSD框架从image实现人脸检测。在

modelFile = "./ssd/res10_300x300_ssd_iter_140000.caffemodel"
configFile = "./ssd/deploy.prototxt"
net = cv2.dnn.readNetFromCaffe(configFile, modelFile)
image = cv2.imread("face.jpg")
(h, w) = image.shape[:2]
blob = cv2.dnn.blobFromImage(cv2.resize(image, (300, 300)), 1.0, (300, 300), (104.0, 177.0, 123.0))
net.setInput(blob)
detections = net.forward()

但是detections = net.forward()返回错误:

error: OpenCV(4.0.0) C:\projects\opencv-python\opencv\modules\dnn\src\layers\convolution_layer.cpp:236: error: (-215:Assertion failed) blobs.size() != 0 in function 'cv::dnn::ConvolutionLayerImpl::getMemoryShapes'

仍在寻找更多信息,但不知道是代码错误还是库中的错误。。。有人知道什么会引起问题吗?任何帮助都将不胜感激。在


Tags: imagenet错误errorcv2opencvblobtutorial
2条回答

我不能同时使用opencv3.4.2和opencv4.0.0来重现您的问题。在

我得到的是:

enter image description here

请注意,我从https://raw.githubusercontent.com/opencv/opencv_3rdparty/dnn_samples_face_detector_20170830/res10_300x300_ssd_iter_140000.caffemodel下载res10_300x300_ssd_iter_140000.caffemodel部署.prototxt来自https://github.com/opencv/opencv/raw/3.4.0/samples/dnn/face_detector/deploy.prototxt。在

我想我知道你的问题在哪里,请检查这两个文件”部署.prototxt在您的ssd文件夹下的“res10_300x300_ssd_iter_.caffemodel”。如果文件大小不为零,则可能会发生下载被阻止/中断(被防火墙阻止、连接失败等)与原始大小进行比较。如果大小为零,则根本没有下载。在

在这两种情况下, 请转到“https://github.com/opencv/opencv/blob/master/samples/dnn/face_detector/deploy.prototxt”github存储库

以及

https://github.com/opencv/opencv_3rdparty/raw/dnn_samples_face_detector_20170830/res10_300x300_ssd_iter_140000.caffemodel”下载同名的两个文件并替换它们。在

或者你可以使用以前使用过的同一个源。在

相关问题 更多 >