0

我是一名生物学家,为了我的实验工作,我想开发一个可以检测载玻片上任何运动的软件。

我想修改以下代码,以便它可以检测围绕特定 xy 坐标而不是整个帧的所需半径圆内的运动。你能建议哪些改变是必要的吗?

from SimpleCV import *

from SimpleCV import VirtualCamera
#from time import *
vir = VirtualCamera("video.mpg", "video")
vir.getImage().show()
cam = Camera()
threshold = 0.2 # if mean exceeds this amount do something

while True:
        previous = vir.getImage() #grab a frame
        #time.sleep(0.5) #wait for half a second
        current = vir.getImage() #grab another frame
        diff = current - previous
        lines = diff.findLines(threshold=1, minlinelength=1)
        lines.draw(width=2)
        current.addDrawingLayer(diff.dl())  
        matrix = diff.getNumpy()
        mean = matrix.mean()
        current.show()

        if mean >= threshold:
                print "Motion Detected"
                print mean
4

1 回答 1

1

在 C++ 中使用 OpenCV:

//Subtract consecutive frames
cv::Mat matN=cv::imread("frame1.jpg");
cv::Mat matM=cv::imread("frame2.jpg");
cv::Mat matDiff=abs(matM-matN);

//Set region of interest (subframe)
int x(10),y(10),width(30),height(40);
cv::Rect myRegionOfInterest(x,y,width,height);

//Define motion
double Threshold=0.1;
double nze=cv::countNonZero( matDiff(myRegionOfInterest) );
double motionFactor=nze/(width*height*C); //C=255 for uchar, C=1 for binary, etc.
if (motionFactor>Threshold)
 std::cout<<"Motion detected at specific ROI";
于 2014-01-22T13:30:51.520 回答