Save an iterated 3D pixel sum as a vector? (Successful help -> I'll paypal the value of a beer!)

3 ビュー (過去 30 日間)
Evan
Evan 2012 年 4 月 26 日
Hello,
I have written a program that extracts SPECT data from regions of interest (ROI) within an image set. Part of the program iterates a mask for the ROI over a 3D space to sum all the pixel values within that volume for the set of images.
What do I need to add to the code to successfully save the pixel sum as a vector and not scalar that's replaced each iteration? I've tried all the basics and keep getting different error messages.
Thank you for any help.
(This is part of a nested for loop iterated over a series of 29 images)
%Sum over heart
sumHeart=0;
heart = ImgBig.*uint16(heartmask);
for h=heightLower(CaseStudy,1):heightUpper(CaseStudy,1)
for w=widthLower(CaseStudy,1):widthUpper(CaseStudy,1)
for d=depthLower(CaseStudy,1):depthUpper(CaseStudy,1)
sumHeart = sumHeart + heart(h,w,d);
end
end
end
  3 件のコメント
Geoff
Geoff 2012 年 4 月 26 日
Are we talking about a decent beer, or a rubbish beer? =)
Evan
Evan 2012 年 4 月 26 日
@Geoff: Sir! I am in graduate school, and have long since moved beyond the swill to which my undergrad budget once constrained me!
We are talking about the value of a fine microbrew from your favorite local tavern :)

サインインしてコメントする。

回答 (2 件)

Image Analyst
Image Analyst 2012 年 4 月 26 日
How about this:
counter = 1; % Before the loops start.
Then inside the loop, just make sumheart an array:
sumHeart(counter) = sumHeart(counter-1) + heart(h,w,d);
counter = counter + 1;
Is that what you want?
  9 件のコメント
Evan
Evan 2012 年 4 月 27 日
Hey guys,
Couldn't get either of those approaches to work successfully. I kept getting sumHeart as a massive array of zeros, so I ended up just going the inefficient way of iterating the entire program.
It takes an hour to run, but whatever. Anyway, thanks for all your help. Send me your paypal email addresses (to ethomas@uab.edu) and I'll buy you each a beer for your help anyway.
Cheers.
Geoff
Geoff 2012 年 4 月 29 日
If it comes out as all zeros, then I'd be suspicious of the data in your 'heart' matrix... What is the original data? I assume it's ImgBig. Is that uint16? What is the value of max(uint16(heartmask(:)))?
I suspect you have values that are being rounded to zero in your initial array. And/or you may need to cast your values to double as you sum them.

サインインしてコメントする。


Geoff
Geoff 2012 年 4 月 26 日
Just gonna chuck in my 2c worth...
h = heightLower(CaseStudy,1):heightUpper(CaseStudy,1);
w = widthLower(CaseStudy,1):widthUpper(CaseStudy,1);
d = depthLower(CaseStudy,1):depthUpper(CaseStudy,1);
H = permute( heart(h,w,d), [3 2 1] );
heartSum = cumsum(H(:));

カテゴリ

Help Center および File ExchangeMathematics and Optimization についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by