function res = test_fourValuedSignal_not
% test_fourValuedSignal_not - unit test function of not
%
% Syntax:
%    res = test_fourValuedSignal_not
%
% Inputs:
%    -
%
% Outputs:
%    res - true/false
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: none

% Authors:       Florian Lercher
% Written:       20-February-2024
% Last update:   ---
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

% signals
tt = true;
ff = false;
signals = {
    fourValuedSignal( ...
        kleeneSignal( ...
            pointSegmentSignal([0,1,2,2.5],[tt,tt,ff,tt,tt,ff,ff,tt]), ...
                pointSegmentSignal.indicator(stlInterval(1.5,2.25,tt,ff),tt,ff) ...
        ), ...
        pointSegmentSignal.indicator(stlInterval(0.5,1,ff,tt),tt,ff) ...
    );
    fourValuedSignal( ...
        kleeneSignal( ...
            pointSegmentSignal([0,1,3,4,9.5],[tt,ff,ff,tt,ff,ff,tt,tt,tt,ff]), ...
                pointSegmentSignal.indicator(stlInterval(5,10),tt,ff) ...
        ), ...
        pointSegmentSignal.indicator(stlInterval(6,19,tt,ff),tt,ff) ...
    );
};
fourValuedVals = [fourValued.True,fourValued.Unknown,fourValued.False,fourValued.Inconclusive];

for i = 1:length(signals)
    sig = signals{i};
    actual = ~sig;
    sigInt = arrayfun(@(match) sig.findIntervals(match),fourValuedVals,'UniformOutput',false);
    actualInt = arrayfun(@(match) actual.findIntervals(match),fourValuedVals,'UniformOutput',false);
    if ~compareIntervals(sigInt{1},actualInt{3}) || ... % true becomes false
       ~compareIntervals(sigInt{2},actualInt{2}) || ... % unknown stays unknown
       ~compareIntervals(sigInt{3},actualInt{1}) || ... % false becomes true
       ~compareIntervals(sigInt{4},actualInt{4})        % inconclusive stays inconclusive
        res = false;
        return;
    end
end

res = true;

% ------------------------------ END OF CODE ------------------------------
