check.m 2.39 KB
Newer Older
1
function [error_flag, message] = check(o)
2

3
% Copyright (C) 2013-2017 Dynare Team
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
%
% 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/>.

error_flag = 0;

22
[n,m] = size(o.data);
23

24
if ~isequal(m, vobs(o));
25 26 27 28 29 30 31
    error_flag = 1;
    if nargout>1
        message = ['dseries: Wrong number of variables in dseries object ''' inputname(1) '''!'];
    end
    return
end

32
if ~isequal(n,nobs(o));
33 34 35 36 37 38 39
    error_flag = 1;
    if nargout>1
        message = ['dseries: Wrong number of observations in dseries object ''' inputname(1) '''!'];
    end
    return
end

40
if ~isequal(m,numel(o.name));
41 42 43 44 45 46 47
    error_flag = 1;
    if nargout>1
        message = ['dseries: Wrong number of variable names in dseries object ''' inputname(1) '''!'];
    end
    return
end

48
if ~isequal(m,numel(o.tex));
49 50 51 52 53 54 55
    error_flag = 1;
    if nargout>1
        message = ['dseries: Wrong number of variable tex names in dseries object ''' inputname(1) '''!'];
    end
    return
end

56
if ~isequal(numel(o.name), numel(o.tex));
57 58 59 60 61 62 63
    error_flag = 1;
    if nargout>1
        message = ['dseries: The number of variable tex names has to be equal to the number of variable names in dseries object ''' inputname(1) '''!'];
    end
    return
end

64
if ~isequal(numel(unique(o.name)), numel(o.name));
65 66 67 68 69 70 71
    error_flag = 1;
    if nargout>1
        message = ['dseries: The variable names in dseries object ''' inputname(1) ''' are not unique!'];
    end
    return
end

72
if ~isequal(numel(unique(o.tex)), numel(o.tex));
73 74 75 76 77 78 79
    error_flag = 1;
    if nargout>1
        message = ['dseries: The variable tex names in dseries object ''' inputname(1) ''' are not unique!'];
    end
    return
end

80
if ~isequal(o.dates, firstdate(o):firstdate(o)+nobs(o))
81 82 83 84 85 86
    error_flag = 1;
    if nargout>1
        message = ['dseries: Wrong definition of the dates member in dseries object ''' inputname(1) '''!'];
    end
    return
end