vqdecode.asv

来自「wav声音文件的通过多脉冲激励编码器」· ASV 代码 · 共 39 行

ASV
39
字号
function parameter=VQdecode(codeNum,CodeBoundary,dim1,dim2,filename)
parameter=zeros(dim1,dim2);
parameter1=zeros(dim1,dim2);
parameter2=zeros(dim1,dim2);
fid=fopen(filename,'rb'); 
if(fid==-1) 
display('File not exist!'); 
return; 
end 
binarynumber=1;
while(~feof(fid)) 

     str=fscanf(fid,'%s',1);
     if isempty(str)==0

        for i=1:codeNum
           if(str(codeNum-i+1)=='1')
            parameter2(ceil(binarynumber/(dim2+1)),mod(binarynumber,(dim2+1)))=parameter2(ceil(binarynumber/(dim2+1)),mod(binarynumber,(dim2+1)))+2^(i-1);
             if CodeBoundary(1)<0 & CodeBoundary(2)>0
              CodeBoundarylow=floor(CodeBoundary(1)*10000);
              parameter1(ceil(binarynumber/(dim2+1)),mod(binarynumber,(dim2+1)))=(parameter1(ceil(binarynumber/(dim2+1)),mod(binarynumber,(dim2+1)))+CodeBoundarylow)/10000;
           
             end
          end
        end

       binarynumber=binarynumber+1;
       
    end
end
fclose(fid);
if CodeBoundary(1)<0 & CodeBoundary(2)>0
     parameter= parameter1;
else
     parameter= parameter2;
end
    
    
     

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?