plotCDFOverhead.m 2.69 KB
Newer Older
% function to plot several statistics for the Sigcomm paper 
% opt - graph type 
% remote   - local or remote experiment
% parallel - if = 1 it refers to experiment ran on multiple machines at the same time
% role     - required by option 7 to indicate whether we wannt plot for "client", "server" or "mbox"

function [] = plotCDFOverhead(res)

MAC 		= 9/5
HANDSHAKE	= 8/5
PADDING 	= 6/5
HEADER		= 7/5

% Common variables 
folder = sprintf ('/home/varvello/WorkTelefonica/HTTP-2/sigcomm_evaluation/secure_proxy_protocol/evaluation/%s', res);  
figFolder = './fig/matlab';
kind_line = ['m';'b';'g';'m';'b';'g';'m';'b';'g';'m';'o';':';'d';'+';'<';'s';'.';'-';'g';'p'];
line_style = ['-';';';':'];

% Protocol  and protocol labels 
protocol = [
	'spp    '
	'fwd    '
	'ssl    '
	]; 
nProt = size(protocol, 1); 

protoLabel = [
	'SPP             '
	'TLS (forwarding)'
	'TLS (splitting) '
	]; 

ovLabel = [
	'PADDING  '
	'HEADER   '
	'HANDSHAKE'
	'MAC      '
	]; 

%Parameters 
suffix = 'four-slices_byteOverhead_browser'
overheadTypes = 4	
appData = 5

% create Figure handlers
for jj = 1 : overheadTypes
	fig(jj) = figure(); 
end
appdata = figure(); 

% iterate over protocols 
counter = 1
for ii = 1 : nProt
	currProt = strtrim(protocol(ii, :)) 
	currProtLabel = strtrim(protoLabel(ii, :)); 
	%FIXME
	file = sprintf('%s/res_%s_%s', folder, currProt, suffix) 
	if exist(file, 'file') ~= 2
		continue
	end
	data = dlmread(file);
	
	for jj = 1 : overheadTypes
		figure(fig(jj)); 
		h = cdfplot(data(:, (appData + jj))./data(:, appData)); 
		hold on; 
		if (counter == 3)
			set (h, 'color', kind_line(counter), 'LineWidth', 3, 'LineStyle', '--');
		else 
			set (h, 'color', kind_line(counter), 'LineWidth', 3);
		end
	end
	if (counter == 1)
		leg = {sprintf('%s',currProtLabel)};
	else
		leg = [leg, {sprintf('%s', currProtLabel)}];
	end
	if (counter == 1) 
		figure(appdata); 
		h = cdfplot(data(:, appData)./1024); 
		hold on; 
		set (h, 'color', kind_line(counter), 'LineWidth', 3);
		leg2 = {sprintf('Application Data')};
	end
	counter = counter + 1;
end

for jj = 1 : overheadTypes
	figure(fig(jj)); 
	xlabel('% of App Data Size');
	ylabel('CDF (0-1)');
	legend(leg, 'Location', 'SouthEast');
	grid on 
	set(0,'defaultaxesfontsize',18);
	set(gca, 'XScale','log');
	overheadLabel = strtrim(ovLabel(jj, :)); 
	t = sprintf('%s', overheadLabel); 
	title(t);
	outFile = sprintf ('%s/overhead_%s.eps', figFolder, overheadLabel); 
	saveas (fig(jj), outFile, 'psc2');
end

figure(appdata); 
xlabel('App Data Size (KBytes)');
ylabel('CDF (0-1)');
legend(leg2, 'Location', 'NorthWest');
grid on 
set(0,'defaultaxesfontsize',18);
set(gca, 'XScale','log');
title('');
outFile = sprintf ('%s/app_data_size.eps', figFolder);  
saveas (appdata, outFile, 'psc2');