Files
matlab-python/ATD/defDatiWEL.m

70 lines
2.4 KiB
Matlab
Executable File

% funzione che definisce i dati per la Barretta Estensimetrica, in particolare
% tempo (TimeEL) e Dato (Extensometer)
function [TimeWEL,WireExtensometer,NTCWireExtensometer,ErrWireExtensometerLink]...
= defDatiWEL(DatiWireExtensometerLink,DatiNTCWireExtensometerLink,...
ErrWireExtensometerLink,ChWEL,WEL_NTC,rWEL,Ndatidespike,FileName)
fileID = fopen(FileName,'a');
fmt = '%s \r';
text = 'defDatiWEL function started';
fprintf(fileID,fmt,text);
[r,c] = size(DatiWireExtensometerLink);
Ncorr = 0;
% Elimino gli eventuali Not a Number
for a = 2:r
for b = 2:c
check = isnan(DatiWireExtensometerLink(a,b));
if check == 1
DatiWireExtensometerLink(a,b) = DatiWireExtensometerLink(a-1,b);
ErrWireExtensometerLink(a,b-1) = 1;
Ncorr = Ncorr+1;
end
if WEL_NTC(b-1) == 1 % La prima colonna è una data
check = isnan(DatiNTCWireExtensometerLink(a,b));
if check == 1
DatiNTCWireExtensometerLink(a,b) = DatiNTCWireExtensometerLink(a-1,b);
if ErrWireExtensometerLink(a,b-1) == 0
ErrWireExtensometerLink(a,b-1) = 0.5;
else
ErrWireExtensometerLink(a,b-1) = 1;
end
Ncorr = Ncorr+1;
end
end
end
end
text = ['' num2str(Ncorr) ' NaN of Wire Extensometer Link corrected by defDatiWEL function'];
fprintf(fileID,fmt,text);
TimeWEL = DatiWireExtensometerLink(:,1); % data
WireExtensometer = zeros(r,rWEL); % dati Wire Extensometer Link
NTCWireExtensometer = zeros(r,rWEL);
b = 2; % colonna del primo dato
for s = 1:rWEL
WireExtensometer(:,s) = DatiWireExtensometerLink(:,b); % dati Wire Extensometer Link
if ChWEL(s,1) == 1 || ChWEL(s,1) >= 2 % Solo estensimetro
if WEL_NTC(s,1)==1 % si legge anche il termometro
NTCWireExtensometer(:,s) = DatiNTCWireExtensometerLink(:,b); % dati Extensometer Link
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:rWEL
% despiking Barrette Estensimetriche
WireExtensometer(1:end-1,i) = filloutliers(WireExtensometer(1:end-1,i),'linear','movmedian',Num_Dati);
end
text = 'Data of Wire Extensometer Link defined correctly. defDatiWEL function closed';
fprintf(fileID,fmt,text);
fclose(fileID);
end