feat(matlab): comm lab 5

This commit is contained in:
iridiumR 2022-11-26 17:24:08 +08:00
parent 19d2491d51
commit 05c2027520

View file

@ -1,23 +1,23 @@
clc clc
clear
%================================================ %================================================
% %
%================================================ %================================================
x = 2047 %/ x = 500
pcmcode = pcmEnCode(x) %pcmCode()PCM pcmcode = pcmEnCode(x)
amp = pcmDeCode(pcmcode) %pcmDecode()PCM amp = pcmDeCode(pcmcode)
amp = pcmDecode(pcmcode) qerror = x-amp
%qerror = x-amp %
%================================================ %================================================
% %
%================================================ %================================================
% M = 5; % -5~+5 M = 5
% delta = M/2^11; % d = M/2^11;
% y = +2.5 %/V x = 2.5
% y0 = round(y/delta) % x0 = round(x/d)
% pcmcode = pcmCode(y0) %PCM pcmcode = pcmEnCode(x0);
% amp=pcmDecode(pcmcode); %PCM amp0=pcmDeCode(pcmcode);
% amp = amp*delta % amp0 = amp0*d
% qerror=y-amp % qerror=x-amp0
function pcmcode = pcmEnCode(s) function pcmcode = pcmEnCode(s)
@ -27,7 +27,7 @@ function pcmcode = pcmEnCode(s)
if s>0 if s>0
pcm=pcm+bitshift(1,7); pcm=pcm+bitshift(1,7);
else else
s=abs(s) s=abs(s);
end end
for i = 0:7 for i = 0:7
if s < start_t(i+2) if s < start_t(i+2)
@ -43,30 +43,14 @@ function amp = pcmDeCode(pcmcode)
start_t=[0,2.^(4:11)]; start_t=[0,2.^(4:11)];
width_t=[1,1,2,4,8,16,32,64]; width_t=[1,1,2,4,8,16,32,64];
code=bin2dec(pcmcode); code=bin2dec(pcmcode);
isNeg=0; ucode=bitand(code,0b01111111);
if code < 128 k=bitshift(ucode,-4);
isNeg=1; m=bitand(ucode,0b00001111);
k=bitshift(bitand(code,0b01111111),-4); amp=start_t(k+1)+double(m)*width_t(k+1)+width_t(k+1)/2;
amp=start_t(k+1) ... if code<=128
+ double(mod(bitand(code,0b01111111),16)) ... amp=-amp;
* width_t(k+1); else
if isNeg=1 amp=-amp;end amp=amp;
end
end end
%PCM
function amp = pcmDecode(pcmcode)
code_table=[0,2.^(4:11)]; %
delta=[1,1,2,4,8,16,32,64]; %
codeDec=bin2dec(pcmcode); %
ucode=bitand(codeDec,0b01111111); %
k=bitshift(ucode,-4); %4
x0=code_table(k+1); %
m=bitand(ucode,0b00001111); %
x1=double(m)*delta(k+1); %
dV=x0+x1+delta(k+1)/2; %
if codeDec<=128 %
amp=-dV;
else
amp=dV;
end
end