function res = simulateGaussian_old(obj, params, options)
% simulateGaussian_old - performs several random simulation of the system 
% assuming Gaussian distributions of the initial states, the disturbance, 
% and the sensor noise. In order to respect hard limits of the 
% aforementioned variables, values are cut off to respect these bounds.  It 
% can be set how many simulations should be performed and to which sigma 
% value the provided bounds correspond. This function does not realize
% white noise; thus, results differ depending on the step size. Proper
% white noise simulations are provided in the class linProbSys.
%
% Syntax:
%   res = simulateGaussian_old(obj, params, options)
%
% Inputs:
%    obj - contDynamics object
%    params - system parameters
%    options - settings for random simulation
%       .points - nr of simulation runs
%       .fracVert - fraction of initial states starting from vertices
%       .fracInpVert - fraction of input values taken from the 
%                       vertices of the input set
%       .inpChanges - optional: number of times the input is changed in a simulation run
%
% Outputs:
%    res - object of class simResult storing time and states of the 
%          simulated trajectories.

% Authors:       Matthias Althoff
% Written:       19-November-2020
% Last update:   04-January-2021
%                16-November-2021 (MW, integrate W and V sets)
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

% options preprocessing
[params,options] = validateOptions(obj,params,options);

% set default setting for input changes
if ~isfield(options,'inpChanges')
    % if input changes are not defined, use length of input vector
    if isfield(params,'uTransVec')
        options.inpChanges = length(params.uTransVec(1,:));
    elseif isfield(options,'timeStep')
        options.inpChanges = ceil((params.tFinal - params.tStart)/options.timeStep);
    else
        options.inpChanges = 0;
    end
end

% check if trajectory tracking is required
if isfield(params,'uTransVec')
    trackingChanges = length(params.uTransVec(1,:));
    totalInputChanges = max(trackingChanges, options.inpChanges);
    tracking = true;

else
    % correct meaning of totalInputChanges according to its usage below:
    % = number of time intervals with different input signals
    % ... hence, we increase the user-defined value by 1
    totalInputChanges = options.inpChanges + 1;
    tracking = false;
end

% discrete-time systems input changes have to be a multiple of the
% sampling rate
if isa(obj,'linearSysDT') || isa(obj,'nonlinearSysDT')
   reachSteps = length(params.tStart:obj.dt:params.tFinal)-1;
   if totalInputChanges > reachSteps
       totalInputChanges = reachSteps;
   else
       temp = ceil(reachSteps / totalInputChanges);
       for i = temp:-1:1
          if mod(reachSteps/i,1) == 0
             totalInputChanges = reachSteps/i;
             break;
          end
       end
   end
end

% extract final time
finalTime = params.tFinal;
startTime = params.tStart;

% initialize results
t = cell(options.points,1);
x = cell(options.points,1);
y = cell(options.points,1);

% loop over all runs
for i = 1:options.points
    
    % set start and final time for partial simulation
    params.tStart = 0;
    params.tFinal = (finalTime-startTime)/totalInputChanges;
    
    % loop over input changes
    for iChange = 1:totalInputChanges-1

        % set initial state
        if iChange == 1
            params.x0 = randPoint(params.R0,1,'gaussian',options.p_conf);
            t{i}(1) = startTime;
            x{i}(1,:) = params.x0;
        else
            params.x0 = xTemp(end,:);
            params.tStart = params.tFinal;
            params.tFinal = params.tFinal + (finalTime-startTime)/totalInputChanges;
        end

        % set input (tracking)
        if tracking
            params.uTrans = params.uTransVec(:,iChange);
        end
        
        %% obtain random input
        if isfield(params,'U') && ~representsa_(params.U,'emptySet',eps)
            % set input
            uRand = randPoint(params.U,1,'gaussian',options.p_conf);

            % combine inputs (random input + tracking) 
            params.u = uRand + params.uTrans;
        else
            params.u = params.uTrans;
        end
        
        %% obtain disturbance and sensor noise
        params.w = randPoint(params.W,1,'gaussian',options.p_conf);
        params.v = randPoint(params.V,1,'gaussian',options.p_conf);

        % uncertain parameters
        if isfield(params,'paramInt')
            pInt = params.paramInt;
            params.p = pInt.inf + 2*pInt.rad*rand;
        end
        
        %% simulate dynamic system
        [tTemp,xTemp,~,yTemp] = simulate(obj,params); 
        
        t{i}(end+1:end+length(tTemp),1) = tTemp + startTime;
        x{i}(end+1:end+length(tTemp),:) = xTemp;
        y{i}(end+1:end+length(tTemp),:) = yTemp;
    end
end

% construct object storing the simulation results
res = simResult(x,t,{},y);

% ------------------------------ END OF CODE ------------------------------
