-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdemo_loadgps.m
85 lines (71 loc) · 2.06 KB
/
demo_loadgps.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
clear
%
% Download the data directly from the source
% (note the station name and reference frame in the URL)
%
% If your computer doesn't like the "curl" command, skip this line and just
% use a file you downloaded from the website by right-click SaveAs as before.
%
% !curl http://geodesy.unr.edu/gps_timeseries/tenv3/plates/OK/J175.OK.tenv3 > J175.OK.tenv3
% !curl http://geodesy.unr.edu/gps_timeseries/tenv3/plates/NA/P404.NA.tenv3 > P404.NA.tenv3
%
% Load the data
%
%fid=fopen('P404.NA.tenv3.txt');
fid=fopen('P396.NA.tenv3.txt');
%fid=fopen('P395.NA.tenv3.txt');
C=textscan(fid,'%s %s %f %f %f %f %f %f %f %f %f %f %f %f %f %f %f %f %f %f %f %f %f','headerlines',1);
fclose(fid);
t=C{3};
x=C{9};
y=C{11};
z=C{13};
stationlat=C{21}(1);
stationlon=C{22}(1);
%
% Plot the data
%
figure(1),clf,
subplot(311),plot(t,x,'.-'),grid,ylabel('east (m)'),
% title('J175 in fixed Okhotsk reference frame')
subplot(3,1,2),plot(t,y,'.-'),grid,ylabel('north (m)')
subplot(3,1,3),plot(t,z,'.-'),grid,ylabel('elevation (m)')
%
% Calculate the velocity of each component
%
pX=polyfit(t,x,1);
pY=polyfit(t,y,1);
pZ=polyfit(t,z,1);
vX=pX(1);
vY=pY(1);
vZ=pZ(1);
%
% Add the best fit line to the original plot
%
subplot(311),hold on,plot(t,polyval(pX,t),'linewidth',3)
subplot(312),hold on,plot(t,polyval(pY,t),'linewidth',3)
subplot(313),hold on,plot(t,polyval(pZ,t),'linewidth',3)
%
% Plot the residuals! (what's left after you subtract the trend)
%
figure(2),clf
subplot(311),plot(t,x-polyval(pX,t),'linewidth',3)
subplot(312),plot(t,y-polyval(pY,t),'linewidth',3)
subplot(313),plot(t,z-polyval(pZ,t),'linewidth',3)
%
% Load the lazy map data and make a simple velocity plot
%
c=load('coastfile.xy.txt');
b=load('politicalboundaryfile.xy.txt');
figure(3),clf
plot(c(:,1),c(:,2))
hold on
plot(b(:,1),b(:,2),'color',[1 1 1]*0.75)
plot(stationlon,stationlat,'^k')
quiver(stationlon,stationlat,vX,vY,1e2)
scatter(stationlon,stationlat,50,vZ*1000,'filled')
colorbar
caxis([-1,1])
colormap(jet)
xlim([-127,-115])
ylim([41,50])