Memory leak with ~ suppresed wavread function output

1 view (last 30 days)
Why is the following code:
[~,~,~,opts]=wavread('example.wav');
causing apparent readout of all signal data into the memory? (memory is freed immediately upon completion making it hard to spot) This causes 'Out of memory' error when attempting to only read a small 'opts' parameters portion from a large .wav file.
Quote from help: Using the tilde (~) operator, you can change the declaration of a function so that it ignores any one or more entries in the input argument list(...)This can help you to keep your workspace clear of variables you have no use for, and also help you conserve memory.
At the same time wavread('size') does not cause this type of problems.
The only workaround I found to tis problem is: [~,~,~,opts]=wavread('example.wav',0);
Kind regards
Michal

Accepted Answer

Jan
Jan on 26 Feb 2012
This is not a "memory leak", but the expected behaviour. The called function, here wavread does not and cannot have information about the omitted output variables. So the tilde ~ helps to conserve memory by immediately deleting the variable during the return from the called function, but inside the function the memory is still used and can cause a "Out of memory" error.
The workaround you've mentioned is efficient, if only the options are wanted:
[~,~,~,opts] = wavread('example.wav', 0)

More Answers (1)

MatrixMichael
MatrixMichael on 26 Feb 2012
Thank you for the answer. This is something I didnt know about ~ real working after many years of using Matlab. I assume this is already stated in the help files?
Your answer will surely spare me some more trouble at other ocasions.
Thanks
  1 Comment
Jan
Jan on 27 Feb 2012
The internal behaviour of ~ gets clear when you write a Mex-function. From inside the Mex (which is called as any other M-function also), you can get the value of nlhs, "Number of left hand side arguments". In an M-file this is "nargout". But there is no information available, if some of the outputs are ignored by using ~.
Because I write Matlab code compatible to version 2009a and earlier, I do not use the tilde, but "[dummy, dummy, dummy, opts]=..." and "clear('dummy')" afterwards if a large memory occupation is expected.

Sign in to comment.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!