Page 2 of 3

Re: I wrote an object-detection add-on for ZM

Posted: Mon Jun 05, 2017 8:01 pm
by tpcarmen
you might have to fix the makefile to point to where your mysqsl libs are. It might be different than on my system.

Re: I wrote an object-detection add-on for ZM

Posted: Mon Jun 05, 2017 8:05 pm
by asker
On OSX, I needed to modify the Makefile LDFLAGS:

Code: Select all

LDFLAGS= -lm -pthread -lconfuse `mysql_config --cflags --libs`

Re: I wrote an object-detection add-on for ZM

Posted: Mon Jun 05, 2017 11:30 pm
by rockedge
@asker thanks for the LDFLAGS.... I used yours to see if it would compile.....and it worked. So now I have tried
and I get a :

Code: Select all

root#./zmdn
Segmentation fault

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 12:02 am
by tpcarmen
Set debug=1 in the /etc/zmdn.conf and see how far it gets and what the last thing is it says.

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 12:40 am
by rockedge
I have no /etc/zmdn.conf !! Should I create one and add debug=1? what does the config file look like? I compiled a version with debug=1 in the Makefile.

I still have a Segmentation fault. Getting closer

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 2:14 am
by tpcarmen
It's supposed to create the config file by itself.

Try getting the newest code from github.

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 3:19 am
by rockedge
OK it worked! I used the latest code from git, modified the Makefile,
on line 1->

Code: Select all

GPU=0
on line 21 changed:

Code: Select all

LDFLAGS= -lm -pthread
to->

Code: Select all

LDFLAGS= -lm -pthread -lconfuse `mysql_config --cflags --libs`
capture4354.png
capture4354.png (28.77 KiB) Viewed 13498 times

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 3:36 am
by tpcarmen
Very cool!

It's running and waiting for frames that have a score greater than "MinFrameScoreToCheck" from the config file.

When it finds one, it runs the detection code, and INSERTs records into the FrameMatches table, listing what it found in the frame.

All we need now is for someone to glue the FrameMatches back into ZoneMinder, so besides "Events" we can have "Stuff I found" 8-)

If you go into zmdn.conf. you can set debug to 0, and stop the messages, or leave them running for a while to keep an eye on it.

At some point soon (maybe tomorrow) I'll have it output to a log file or table.

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 3:40 am
by rockedge
looks great and I think I am getting results!
capture16282.png
capture16282.png (146.1 KiB) Viewed 13493 times
I will try to find a place to integrate for experimentation.

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 1:00 pm
by tpcarmen
Yep! Those are results all right! 8-)

Very cool, thanks for playing with it!

If you start picking up invalid detections, you can raise "thresh" in zmdn.conf. Probabilities that are less than "thresh" aren't INSERTed into the DB.

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 3:28 pm
by asker
rockedge wrote: Mon Jun 05, 2017 5:23 pm Both looking at image data via the Frame table, or processing live streams should be options. A daemon process that can be started to achieve this along the path tpcarmen is suggesting, something like zmaudit.pl? The real-time analysis need only be applied maybe in the alarm frames and then at first by working with a sampling of some frames and then some logic to determine if that analysis frame rate should increase. So let ZM detect the initial motion then trigger real time analysis?
No, you can't use this approach for real-time detection without a very powerful GPU enabled system. I've played with YoLo before. It took 11 seconds to identify a person on a 65KB downsized image (https://pjreddie.com/darknet/yolo/) without a GPU (2.9GHz/i5/15GB DDR3, Iris Graphics - so no CUDA GPU). This is the key reason why we integrated with Dlib instead of Yolo - it was faster when we compared CNNs (and also offered non CNN models). The entire concept for real-time detection is for it to be real-time and detect before alarms are sent out. The #1 use case of image labeling for regular consumers is related to alerts - they don't want spam alerts but want alerts in time. For enterprises, this soft of passive analysis is useful because they record 24x7, and when a theft occurs, they want post-analysis (and time-shifting here is fine).Obviously non real time analysis is useful for consumers too, but its not something that is a primary use.

So bottom line, you can't run a daemon with this approach (CNN based) for real-time as a general purpose soln.

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 5:58 pm
by asker
I hate to keep diverting this topic, but I've never tried tiny-yolo mentioned by tpcarmen. Its speed is amazing, but its prediction capability is quite low. But I do think tiny-yolo is very impressive and potentially a candidate for real-time analysis. I'll look into how its training is done. I suspect it can be tweaked - I ran tiny-yolo with low quality security cam footage of people in front of cars. In around half the cases it said "person" which is a great start. And without GPU it takes a second to half a second

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 7:48 pm
by tpcarmen
asker wrote: Tue Jun 06, 2017 5:58 pm I hate to keep diverting this topic, but I've never tried tiny-yolo mentioned by tpcarmen. Its speed is amazing, but its prediction capability is quite low. But I do think tiny-yolo is very impressive and potentially a candidate for real-time analysis. I'll look into how its training is done. I suspect it can be tweaked - I ran tiny-yolo with low quality security cam footage of people in front of cars. In around half the cases it said "person" which is a great start. And without GPU it takes a second to half a second
That would be great, because I really only care about cars, people, truck, dogs and maybe a few others.

The GPU is a huge performance boost even with a cheap gpu. I went from 10 seconds/image to about .25 seconds/image.

I wish I understood more about image processing. I read the darknet paper but don't even have the context to make sense out of it. Especially exactly what they mean by convolutional image processing. I understand about sharpening, blurring, etc, but have no idea how they get from there to "person".

FWIW, I'm not using tiny.yolo, I'm using the regular one. The tiny one wasn't very accurate for me.

Re: I wrote an object-detection add-on for ZM

Posted: Tue Jun 06, 2017 11:11 pm
by rockedge
asker wrote: Tue Jun 06, 2017 3:28 pm
No, you can't use this approach for real-time detection without a very powerful GPU enabled system.

So bottom line, you can't run a daemon with this approach (CNN based) for real-time as a general purpose soln.
Yes, well explained.....I am sending individual images via the Frame console to pjreddie's /darknet/yolo and it takes 6-12 seconds
on this machine :

Genuine Intel(R) CPU T2400 @ 1.83GHz
Socket Designation: Microprocessor
Manufacturer: Intel
Voltage: 3.3 V
External Clock: 166 MHz
Max Speed: 1833 MHz
Current Speed of Core 0:1000 MHz, 1:1833 MHz
Core Count: 2
Thread Count: 2

there is no way to even run a single web cam and run darknet/yolo, the system almost seems stopped. Real time detection on a zoneminder stream before zm sends alarm or in any other way is not possible on my set ups.

but for experimentation I would like to make a button or another column to select both views, one from zm and other after it runs through yolo. Also the FrameMatches table .... are the times synced with the event id and/or frame id? The FrameMatches table used in Filters as an added condition or reported in the notification email/message/push notification (in zmNinja). It all may not be practical, but fun to add and who knows?

Re: I wrote an object-detection add-on for ZM

Posted: Wed Jun 07, 2017 12:21 am
by tpcarmen
rockedge wrote: Tue Jun 06, 2017 11:11 pm but for experimentation I would like to make a button or another column to select both views, one from zm and other after it runs through yolo.
Sounds great!

rockedge wrote: Tue Jun 06, 2017 11:11 pm Also the FrameMatches table .... are the times synced with the event id and/or frame id?
Neither. The FrameMatches table is linked to the Frames Table on the Frames.Id = FrameMatches.FrameId

FrameMatches.Added is the time that the row was created, which would be when zmdn finished analysing the image and figured out what it contained.

rockedge wrote: Tue Jun 06, 2017 11:11 pm The FrameMatches table used in Filters as an added condition or reported in the notification email/message/push notification (in zmNinja). It all may not be practical, but fun to add and who knows?
That would be great! It would be awesome to be able to set an alert for "Person at Back Door"

Terry