67 lines
2.0 KiB
Matlab
Executable File
67 lines
2.0 KiB
Matlab
Executable File
% funzione che definisce i dati per la Barretta Estensimetrica, in particolare
|
|
% tempo (TimeCrL) e Dato (Crack)
|
|
|
|
function [TimeCrL,Crack,NTCCrack,ErrCrackLink] = defDatiCrL(DatiCrackLink,...
|
|
DatiNTCCrackLink,ErrCrackLink,ChCrL,CrL_NTC,rCrL,Ndatidespike,FileName)
|
|
|
|
fileID = fopen(FileName,'a');
|
|
fmt = '%s \r';
|
|
text = 'defDatiCrL function started';
|
|
fprintf(fileID,fmt,text);
|
|
|
|
[r,c] = size(DatiCrackLink);
|
|
Ncorr = 0;
|
|
% Elimino gli eventuali Not a Number
|
|
for a = 2:r
|
|
for b = 2:c
|
|
check = isnan(DatiCrackLink(a,b));
|
|
if check == 1
|
|
DatiCrackLink(a,b) = DatiCrackLink(a-1,b);
|
|
ErrCrackLink(a,b-1) = 1;
|
|
Ncorr = Ncorr+1;
|
|
end
|
|
if CrL_NTC(b-1) == 1 % La prima colonna è una data
|
|
check = isnan(DatiNTCCrackLink(a,b));
|
|
if check == 1
|
|
DatiNTCCrackLink(a,b) = DatiNTCCrackLink(a-1,b);
|
|
if ErrCrackLink(a,b-1) == 0
|
|
ErrCrackLink(a,b-1) = 0.5;
|
|
else
|
|
ErrCrackLink(a,b-1) = 1;
|
|
end
|
|
Ncorr = Ncorr+1;
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
text = ['' num2str(Ncorr) ' NaN of Crack Link corrected by defDatiCrL function'];
|
|
fprintf(fileID,fmt,text);
|
|
|
|
TimeCrL = DatiCrackLink(:,1); % data
|
|
Crack = zeros(r,rCrL);
|
|
NTCCrack = zeros(r,rCrL);
|
|
b = 2; % colonna del primo dato
|
|
for s = 1:rCrL
|
|
Crack(:,s) = DatiCrackLink(:,b);
|
|
if ChCrL(s,1) == 1 || ChCrL(s,1) >= 2 % Solo fessurimetro
|
|
if CrL_NTC(s,1)==1 % si legge anche il termometro
|
|
NTCCrack(:,s) = DatiNTCCrackLink(:,b); % dati NTC
|
|
end
|
|
b = b+1;
|
|
end
|
|
end
|
|
|
|
Num_Dati = Ndatidespike; % numero di dati per il despike
|
|
if Num_Dati > r
|
|
Num_Dati = r;
|
|
end
|
|
for i = 1:rCrL
|
|
% despiking accelerometri
|
|
Crack(1:end-1,i) = filloutliers(Crack(1:end-1,i),'linear','movmedian',Num_Dati);
|
|
end
|
|
|
|
text = 'Data of Crack Link defined correctly. defDatiCrL function closed';
|
|
fprintf(fileID,fmt,text);
|
|
fclose(fileID);
|
|
end |