forked from PeterRochford/SkillMetricsToolbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwrite_taylor_stats.m
131 lines (119 loc) · 4.29 KB
/
write_taylor_stats.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
function write_taylor_stats(filename,data,varargin)
% WRITE_TAYLOR_STATS Write statistics used in a Taylor diagram to an Excel file.
%
% write_taylor_stats(filename,data[,'option',value])
%
% This function writes to an Excel file FILENAME the statistics used to
% create a Taylor diagram for each of the data sets contained in DATA.
% The first 2 arguments must be the inputs as described below followed by
% optional arguments in the format of 'OPTION' name followed by its value
% 'VALUE'.
%
% INPUTS:
% filename : name for statistics Excel file
% data : a multi-cell data structure containing the statistics used in
% taylor diagrams
% data.sdev : Standard deviations (sigma)
% data.crmsd : Centered Root Mean Square Difference
% data.ccoef : Correlation Coefficient (r)
%
% OUTPUTS:
% None.
%
% LIST OF OPTIONS:
% A title description for each dataset TITLE can be optionally provided as
% well as a LABEL for each data point in the diagram.
%
% 'label', label : label for each data point in Taylor diagram, e.g.
% 'OC445 (CB)'
% 'overwrite', boolean : true/false flag to overwrite Excel file
% 'title', title : title descriptor for each data set in data, e.g.
% 'Expt. 01.0'
%
% See also taylor_diagram
% Get optional arguments
option = get_write_taylor_stats_options(varargin{:});
% Check for existence of file
if exist(filename,'file')
if strcmp(option.overwrite,'on')
delete(filename);
else
error(['File already exists: ' filename]);
endif
end
% Write title information to file
status = xlswrite(filename,{'Taylor Statistics'},'A2:A2');
% Determine number of cells in data structure
ncell = length(data);
% Write data for each cell
start_row = 4;
headers = {'Description','Standard Deviation','CRMSD','Correlation Coeff.'};
for i=1:ncell
if length(option.title) > 0
% Write dataset descriptor
title = cellstr(option.title{i});
row = num2str(start_row);
xlrange = ['A' row ':A' row];
status = xlswrite(filename,title,xlrange);
end
% Write column headers
row = num2str(start_row+1);
xlrange = ['A' row ':D' row];
status = xlswrite(filename,headers,xlrange);
% Write each row of data
ndata = length(data{i}.sdev);
A = [];
for j=1:ndata
if length(option.label) > 0
row_data = {option.label{j}, data{i}.sdev(j), data{i}.crmsd(j), ...
data{i}.ccoef(j)};
else
row_data = {'', data{i}.sdev(j), data{i}.crmsd(j), data{i}.ccoef(j)};
end
A = [A; row_data];
end
xlrange = ['A' num2str(start_row+2) ':D' num2str(start_row+1+ndata)];
status = xlswrite(filename,A,xlrange);
start_row = start_row + ndata + 3;
end
end % write_taylor_stats function
function option = get_write_taylor_stats_options(varargin)
%GET_WRITE_TAYLOR_STATS_OPTIONS Get optional arguments for write_taylor_stats function.
%
% [OPTION] = GET_WRITE_TAYLOR_STATS_OPTIONS(NARG,VARARGIN)
% Retrieves the NARG optional arguments supplied to the WRITE_TAYLOR_STATS
% function as a variable-length input argument list (VARARGIN), and
% returns the values in a OPTION data structure. Default values are
% assigned to selected optional arguments. Unassigned arguments do not
% appear in the OPTION data structure. The function will terminate
% with an error if an unrecognized optional argument is supplied.
%
% INPUTS:
% varagin : variable-length input argument list
%
% OUTPUTS:
% option : data structure containing option values.
% option.label : label for each data point in data set.
% option.overwrite : boolean to overwrite Excel file.
% option.title : title descriptor for data set.
% Set default parameters
option.label = [];
option.overwrite = 'off';
option.title = [];
% Load custom options, storing values in option data structure
nopt = nargin/2;
for iopt = 1 : 2 : nargin
optname = varargin{iopt};
optvalue = varargin{iopt+1};
switch lower(optname)
case 'label'
option.label = optvalue;
case 'overwrite'
option.overwrite = check_on_off(optvalue);
case 'title'
option.title=optvalue;
otherwise
error(['Unrecognized option: ' optname]);
end
end % iopt loop
end %function get_write_taylor_stats_options