function res = example_neuralNetwork_verify_04_safe_falsified()
% example_neuralNetwork_verify_04_safe_falsified - example for 
%    neural network falsification using an safe set as specification
%
% Syntax:
%    res = example_neuralNetwork_verify_04_safe_falsified()
%
% Inputs:
%    no
%
% Outputs:
%    res - boolean 

% Authors:       Tobias Ladner
% Written:       01-December-2022
% Last update:   ---
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

rng(17)

% get a neural network
nn = neuralNetwork.generateRandom( ...
    'NrInputs', 2, ...
    'NrOutputs', 2, ...
    'ActivationFun', 'relu', ...
    'NrLayers', 3 ...
);

% input set
X0 = interval.generateRandom('Dimension', 2);

% specification
spec = specification(interval([0; 0], [7;0.97]), 'safeSet');

% run verification
doPlot = length(dbstack) == 1; % only plot if called directly.
[isVerified, x] = nn.verify(X0, spec, 'Plot',doPlot,'Verbose',doPlot);

if doPlot
    if isVerified
        disp("Verification was successful!")
    else
        disp("Verification was not succesful.")
        disp("Counterexample:")
        disp(x)
        disp("In output space:")
        y = nn.evaluate(x);
        disp(y)
    end
end

% falsificaiton should succeed
res = ~isVerified;
    
% ------------------------------ END OF CODE ------------------------------
