Has anyone seen a camera dropped the frame during certain time every day? For example, when we set the frame rate to 20, the camera was streaming at 20 fps most of the time, but started to drop around middle night. It took the camera 2-3 hours to drop to 14 fps then increased to 20 fps after another 2-3 hours. The pipeline we are using is:
This sounds like a load issue on your machine. Check every cron jobs that can start around midnight, or external access that could happen if your machine if offering some services, paying special attention to network use if your camera is a GigEVision one.
Thanks @Emmanuel. Another behavior we saw was that the same camera had cosine shape frame rate before we changed to the new pipeline above. The cosign shape reached the lowest frame rate 0 every 22 hours and reached the highest frame rate 8 fps every 22 hours. The pipeline we were using before:
Is it getting darker at midnight? You are using automatic exposure. If you need to expose longer than the time of each frame its natural that frame rate drops.
You might need to increase camera gain.
It happened at local day time, and sometimes at midnight as well recently. One thing I noticed was that the network packets dropped 5% from camera to docker container, and only dropped <0.5% from camera to host. It sounds like the traffic from camera to host has enough network buffer size, but the traffic from host to camera does not.
This is a Balser camera. I didn’t see correlation between the network packet drop and the frame rate. Maybe the GevSCPD and GevTimestampTickFrequency could affect the frame rate?
GevTimestampTickFrequency can’t affect the framerate, it is normally a constant. GevSCPD can, but only if you are using several camera on the same network.
Is the camera directly connected to your machine ?
Try to debug your issue without using container or virtualisation, they add another layer of complexity that does not help.
Did you try to enable the debug output ? ARV_DEBUG=device should give you some statistics about packet transfers at the end of the run. Something like:
From camera to the host, there were no packets dropped, and there were always some packets dropped from the host to the container, even the frame rate was 1.0.
I do not think the framrate is going down due to increased exposure time,
rather, either the processing in appsink clogs the system up, or you are having some network issues.
Your payload size is quite small so you shoud not be maxing out the connection.
Check with fakesink. Should help diagnose.
Well, fakesink is just a black hole, capturing from it would be tricky.
The point of using it it to see if the problem lies with camera or the processing of frames.
if the frame processing requirement by appsink varies, the pipe could get clogged.
if you replace your source with a testsource (not sure there is a bayer one, so you might need to adjust your pipeline accordingly.
Another way to track down the problem could be to capture to disk, then replay it into your pipeline.
Other options include to time your appsink loop. (does it take to long?)
Sometimes it helps with inserting a tee and queue elements in the pipeline (multiple threads) for speedup.