Jump to content

A Mat-file IO Library


cookjr

Recommended Posts

Hello,

I made a library for reading/writing MATLAB Mat-files in LabVIEW, and posted it on Sourceforge. It's written in pure G, with no external DLLs. Anyone is welcome to use the code if they want. It can be downloaded at http://matio-labview.sourceforge.net/. If you do try it out, I would appreciate any feedback you could provide.

Here is some sample code. I'm writing a cluster of various items to the file test.mat. This will create a structure in MATLAB with field names derived from the labels of the items in the cluster.

post-4414-125259520164_thumb.png

After running "load test.mat" in MATLAB, here is the result (shown in the variable editor):

post-4414-125259519743_thumb.png

Thanks,

Jim

  • Like 1
Link to comment

Hi Anders,

Thanks! I'm glad you might get use out of the library.

Regarding structs and cell arrays, I was thinking of changing how the "Append Data Element (Anything)" VI handles arrays of clusters. The current version writes them to file as a cell array of structs. I'm thinking a struct array might make more sense. Of course you would always be able to use the low-level VIs in the case that you want a cell array of structs. Does anyone have an opinion on this?

Jim

Link to comment

Hi Anders,

Thanks! I'm glad you might get use out of the library.

Regarding structs and cell arrays, I was thinking of changing how the "Append Data Element (Anything)" VI handles arrays of clusters. The current version writes them to file as a cell array of structs. I'm thinking a struct array might make more sense. Of course you would always be able to use the low-level VIs in the case that you want a cell array of structs. Does anyone have an opinion on this?

Jim

Yes matlab structs for labview clusters make more sense and the reversed. Have you thought making a whos -file subVI? Would it be hard?

Link to comment

Nice work.

Unfortunately writing an array of clusters does not work.

There seems to be no variable in the mat file. If i understood correctly

an array of clusters should be mapped to a cell array of structs or

a struct array in Matlab.

Another issue (maybe related to the one above): Writing a waveform

does not work as well, although this is essentially just a LV cluster.

Link to comment

Nice work.

Unfortunately writing an array of clusters does not work.

There seems to be no variable in the mat file. If i understood correctly

an array of clusters should be mapped to a cell array of structs or

a struct array in Matlab.

Another issue (maybe related to the one above): Writing a waveform

does not work as well, although this is essentially just a LV cluster.

Hi kinimod,

Thank you for taking the time to report this.

I hope we can isolate exactly why it didn't work for you, so the library can be improved for future users. It would be very helpful if you could provide more details about the steps you took to write the data.

  1. What version of the matio library did you use? Some bugs were found in earlier versions that have since been fixed.
  2. Did you install using the OpenG package format, or the zip package format?
  3. What steps did you take to write the array of clusters? A screenshot or some sample code would be helpful here.
  4. Could you send a sample of your data?

Regarding the waveform data: I think that the waveform data structure is a little different internally than a cluster, although they do some similar things. I don't normally use waveforms, so my original intent was to store them so that LabVIEW could read them back in properly instead of transforming them into something that MATLAB could use (i.e. a timeseries object). Were you able to read the waveform data back into LabVIEW?

Thanks again for your help.

Jim

Link to comment

Hi Jim,

thanks for the quick reply.

Hi kinimod,

Thank you for taking the time to report this.

I hope we can isolate exactly why it didn't work for you, so the library can be improved for future users. It would be very helpful if you could provide more details about the steps you took to write the data.

  1. What version of the matio library did you use? Some bugs were found in earlier versions that have since been fixed.
  2. Did you install using the OpenG package format, or the zip package format?
  3. What steps did you take to write the array of clusters? A screenshot or some sample code would be helpful here.
  4. Could you send a sample of your data?

[\quote]

  • Version 0.1.6. Should be the most recent one.
  • I used the OpenG package and installed it with the VI package manager. My LabView version is 2009 (9.0)
  • I simply modified the example VI given by the screenshot in your fist post (see attached image).
  • Due to forum limitations i could not upload the resulting 'test.mat', but attached the VI used to create the data.

Regarding the waveform data: I think that the waveform data structure is a little different internally than a cluster, although they do some similar things. I don't normally use waveforms, so my original intent was to store them so that LabVIEW could read them back in properly instead of transforming them into something that MATLAB could use (i.e. a timeseries object). Were you able to read the waveform data back into LabVIEW?

Having waveforms as timeseries objects would be nice. But writing arrays of clusters would

already be fine, since converting waveforms to clusters is straightforward.

Writing and subsequent reading of waveforms from LabView works (see attached test_matio_waveform.vi).

Dominik

post-16481-125382181346_thumb.png

test_matio.vi

test_matio_waveform.vi

Edited by kinimod
Link to comment

Hi Dominik,

  • Version 0.1.6. Should be the most recent one.
  • I used the OpenG package and installed it with the VI package manager. My LabView version is 2009 (9.0)
  • I simply modified the example VI given by the screenshot in your fist post (see attached image).
  • Due to forum limitations i could not upload the resulting 'test.mat', but attached the VI used to create the data.

Looks like you did everything right. The only thing that stands out to me is LabVIEW 2009. I do all my testing with LabVIEW 8.2.1. It won't be a problem for me to run the tests using LabVIEW 2009 when I get back to work.

Writing and subsequent reading of waveforms from LabView works (see attached test_matio_waveform.vi).

Very good to know. Thank you for testing this.

Unfortunately, I'll be away from work until Monday, so I can't even look at your VIs until then. But I will definitely look into this problem and hopefully get it fixed asap. If you need MAT-files right away, you could use the lower-level VIs (Append Data Element (1D Double, N-D Struct, 1D Cell, etc.)). These give you more fine control over the result anyway.

Thanks

Jim

Link to comment

Hi Dominik,

I should have caught this before by looking at your screenshot.

All variables in MATLAB must have a name. The build array primitive creates an unnamed array. The current version of the matio library does not enforce the naming of data inputs (basically because sub-elements of cell and struct arrays cannot have a name). So the "Append Data Element" VI saved your data appropriately, but MATLAB didn't know what to do with it, since it didn't have a name. Here is one way to fix it using the "Insert Into Array" primitive:

post-4414-125414214486_thumb.png

Future versions of the library will have some logic that will at least throw an error if there's a problem with element naming. Obviously some documentation would be beneficial for the current version.

Thanks again for helping test the library.

Jim

Link to comment

Hi Jim,

thanks for the quick reply. This solved the previously reported problem.

Unfortunately there is another issue: when column vectors are created in MATLAB,

e.g. n x 1 arrays, they are not correctly read by the library.

The variable returned just contains a single element.

This does not occur, if row vectors, e.g. 1 x n arrays are created.

Further, when chaining multiple read-mat VIs it would be convenient to have a

copy of the endianess input as output.

And maybe it would be nice if one could specify the name of a variable to

read from the file instead of having to read them sequentially in alphabetic order.

Nevertheless the library is very useful already :).

Best regards

Dominik

Link to comment

Hi Dominik,

Unfortunately there is another issue: when column vectors are created in MATLAB,

e.g. n x 1 arrays, they are not correctly read by the library.

The variable returned just contains a single element.

This does not occur, if row vectors, e.g. 1 x n arrays are created.

matio-0.1-7 was just uploaded and it should have fixed this bug. For your info, the bug was given ID #2869727.

Further, when chaining multiple read-mat VIs it would be convenient to have a

copy of the endianess input as output.

This feature request was given ID # 2869732.

And maybe it would be nice if one could specify the name of a variable to

read from the file instead of having to read them sequentially in alphabetic order.

This feature request was given ID # 2869734. This is a great idea. I think a separate "Extract Data Element By Name" polymorphic VI could be created. FYI, I think MATLAB stores variables to a MAT-file in the order that they were created, not in alphabetical order. Currently, you have to read the variables using the Extract Data Element VI in the order that they occur in the file. The List Variables VI can be used to determine the order of the variables.

Nevertheless the library is very useful already :).

Thanks! And thank you for your bug reports and feature requests. The library is getting better, because of your help. Any new features will be added in version 0.2.

Jim

Link to comment

I tried to use the 1D to Cell function and it does not work. The data in cell one spills over to the next array element. The output does not load in MATLAB so I tried a data in data out LabView vi. The results are below. Using matio-0.1-7 release 45, LV8.6, MAT7.3.0 on XPSP3.

I justed tried the 2D to Cell with the same results.

post-16523-125448797711_thumb.png

post-16523-125448798549_thumb.png

post-16523-125448846802_thumb.png

post-16523-125448848214_thumb.png

Link to comment

I tried to use the 1D to Cell function and it does not work. The data in cell one spills over to the next array element. The output does not load in MATLAB so I tried a data in data out LabView vi. The results are below. Using matio-0.1-7 release 45, LV8.6, MAT7.3.0 on XPSP3.

I justed tried the 2D to Cell with the same results.

Hi Steven,

The Append 1D Cell function requires a 1D array of "data elements". Data elements are the string output of any of the Append Data Element functions. This allows you to have different data types inside your cell array. All of the cell and struct functions work with data elements. Here's an example:

post-4414-125449772928_thumb.png

Please note that the data elements inside a cell or struct array must not be compressed, and they must not have a name.

Jim

cellArrayOfStrings_example.vi

Edited by cookjr
Link to comment

Hi Jim,

now I have problems converting large tdms files (about 70MB) to a mat file.

The matio library fails with an "Out of memory" error.

Is some part of the library leaking memory or is this simply a misusage of

the library VIs on my side?

Attached is one minimal VI that reproduces the problem.

The waveform_array_to_cluster_array SubVI transforms the

waveform array read from the tdms file into a cluster array

to be written by the matio library.

Dominik

test_tdms_to_mat.vi

waveform_array_to_cluster_array.vi

Link to comment

now I have problems converting large tdms files (about 70MB) to a mat file.

The matio library fails with an "Out of memory" error.

Is some part of the library leaking memory or is this simply a misusage of

the library VIs on my side?

Hi Dominik,

Try the attached edited VIs. This won't give you the same structure as the "Anything" VI (cell array of structs), but it has the best chance at completing without throwing "out of memory" errors.

Note that the only thing I changed in the waveform_array_to_cluster_array VI was that I switched the "insert into array" primitive with the "replace array subset" primitive, since you were preallocating an array.

Efficiency is something that I would like to see improved in the library. It's not leaking memory, but it's not as efficient as it could be either. It's possible that using byte arrays and queues instead of strings would improve memory efficiency. This would be a major rewrite though.

Anyway, I hope the workaround VIs work for you.

Jim

jrc2_test_tdms_to_mat.vi

waveform_array_to_cluster_array.vi

Link to comment
  • 5 months later...

Hi Jim,

Can you write a simple vi to read a mat file with a 1D array of double? (I am using Labview 8.6 and Matlab 2008). I can write a mat file and read it in matlab, but I can't seem to get read a mat file in labview, I got"Error 74 occured at Unflatten From String in level5.lvlib:Extract MAT-File Tag Field.vi->level5.lvlib:Extract Data Element (2D Array of Double).vi". Thanks very much.

Jason

Link to comment

Hi Jim,

Can you write a simple vi to read a mat file with a 1D array of double? (I am using Labview 8.6 and Matlab 2008). I can write a mat file and read it in matlab, but I can't seem to get read a mat file in labview, I got"Error 74 occured at Unflatten From String in level5.lvlib:Extract MAT-File Tag Field.vi->level5.lvlib:Extract Data Element (2D Array of Double).vi". Thanks very much.

Jason

Hi Jason,

Could you send me a mat file that is similar to one that you're having trouble opening? It doesn't have to have real data in it. Then I'll see what I can do.

Jim

Link to comment
  • 2 months later...

Hey Jim,

I've been using your book (LabVIEW For Everyone) and your openG software for a few weeks now, and I recently discovered the MatIO library you created and it looks exactly like what I need to store my data using clusters. I am currently running LabVIEW 8.6, and I was able to successfully install the VI manager on my computer and recreate an example VI posted on this forum (the VI was called test_matio.vi) just to see if my system was storing the data correctly .I ran into a few problems,mainly when I open the generated file, the elements of the clusters don't have names, so I end up with an error when I try to access them in Matlab. I noticed someone else had a similar error so I made sure to use "insert into array" function instead of "append data element' , but I am still having issues. I am pretty confident that the installation on my computer is correct, because I followed the same process on a different computer (a macintosh running v9.0, whereas this computer uses windows and runs v8.6) and I got everything to work.Unfortunately the computer which is not currently working is the one that needs to be setup to the DAQ, so I need to resolve this issue on the machine. If you could take a quick look at my VI to let me know if you see anything obvious I would really appreciate it..test_cluster_structure.vi

All the best,

-Jon

Link to comment

Hi Jon,

I think you're confusing me with Jim Kring.

I can see if I can help you with the MatIO problem though. I'll get back to you when I have an answer.

Jim

Jim,

Thanks for getting back to me so quickly, and I apologize for the confusion. I had read that Jim Kring was very active in the open G community so when I saw the MatIO library and how well it was working my mind immediately made an association. That being said, this library is still fantastic and exactly what I am looking for, and I thank you for your work and development of it. I look forward to hearing feedback from you when you get the chance.

-Jon

Link to comment

Please sign in to comment

You will be able to leave a comment after signing in



Sign In Now
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.