source: issm/trunk/src/m/contrib/morlighem/gslib/gslib.m@ 20500

Last change on this file since 20500 was 20500, checked in by Mathieu Morlighem, 9 years ago

merged trunk-jpl and trunk for revision 20497

File size: 4.6 KB
Line 
1function [B E] = gslib(x,y,data,xmin,ymin,nx,ny,deltax,deltay,varargin)
2%GSLIB - use gslib for Kriging
3%
4% Usage:
5% output = gslib(x,y,data,varargin)
6
7%process options
8options = pairoptions(varargin{:});
9
10%Variogram
11nugget= getfieldvalue(options,'nugget',10);
12sill = getfieldvalue(options,'sill',164);
13range = getfieldvalue(options,'range',25763);
14
15%Kriging options
16mindata = getfieldvalue(options,'mindata',1);
17maxdata = getfieldvalue(options,'maxdata',50);
18maxsearchradius = getfieldvalue(options,'searchrange',50000);
19
20%Some intermediaries (Convert to gslib's parameters);
21c = (sill-nugget);
22a = sqrt(3)*range;
23
24%Write data file
25fid=fopen('cluster.dat','w');
26fprintf(fid,'%s\n','Data file');
27fprintf(fid,'%i\n',3);
28fprintf(fid,'%s\n','Xlocation');
29fprintf(fid,'%s\n','Ylocation');
30fprintf(fid,'%s\n','Data');
31fprintf(fid,'%g %g %g\n',[x y data]');
32fclose(fid);
33
34if 0, %GAMV
35 %Write parameter file
36 fid=fopen('gamv.par','w');
37 fprintf(fid,'\t\t\t\t%s\n','Parameters for GAMV');
38 fprintf(fid,'\t\t\t\t%s\n','*******************');
39 fprintf(fid,'\n');
40 fprintf(fid,'%s\n','START OF PARAMETERS:');
41 fprintf(fid,'%-30s %s\n','./cluster.dat' ,'\file with data');
42 fprintf(fid,'%-30s %s\n','1 2 0' ,'\columns for X, Y, Z coordinates');
43 fprintf(fid,'%-30s %s\n','1 3 ' ,'\number of variables, column number');
44 fprintf(fid,'%-30s %s\n','-1.0e21 1.0e21' ,'\trimming limits');
45 fprintf(fid,'%-30s %s\n','gamv.out' ,'\file for variogram output');
46 fprintf(fid,'%-30s %s\n','20' ,'\number of lags');
47 fprintf(fid,'%-30s %s\n','5.0' ,'\lag separation distance');
48 fprintf(fid,'%-30s %s\n','3.0' ,'\lag tolerance');
49 fprintf(fid,'%-30s %s\n','3' ,'\number of directions');
50 fprintf(fid,'%-30s %s\n','0.0 90.0 50.0 0.0 90.0 50.0','\azm, atol, bandh, dip, dtol, bandv');
51 fprintf(fid,'%-30s %s\n','0.0 22.5 25.0 0.0 22.5 25.0','\azm, atol, bandh, dip, dtol, bandv');
52 fprintf(fid,'%-30s %s\n','90. 22.5 25.0 0.0 22.5 25.0','\azm, atol, bandh, dip, dtol, bandv');
53 fprintf(fid,'%-30s %s\n','0' ,'\standardize sill? (0=no, 1=yes)');
54 fprintf(fid,'%-30s %s\n','2' ,'\number of variograms');
55 fprintf(fid,'%-30s %s\n','1 1 1' ,'\tail var., head vars., variogram type');
56 fprintf(fid,'%-30s %s\n','1 1 3' ,'\tail var., head vars., variogram type');
57 fclose(fid);
58
59 %Call gamv
60 system([issmdir() '/externalpackages/gslib/install/gamv gamv.par']);
61
62else, %Kriging KB2D
63 %Write parameter file
64 fid=fopen('kb2d.par','w');
65 fprintf(fid,'\t\t\t\t%s\n','Parameters for KB2D');
66 fprintf(fid,'\t\t\t\t%s\n','*******************');
67 fprintf(fid,'\n');
68 fprintf(fid,'%s\n','START OF PARAMETERS:');
69 fprintf(fid,'%-30s %s\n','./cluster.dat' ,'\file with data');
70 fprintf(fid,'%-30s %s\n','1 2 3' ,'\columns for X, Y and variable');
71 fprintf(fid,'%-30s %s\n','-1.0e21 1.0e21' ,'\trimming limits');
72 fprintf(fid,'%-30s %s\n','0' ,'\debugging level: 0,1,2,3');
73 fprintf(fid,'%-30s %s\n','kb2d.dbg' ,'\file for debuggging output');
74 fprintf(fid,'%-30s %s\n','kb2d.out' ,'\file for kriged output');
75 fprintf(fid,'%-30s %s\n',num2str([nx xmin deltax],'%i %10g %6g') ,'\nx, xmn, xsiz');
76 fprintf(fid,'%-30s %s\n',num2str([ny ymin deltay],'%i %10g %6g') ,'\nx, xmn, xsiz');
77 fprintf(fid,'%-30s %s\n','1 1' ,'\x and y block discretization');
78 fprintf(fid,'%-30s %s\n',num2str([mindata maxdata],'%6g') ,'\min and max data for kriging');
79 fprintf(fid,'%-30s %s\n',num2str(maxsearchradius,'%6g') ,'\max search radius');
80 fprintf(fid,'%-30s %s\n','1 2.302' ,'\0=SK, 1=OK, (mean if SK)');
81 fprintf(fid,'%-30s %s\n',['1 ' num2str(nugget)] ,'\nst, nugget effect');
82 fprintf(fid,'%-30s %s\n',['3 ' num2str([c 0.0 a a],'%10g')],'\it, c, azm, a_max, a_min');
83 fclose(fid);
84
85 tic;system([issmdir() '/externalpackages/gslib/install/kb2d kb2d.par']);toc;
86 delete('kb2d.par');
87
88 %Read output
89 fid=fopen('kb2d.out','r');
90 while (~feof(fid)),
91 A=fscanf(fid,'%s',1);
92 if strcmp(A,'KB2D');
93 A=fscanf(fid,'%s',1); %Read output
94 params=fscanf(fid,'%i %i %i %i %g %g %g %g %g %g %1',[11 1]);
95 elseif strcmp(A,' Estimate'),
96 continue;
97 elseif strcmp(A,'Estimation'),
98 A=fscanf(fid,'%s',1); %Read Variance
99 A=fscanf(fid,'%g %g',[params(1) params(2)*params(3)]);
100 B=A(1,:); B=reshape(B,[params(3),params(2)])';
101 E=A(2,:); E=reshape(E,[params(3),params(2)])';
102 else
103 %do nothing
104 end
105 end
106 fclose(fid);
107end
Note: See TracBrowser for help on using the repository browser.