05-20-2019 08:27 PM
Hello.
I am trying to send an array of values from MatLab to Labview via UDP.
I understand MatLab writes to UDP in binary if one uses the "fwrite" command and I can use a simple string to byte array conversion for that, but I want to retain the numerical value of each entry in the array.
If I send the array data via "fprintf" I can send the exact values of the array, but as a string.
I have been struggling with extracting the data from the string and reassembling it into the array I desire. I found an example that seemed to be something similar to what I am doing. It used the "Scan from String" function, but I am receiving an error when I run it (Error 85: Scan failed. The input string does not contain data in the expected format). I see the correct values being read in, but then it experiences the error after all 3 values have been read. I've attached a screenshot of the VI I'm trying to build.
I would like to be able to receive a 1x3 matrix in this script (and a 1x6 matrix in another script).
Solved! Go to Solution.
05-21-2019 12:05 AM - edited 05-21-2019 12:07 AM
We cannot work with pictures*, so please attach the VI. How does the received string look like?
How does matlab format/cast the array to a string? Can you show that code too?
* there are many things wrong with your code, even if we can't see what's in the other cases, etc.:
05-21-2019 02:09 AM
Thanks for the response.
I've attached the VI to this post and a picture of probe results from the string containing the 1x3 array being read in from MatLab.
As far as the VI itself, it's a controller for a wheelchair. I'm trying to read in the values from classifiers (from MatLab) that will be fed into a fuzzy logic controller. The classifier values are 5 digit (0.xxxx) precision numbers, but when MatLab writes them into LabView they are displayed as 8 digit precision numbers in scientific notation (x.xxxxxxxe-01). The controller directs a header to a certain direction. This is a sample VI that mimics what the actual one will be.
Previously, I was writing in an array of binary data and I could accomplish that with a string to byte array conversion. However, I need the extra precision for more accurate control with the fuzzy logic controller.
I apologize for my newness...
05-21-2019 02:50 AM - edited 05-21-2019 02:51 AM
I should think that a double would be much more accurate sent as binary bytes rather than a string of ASCII characters representing a number accurate to 5 places because the 8 bytes sent is the double, itself.
Don't do any kind of conversion before sending. Send the actual value.
05-21-2019 01:27 PM - edited 05-21-2019 01:29 PM
It is to my understanding that double precision is the default format for matlab?
When I send the array from matlab to labview using the fprintf command (in matlab), it is as a string, but matlab has stored the values as double precision numbers before sending them. I've changed that by including a decimal limiter in matlab to the fprintf command fprintf(u,'%.4f\n',score); where u is the udp client object in matlab. Are you suggesting that I remove the format?
I've gone ahead and included a photo of the entire system. The command window on the left shows the arrays being calculated in the matlab engine and the probe display shows the values in labview being read in as a string (I've gone back to the string to byte array form).
The byte array is in decimal form correct? Can I use that to get my array back?
Edit: included the VI as well
05-23-2019 12:52 AM
When I use the fwrite command in matlab without a format indicator, I get binary values output to labview (first picture). When I specify a precision (single, for example), I get a different kind of data output to labview (second picture).
Can anyone explain to me what the data in the second picture is? It's supposed to be the three decimal values displayed in the command window on the left side of the photo.
05-23-2019 02:04 AM - edited 05-23-2019 02:08 AM
@traviskv wrote:
When I use the fwrite command in matlab without a format indicator, I get binary values output to labview (first picture). When I specify a precision (single, for example), I get a different kind of data output to labview (second picture).
Can anyone explain to me what the data in the second picture is? It's supposed to be the three decimal values displayed in the command window on the left side of the photo.
I sure can! Those are single precision numbers represented as bytes. Three numbers X 4 bytes per single precision number = 12 bytes. 🙂
Seems like you're doing everything right so far!
05-23-2019 12:29 PM - edited 05-23-2019 12:33 PM
Thank you, billko. That makes a lot of sense.
I tried following your example. I don't get an error, but I get a different answer. I've attached my VI and a screenshot.
Is this because I am trying to read in an 1x3 array and instead it is being read in as one number?
05-23-2019 02:10 PM
You have a coercion dot on your array of single. This indicates that you did not make your type array as double. Change it to double and you should get the correct results.
05-23-2019 05:17 PM - edited 05-23-2019 05:19 PM
The simplest way to duplicate the code in the picture... is to duplicate the code! 😄
The picture of the code in my other post is magical! Well, okay, it's a png file with metadata included that, when dropped on to the block diagram of a VI, converts it into real code. But it's almost like magic. 😉
So click on the picture - it's called a "snippet" - and download it. Then open up a blank VI and drag that png file into your block diagram. If you notice, the little text on the right side says "2014" so you'll have to have LV 2014 or newer to make this work. (Although snippets have been around a lot longer than that.)
Try it out! 🙂
edit: seems like I only did the first number in my snippet, but you already have the idea. 🙂