Commit 76682e8cb56b59325818dff1dde8468ba8642c3d
1 parent
b7831cf1aa
Exists in
master
allanplot_cov: add detrend options
Showing 1 changed file with 9 additions and 6 deletions Inline Diff
allanplot_cov.m
#!/usr/bin/octave-cli --persist | 1 | 1 | #!/usr/bin/octave-cli --persist | |
2 | 2 | |||
filename = argv(){1}; | 3 | 3 | filename = argv(){1}; | |
col1 = eval(argv(){2}); | 4 | 4 | col1 = eval(argv(){2}); | |
col2 = eval(argv(){3}); | 5 | 5 | col2 = eval(argv(){3}); | |
mult1 = eval(argv(){4}); | 6 | 6 | fs = eval(argv(){4}); | |
mult2 = eval(argv(){5}); | 7 | 7 | mult1 = eval(argv(){5}); | |
arg_save = eval(argv(){6}); | 8 | 8 | mult2 = eval(argv(){6}); | |
9 | driftRem1 = eval(argv(){7}); | |||
10 | driftRem2 = eval(argv(){8}); | |||
11 | arg_save = eval(argv(){9}); | |||
9 | 12 | |||
if length(col1) == length(mult1) | 10 | 13 | if length(col1) == length(mult1) | |
figure | 11 | 14 | figure | |
hold all | 12 | 15 | hold all | |
grid on | 13 | 16 | grid on | |
cc = 'bkcgmry'; | 14 | 17 | cc = 'bkcgmry'; | |
for i = [1:length(col1)] | 15 | 18 | for i = [1:length(col1)] | |
data.freq = load(filename)(:,col1(i)).*mult1(i); | 16 | 19 | data.freq = load(filename)(:,col1(i)).*mult1(i); | |
data.freq2 = load(filename)(:,col2(i)).*mult2(i); | 17 | 20 | data.freq2 = load(filename)(:,col2(i)).*mult2(i); | |
data.freq = data.freq(1:min(length(data.freq), length(data.freq2))); | 18 | 21 | data.freq = data.freq(1:min(length(data.freq), length(data.freq2))); | |
data.freq2 = data.freq2(1:min(length(data.freq), length(data.freq2))); | 19 | 22 | data.freq2 = data.freq2(1:min(length(data.freq), length(data.freq2))); | |
if eval(argv(){end-1}) == 1 | 20 | 23 | if driftRem1 == 1 | |
printf('\ndata1 drift removed\n\n') | 21 | 24 | printf('\ndata1 drift removed\n\n') | |
data.freq = detrend(data.freq); | 22 | 25 | data.freq = detrend(data.freq); | |
end | 23 | 26 | end | |
if eval(argv(){end}) == 1 | 24 | 27 | if driftRem2 == 1 | |
printf('\ndata2 drift removed\n\n') | 25 | 28 | printf('\ndata2 drift removed\n\n') | |
data.freq2 = detrend(data.freq2); | 26 | 29 | data.freq2 = detrend(data.freq2); | |
end | 27 | 30 | end | |
data.rate = 1; | 28 | 31 | data.rate = fs(i); | |
[ad, S, err, tau] = allan_cov(data, horzcat(reshape([1:0.1:9]'.*10.^[0:round(log10(length(data.freq)))-1],1,[]), 10^(round(log10(length(data.freq)))-1))./data.rate, strcat(strsplit(filename, '/'){end}, num2str(i)), 0); | 29 | 32 | [ad, S, err, tau] = allan_cov(data, horzcat(reshape([1:0.1:9]'.*10.^[0:round(log10(length(data.freq)))-1],1,[]), 10^(round(log10(length(data.freq)))-1))./data.rate, strcat(strsplit(filename, '/'){end}, num2str(i)), 0); | |
loglogerr(tau, ad, err, strcat(cc(mod(i, length(cc))), '-s')) | 30 | 33 | loglogerr(tau, ad, err, strcat(cc(mod(i, length(cc))), '-s')) | |
leg{i} = strcat(filename, ' cov col', num2str(col1(i)), ' col', num2str(col2(i))); | 31 | 34 | leg{i} = strcat(filename, ' cov col', num2str(col1(i)), ' col', num2str(col2(i))); | |
axis(10.^ceil(log10([tau(1), tau(end)]))) | 32 | 35 | axis(10.^ceil(log10([tau(1), tau(end)]))) | |
hold on | 33 | 36 | hold on | |
if arg_save ==1 | 34 | 37 | if arg_save ==1 | |
filenameout = strcat(strsplit(filename,'.'){1},'-cov-',num2str(col1),num2str(col2),'.sig') | 35 | 38 | filenameout = strcat(strsplit(filename,'.'){1},'-cov-',num2str(col1),num2str(col2),'.sig') | |
datatosave = horzcat(tau', ad', err'); | 36 | 39 | datatosave = horzcat(tau', ad', err'); | |
save('-text', filenameout , 'datatosave'); | 37 | 40 | save('-text', filenameout , 'datatosave'); | |
end | 38 | 41 | end | |
end | 39 | 42 | end | |
legend(leg) | 40 | 43 | legend(leg) | |
input("Press to continue..."); | 41 | 44 | input("Press to continue..."); | |
end | 42 | 45 | end | |
exit | 43 | 46 | exit | |
44 | 47 | |||