view aim-mat/tools/getAIFFinfo.m @ 4:537f939baef0 tip

various bug fixes and changed copyright message
author Stefan Bleeck <bleeck@gmail.com>
date Tue, 16 Aug 2011 14:37:17 +0100
parents 20ada0af3d7d
children
line wrap: on
line source
% tool
% 
%   INPUT VALUES:
%  
%   RETURN VALUE:
%
% 
% (c) 2011, University of Southampton
% Maintained by Stefan Bleeck (bleeck@gmail.com)
% download of current version is on the soundsoftware site: 
% http://code.soundsoftware.ac.uk/projects/aimmat
% documentation and everything is on http://www.acousticscale.org


%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% File:			GetAIFFinfo.m
% by stefan@bleeck.de
%%%%%%%%%%%%%%%%%%%%%%%%%%%

function ret = GetAIFFinfo(fname)

[fid, msg] = fopen(fname);
if fid == -1
    error('File open error. Please check that the file name is correctly spelled.')
end
littleEndian = 0;
aiff_form = ReadBytes(fid, 4, littleEndian);
if aiff_form' == double('FORM')
%	disp('big-endian');
else
%	disp('little-endian');
	littleEndian = 1;
end;

chunkSize = Read32Bits(fid, littleEndian);

aiff_aiff = ReadBytes(fid, 4, littleEndian);
if aiff_aiff' ~= double('AIFF')
	aiff_aiff
	disp('Not a valid AIFF file.');
	return
end;
chunkSize = chunkSize - 16;

while chunkSize - 4 > 0;
	chunkName = ReadBytes(fid, 4, littleEndian);
	chunkSize = chunkSize - 4;
	if chunkName' == double('COMM');
% 		disp('step COMM');
 		subSize = Read32Bits(fid, littleEndian);
 		chunkSize = chunkSize-subSize;
 		numChannels = Read16Bits(fid, littleEndian);
 		subSize = subSize - 2;
 		numSampleFrames = Read32Bits(fid, littleEndian);
 		subSize = subSize - 4; 
 		sampleSize = Read16Bits(fid, littleEndian);
 		subSize = subSize - 2;
 		sampleRate = ReadIEEE2(fid, littleEndian);
 		subSize = subSize - 10;
 		fread(fid, subSize, 'char');
	elseif chunkName' == double('SSND');
% 		disp('step SSND');
 		subSize = Read32Bits(fid, littleEndian);
 		chunkSize = chunkSize - subSize;
 		offset = Read32Bits(fid, littleEndian);
		subSize = subSize - 4;
		blockSize = Read32Bits(fid, littleEndian);
		subSize = subSize - 4;
		soundPosition = ftell(fid) + offset;
		fread(fid, subSize, 'char');
	elseif chunkName' == double('LUT2');
% 		disp('step LUT2');
 		subSize = Read32Bits(fid, littleEndian);
 		chunkSize = chunkSize - subSize;
 		interleaveLevel = Read16Bits(fid, littleEndian);
 		subSize = subSize - 2;
  		numWindowFrames = Read16Bits(fid, littleEndian);
 		subSize = subSize - 2;
  		staticTimeFlag = Read16Bits(fid, littleEndian);
 		subSize = subSize - 2;
		outputTimeOffset = ReadIEEE2(fid, littleEndian);
 		subSize = subSize - 10;
 		absoluteNormalise = ReadIEEE2(fid, littleEndian);

 		subSize = subSize - 10;
 		fread(fid, subSize, 'char');
		
 	else;
 		subSize = Read32Bits(fid, littleEndian);
 		chunkSize = chunkSize - subSize;
 		fread(fid, subSize, 'char');
 			
 	end;
end;
fclose(fid);

wordSize = floor((sampleSize + 7 ) / 8);
normalise = (2^16 - 1) / 2^(17 - wordSize * 8) / absoluteNormalise;
switch wordSize
	case 1, scale = normalise / 127.0;
	case 2, scale = normalise / 32768.0;
	case 4, scale = normalise / 32768.0 / 65536;
end
frameLength = numSampleFrames / numWindowFrames;

ret.totalframetime=frameLength/sampleRate;
ret.numWindowFrames=numWindowFrames;
ret.scale=scale;
ret.wordSize=wordSize;
ret.soundPosition=soundPosition;
ret.littleEndian=littleEndian;
ret.frameLength=frameLength;
ret.numChannels=numChannels;
ret.numSampleFrames=numSampleFrames;
ret.sampleSize=sampleSize;
ret.sampleRate=sampleRate;
ret.interleaveLevel=interleaveLevel;
ret.numWindowFrames=numWindowFrames;
ret.staticTimeFlag=staticTimeFlag;
ret.outputTimeOffset=outputTimeOffset;
ret.absoluteNormalise=absoluteNormalise;