Skip to content
Snippets Groups Projects
PlotResults.m 1.54 KiB
Newer Older
function PlotResults(times,kernelName,numDevices)
    types = {'uint8';'uint16';'single';'double'};
    
% times has size of image, cuda time, matlab time, cuda times faster,
%   matlab over cuda
% third dimension is type
    
    f = figure;
    multiDevs = false;
    if (times(end,4,end)>1)
        multiDevs = true;
    end
    
    subIdx = [1,2,5,6];
    for i=1:size(types,1)
        subplot(2,4,subIdx(i));
        loglog(times(:,1,i),times(:,2,i),'-s','markersize',16);
        loglog(times(:,1,i),times(:,3,i),'-s','markersize',16);
        if (numDevices>1)
            loglog(times(:,1,i),times(:,4,i),'-*','markersize',16);
            legend('Cuda','Matlab',sprintf('Cuda %d devices',numDevices),'Location','northwest');
        else
Eric Wait's avatar
Eric Wait committed
            legend('Cuda','Matlab','Location','northwest');
        hold off
        xlabel('Number of Voxels');
        ylabel('Execution Time (sec)');
        title(types{i});
    end

    subplot(2,4,[3,4,7,8]);
    for i=1:size(types,1)
        loglog(times(:,1,i),times(:,5,i),'-s','markersize',16);
    if (numDevices>1)
        for i=1:size(types,1)
            loglog(times(:,1,i),times(:,6,i),':*','markersize',16);
        end
Eric Wait's avatar
Eric Wait committed
        typesDev = cellfun(@(x)([x,' multidevice']),types,'UniformOutput',false);
        types = vertcat(types,typesDev);
Eric Wait's avatar
Eric Wait committed
    legend(types,'Location','southwest');
Eric Wait's avatar
Eric Wait committed

    title(kernelName)
    xlabel('Number of Voxels');
Eric Wait's avatar
Eric Wait committed
    ylabel('Cuda Speedup');
    
    f.Units = 'normalized';
    f.Position = [0,0,1,1];
    drawnow
Eric Wait's avatar
Eric Wait committed
end