mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-10 09:20:32 +00:00
MOD: matlab trk_cmd files updated
This commit is contained in:
parent
4d5a92b5ad
commit
f466687b23
@ -23,6 +23,7 @@ clearvars
|
||||
% end
|
||||
SPEED_OF_LIGHT_M_S=299792458.0;
|
||||
Lambda_GPS_L1=0.1902937;
|
||||
GPS_L1_freq_hz=1575.42e6;
|
||||
%%
|
||||
samplingFreq=5000000;
|
||||
channels=6;
|
||||
@ -34,12 +35,13 @@ plot_reference=1;
|
||||
load_observables=1;
|
||||
advance_vtl_data_available=1;
|
||||
load_vtl=1;
|
||||
load_tfk_cmd=1;
|
||||
|
||||
navSolution = GnssSDR2struct('PVT_raw.mat');
|
||||
refSolution = SpirentMotion2struct('..\log_spirent\motion_V1_SPF_LD_05.csv');
|
||||
%%
|
||||
if(load_observables)
|
||||
load observables\observable_raw.mat
|
||||
load observables\observables_raw.mat
|
||||
refSatData = SpirentSatData2struct('..\log_spirent\sat_data_V1A1_SPF_LD_05.csv');
|
||||
rx_PRN=[28 4 17 15 27 9]; % for SPF_LD_05.
|
||||
end
|
||||
@ -53,6 +55,25 @@ if(load_vtl)
|
||||
vtlSolution = Vtl2struct('dump_vtl_file.csv');
|
||||
end
|
||||
|
||||
if(load_tfk_cmd)
|
||||
trkSolution=trk2struct('dump_trk_file.csv');
|
||||
|
||||
%% split by solution type
|
||||
figure;sgtitle('real doppler')
|
||||
for chan=0:4
|
||||
eval(['[indCH' num2str(chan) ',~]= find(trkSolution.dopp.real==chan);'])
|
||||
eval(['Dopp_real_CH' num2str(chan) '=trkSolution.dopp.real(indCH' num2str(chan) ',2);'])
|
||||
eval(['subplot(2,3,' num2str(chan+1) ');plot(Dopp_real_CH' num2str(chan) ')'])
|
||||
end
|
||||
figure;sgtitle('cmd doppler')
|
||||
for chan=0:4
|
||||
eval(['[indCH' num2str(chan) ',~]= find(trkSolution.dopp.cmd==chan);'])
|
||||
eval(['Dopp_cmd_CH' num2str(chan) '=trkSolution.dopp.cmd(indCH' num2str(chan) ',2);'])
|
||||
eval(['subplot(2,3,' num2str(chan+1) ');plot(Dopp_cmd_CH' num2str(chan) ')'])
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
%% calculate LOS Rx-sat if advance_vtl_data_available=1
|
||||
|
||||
if(advance_vtl_data_available)
|
||||
|
56
src/utils/matlab/vtl/trk2struct.m
Normal file
56
src/utils/matlab/vtl/trk2struct.m
Normal file
@ -0,0 +1,56 @@
|
||||
%% Import data from text file
|
||||
% Script for importing data from the following text file:
|
||||
%
|
||||
% filename: D:\virtualBOX_VM\ubuntu20\ubuntu20\shareFolder\myWork\results\spirent_usrp_airing\dump_vtl_file.csv
|
||||
%
|
||||
% %
|
||||
% -------------------------------------------------------------------------
|
||||
% USE EXAMPLE: vtlSolution = Vtl2struct('dump_vtl_file.csv')
|
||||
% -------------------------------------------------------------------------
|
||||
|
||||
% Auto-generated by MATLAB on 24-Nov-2022 17:34:27
|
||||
function [trkSolution] = trk2struct(path_to_trk_csv)
|
||||
%% Set up the Import Options and import the data
|
||||
opts = delimitedTextImportOptions("NumVariables", 4);
|
||||
|
||||
% Specify range and delimiter
|
||||
opts.DataLines = [1, Inf];
|
||||
opts.Delimiter = ",";
|
||||
|
||||
% Specify column names and types
|
||||
opts.VariableNames = ["doppler_corr", "VarName2", "VarName3", "VarName4"];
|
||||
opts.VariableTypes = ["char", "double", "double", "double"];
|
||||
|
||||
% Specify file level properties
|
||||
opts.ExtraColumnsRule = "ignore";
|
||||
opts.EmptyLineRule = "read";
|
||||
|
||||
% Specify variable properties
|
||||
opts = setvaropts(opts, "doppler_corr", "WhitespaceRule", "preserve");
|
||||
opts = setvaropts(opts, "doppler_corr", "EmptyFieldRule", "auto");
|
||||
|
||||
% Import the data
|
||||
dumptrackingfile = readtable(path_to_trk_csv, opts);
|
||||
|
||||
%% Convert to output type
|
||||
dumptrackingfile = table2cell(dumptrackingfile);
|
||||
numIdx = cellfun(@(x) ~isnan(str2double(x)), dumptrackingfile);
|
||||
dumptrackingfile(numIdx) = cellfun(@(x) {str2double(x)}, dumptrackingfile(numIdx));
|
||||
|
||||
%% Clear temporary variables
|
||||
clear numIdx opts
|
||||
|
||||
trkSolution.dopp=[];
|
||||
|
||||
%% split by solution type
|
||||
[indDopp,~]= find(strcmp(dumptrackingfile, 'doppler_corr'));
|
||||
|
||||
trk_dopp=dumptrackingfile(indDopp,:);trk_dopp(:,1)=[];
|
||||
|
||||
trk_dopp=cell2mat(trk_dopp);
|
||||
|
||||
for i=1:length(trk_dopp)
|
||||
trkSolution.dopp.real=[trk_dopp(:,1) trk_dopp(:,3)];
|
||||
trkSolution.dopp.cmd=[trk_dopp(:,1) trk_dopp(:,2)];
|
||||
end
|
||||
end
|
@ -23,15 +23,16 @@ clearvars
|
||||
% end
|
||||
SPEED_OF_LIGHT_M_S=299792458.0;
|
||||
Lambda_GPS_L1=0.1902937;
|
||||
point_of_closure=6000;
|
||||
GPS_L1_freq_hz=1575.42e6;
|
||||
point_of_closure=3400;
|
||||
|
||||
%% ==================== VARIANCES =============================
|
||||
pos_var=100;%m^2
|
||||
vel_var=10;%m^2/s^2
|
||||
clk_bias_var=40;%m^2
|
||||
clk_drift_var=1500;%m^2/s^2
|
||||
pr_var=10;%m^2
|
||||
pr_dot_var=30;%m^2/s^2
|
||||
pr_var=20;%m^2
|
||||
pr_dot_var=2;%m^2/s^2
|
||||
|
||||
% CARLES PAPER LTE GNSS VTL
|
||||
% pos_var=2;%m^2
|
||||
@ -55,14 +56,14 @@ load_observables=1;
|
||||
navSolution = GnssSDR2struct('PVT_raw.mat');
|
||||
refSolution = SpirentMotion2struct('..\log_spirent\motion_V1_SPF_LD_05.csv');
|
||||
%
|
||||
load observables\observable_raw.mat
|
||||
load observables\observables_raw.mat
|
||||
% refSatData = SpirentSatData2struct('..\log_spirent\sat_data_V1A1_SPF_LD_05.csv');
|
||||
rx_PRN=[28 4 17 15 27 9]; % for SPF_LD_05.
|
||||
load('PVT_raw.mat','sat_posX_m','sat_posY_m','sat_posZ_m','sat_velX','sat_velY'...
|
||||
,'sat_velZ','sat_prg_m','clk_bias_s','clk_drift','sat_dopp_hz','user_clk_offset')
|
||||
|
||||
if(load_observables)
|
||||
load observables\observable_raw.mat
|
||||
load observables\observables_raw.mat
|
||||
refSatData = SpirentSatData2struct('..\log_spirent\sat_data_V1A1_SPF_LD_05.csv');
|
||||
end
|
||||
%%
|
||||
|
@ -23,42 +23,58 @@ clearvars
|
||||
SPEED_OF_LIGHT_M_S=299792458.0;
|
||||
Lambda_GPS_L1=0.1902937;
|
||||
%%
|
||||
trkSolution=trk2struct('dump_trk_file.csv');
|
||||
|
||||
%% split by solution type
|
||||
figure;sgtitle('real doppler')
|
||||
for chan=0:4
|
||||
load(['tracking\tracking_raw' num2str(chan) '.mat']);
|
||||
tracking_channel(chan+1).PRN=PRN;
|
||||
tracking_channel(chan+1).CN0_SNV_dB_Hz=CN0_SNV_dB_Hz;
|
||||
tracking_channel(chan+1).carrier_doppler_hz=carrier_doppler_hz;
|
||||
tracking_channel(chan+1).carrier_doppler_rate_hz=carrier_doppler_rate_hz;
|
||||
tracking_channel(chan+1).code_error_chips=code_error_chips;
|
||||
tracking_channel(chan+1).code_freq_chips=code_freq_chips;
|
||||
tracking_channel(chan+1).code_freq_rate_chips=code_freq_rate_chips;
|
||||
tracking_channel(chan+1).acc_carrier_phase_rad=acc_carrier_phase_rad;
|
||||
|
||||
clearvars -except tracking_channel chan
|
||||
eval(['[indCH' num2str(chan) ',~]= find(trkSolution.dopp.real==chan);'])
|
||||
eval(['Dopp_real_CH' num2str(chan) '=trkSolution.dopp.real(indCH' num2str(chan) ',2);'])
|
||||
eval(['subplot(2,3,' num2str(chan+1) ');plot(Dopp_real_CH' num2str(chan) ')'])
|
||||
end
|
||||
%%
|
||||
figure
|
||||
for chan=1:5
|
||||
subplot(2,3,chan);
|
||||
plot(tracking_channel(chan).carrier_doppler_hz);
|
||||
grid minor
|
||||
figure;sgtitle('cmd doppler')
|
||||
for chan=0:4
|
||||
eval(['[indCH' num2str(chan) ',~]= find(trkSolution.dopp.cmd==chan);'])
|
||||
eval(['Dopp_cmd_CH' num2str(chan) '=trkSolution.dopp.cmd(indCH' num2str(chan) ',2);'])
|
||||
eval(['subplot(2,3,' num2str(chan+1) ');plot(Dopp_cmd_CH' num2str(chan) ')'])
|
||||
end
|
||||
sgtitle('carrier doppler hz channel')
|
||||
%%
|
||||
figure
|
||||
for chan=1:5
|
||||
subplot(2,3,chan);
|
||||
plot(tracking_channel(chan).CN0_SNV_dB_Hz);
|
||||
grid minor
|
||||
end
|
||||
sgtitle('CN0 SNV dB Hz channel')
|
||||
|
||||
%%
|
||||
figure
|
||||
for chan=1:5
|
||||
subplot(2,3,chan);
|
||||
plot(tracking_channel(chan).acc_carrier_phase_rad);
|
||||
grid minor
|
||||
end
|
||||
sgtitle('acc carrier phase rad')
|
||||
% for chan=0:4
|
||||
% load(['tracking\tracking_raw' num2str(chan) '.mat']);
|
||||
% tracking_channel(chan+1).PRN=PRN;
|
||||
% tracking_channel(chan+1).CN0_SNV_dB_Hz=CN0_SNV_dB_Hz;
|
||||
% tracking_channel(chan+1).carrier_doppler_hz=carrier_doppler_hz;
|
||||
% tracking_channel(chan+1).carrier_doppler_rate_hz=carrier_doppler_rate_hz;
|
||||
% tracking_channel(chan+1).code_error_chips=code_error_chips;
|
||||
% tracking_channel(chan+1).code_freq_chips=code_freq_chips;
|
||||
% tracking_channel(chan+1).code_freq_rate_chips=code_freq_rate_chips;
|
||||
% tracking_channel(chan+1).acc_carrier_phase_rad=acc_carrier_phase_rad;
|
||||
%
|
||||
% clearvars -except tracking_channel chan
|
||||
% end
|
||||
% %%
|
||||
% figure
|
||||
% for chan=1:5
|
||||
% subplot(2,3,chan);
|
||||
% plot(tracking_channel(chan).carrier_doppler_hz);
|
||||
% grid minor
|
||||
% end
|
||||
% sgtitle('carrier doppler hz channel')
|
||||
% %%
|
||||
% figure
|
||||
% for chan=1:5
|
||||
% subplot(2,3,chan);
|
||||
% plot(tracking_channel(chan).CN0_SNV_dB_Hz);
|
||||
% grid minor
|
||||
% end
|
||||
% sgtitle('CN0 SNV dB Hz channel')
|
||||
%
|
||||
% %%
|
||||
% figure
|
||||
% for chan=1:5
|
||||
% subplot(2,3,chan);
|
||||
% plot(tracking_channel(chan).acc_carrier_phase_rad);
|
||||
% grid minor
|
||||
% end
|
||||
% sgtitle('acc carrier phase rad')
|
Loading…
Reference in New Issue
Block a user