 markquinn
		
			markquinn
		
		
		
		
		
		
		
		
	
			03-07-2021 01:41 PM
Hi all,
I've got an xiQ camera from Ximea which is a nifty little USB3 Vision compatible high speed camera capable of a range of frame rates (up to 1.5 ish kHz) depending on binning and frame size reduction.
I can set high frame rates in the camera native software and also in MAX but when I try and use the calculated frame rate VI in imaqdx I get 500fps maximum (a suspiciously constant 500fps at that). I suspect this is a limit of the windows timestamp information more than anything else but please correct me if I'm wrong.
I'm trying to program this camera in LabVIEW such that I actually know the timestamp of each image so I can work out the frame rate exactly (accepting that it might not be totally constant) or know the timestamp of each frame.
Any ideas?
My code is a producer consumer architecture which places the images in a queue (not sure if this is actually necessary in imaqdx but it works fine for non high speed cameras) and deals with them elsewhere (saving or calculating averages etc). The image presentation on the screen is also reduced heavily (by a factor of 50) to reduce the load on the PC.
 NPowl
		
			NPowl
		
		
		
		
		
		
		
		
	
			03-09-2021 01:41 PM
Hey Mark,
I had a look at the Ximea cameras available (https://www.ximea.com/usb3-vision-camera under 'Models') and the highest framerate there is 500FPS. Which camera are you using?
With regards to the immediate question about timestamps - I had a quick look and couldn't see any GigE features, but that may have been me not looking enough. Is there anything that gets sent in the frame metadata that contains this information? Otherwise, we can try to timestamp as here but this has obvious limitations.
Looking further.. it looks as though there's various IO on the camera that reads timestamp values from the camera as well as a ready made wrapper for these in LabVIEW here.
I'm unable to run this to get the attributes, but are you able to confirm what's available through those keys or whether the wrapper for the Ximea API serves the purpose of letting you call "XI_PRM_TIMESTAMP"?
Cheers,
Nick
03-10-2021 05:34 AM
Hi Nick,
The camera I am using is the MQ013CG-ON model which can go faster than 500 fps if the frame is cropped more than VGA (the native Ximea software handles this ok) but maybe there is something more too it that isn't handled by the U3V driver for it.
Even if I can't run the camera faster than 500 fps in LabVIEW it would still be useful to know the timestamp more accurately than 1ms.
I've tried the approaches you showed already (getting custom keys) but this is limited as you said.
 NPowl
		
			NPowl
		
		
		
		
		
		
		
		
	
			03-10-2021 04:48 PM
Does the Ximea LabVIEW API expose XI_PRM_TIMESTAMP? That seems to be hardware timed from the camera so should be able to give accurate timestamps.
03-11-2021 06:54 AM
Hi,
If it does I'm not really sure how to call it. I'm currently operating the camera in LabVIEW via the U3V driver so I would need to change to the Ximea API driver and rewrite my code - not impossible but a pain 😕 Unless there is a way to call the API function/interface with whatever register the timestamp is at on the device and pull it out separately.
 NPowl
		
			NPowl
		
		
		
		
		
		
		
		
	
			03-13-2021 06:50 AM
The only way to get timestamps more accurate than the IMAQdx timestamping from Windows are to somehow pull the data from the camera itself. This could be in frame metadata/chunkdata or through the actual IO on the camera.
Unfortunately without the camera, it's hard to verify what's available on my end. Perhaps shooting Ximea an email to see whether these are exposed at all would be a good idea
Cheers,
Nick
03-21-2021 11:24 PM
The timestamps from the camera are attached as metadata to the images by IMAQdx. These can be read using the Custom Data VIs in the Vision utilities palette.