-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathquantize.m
57 lines (45 loc) · 1.35 KB
/
quantize.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
function [y, x2, errorcuantizacion] = quantize(x,opcion,nivel)
% Levels of uniform quantization
dif=(max(x)-min(x))/(nivel-1);
val=[min(x):dif:max(x)];
% y = vector to plot levels of quantization
y=kron(val',ones(1,size(x,1)));
%------------ TYPES OF QUANTIZATION
switch opcion
case 1
%------------ UNIFORM QUANTIZATION
%No amplification
xp=x;
case 2
%------------ MU LAW
mu=255;
xp=sign(x).*(log(1+mu*abs(x))/log(1 + mu));
case 3
%------------ A LAW
A=87.6;
for i=1:length(x)
if abs(x(i))<(1/A)
xp(i,1)=sign(x(i)).*((A*abs(x(i)))/(1+log(A)));
else
xp(i,1)=sign(x(i)).*((1+log(A*abs(x(i))))/(1+log(A)));
end
end
end
% Value decision: it decides where the value corresponds to one level
% according minimum distance
ref=repmat(xp',nivel,1);
x1=abs(y-ref);
[distancia x2]=min(x1);
%------------ QUANTIZATION ERROR
%Signal normalization
m=2/(nivel-1);
b=(-nivel-1)/(nivel-1);
xerror=m.*x2+b;
for i=1:size(xp,1)
if xp(i)==0
xp(i)=0.001;
end
er(i)=abs((xp(i)-xerror(i))/xp(i));
end
errorcuantizacion=mean(er);
end