-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathAnalyszeRunTimeResults0002.m
102 lines (72 loc) · 3 KB
/
AnalyszeRunTimeResults0002.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
% ----------------------------------------------------------------------------------------------- %
% Analyze MATLAB & Julia Run Time Results - Test Suite 0002
% Reference:
% 1. C.
% Remarks:
% 1. W.
% TODO:
% 1. A
% Release Notes:
% - 1.0.001 11/02/2017 Royi Avital
% * Added support for Julia Optimized.
% * Saving figures into Figures sub folder.
% - 1.0.000 09/02/2017 Royi Avital
% * First release version.
% ----------------------------------------------------------------------------------------------- %
%% Setting Enviorment Parameters
run('InitScript.m');
RUN_TIME_DATA_FOLDER = 'RunTimeData\';
MATLAB_IDX = 1;
JULIA_IDX = 2;
MATLAB_RUN_TIME_FILE_NAME = 'RunTimeMatlab0002.csv';
JULIA_RUN_TIME_FILE_NAME = 'RunTimeJulia0002.csv';
JULIA_MKL_RUN_TIME_FILE_NAME = 'RunTimeJulia0002MKL.csv';
cLegendString = {['MATLAB'], ['Julia'], ['Julia MKL.jl']};
figureIdx = 6;
figureCounterSpec = '%04d';
vMatrixSize = csvread('vMatrixSizeFull.csv');
cFunctionString = {['Matrix Exponential'], ['Matrix Square Root'], ['SVD'], ...
['Eigen Decomposition'], ['Cholesky Decomposition'], ['Matrix Inversion']};
%% Setting Parameters
generateImages = ON;
%% Loading Data
mRunTimeMatlab = csvread([RUN_TIME_DATA_FOLDER, MATLAB_RUN_TIME_FILE_NAME]);
mRunTimeJulia = csvread([RUN_TIME_DATA_FOLDER, JULIA_RUN_TIME_FILE_NAME]);
mRunTimeJuliaMkl = csvread([RUN_TIME_DATA_FOLDER, JULIA_MKL_RUN_TIME_FILE_NAME]);
numTests = length(cFunctionString);
numMatSize = length(vMatrixSize);
if(any(size(mRunTimeMatlab) ~= size(mRunTimeJulia)))
error(['Run Time Data Dimensions Don''t Match']);
end
if(any(size(mRunTimeMatlab) ~= size(mRunTimeJuliaMkl)))
error(['Run Time Data Dimensions Don''t Match']);
end
if(size(mRunTimeMatlab, 2) ~= numTests)
error(['Run Time Data Has Incompatible Number of Tests']);
end
if(size(mRunTimeMatlab, 1) ~= numMatSize)
error(['Run Time Data Has Incompatible Number of Matrix Size']);
end
%% Displaying Results
for ii = 1:numTests
figureIdx = figureIdx + 1;
hFigure = figure('Position', figPosMedium);
hAxes = axes();
set(hAxes, 'NextPlot', 'add');
hLineSeries = plot(vMatrixSize, [mRunTimeMatlab(:, ii), mRunTimeJulia(:, ii), mRunTimeJuliaMkl(:, ii)]);
set(hLineSeries, 'LineWidth', lineWidthNormal);
set(get(hAxes, 'Title'), 'String', ['Test - ', cFunctionString{ii}], ...
'FontSize', fontSizeTitle);
set(get(hAxes, 'XLabel'), 'String', 'Matrix Size', ...
'FontSize', fontSizeAxis);
set(get(hAxes, 'YLabel'), 'String', 'Run Time [Sec]', ...
'FontSize', fontSizeAxis);
hLegend = ClickableLegend(cLegendString);
if(generateImages == ON)
set(hAxes, 'LooseInset', [0.05, 0.05, 0.05, 0.05]);
saveas(hFigure,['Figures\Figure', num2str(figureIdx, figureCounterSpec), '.png']);
end
end
%% Restoring Defaults
% set(0, 'DefaultFigureWindowStyle', 'normal');
% set(0, 'DefaultAxesLooseInset', defaultLooseInset);