05-31-2012 08:57 AM
OK, new VI posted in attachment.
05-31-2012 10:23 AM
The first thing that I notice is that you might have a race condition. Are you sending any of the button commands when the "error" happens? Maybe the device is sending a reply or ACK as well. I would put the button commands into an event structure and the CMD + Read section into the timeout event.
05-31-2012 08:43 PM
Thank you.
crossrulz has a good point. It might be better to have just one Write and feed the command strings to that Write depending on which button is pressed.
Do you see variations in the Number of Bytes at Serial Port when these errors occur?
Is the instrument doing anything different at the times the errors occur?
Have you detected any patterns, such as every tenth Read, when the errors occur?
Lynn
06-01-2012 01:07 AM - edited 06-01-2012 01:09 AM
When I send button commands I don't care what I get in return. The problem exist for me only when I don't operate with buttons.
Have you detected any patterns, such as every tenth Read, when the errors occur?
Yes, now the problem exist with every second read.
06-01-2012 08:43 AM
I am beginning to think the problem is either something the remote device is sending or that there is something in the communications protocol which you are missing. At this point, I do not have any ideas how to determine where the problem is.
Lynn
06-01-2012 02:56 PM
Well.... This is what I thought at the beginning. The problem is that a producer says that the documentation is OK (but I proved that has some errors) and that the communication is standard and simple. At this point I am thinking how to use this two cases that I have now - the good and bad one.
I will probably check the string length and then if it is not correct cut the additional bytes to read the only proper bytes. This is the only idea I have for this problem at the moment.
06-01-2012 05:02 PM
There is no such thing as "Standard" when it comes to RS-232 communications. The only things which are standardized are the voltages and the byte framing. The values of the bytes transmitted are absolutely, completely up to the choices made by the person designing the system.
The biggest problem I see with using the string length is that you do not know which byte or bytes are the wrong ones. In the small amount of erroneous data you have posted, it appears that the extra bytes are usually 00. However some valid bytes are also 00, so you cannot just remove them.
Do you have any way of validating the data to be sure that you removed the appropriate bytes?
Lynn
06-02-2012 04:40 AM
I don't have this device available right now, but i remember that there is an additional 3-bytes long string before the proper message. Thus I can distinguish whether I have a proper or wrong string. Monday I will try it and let you know what the result is.