-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathistdct.m
56 lines (47 loc) · 1.21 KB
/
istdct.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
function y = istdct(X,R,M,K,N)
% y = ipSTFT2(X,M,K)
% Inverse Short-time Fourier Transform (inverse of pSTFT2).
% Input:
% X - STFT produced by 'pSTFT2'
% R - block length
% M - over-sampling rate
% K - window shape parameter
% N - length of signal
% Note: Inversion of first and last block of signal is not implemented
%
% Last Edit: 12/28/2016.
% Contact: Ankit Parekh ([email protected](
% (c) Ivan Selesnick ([email protected])
[Nfft, Nc] = size(X); % get size
n = (1:R) - 0.5;
win = sin(pi*n/R).^K; % make cosine window
NC = sqrt(sum(win.^2) * M * Nfft/R); % normalization constant
Y = idct(X); % inverse FFT of each column of X
Y = Y(1:R,:); % truncate down to block length
Y = bsxfun(@times, Y, win');
y = zeros(1,R/M*(Nc+M-1));
i = 0;
for k = 1:Nc
y(i + (1:R)) = y(i + (1:R)) + Y(:,k).';
i = i + R/M;
end
y = NC * y(R+(1:N));
y = y*(2/M);
if K == 1
A = 1;
elseif K == 2
A = 4/3;
elseif K == 3
A = 8/5;
elseif K == 4
A = 2^6/(5*7);
elseif K == 5
A = 128/63;
elseif K == 6
A = 2^9 / (3*7*11);
elseif K == 7
A = 2^10 / (3*11*13);
else
disp('Implmented only for K = 1,...,7')
end
y = A*y';