-
【功能模块】【操作步骤&问题现象】1、在代码中利用opencv创建视频采集对象,打开网络相机失败,但是在虚拟机上可以正常打开网络相机的rtsp流2、【截图信息】【日志信息】(可选,上传日志内容或者附件)
-
问题描述源码编译安装opencv时,在cmake里加了python相关的参数,可以同时编出供python使用的opencv,即import cv2 ,python的opencv依赖numpy。但在make的时候出现如下错误,fatal error:numpy/ndarrayobject.h :No such file or directory可能原因系统中存在多个版本的numpy,存在冲突,make时链接不到正确的numpy。解决方案root 用户下查找下ndarrayobject.h文件find / -name ndarrayobject.h找到后,修改报错的cpp文件,将报错的include 换成绝对路径即可。修改方式如下图,修改好后,重新make 即可。
-
【功能模块】我想在Atlas 500上运行Python程序,并安装opencv的模块,在Python里面使用opencv做一些图片的处理,请问有没有相关的教程?
-
如果使用opencv读取一张图片或者解码一段视频,将Mat里面的data作为ACL的输入buffer时,需要注意的是OpenCV对于RGB图像的数据排列方式为HWC,而使用caffe模型转换得到的om模型则是CHW的数据排列。此时可使用opencv里面的split函数将Mat分离成3张单通道图片,再将三段内存拼接作为ACL的输入buffer即可。-----广州鲲鹏+昇腾生态创新中心
-
我再python3环境编译opencv使用没问题,但是读取视频文件返回为False下面代码我再Ubuntu上面测试没有问题,但是再开发版上success直接返回False,请问是开发版不支持吗,视频文件经过检查不存在问题import cv2videoCapture = cv2.VideoCapture("video.mp4")success, frame = videoCapture.read()print("read status:",success)while success: # 循环直到没有帧了 cv2.imshow("result",frame) cv2.waitKey(1) success, frame = videoCapture.read()
-
人脸检测技术在我们生活中经常被用到,人脸面部识别、年龄以及表情的识别都是以人脸为基础。目前常用的人脸检测工具有:OpenCV Haar级联分类器、MTCNN方式、dlib方式等等,本文主要基于安装时长、检测时长、和检测准确度进行dlib、MTCNN、OpenCV检测工具对比。实验结果:从数据我们可以得出如下结论:从安装时长考虑:dlib工具安装时长最长,OpenCV工具由于环境自带没有可比性;从检测时长考虑:OpenCV工具明显优于dlib、MTCNN工具。从检测准确度考虑:MTCNN工具人脸全部检测出来,关键点检测齐全,准确度最高;dlib工具人脸全部检测出来关键点检测有部分遗漏,准确度次之;OpenCV工具人脸有遗漏。实验截图:一、dlib工具检测1、安装2、首次检测3、再次检测二、MTCNN工具检测1、安装2、首次检测3、再次检测三、OpenCV工具1、首次检测2、再次检测
-
1,前置条件yum install numpy opencv* python-devel gstreamer-plugins-base-devel libv4l-devel libpng-devel libjpeg-turbo-devel jasper-devel openexr-devel libtiff-devel libwebp-devel python-sphinx texlive python3-devel python3.aarch64 -y python3 -m pip install cython yum install blas-devel lapack-devel python3-devel pip3 install scipy //会自动安装依赖numpy,本次采用官方源,未使用镜像源加速,安装过程很漫长,因为会自动编译安装 2,安装cmake,参考下边链接http://ic-openlabs.huawei.com/openlab/#/knowledgebasequery?task_id=R1S1584D002187178201911251854493362566973,下载opencv和opencv_contrib,两者版本必须一致,3.2.0测试编译成功,高版本可能失败wget https://github.com/opencv/opencv/archive/3.2.0.zip wget https://github.com/opencv/opencv_contrib/archive/3.2.0.zip4,解压,编译unzip 3.2.0.zip unzip 3.2.0.zip.1 cd opencv mkdir -p build cd build cmake -D CMAKE_BUILD_TYPE=RELEASE -D CMAKE_INSTALL_PREFIX=/usr/local -D BUILD_opencv_python3=YES -D BUILD_opencv_python2=NO -D PYTHON3_NUMPY_INCLUDE_DIRS=/usr/local/lib64/python3.6/site-packages/numpy/core/include/ -D OPENCV_EXTRA_MODULES=../../opencv_contrib-3.2.0/modules/ -D PYTHON3_LIBRARIES=/lib64/libpython3.so -D PYTHON_DEFAULT_EXECUTABLE=/usr/bin/python3 -D __INSTALL_PATH_PYTHON3=/usr/local/lib/python3.6/site-packages/ ..5,安装make -j$(nproc) make install6,验证
-
前期和你们交流的时候,说是DVPP的RESIZE用了你们内部自研的NEAREST的方法。请问一下,如果预处理不一致导致精度有损失,是不是只能重新训练?你们的这个自研方法有没有相似的OPENCV函数?
-
我根据《aarch64架构linux服务器软件编译与部署指南》在交叉编译环境下安装好了opencv,那我如何将opencv嵌入到代码里呢,在编译的时候需要修改哪些地方呢?
-
请问根据《aarch64架构linux服务器软件编译与部署指南》安装好的opencv是C++调用的吗,有python能使用opencv吗
-
推理完成后,部署上线>在线服务 启动后 ```text ... File "/home/mind/model/1/core/utils.py", line 8, in import cv2 File "/home/modelarts/.local/lib/python3.7/site-packages/cv2/__init__.py", line 3, in from .cv2 import * ImportError: libSM.so.6: cannot open shared object file: No such file or directory ... ``` 我在推理时的依赖 ```json { "restraint": "ATLEAST", "package_version": "0.14.5", "package_name": "scikit-image" }, { "restraint": "ATLEAST", "package_version": "1.17.0", "package_name": "numpy" }, { "restraint": "ATLEAST", "package_version": "3.4.4.19", "package_name": "opencv-python" } ```
-
第一个问题:Atlas200 DK 如何交叉部署第三方软件库?如:opencv、ffmpeg、x264等?第二个问题:Atlas200 DK是不是也要分host侧和device侧?ddk中包换的opencv应该是device的吧,是不是应该交叉编译一个host侧的opencv等第三方软件库?第三个问题:可否将Atlas500上交叉编译后生成的opencv、ffmepg、x264等文件直接上传到Atlas200 DK相应位置,并修改环境变量后直接使用?第四个问题:可否按照Atlas500交叉编译第三方软件的方法,在Atlas200 DK上部署第三方程序?
-
import cv2 img_path='' img=cv2.imread(img_path)此时如果import matplotlib as plt plt.imshow(img)将会得到一个颜色和原图片不同的图片因为一个.jpg的图像,原本是R, G, B三通道,使用OpenCV的imread后会自动变为B,G,R也就是说经过opencv的imread,再通过plt的imshow后,将会显示下面的颜色而若使用cv2.imshow('img',img)仍输出原图因为 opencv的imshow(),imwrite(),imread()都会交换R(red),B(blue)通道通过img_rgb=img[:,:,::-1]切片第一个“:”切片遍历所有行第二个“:”切边遍历所有列第三个“:”遍历所有通道,并且因为最后一个参数(步长)为-1,逆序取值,r,g,b变为b,g,r如果对您有帮助,请动动小手,点个赞吧
-
华为云AI实战训练营第四章扩展作业华为云账号:hw54888057 今天尝试使用作业中给出的代码对OpenCv、MTCNN、dlib三种检测人脸的工具进行一个小的比较。我是一个刚刚入门的小白,如果有表达得不完善和错漏之处,请各位指出,感激不尽。 在这里我选择使用包含多张人脸的图片进行检测,先选了两张,如下: img4.jpg img1.jpeg 首先使用给的OpenCv代码段,分别对第一张图片和第二张图片进行人脸检测:#导入模型 path="/home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/cv2/data/haarcascade_frontalface_alt.xml" import cv2 face_cascade = cv2.CascadeClassifier(path) #修改为自己的图片文件名 #image_path = "./img1.jpeg" image_path = "./img4.jpg" img = cv2.imread(image_path) gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) faces = face_cascade.detectMultiScale(gray,1.3,5) for(x,y,w,h) in faces: cv2.rectangle(img,(x,y),(x+w,y+h),(0,255,0),2) img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB) from PIL import Image Image.fromarray(img) 结果是这样的,第一张图片一共有6张人脸,只检测出来4张,而第二张图片2张人脸,只检测出来1张: 可见检测结果并不是十分可靠,那么我在不改变参数的情况下,将两张图片所有人脸单独切割出来,分别进行检测: 从结果中可以看到,图一中的6张人脸能够检测出5张,而图二中的两张人脸能够全部检测出来,准确度提升了一些。在我并没有改变参数和对图片进行除了裁剪之外的额外处理下的情况下,检测的准确度会发生变化,但这并不符合我们日常的使用习惯,我尝试更改参数,进行第二轮实验。 在下面这一行代码中,一共有三个自定义参数,而定义如下图:faces = face_cascade.detectMultiScale(gray,1.3,5) 这里我选择更改scaleFactor这个参数,因为我认为图像的比例跟检测的结果有关,那么每次图像缩小的比例越小,检测的准确度应该会大一点。我先将其从1.3改成默认的1.1,即:scaleFactor=1.1faces = face_cascade.detectMultiScale(gray,1.1,5) 检测结果如下:看来调整之后的精度提高了一些,但是图一中还是有一张人脸没有检测出来,我再次将该参数调低到1.03,如下:faces = face_cascade.detectMultiScale(gray,1.03,5)scaleFactor=1.03结果如下:所有人脸都能检测出来了,而当我将该参数调低到1.01时,另外一种情况发生了:scaleFactor=1.01在图二中非人脸的区域,检测到了人脸。。。在scaleFactor参数为1.03,1.1,1.3时,我又对其它同时包含大脸和小脸的多人集体照进行识别,结果如下:scaleFactor=1.03,两张人脸未检出scaleFactor=1.1,两张人脸未检测出scaleFactor=1.3,五张人脸未检测出 关于OpenCv的测试我就先写到这里,可见,适当地调整某些参数能将人脸检测的准确度提高,但选择最合适的参数还需要在大量的数据集中进行验证。另外,在相同参数的情况下,在原图中不能够识别到人脸但裁剪图片能够识别的情况我还没有想明白,希望有大佬们可以解答我的疑惑。。。。 下面使用dlib进行人脸检测的相关测试: 还是使用以上的图片,代码如下:!pip install dlib==19.17.0import dlib cnn_face_detector=dlib.cnn_face_detection_model_v1("../FaceRecognition/models/detector.dat") image=dlib.load_rgb_image("./img4.jpg") dets=cnn_face_detector(image,1) print("number of faces datected: {}".format(len(dets))) for i,d in enumerate(dets): print("Detection{%s}: Left:{%s} Top:{%s } Right:{%s} Bottom:{%s} " % (i,format(d.rect.left()),format(d.rect.top()),format(d.rect.right()),format(d.rect.bottom()))) cv2.rectangle(image,(d.rect.left(),d.rect.top()),(d.rect.right(),d.rect.bottom()),(0,255,0),2) from PIL import Image Image.fromarray(image)结果如下图:哦天哪,在我费力地更改上面OpenCv代码参数情况下,使用dilb居然几乎将所有人脸都检测出来了。。只剩下最后一张只有不到半个脸露面的小男孩没有检测出来。但是我发现它检测出来的人脸貌似有点小,有些人脸并不能完全嵌进去,很多都只是框住了五官。使用MTCNN库进行人脸检测!pip install mtcnn==0.0.8from mtcnn.mtcnn import MTCNN detector = MTCNN() import cv2 img = cv2.cvtColor( cv2.imread("./img4.jpg"), cv2.COLOR_BGR2RGB) from PIL import Image Image.fromarray(img) results = detector.detect_faces(img) #print(results)for result in results: # print(result['box'][0]) cv2.rectangle(img,(result['box'][0],result['box'][1]),(result['box'][2]+result['box'][0],result['box'][3]+result['box'][1]),(0,255,0),2) from PIL import Image Image.fromarray(img) 对比OpenCv和dlib库,可以发现,使用MTCNN库进行人脸检测能够将这三张图中的所有人脸检测出来,不过也出现了检测到非人脸范围的情况。但是我认为在人脸范围内比上面使用dlib检测得更加贴近人的真实面部,并且能够检测出上面两种方法都检测不到的露出半张脸的小男孩。 总结一下:在以上的测试中,我认为dlib和MTCNN库的准确度比较好,MTCNN更是能识别出部分人脸,但会检测到非人脸的情况。而在人脸的标识中,我认为OpenCv和MTCNN表现得比较好,而dlib的矩形框有点小。 目前所有的测试就进行到这里,希望能够抛砖引玉,如有错漏请大家提出。。
-
Euler.cmake在opt目录下使用cmake -DCMAKE_TOOLCHAIN_FILE=/opt/Euler.cmake .这条命令时出现以下错误:然后我试了编译opencv,可以编译成功,我按照上面的操作,可以正常完成编译过程,这个里面也有-DCMAKE_TOOLCHAIN_FILE=/opt/Euler.cmake这条命令,为什么在opencv的编译过程中可以成功,在opt目录下去执行编译会报错,请教大佬!
上滑加载中
推荐直播
-
算子工具性能优化新特性演示——MatMulLeakyRelu性能调优实操
2025/01/10 周五 15:30-17:30
MindStudio布道师
算子工具性能优化新特性演示——MatMulLeakyRelu性能调优实操
即将直播 -
用代码全方位驱动 OBS 存储
2025/01/14 周二 16:30-18:00
阿肯 华为云生态技术讲师
如何用代码驱动OBS?常用的数据管理,对象清理,多版本对象访问等应该如何编码?本期课程一一演示解答。
即将直播
热门标签