- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试运行多个 CMT trackers同时地。出于这个原因,我设置了一个线程池:
import argparse
import cv2
from multiprocessing import Pool
import numpy as np
import os
import sys
import time
import VARtracker
import util
CMT1 = VARtracker.CMT()
... # code lines removed
# Clean up
cv2.destroyAllWindows()
if args.inputpath is not None:
# If a path to a file was given, assume it is a single video file
if os.path.isfile(args.inputpath):
cap = cv2.VideoCapture(args.inputpath)
# Skip first frames if required
if args.skip is not None:
cap.set(cv2.cv.CV_CAP_PROP_POS_FRAMES, args.skip)
# Otherwise assume it is a format string for reading images
else:
cap = util.FileVideoCapture(args.inputpath)
# Skip first frames if required
if args.skip is not None:
cap.frame = 1 + args.skip
# Check if videocapture is working
if not cap.isOpened():
print 'Unable to open video input.'
sys.exit(1)
# Read first frame
status, im0 = cap.read()
im_gray0 = cv2.cvtColor(im0, cv2.COLOR_BGR2GRAY)
im_draw = np.copy(im0)
# Getting initial bounding boxes
tl1 = [405, 160]
br1 = [450, 275]
VARtracker.initialise(CMT1, im_gray0, tl1, br1)
frame = 1
while True:
pool = Pool(processes=4)
print frame
# Read image
status, im = cap.read()
if not status:
break
im_gray = cv2.cvtColor(im, cv2.COLOR_BGR2GRAY)
im_draw = np.copy(im)
tic = time.time()
# Serial approach
#res1 = VARtracker.process_frame(CMT1, im_gray)
# Parallel approach
res1 = pool.apply_async(VARtracker.process_frame, (CMT2, im_gray))
pool.close()
pool.join()
res1 = res1.get()
toc = time.time()
# Display results
if res1.has_result:
cv2.line(im_draw, res1.tl, res1.tr, (255, 0, 0), 4)
cv2.line(im_draw, res1.tr, res1.br, (255, 0, 0), 4)
cv2.line(im_draw, res1.br, res1.bl, (255, 0, 0), 4)
cv2.line(im_draw, res1.bl, res1.tl, (255, 0, 0), 4)
if not args.quiet:
cv2.imshow('main', im_draw)
cv2.waitKey(pause_time)
# Remember image
im_prev = im_gray
frame += 1
每当我评论串行方法并尝试使用线程(并行方法)时,我都会遇到以下错误:
Traceback (most recent call last):
File "/home/rafael/GIT/CMT-Tracker/VaretoCMT/VARmain.py", line 128, in module res1 = res1.get()
File "/usr/lib/python2.7/multiprocessing/pool.py", line 558, in get raise self._value
cPickle.PicklingError:无法腌制:属性查找 cv2.BRISK 失败
其他文件可以在VARmain.py, VARtracker.py and util.py上遇到.
我已经尝试了很多方法,但仍然没有找到克服此 Python 限制的方法。我发现我不能序列化类方法,只能序列化函数。如果可能,我想使用 Python 标准库来解决它。
最佳答案
我设法解决了它。感谢@Matt 和@Yamaneko。基本上,我将读取图像的 block 移到了辅助函数中。因此,如果 pool size = 6 并且有六个边界框,则每个帧将被读取六次(在每个 worker 中)。这是我发现让它发挥作用的唯一方法。
可以找到当前版本here .
import cv2 as cv
import multiprocessing as mp
import time
def worker(folder_path, list_name, top_left, bot_right, index):
frame_path = folder_path + '/' + list_name[0]
image_0 = cv.imread(frame_path)
gray_0 = cv.cvtColor(image_0, cv.COLOR_BGR2GRAY)
cmt = VARtracker.CMT()
cmt.initialise(gray_0, top_left, bot_right)
box_queue = mp.Queue()
for name in list_name:
frame_path = folder_path + '/' + name
image_now = cv.imread(frame_path)
gray_now = cv.cvtColor(image_now, cv.COLOR_BGR2GRAY)
cmt.process_frame(gray_now)
if cmt.has_result:
print index, name, zip(cmt.tl, cmt.br)
output.put((index, name, zip(cmt.tl, cmt.br)))
print 'Process {} finished'.format(index)
def VARmethod(folder_path, final_frame, top_left, bot_right):
tic = time.time()
if len(top_left) == len(bot_right):
list_frame = [index for index in range(1, final_frame + 1)]
list_name = [str(index) + '.jpg' for index in list_frame]
pool = mp.Pool(5)
for index in range(0, len(top_left)):
pool.apply_async(worker, args=(folder_path, list_name, top_left[index], bot_right[index], index))
pool.close()
pool.join()
print 'Finished with the script'
toc = time.time()
print output.qsize()
print (toc - tic)
关于python - 无法腌制 <type 'cv2.BRISK' > : attribute lookup cv2. BRISK 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38150402/
我在使用以下代码时遇到问题: function http_file_exists($url){ $f=fopen($url,"r"); if($f){ fclose($f); retu
我已经通过 Git 部署到 Azure 几个月了,没有出现重大问题,但现在我似乎遇到了一个无法克服的错误。 我创建了一个新的 Azure 网站,为正在开发的项目创建单独的预览链接。我在新站点上设置了
我已经通过flutter创建了一个App并完成了它,我想在flutter文档中阅读时进行部署。 我收到此错误: FAILURE: Build failed with an exception. * W
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
我正在尝试使用 RapidJSON 解析从服务器接收到的数据。以下是收到的确切字符串: [ { "Node": "9478149a08f9", "Address": "172.17
我尝试为 ios 编译 OpenCV。我总是收到这些错误。我用不同版本的opencv试了一下,结果都是一样的。 我运行这个:python 平台/ios/build_framework.py ios_o
我在一台机器上做基本的发布/订阅,我的客户端是 StackExchange-Redis 的 C# 客户端,我在同一台机器上运行基于 Windows 的 Redis 服务器(服务器版本 2.8.4) 当
我有这段代码,但无法执行,请帮我解决这个问题 连接 connect_error) { die ("connection failed: " . $terhubung->connect_erro
我在 tomcat 上运行并由 maven 编译的 Web 应用程序给出了以下警告和错误。我可以在本地存储库中看到所有 JAR,但有人可以帮忙吗。 WARNING: Failed to scan JA
我正在 Windows 8 上使用 Android Studio 开发一个 android 应用程序,我正在使用一些 native 代码。突然间我无法编译我的 C 文件。当我运行 ndk-build
下面的代码对类和结构的成员进行序列化和反序列化。序列化工作正常,但我在尝试使用 oarch >> BOOST_SERIALIZATION_NVP(outObj); 反序列化时遇到了以下错误; 代码中是
如果我运行此命令“rspec ./spec/requests/api/v1/password_reset_request_spec.rb”,此文件中的所有测试都会通过。 但是,当我运行“rspec”时
我在尝试执行测试以使用 Protractor 上传文件时出错,我的代码是这个 it('it should be possible to upload a file', function() {
System.loadLibrary("nativefaceswap"); 当我运行我的应用程序时,我在 Android Studio 中发现了此类错误。在logcat中显示: java.lang.U
我希望有人能帮助我!使用任何方法或命令行的任何 SSL/HTTPS 调用均无效。 我在 Windows 10 中使用 Ubuntu Server 18.04 作为子系统。我的问题是昨天才开始出现的,因
通过删除这两个值将日期字段从 null=True 和 Blank=True 更改为 required 时,使用 db.alter 命令时遇到问题。 当以下行被注释掉时,迁移运行不会出现问题。
我第一次使用 Heroku 尝试创建应用程序(使用 SendGrid 的 Inbound Parse Webhook"和 Twilio SMS 通过电子邮件发送和接收 SMS 消息)。通过 Virtu
我正在将我的 swift 项目更新到 Xcode 7 上的 Swift 2.0。xcode 在构建项目时报告了以下错误: 命令/Applications/Xcode.app/Contents/Deve
在我的代码中,SSL 库函数 SSL_library_init() 没有按预期返回 1。我如何才能看到它返回了什么错误? 我在 SSL_library_init() 之后调用了 SSL_load_er
我正在尝试运行在以下链接中找到的答案: Asynchronously Load the Contents of a Div 但是当我这样做时,我会遇到我不太理解的错误。 我的代码: $(documen
我是一名优秀的程序员,十分优秀!