function res = test_interval_plus
% test_interval_plus - unit_test_function of plus,
%    overloaded '+' operator for intervals
%
% Syntax:
%    res = test_interval_plus
%
% Inputs:
%    -
%
% Outputs:
%    res - true/false
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: mtimes

% Authors:       Dmitry Grebenyuk
% Written:       04-January-2016
% Last update:   13-January-2016 (DG)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

tol = 1e-9;
res = true;

a = interval(0, 0);
b = interval(1, 1);
c = a + b;

% empty set
if ~representsa(b+interval(),'emptySet')
    res = false;
end

if abs( infimum(c) - 1.0 ) > tol || abs( supremum(c) - 1.0 ) > tol
	res = false;
	return;
end

a = interval(-1, 0);
b = interval(-1, 0);
c = a + b;
if abs( infimum(c) + 2.0 ) > tol || abs( supremum(c) - 0.0 ) > tol
	res = false;
	return;
end

a = interval(-1, 0);
b = interval(-2, 0);
c = a + b;
if abs( infimum(c) + 3.0 ) > tol || abs( supremum(c) - 0.0 ) > tol
	res = false;
	return;
end

a = interval(-1.0, 0);
b = interval(-2.0, 0);
c = a + b;
if abs( infimum(c) + 3.0 ) > tol || abs( supremum(c) - 0.0 ) > tol
	res = false;
	return;
end

a = interval(0, 1);
b = interval(0, 1);
c = a + b;
if abs( infimum(c) - 0.0 ) > tol || abs( supremum(c) - 2.0 ) > tol
	res = false;
	return;
end

a = interval(0, 1);
b = interval(0, 2);
c = a + b;
if abs( infimum(c) - 0.0 ) > tol || abs( supremum(c) - 3.0 ) > tol
	res = false;
	return;
end

a = interval(0, 1.0);
b = interval(0, 2.0);
c = a + b;
if abs( infimum(c) - 0.0 ) > tol || abs( supremum(c) - 3.0 ) > tol
	res = false;
	return;
end

a = interval(-2.0, 1.0);
b = interval(-3.0, 2.0);
c = a + b;
if abs( infimum(c) + 5.0 ) > tol || abs( supremum(c) - 3.0 ) > tol
	res = false;
	return;
end

a = interval(-2.0, 1.0);
c = 1 + a;
if abs( infimum(c) + 1.0 ) > tol || abs( supremum(c) - 2.0 ) > tol
	res = false;
	return;
end


a = interval([-5.0, -4.0, -3, 0, 0, 5], [-2, 0.0, 2.0, 0, 5, 8]);
b = interval([-6.1, -4.5, -3.3, 0, 0, 5], [-2.2, 0.0, 2.8, 0, 5.7, 8.2]);
c = a + b;

if abs( infimum(c(1)) + 11.1 ) > tol || abs( supremum(c(1)) + 4.2 ) > tol
	res = false;
	return;
end

if abs( infimum(c(2)) + 8.5 ) > tol || abs( supremum(c(2)) - 0.0 ) > tol
	res = false;
	return;
end

if abs( infimum(c(3)) + 6.3 ) > tol || abs( supremum(c(3)) - 4.8 ) > tol
	res = false;
	return;
end

if abs( infimum(c(4)) - 0.0 ) > tol || abs( supremum(c(4)) - 0.0 ) > tol
	res = false;
	return;
end

if abs( infimum(c(5)) - 0.0 ) > tol || abs( supremum(c(5)) - 10.7 ) > tol
	res = false;
	return;
end

if abs( infimum(c(6)) - 10.0 ) > tol || abs( supremum(c(6)) - 16.2 ) > tol
	res = false;
	return;
end

% ------------------------------ END OF CODE ------------------------------
