-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathopDCT2.m
98 lines (85 loc) · 3.33 KB
/
opDCT2.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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
classdef opDCT2 < opOrthogonal
%OPDCT2 Two-dimensional discrete cosine transform (DCT).
%
% opDCT2(M,N) creates a two-dimensional discrete cosine transform
% operator for matrices of size M-by-N. Input and output of the
% matrices is done in vectorized form. When N is omitted it is set
% to M by default.
% Copyright 2009, Ewout van den Berg and Michael P. Friedlander
% See the file COPYING.txt for full copyright information.
% Use the command 'spot.gpl' to locate this file.
% http://www.cs.ubc.ca/labs/scl/spot
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Properties
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
properties( SetAccess = private )
inputdims; % Dimensions of the input
end % properties - private
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Methods - public
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
methods
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% opDCT2. Constructor.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function op = opDCT2(m,n)
if nargin < 1
error('Too few arguments');
elseif nargin == 1
n = m;
end
if ~isscalar(m) || m~=round(m) || m <= 0
error('First argument to opDCT2 must be a positive integer.');
end
if ~isscalar(n) || n~=round(n) || n <= 0
error('Second argument to opDCT2 must be a positive integer.');
end
op = op@opOrthogonal('DCT2',m*n,m*n);
op.inputdims = [m,n];
end % function opDCT2
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% spy. Really only a pedagogical tool, and only practical to
% execute for DCTs that have less than, say, a dozen columns.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function spy(op)
colormap('gray');
mSig = op.inputdims(1);
nSig = op.inputdims(2);
x = zeros(mSig*nSig,1);
% Create image with single pixel.
k = 0;
for i=1:mSig
for j=1:nSig
k = k + 1;
x(k) = 1;
y = op'*x;
x(k) = 0;
subplot(nSig,mSig,k);
imagesc(reshape(y,mSig,nSig));
axis square; axis off;
end
end
end % function plot
end % methods - public
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% Methods - protected
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
methods( Access = protected )
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% multiply.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function y = multiply(op,x,mode)
m = op.inputdims(1);
n = op.inputdims(2);
if mode == 1
y = spot.utils.dct(full(reshape(x,m,n)));
y = spot.utils.dct(y')';
y = y(:);
else
y = spot.utils.idct(full(reshape(x,m,n)));
y = spot.utils.idct(y')';
y = y(:);
end
end % function multiply
end % methods - protected
end % classdef