Memory leak with ~ suppresed wavread function output

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

 Réponse acceptée

Jan
Jan le 26 Fév 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)

Plus de réponses (1)

MatrixMichael
MatrixMichael le 26 Fév 2012

0 votes

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 commentaire

Jan
Jan le 27 Fév 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.

Connectez-vous pour commenter.

Community Treasure Hunt

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

Start Hunting!

Translated by