 jujian9
		
			jujian9
		
		
		
		
		
		
		
		
	
			11-11-2019 06:37 AM
 Andrey_Dmitriev
		
			Andrey_Dmitriev
		
		
		
		
		
		
		
		
	
			11-11-2019 09:07 AM
You should be careful with producer/consumer pattern when using it with IMAQ images. In general the IMAQ images stored by reference and not by value, it means that in your case all images in the queue will point to the same image.
You have in general two possilities. The first obvious solution is to convert images to the arrays and enqueue arrays instead of native IMAQ images. In this case you will get "conversion penalties". You can use this way if this acceptably from performance point of view. Another way (which is more elegant) is to create array of the IMAQ images, using "ring acquisition".and limit size of the queue to the size of the array to be sure that the image under procession in the consumer loop will never be overwritten with producer loop.
with best regards,
Andrey.
11-13-2019 07:16 AM
Hi Andrey,
Thank you for your advice. I've tried two ways based on your comments.
1) make an image copy and then en-queue
2) convert the image into a 2D array and then en-queue.
However, both ways did not work. The de-queue does not work at all, just like before. I've attached the raw vi here for your reference.
I've also attached a screenshot by using a simple look for the en-queue, where in such a case the whole system work smoothly and as we expected.
Thank you and look forward to your reply.
Cheers,
JJ
 Andrey_Dmitriev
		
			Andrey_Dmitriev
		
		
		
		
		
		
		
		
	
			11-14-2019 05:53 AM
Hi,
You should perform copy in the acquisition loop and not in processing loop, otherwise you sztill have a problem that the different elemnts in the queue are referred to the same image.
Let me explain what happened.
At the first I will create pretty simple Producer/Consumer example. "For" loop acts as producer, send every 20 ms one image to the queue. "While" loop is consumer, where some processing is done. I will fill the image with constant gray value and will check this gray value in the processing loop. What I expect - that the every buffer will get intensity equal to the number of the buffer:
So far it works:
But now I will delay processing loop for 100 ms for every 10th image:
What happened now? Now I will get different buffers with same values:
This happened, because buffers 1,2,3,4,5 are filled with same image, because the IMAQ images stored by reference - they referred to the same image. When processing cycle is not fast enough, then acquisition loop sends 5 queue elements, and when processing loop is able to process, then the image which is just acquired in this moment is processed - there is no copy in queue, just reference.
What can I do? I can transfer images as arrays instead of native IMAQ images:
As result I have performance penalties for conversion to and from array, but it works without collisions, because each element in the queue filled with proper data (and holds a copy of the acquired image).
Another way is transfer images as native IMAQ images, buth then you have to limit size of the queue and do it with ring buffer, something like that:
Now result back to expected:
Hope it helps for understanding.
with best regards,
Andrey.