Hi, I have this program:
My program analyzes 21 different images and crops (for each image) 6 ROIs. The ROIs are cropped from a reference image and the coordinates are used to crop the ROIs to the other images. Then for each ROI the mean (saved in a 6x21 matrix named as meanbasket) and the standard deviation (saved in another 6x21 matrix named as devstdbasket) are made. The matrices are 6x21 because 6 is the number of ROIs and 21 the number of images. After that the values of the means are compared with the real values and the results are saved in another 6x21 matrix (errbasket).
My problem are:
- Preallocating devstdbasket before entering the loop by using zeros, ones, cell, or a similar function. Because MatLab suggest me that because of the different size of the matrix
- Plot in one graph the matrix errbasket (The matrix must be plotted transposed, as I need the curves of the graph to be the rows of the matrix and not the columns) with the error bars (as in the figure below).
The values in devstdbasket determine the lengths of each error bar above and below the data points, so the total error bar lengths are double the devstdbasket values.
srcFile = dir('C:\Users\agnes\Pictures\PP4 TGC-MED RD\PP4 TGC-MED RD 100\*.dcm');
pathname = ('C:\Users\agnes\Pictures\PP4 TGC-MED RD\PP4 TGC-MED RD 100\');
masks=cell(numberofroi,1);
h = drawrectangle(gca); wait(h);
roibasket = cell(numberofroi,numberofimages);
meanbasket = nan(size(roibasket));
for ni = 1:numberofimages
pileofimages=dicomread(strcat(pathname,filename));
info=dicominfo(strcat(pathname,filename));
roibasket{nr,ni} = imcrop(pileofimages,R(nr,:));
meanbasket(nr,ni) = mean( pileofimages(masks{nr}) );
devstdbasket(nr,ni) = std2 ( pileofimages(masks{nr}) );
rvalue = [-9; -6; -3; 3; 6; 9];
errbasket = (meanbasket - rvalue);
errbasketT = transpose(errbasket);
figure; errorbar(x,errbasketT,devstdbasket); hold on
In this graph you can see the error bars that I was talking about And it would be useful if you added a legend to the graph to be able to distinguish the curves.
Thank you