Sync from remote server: 2025-10-12 18:56:41
This commit is contained in:
103
Tilt/conv_grezziTLH.m
Executable file
103
Tilt/conv_grezziTLH.m
Executable file
@@ -0,0 +1,103 @@
|
||||
% Funzione che converte i dati grezzi in dati di accelerazione usando i
|
||||
% valori delle calibrazioni per i Tilt Link
|
||||
% accTL raccoglie le accelerazioni
|
||||
% magTL raccoglie i dati di campo magnetico
|
||||
|
||||
function [accTLH,ris_acc_TLH,tempTLH,ErrTiltLinkH] = conv_grezziTLH(rTLH,...
|
||||
accTLH,tempTLH,DCalTLHTot,tolleranzaAcc,MEMS,ErrTiltLinkH,FileName)
|
||||
|
||||
text = 'conv_grezziTLH function started';
|
||||
fileID = fopen(FileName,'a');
|
||||
fmt = '%s \r';
|
||||
fprintf(fileID,fmt,text);
|
||||
|
||||
if MEMS == 1 || MEMS == 2
|
||||
caX = DCalTLHTot(:,1);
|
||||
caY = DCalTLHTot(:,4);
|
||||
caZ = DCalTLHTot(:,7);
|
||||
pIntX = DCalTLHTot(:,2);
|
||||
pIntY = DCalTLHTot(:,5);
|
||||
pIntZ = DCalTLHTot(:,8);
|
||||
iIntX = DCalTLHTot(:,3);
|
||||
iIntY = DCalTLHTot(:,6);
|
||||
iIntZ = DCalTLHTot(:,9);
|
||||
caT = DCalTLHTot(:,10);
|
||||
intT = DCalTLHTot(:,11);
|
||||
|
||||
%% Accelerometri
|
||||
cont = 1;
|
||||
cn = 1;
|
||||
t = 1;
|
||||
% Contatore dei nodi, corregge le accelerazioni con le calibrazioni
|
||||
for ii=1:3*rTLH
|
||||
if cont==1
|
||||
accTLH(:,ii) = accTLH(:,ii)*caX(cn)+(tempTLH(:,cn)*pIntX(cn)+iIntX(cn));
|
||||
cont = cont+1;
|
||||
elseif cont==2
|
||||
accTLH(:,ii) = accTLH(:,ii)*caY(cn)+(tempTLH(:,cn)*pIntY(cn)+iIntY(cn));
|
||||
cont = cont+1;
|
||||
else
|
||||
accTLH(:,ii) = accTLH(:,ii)*caZ(cn)+(tempTLH(:,cn)*pIntZ(cn)+iIntZ(cn));
|
||||
cont = 1;
|
||||
cn = cn+1;
|
||||
end
|
||||
end
|
||||
|
||||
%% Conversione delle temperature
|
||||
for t = 1:rTLH
|
||||
tempTLH(:,t) = tempTLH(:,t)*caT(t,1) + intT(t,1);
|
||||
end
|
||||
|
||||
%% Calcolo della risultante
|
||||
[rAcc,cAcc] = size(accTLH);
|
||||
ris_acc_TLH = zeros(rAcc,cAcc/3); % matrice risultante accelerazioni
|
||||
clear i
|
||||
clear ii
|
||||
clear cont
|
||||
clear cn
|
||||
cont = 1; % contatore
|
||||
cn = 0;
|
||||
|
||||
for ii = 1:(cAcc/3) % colonne
|
||||
for i = 1:rAcc % righe
|
||||
ris_acc_TLH(i,cont) = (accTLH(i,cn*3+1)^2+accTLH(i,cn*3+2)^2+accTLH(i,cn*3+3)^2)^0.5;
|
||||
end
|
||||
cn = cn+1;
|
||||
cont = cont+1;
|
||||
end
|
||||
|
||||
%% Filtri sulla risultante
|
||||
[r,c] = size(ris_acc_TLH);
|
||||
mmm = 1;
|
||||
Err = 1;
|
||||
for j = 1:c % Nodi
|
||||
for i = 2:r % Letture
|
||||
% se il valore assoluto della differenza è maggiore della
|
||||
% tolleranza, pongo gli spostamenti giornalieri pari a 0
|
||||
if abs(ris_acc_TLH(i,j)-ris_acc_TLH(i-1,j)) > tolleranzaAcc
|
||||
accTLH(i,mmm) = accTLH(i-1,mmm);
|
||||
accTLH(i,mmm+1) = accTLH(i-1,mmm+1);
|
||||
accTLH(i,mmm+2) = accTLH(i-1,mmm+2);
|
||||
tempTLH(i,j) = tempTLH(i-1,j);
|
||||
ErrTiltLinkH(i,Err:Err+3) = 1;
|
||||
end
|
||||
if ris_acc_TLH(i,j) < 0.9 || ris_acc_TLH(i,j) > 1.1 % Il nodo è fuori taratura!
|
||||
accTLH(i,mmm) = accTLH(i-1,mmm);
|
||||
accTLH(i,mmm+1) = accTLH(i-1,mmm+1);
|
||||
accTLH(i,mmm+2) = accTLH(i-1,mmm+2);
|
||||
tempTLH(i,j) = tempTLH(i-1,j);
|
||||
ErrTiltLinkH(i,Err:Err+3) = 1;
|
||||
end
|
||||
end
|
||||
mmm = mmm+3;
|
||||
Err = Err+4;
|
||||
end
|
||||
else
|
||||
ris_acc_TLH = [];
|
||||
end
|
||||
|
||||
text = 'Raw Data of Tilt Link H converted into physical units correctly. conv_grezziTLH function ended';
|
||||
fprintf(fileID,fmt,text);
|
||||
fclose(fileID);
|
||||
|
||||
end
|
||||
Reference in New Issue
Block a user