LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Acquiring image from multiple cameras sychronically with LabView7.1

Solved!
Go to solution

Hi everyone,

I'm new in LabView, now my experiment need to acquire pixel data from 8 line scan CCD cameras synchronically and write them to text file, but I found my current Labview code seems to fail to do that. (The writing time of each text file is about 20 sec)

Attached is the Vi. files.

The 'For output single'.vi is for acquiring image from single camera.

The 'Multiple camera'.vi is for acquiring image from all 8 cameras at the same time.

My cotroller is pretty old so I'm wondering if it is the hard drive problem. Could anyone tell me if my codes correct? If not, it'd be 

Frame grabber device: PCI-1428;

Chasis: NI PXI-1045

Embended Controller: PXI-8196

Frame grabber: PXI-1428 (with upload memory of 32MB each)

Camera: DALSA Piriha2

 

My research has been stucked for over 3 months because of this. If anyone can help me out, it would be really appreaciated!!!

Download All
0 Kudos
Message 1 of 13
(670 Views)

The correct way would be to set up your cameras for (external) triggering, which the frame grabber seems to be able to.

https://www.ni.com/docs/en-US/bundle/pxi-pci-1428-seri/resource/372176a.pdf

 

Assuming Single camera.vi is not set as reentrant (you didn't include it) the images are now probably taken consecutively in an undetermined order.

0 Kudos
Message 2 of 13
(603 Views)

Hi Ramon,

 

I've tried the triggering method you said, it worked out pretty well.

But instead of external triggering, I used RTSI/PXI backplane, I'm not sure which one it is. But I selected RTSI in the example.vi called 'HL Grab with two boards.vi'. It worked without timeout errors. But I checked the PXI-1428 frame grabber, I didn't see any RTSI cable in it. 

So I'm confused.

 

Moreover, when I tried to extend this 'two boards' to 4 boards, the acquiring time got really slow. It is 0.187s/line (since I'm using all line scan camera) with only three boards (cameras/devices), but it goes to 20s/lin with 4. But the linerate I set is 10kHz for each camera. Do you have any idea with this problem?

 

Attached is my .vi for two cameras and three cameras.

qianma1ucalgaryca_1-1717708581580.pngqianma1ucalgaryca_2-1717708637031.png

Also I'm confused with the 'trigger number', which one should I use for each camera?

Here's my trigger bus routing:

qianma1ucalgaryca_4-1717708790550.png

It'd be a huge favor if you can help me with any of these confusions, thanks in advance!!

 

Trix

 

 

0 Kudos
Message 3 of 13
(557 Views)

Hi Qian Ma,

 

I've never worked with a PXI chassis and it's been forever since i've use an NI frame grabber so you will have to search things.

 

The manual (http://download.ni.com/support/manuals/372862e.pdf) says: "The RTSI bus is integrated into the PXI system’s backplane for the NI PXI-1428", so no cable needed (only for PCI).

 

Not sure if you need to configure MAX to indicate which device are using the RTSI bus, but it looks like that is needed for PCI devices. You may to look around in MAX.

 

Concerning the images of your VI (which is not the same as attaching VIs)

  • Obviously the "Trigger?" boolean must be set to true
  • The flat sequence is not needed because everything is sequenced by wires
  • Make sure to use different image names for each buffer, otherwise you are creating multiple references to the same buffer!

From what I can tell from the example is that an external trigger used to drive a trigger over the RTSI bus to the other frame grabber. Changing it to RTSI might have unexpected behaviour.

 

0 Kudos
Message 4 of 13
(545 Views)

Hi Ramon,

 

I can't say how thankful I am for your help. I've been improving my code according to your last message these months.

 

Now I finally can acquire images from all 8 cameras synchronized with the sampling rate of 1sample/sec. I use 'Wait Until Next ms Multiple' to determine the sampling rate. And indicators of each while loop iteration are used to see whether the acqusitions are sychronized.

 

Attached is my present code. 

 

According to my frame grabber manual, one RTSI trigger can only synchronize 4 devices. So I used 2 different trigger line.

 

Now the problem is, I wanna increase the sampling rate up to 1sample/ms. But I can't. The indicators of each while loop iteration won't be the same after several iteration like this:

qianma1ucalgaryca_0-1724979730947.png

 

Could you please take a glanse of my code?

 

Thanks,

Qian

0 Kudos
Message 5 of 13
(418 Views)

Hi Qian,

 

Can you save for previous version and select LabVIEW 2015?

 

1000 frames per second seems quite high, what is the size of each frame (X*Y*byte/pixel)?

It may require a ring buffer and a producer-consumer pattern.

0 Kudos
Message 6 of 13
(406 Views)

Hi Ramon,

 

Here is the converted version of my code.

 

The size of each frame is 6144*1(X*Y), but I don't know the byte of each pixel yet. The data type I know is 10-bit though.

 

 

 

 

0 Kudos
Message 7 of 13
(391 Views)

If your data is 10 bits, then U16 is probably used to represent the data unless the data stream is bit packed; so 6144 * 2 Bytes = 12288 Bytes/s. For eight cameras 98304 Bytes/s, this is not a huge amount.

 

A few things:

  1. Your loops will never run in parallel, your older CPU does not have enough threads.
  2. Why do you need all the loops? If your cameras are hardware triggered all the cameras should have data ready at the same time. Benchmark how long it takes 1 camera to download data without any other cameras operating, this will be your theoretical maximum rate. I would put all the cameras in one loop. Use a parallel For Loop for the data download, this will be easier to code and future proof if the number of cameras change.
  3. Only download in the loop, nothing else otherwise you will slow down your acquisition. Send the data to another loop to save/process/etc.

 

 

0 Kudos
Message 8 of 13
(382 Views)

Hi,

 

I see your point, but I don't really understand what 'download' in your replying means. I modified the code as you suggested tho, do you mean by this?

 

qianma1ucalgaryca_0-1725050545350.png

 

0 Kudos
Message 9 of 13
(374 Views)

qian.ma1@ucalgary.ca wrote:

Hi,

 

I see your point, but I don't really understand what 'download' in your replying means. I modified the code as you suggested tho, do you mean by this?

 

qianma1ucalgaryca_0-1725050545350.png

 


I forgot you were using LabVIEW 7.1; not sure if the parallel For loop was available then, probably not.

What I meant is you have an array of references for the images, put that array in a parallel For Loop and "download/acquire/etc" the images. But what you put in the For Loop is similar to what I said, only way you can do it without a Parallel For Loop.

If your cameras are waiting for a trigger, there is no need to put a Wait in the loop, they should only acquire when they get a trigger.

 

snip.png

 

0 Kudos
Message 10 of 13
(369 Views)