dynare/matlab/@dates/sort.m

78 lines
1.8 KiB
Matlab
Raw Normal View History

function dd = sort(dd) % --*-- Unitary tests --*--
% Sort method for dates class.
%
% INPUTS
% o dd dates object.
%
% OUTPUTS
% o dd dates object (with dates sorted by increasing order).
2011-10-20 15:02:58 +02:00
2013-06-12 16:42:09 +02:00
% Copyright (C) 2011-2013 Dynare Team
2011-10-20 15:02:58 +02:00
%
% This file is part of Dynare.
%
% Dynare is free software: you can redistribute it and/or modify
% it under the terms of the GNU General Public License as published by
% the Free Software Foundation, either version 3 of the License, or
% (at your option) any later version.
%
% Dynare is distributed in the hope that it will be useful,
% but WITHOUT ANY WARRANTY; without even the implied warranty of
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
% GNU General Public License for more details.
%
% You should have received a copy of the GNU General Public License
% along with Dynare. If not, see <http://www.gnu.org/licenses/>.
2013-11-06 08:39:55 +01:00
if isequal(dd.ndat,1)
2011-10-20 15:02:58 +02:00
return
end
dd.time = sortrows(dd.time,[1,2]);
%@test:1
%$ % Define some dates
2011-10-21 11:38:24 +02:00
%$ B1 = '1953Q4';
2011-10-20 15:02:58 +02:00
%$ B2 = '1950Q2';
%$ B3 = '1950Q1';
2011-10-21 11:38:24 +02:00
%$ B4 = '1945Q3';
2011-10-20 15:02:58 +02:00
%$
%$ % Define expected results.
%$ e.time = [1945 3; 1950 1; 1950 2; 1953 4];
%$ e.freq = 4;
%$ e.ndat = 4;
%$
%$ % Call the tested routine.
2013-10-15 15:36:21 +02:00
%$ d = dates(B1,B2,B3,B4);
%$ d = d.sort;
2012-11-14 11:44:04 +01:00
%$
2011-10-20 15:02:58 +02:00
%$ % Check the results.
%$ t(1) = dyn_assert(d.time,e.time);
%$ t(2) = dyn_assert(d.freq,e.freq);
%$ t(3) = dyn_assert(d.ndat,e.ndat);
%$ T = all(t);
%@eof:1
%@test:1
%$ % Define some dates
%$ B1 = '1953Q4';
%$ B2 = '1950Q2';
%$ B3 = '1950Q1';
%$ B4 = '1945Q3';
%$
%$ % Define expected results.
%$ e.time = [1945 3; 1950 1; 1950 2; 1953 4];
%$ e.freq = 4;
%$ e.ndat = 4;
%$
%$ % Call the tested routine.
2013-10-15 15:36:21 +02:00
%$ d = dates(B1,B2,B3,B4);
%$ d = d.sort();
%$
%$ % Check the results.
%$ t(1) = dyn_assert(d.time,e.time);
%$ t(2) = dyn_assert(d.freq,e.freq);
%$ t(3) = dyn_assert(d.ndat,e.ndat);
%$ T = all(t);
2011-10-20 15:02:58 +02:00
%@eof:1