|  | clear; | 
|  | pack; | 
|  | % | 
|  | % Enter the path to YOUR executable and remember to define the perprocessor | 
|  | % variable PRINT_MIPS te get the instructions printed to the screen. | 
|  | % | 
|  | command = '!iLBCtest.exe 30 speechAndBGnoise.pcm out1.bit out1.pcm tlm10_30ms.dat'; | 
|  | cout=' > st.txt';   %saves to matlab variable 'st' | 
|  | eval(strcat(command,cout)); | 
|  | if(length(cout)>3) | 
|  | load st.txt | 
|  | else | 
|  | disp('No cout file to load') | 
|  | end | 
|  |  | 
|  | % initialize vector to zero | 
|  | index = find(st(1:end,1)==-1); | 
|  | indexnonzero = find(st(1:end,1)>0); | 
|  | frames = length(index)-indexnonzero(1)+1; | 
|  | start = indexnonzero(1) - 1; | 
|  | functionOrder=max(st(:,2)); | 
|  | new=zeros(frames,functionOrder); | 
|  |  | 
|  | for i = 1:frames, | 
|  | for j = index(start-1+i)+1:(index(start+i)-1), | 
|  | new(i,st(j,2)) = new(i,st(j,2)) + st(j,1); | 
|  | end | 
|  | end | 
|  |  | 
|  | result=zeros(functionOrder,3); | 
|  | for i=1:functionOrder | 
|  | nonzeroelements = find(new(1:end,i)>0); | 
|  | result(i,1)=i; | 
|  |  | 
|  | % Compute each function's mean complexity | 
|  | % result(i,2)=(sum(new(nonzeroelements,i))/(length(nonzeroelements)*0.03))/1000000; | 
|  |  | 
|  | % Compute each function's maximum complexity in encoding | 
|  | % and decoding respectively and then add it together: | 
|  | % result(i,3)=(max(new(1:end,i))/0.03)/1000000; | 
|  | result(i,3)=(max(new(1:size(new,1)/2,i))/0.03)/1000000 + (max(new(size(new,1)/2+1:end,i))/0.03)/1000000; | 
|  | end | 
|  |  | 
|  | result | 
|  |  | 
|  | % Compute maximum complexity for a single frame (enc/dec separately and together) | 
|  | maxEncComplexityInAFrame = (max(sum(new(1:size(new,1)/2,:),2))/0.03)/1000000 | 
|  | maxDecComplexityInAFrame = (max(sum(new(size(new,1)/2+1:end,:),2))/0.03)/1000000 | 
|  | totalComplexity = maxEncComplexityInAFrame + maxDecComplexityInAFrame |