-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplotResults.m
110 lines (102 loc) · 3.49 KB
/
plotResults.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
%% FUNCTION NAME: readResults
% This file helps to parse and plot mat results from the solver.
% The N-dimensional data is expanded according to dimensions specified
% Only 1D,2D,3D data can be plotted.
%%
%the third optional argument is the plotting style
%available options:
%1.'linear': plot x and y linearly
%2.'linear-log': plot x versus log10(y)
%3.'km-log': plot -log10(x)*10/0.2 (x is assumed to be transmittance and converted to km) versus log(y)
%4.'none': do not plot
function plotResults(results,parameters,style)
if(~strcmp(style,'none'))
parameters_scan = struct2cell(parameters.scan);
dimensions = getCellDimensions(parameters_scan);
varnames = fieldnames(parameters.scan);
dim = length(parameters_scan);
rate1D = [results.lowerBound]; %can also plot upperBound or FWBound
if(dim>1)
rate = reshape(zeros(1,length(rate1D)),dimensions);
end
for i=1:length(rate1D)
indices=num2cell(expandIndices(i, dimensions));
rate(indices{:})=rate1D(i); %convert the cell array to comma-separated list for indexing
end
rate(rate<0)=0; %truncate the R<0 data points
handleF=figure(1);
set(handleF,'Position',[800,600,800,600]);
if(dim==1)
%1-D plot
X = parameters_scan{1};
if(strcmp(style,'linear-log'))
plot(X,log10(rate))
XAXISL=xlabel(varnames{1});
YAXISL=ylabel('log_{10}(rate)');
elseif(strcmp(style,'km-log'))
plot(-log10(X)*50.0,log10(rate))
XAXISL=xlabel('distance (km)');
YAXISL=ylabel('log_{10}(rate)');
else
plot(X,rate)
XAXISL=xlabel(varnames{1});
YAXISL=ylabel('rate');
end
XAXISL.FontSize=16;
YAXISL.FontSize=16;
elseif(dim==2)
X = parameters_scan{1};
Y = parameters_scan{2};
%2-D contour
contour(cell2mat(parameters_scan(1)),cell2mat(parameters_scan(2)),rate)
XAXISL=xlabel(varnames{1});
YAXISL=ylabel(varnames{2});
ZAXISL=zlabel('rate');
XAXISL.FontSize=16;
YAXISL.FontSize=16;
ZAXISL.FontSize=16;
elseif(dim==3)
X = parameters_scan{1};
Y = parameters_scan{2};
Z = parameters_scan{3};
%3-D contour
isosurface(X,Y,Z,rate)
XAXISL=xlabel(varnames{1});
XAXISL=ylabel(varnames{2});
XAXISL=zlabel(varnames{3});
XAXISL.FontSize=16;
YAXISL.FontSize=16;
ZAXISL.FontSize=16;
else
fprintf('dimension too high for plotting\n')
end
end
end
function indices=expandIndices(i, dimensions)
i = i - 1; % convert to 0-based index
dim = length(dimensions);
indices=[];
residue = i;
for j=1:dim
multiple = 1;
for k=j+1:dim
multiple = multiple * dimensions(k);
end
index = floor(residue/multiple);
residue = rem(residue,multiple);
indices=[indices,index];
end
indices = indices + 1; % convert to 1-based index
end
function dimensions = getCellDimensions(array)
L = length(array);
dimensions = [];
if L~=0
for k=1:L
element = cell2mat(array(k));
dimensions = [dimensions,length(element)];
end
else
dimensions=[0];
end
end