Apply a mask to 4D medical images in a vectorized way

3 vues (au cours des 30 derniers jours)
AP
AP le 11 Fév 2013
Dear All,
I have a 4D array V, with the size [144 144 12 25]. In fact, it is a 4D medical image with 12 stacked slices in 25 different time. I want to apply a mask, named M, to each image in the array in a vectorized way. M is a 144x144 array containing logical values. Could someone help me how to do it?
Thanks,
Ahmad
  1 commentaire
José-Luis
José-Luis le 11 Fév 2013
I notice that you don't seem accept many answers after asking questions. Some of the answers seemed valid to me. Please remember to accept answers if they help you, since it is the only "payment" the volunteers in this forum receive.

Connectez-vous pour commenter.

Réponse acceptée

José-Luis
José-Luis le 11 Fév 2013
Modifié(e) : José-Luis le 12 Fév 2013
data = rand(144,144,12,25);
your_mask = rand(144,144) > 0.5;
Assuming you want to multiply by the mask:
your_result = bsxfun(@times,data,mask);
Note that you can do operations other than multiplication. Please have a look at
doc bsxfun
  4 commentaires
AP
AP le 11 Fév 2013
I want the operation on each image. I thought bsxfun is only for each pixel and can't be applied to each image in a 4D array. Please correct me if I am wrong: so when we call bsxfun(@times,data,mask), bsxfun applies the mask to each 144x144. Is that right?
José-Luis
José-Luis le 12 Fév 2013
Yes. That's what the "singleton expansion" in the documentation means.

Connectez-vous pour commenter.

Plus de réponses (1)

Conrad
Conrad le 11 Fév 2013
Something like this:
fV = V.*M(:,:,ones(1,size(V,3)),ones(1,size(V,4)));
Conrad
  2 commentaires
AP
AP le 11 Fév 2013
How can I convert M, with size [144 144] to M with [144 144 12 25]?
AP
AP le 11 Fév 2013
Modifié(e) : AP le 11 Fév 2013
I think, I have to use
repmat(M, [1 1 size(V,3) size(V,4)])
to duplicate M in other dimensions and make it [144 144 12 25].

Connectez-vous pour commenter.

Community Treasure Hunt

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

Start Hunting!

Translated by