Skip to content
Snippets Groups Projects
corTsgLinear.m 5.02 KiB
Newer Older
function [error] = corTsgLinear(hMainFig, PARA, dateMin, dateMax)
% Correct the TSG salinity time series with the Water sample.
% Use a linear fit to the water sample/tsg difference
% 
% Input
% hMainFig ..... Handle to the main GUI
% PARA ......... Parameter
% dateMin ...... the correction is applied between dateMin and date Max
% dateMax ...... the correction is applied between dateMin and date Max
%
% Output
% Error ........  1 everything OK
%       ........ -1 dateMax <= date Min
%
% The error is maximum, equal to 1, if the correction is computed with
% less than 4 samples
%
% The error minimum cannot be lower than 0.01

% Get application data
% --------------------
tsg    = getappdata( hMainFig, 'tsg_data');
jacques.grelet_ird.fr's avatar
jacques.grelet_ird.fr committed
SAMPLE = tsg.plot.sample;
% -------------------------------------------------------------------------
% Get from the checkbox the QC code on which the correction will be applied
% -------------------------------------------------------------------------

% get list of keys from hashtable tsg.qc.hash, defined inside
% tsg_initialisation.m
% -----------------------------------------------------------
qc_list = keys(tsg.qc.hash);

% TODO: define size of keptCode
% -----------------------------
%keptCode = zeros(numel(qc_list), 1);

% iterate (loop) on each key store inside hastable
% ------------------------------------------------

  % get handle of checkbox
  % ----------------------
  hCb = findobj(hMainFig, 'tag', ['TAG_CHECK_CORRECTION_' char(key)]);
    nKeptCode = nKeptCode + 1;
    keptCode(nKeptCode) = tsg.qc.hash.(key).code;
% Get PROBABLY_GOOD, PROBABLY_BAD and VALUE_CHANGED codes
% -------------------------------------------------------
PROBABLY_GOOD = tsg.qc.hash.PROBABLY_GOOD.code;
PROBABLY_BAD  = tsg.qc.hash.PROBABLY_BAD.code;
VALUE_CHANGED = tsg.qc.hash.VALUE_CHANGED.code;
Yves Gouriou's avatar
Yves Gouriou committed
% Intialisation
% 01/09/2009 : intialisation to NaN
% ---------------------------------
if isempty( tsg.([PARA '_ADJUSTED']) )  
Yves Gouriou's avatar
Yves Gouriou committed
  tsg.([PARA '_ADJUSTED'])       = NaN*ones(size(tsg.(PARA)));
  tsg.([PARA '_ADJUSTED_QC'])    = NaN*ones(size(tsg.([PARA '_QC'])));
  tsg.([PARA '_ADJUSTED_ERROR']) = NaN*ones(size(tsg.(PARA))); 
if dateMax > dateMin
  % Find samples within TIME_WINDOWS with Good, probably Good, QC
  % -------------------------------------------------------------
  ind = find( tsg.DAYD_EXT    >= dateMin &  tsg.DAYD_EXT    <= dateMax &...
              tsg.([SAMPLE '_EXT_QC']) <= PROBABLY_GOOD);

  if ~isempty(ind)

    % detect NaN in sample.SSPS_DIF due to bad QC code for tsg.SSPS
    % -------------------------------------------------------------
    ind2 = find(~isnan(tsg.EXT_DIF(ind)));

    % Compute linear fit of the TSG/SAMPLE difference
    % -----------------------------------------------
    if ~isempty(ind2) && length(ind2) > 1
      if ~isempty(tsg.EXT_DIF(ind(ind2)))
Yves Gouriou's avatar
Yves Gouriou committed

        % Linear fit applied to the difference tsg-sample
        % -----------------------------------------------
        X = tsg.DAYD_EXT(ind(ind2));
        Y = tsg.EXT_DIF(ind(ind2));
Yves Gouriou's avatar
Yves Gouriou committed

        [p, S, mu] = polyfit( X, Y, 1);

        % The correction is applied to the TSG between dateMin and dateMax using
Yves Gouriou's avatar
Yves Gouriou committed
        % a linear interpolation only on measurements with keptCode Quality
        % Codes
Yves Gouriou's avatar
Yves Gouriou committed
        % ----------------------------------------------------------------------
        for icode = 1 : length( keptCode )
          dtTsg = find( tsg.DAYD    >= dateMin  & tsg.DAYD <= dateMax &...
            tsg.([PARA '_QC']) == keptCode( icode ));
          if ~isempty( dtTsg )
            [tsg.([PARA '_ADJUSTED'])(dtTsg),...
                                    tsg.([PARA '_ADJUSTED_ERROR'])(dtTsg)] =...
                                    polyval( p, tsg.DAYD(dtTsg), S, mu);
            tsg.([PARA '_ADJUSTED'])(dtTsg) = ...
                            tsg.(PARA)(dtTsg) + tsg.([PARA '_ADJUSTED'])(dtTsg);
Yves Gouriou's avatar
Yves Gouriou committed
            tsg.([PARA '_ADJUSTED_QC'])(dtTsg) = tsg.([PARA '_QC'])(dtTsg);

            % The error is maximum, equal to 1, if the median is computed with
            % less than 4 samples
            % -------------------------------------------------------------
            if length( ind2 ) < 4
              tsg.([PARA '_ADJUSTED_ERROR'])(dtTsg) = 1;
            end
          end


        % The error minimum cannot be lower than 0.01 or equal to Inf
        % -----------------------------------------------------------
        tsg.([PARA '_ADJUSTED_ERROR'])...
                            ( tsg.([PARA '_ADJUSTED_ERROR']) < 0.01 ) = 0.01;

        tsg.([PARA '_ADJUSTED_ERROR'])...
                            (isinf(tsg.([PARA '_ADJUSTED_ERROR'])) == 1) = 0.01;
Yves Gouriou's avatar
Yves Gouriou committed
      end
  % Update tsg application data
  % ---------------------------
  setappdata( hMainFig, 'tsg_data', tsg);
  % everything OK
  % -------------
  error = 1;

else

  % DateMax <= DateMin
  % ------------------
  error = -1;