LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

how to start getting data properly using rs232

Solved!
Go to solution

I am trying to communication with a few modules using RS232 protocol. Almost every single module is sending data to the PC in packets. The problem is that on my first VISA Read, I don't always get data from the beginning. For example, a temperature module (http://www.medlab.eu/english/downloads/tempoem11.pdf) sends data in the following format (31 bytes long):

 

„1“,<bl>,<bl>,<bl>,T1H,T1T,T1O,<bl>,<bl>, „2“,<bl>,<bl>,<bl>,T2H,T2T,T2O,<ER2>,<bl>,<bl>,
„3“,<bl>,<bl>,<bl>,T3H,T3T,T3O,<ER3>,<bl>,<bl>,<0x0d>,<0x0A>

 

Everytime I call a VISA Read command, I want to be able to read all 31 bytes from the beginning. It seems like I have to do additional synchronizing steps such as checking each byte to make sure I see a certain pattern (eg: first byte is 1 and previous 2 bytes are 0d0A). This takes a bit of time, especially when I am trying to start getting data from all the different modules at the exact same time. Is there a better way to accomplish all this?

 

0 Kudos
Message 1 of 13
(4,772 Views)
Solution
Accepted by abdel2

You should post your VI to see if something is not right in it.

 

If you know your message is 31 bytes long, and always ends in the new line character (ASCII hex 0A), then you should request 31 bytes to read and enable the termination character with the new line character.  If you get a message that is less than 31 bytes long, then you can discard it and retry the read.

 

Also, make sure you are not constantly opening and closing the serial port, otherwise you will risk losing data. 

0 Kudos
Message 2 of 13
(4,759 Views)

The module sends out a new packet every two seconds, the total time to transmit the message is 32.292 ms, 9600 bits/second * 31 bytes * 10 bits/byte (8 data bits + 1 start bit + 1 stop bit) which gives you a lot of "idle" time on the serial line.

 

I would configure the serial ports between a minimum delay time of 35ms and a max delay time of 1800ms, but probably closer to the lower end.  Take a look at the screen shot to get you started.  The serial buffer is flushed, then the program loops until a byte is trasmitted by the module.  If 31 bytes are transmitted within the delay time you should have a valid message, if not the read was started in the middle of the message and the entire process should be repeated.

 

 

serial.jpg

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

Ryan

Certified LabVIEW Developer

www.sconnieeng.com

Message Edited by ryan_k on 08-12-2009 08:26 AM
0 Kudos
Message 3 of 13
(4,733 Views)

Ryan_K, wouldn't flushing the buffer before the read erase all data at the port before the read?

So then there would be 0 bytes at the port.
Or am i misunderstanding what that function does?

Cory K
0 Kudos
Message 4 of 13
(4,708 Views)

No reason to flush.

 

I would program it like this.

Message Edited by Ravens Fan on 08-12-2009 10:40 PM
0 Kudos
Message 5 of 13
(4,703 Views)
Code snippets? .... show off Smiley Sad
Cory K
0 Kudos
Message 6 of 13
(4,698 Views)

Cory K wrote:
Code snippets? .... show off Smiley Sad

Smiley Happy

 I've got to learn to use them some way.

(I'm looking forward to seeing it incorporated in the code capture tool.  Without CCT, it takes a couple extra steps like a file save to get the picture into the post.)

0 Kudos
Message 7 of 13
(4,690 Views)

ryan_k, I tried your method but always gave me 0 bytes. Perhaps flushing and checking for only >1 byte was a problem.

 

Raven, you method worked great! I used the exact same logic except I had to use 13 (0xd) as a termination character becase the 31-byte string I read always had 0xd at the beginning and 0xA at the end (unlike what the manual says).

 

Thanks everyone!

0 Kudos
Message 8 of 13
(4,673 Views)
Did you have False going to the while loop termination from the case statement for 0 bytes?
0 Kudos
Message 9 of 13
(4,662 Views)

Yes.

I think what your code does is it simply waits for any number of bytes (>1) to be available and then it reads 31 bytes. The problem is that those 31 bytes are not necessarily from start to end. Flushing the buffer will only discard all the available bytes in the buffer. 

0 Kudos
Message 10 of 13
(4,655 Views)